aboutsummaryrefslogtreecommitdiff
path: root/Src/replicant/nx/win/nxdata.h
diff options
context:
space:
mode:
authorJef <jef@targetspot.com>2024-09-24 08:54:57 -0400
committerJef <jef@targetspot.com>2024-09-24 08:54:57 -0400
commit20d28e80a5c861a9d5f449ea911ab75b4f37ad0d (patch)
tree12f17f78986871dd2cfb0a56e5e93b545c1ae0d0 /Src/replicant/nx/win/nxdata.h
parent537bcbc86291b32fc04ae4133ce4d7cac8ebe9a7 (diff)
downloadwinamp-20d28e80a5c861a9d5f449ea911ab75b4f37ad0d.tar.gz
Initial community commit
Diffstat (limited to 'Src/replicant/nx/win/nxdata.h')
-rw-r--r--Src/replicant/nx/win/nxdata.h42
1 files changed, 42 insertions, 0 deletions
diff --git a/Src/replicant/nx/win/nxdata.h b/Src/replicant/nx/win/nxdata.h
new file mode 100644
index 00000000..1a5eee94
--- /dev/null
+++ b/Src/replicant/nx/win/nxdata.h
@@ -0,0 +1,42 @@
+#pragma once
+#include "../../foundation/types.h"
+#include "../../nx/nxuri.h"
+#include "../../nx/nxapi.h"
+#include "../../nx/nxfile.h"
+#include "../../nx/nxstring.h"
+
+/* windows implementation */
+#ifdef __cplusplus
+extern "C" {
+#endif
+ typedef struct nx_data_struct_t *nx_data_t;
+
+ NX_API nx_data_t NXDataRetain(nx_data_t data);
+ NX_API void NXDataRelease(nx_data_t data);
+
+ NX_API int NXDataCreate(nx_data_t *data, const void *bytes, size_t length);
+ NX_API int NXDataCreateWithSize(nx_data_t *data, void **bytes, size_t length);
+ /* creates an empty data object. useful if you need to store MIME, source URI, etc. without having actual data */
+ NX_API int NXDataCreateEmpty(nx_data_t *data);
+ /* you can pass file_stats==NULL if you don't care about the file stats */
+ NX_API int NXDataCreateFromURI(nx_data_t *data, nx_uri_t filename);
+
+ NX_API size_t NXDataSize(nx_data_t data);
+ NX_API int NXDataGet(nx_data_t data, const void **bytes, size_t *length);
+
+ /* You can _only_ call these on your own nx_data_t object _before_ you give it to anyone else! */
+ NX_API int NXDataSetMIME(nx_data_t data, nx_string_t mime_type);
+ NX_API int NXDataSetDescription(nx_data_t data, nx_string_t description);
+ NX_API int NXDataSetSourceURI(nx_data_t data, nx_uri_t source_uri);
+ NX_API int NXDataSetSourceStat(nx_data_t data, nx_file_stat_t source_stats);
+
+ /* you need to call NXStringRelease on what you get back (if the function succeeded) */
+ NX_API int NXDataGetMIME(nx_data_t data, nx_string_t *mime_type);
+ NX_API int NXDataGetDescription(nx_data_t data, nx_string_t *description);
+ NX_API int NXDataGetSourceURI(nx_data_t data, nx_uri_t *source_uri);
+ NX_API int NXDataGetSourceStat(nx_data_t data, nx_file_stat_t *source_stats);
+
+
+#ifdef __cplusplus
+}
+#endif