#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