2021-07-18 06:55:30 +08:00
|
|
|
/* Copyright 2018, UCAR/Unidata.
|
2021-09-03 07:04:26 +08:00
|
|
|
See the COPYRIGHT file for more information.
|
2021-07-18 06:55:30 +08:00
|
|
|
*/
|
|
|
|
|
2022-07-06 12:03:52 +08:00
|
|
|
|
2021-07-18 06:55:30 +08:00
|
|
|
#ifndef NCJSON_H
|
|
|
|
#define NCJSON_H 1
|
|
|
|
|
2022-07-06 12:03:52 +08:00
|
|
|
/*
|
|
|
|
WARNING:
|
|
|
|
If you modify this file,
|
|
|
|
then you need to got to
|
|
|
|
the include/ directory
|
|
|
|
and do the command:
|
|
|
|
make makepluginjson
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* Inside libnetcdf and for plugins, export the json symbols */
|
2021-09-03 07:04:26 +08:00
|
|
|
#ifndef DLLEXPORT
|
|
|
|
#ifdef _WIN32
|
|
|
|
#define DLLEXPORT __declspec(dllexport)
|
|
|
|
#else
|
|
|
|
#define DLLEXPORT
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
2022-07-06 12:03:52 +08:00
|
|
|
/* Override for plugins */
|
|
|
|
#ifdef NETCDF_JSON_H
|
|
|
|
#define OPTEXPORT static
|
|
|
|
#else
|
|
|
|
#define OPTEXPORT DLLEXPORT
|
|
|
|
#endif /*NETCDF_JSON_H*/
|
|
|
|
|
2021-09-03 07:04:26 +08:00
|
|
|
/**************************************************/
|
2021-07-18 06:55:30 +08:00
|
|
|
/* Json object sorts (note use of term sort rather than e.g. type or discriminant) */
|
|
|
|
#define NCJ_UNDEF 0
|
|
|
|
#define NCJ_STRING 1
|
|
|
|
#define NCJ_INT 2
|
|
|
|
#define NCJ_DOUBLE 3
|
|
|
|
#define NCJ_BOOLEAN 4
|
|
|
|
#define NCJ_DICT 5
|
|
|
|
#define NCJ_ARRAY 6
|
|
|
|
#define NCJ_NULL 7
|
|
|
|
|
|
|
|
#define NCJ_NSORTS 8
|
|
|
|
|
2021-09-03 07:04:26 +08:00
|
|
|
/* Define a struct to store primitive values as unquoted
|
|
|
|
strings. The sort will provide more info. Do not bother with
|
|
|
|
a union since the amount of saved space is minimal.
|
2021-07-18 06:55:30 +08:00
|
|
|
*/
|
|
|
|
|
|
|
|
typedef struct NCjson {
|
|
|
|
int sort; /* of this object */
|
|
|
|
char* string; /* sort != DICT|ARRAY */
|
|
|
|
struct NCjlist {
|
|
|
|
int len;
|
|
|
|
struct NCjson** contents;
|
|
|
|
} list; /* sort == DICT|ARRAY */
|
|
|
|
} NCjson;
|
|
|
|
|
2021-09-03 07:04:26 +08:00
|
|
|
/* Structure to hold result of convertinf one json sort to value of another type;
|
|
|
|
don't use union so we can know when to reclaim sval
|
|
|
|
*/
|
|
|
|
struct NCJconst {int bval; long long ival; double dval; char* sval;};
|
2022-08-28 10:21:13 +08:00
|
|
|
#define NCJconst_empty {0,0,0.0,NULL}
|
2021-09-03 07:04:26 +08:00
|
|
|
|
|
|
|
/**************************************************/
|
|
|
|
/* Extended API */
|
|
|
|
|
|
|
|
/* Return 0 if ok else -1 */
|
2021-07-18 06:55:30 +08:00
|
|
|
|
|
|
|
#if defined(__cplusplus)
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2022-04-07 05:54:42 +08:00
|
|
|
/* Parse a string to NCjson*/
|
2022-07-06 12:03:52 +08:00
|
|
|
OPTEXPORT int NCJparse(const char* text, unsigned flags, NCjson** jsonp);
|
2021-09-03 07:04:26 +08:00
|
|
|
|
2022-04-07 05:54:42 +08:00
|
|
|
/* Parse a counted string to NCjson*/
|
2022-07-06 12:03:52 +08:00
|
|
|
OPTEXPORT int NCJparsen(size_t len, const char* text, unsigned flags, NCjson** jsonp);
|
2022-04-07 05:54:42 +08:00
|
|
|
|
2021-09-03 07:04:26 +08:00
|
|
|
/* Reclaim a JSON tree */
|
2022-07-06 12:03:52 +08:00
|
|
|
OPTEXPORT void NCJreclaim(NCjson* json);
|
2021-09-03 07:04:26 +08:00
|
|
|
|
|
|
|
/* Create a new JSON node of a given sort */
|
2022-07-06 12:03:52 +08:00
|
|
|
OPTEXPORT int NCJnew(int sort, NCjson** objectp);
|
2021-07-18 06:55:30 +08:00
|
|
|
|
2021-09-03 07:04:26 +08:00
|
|
|
/* Create new json object with given string content */
|
2022-07-06 12:03:52 +08:00
|
|
|
OPTEXPORT int NCJnewstring(int sort, const char* value, NCjson** jsonp);
|
2021-07-18 06:55:30 +08:00
|
|
|
|
2021-09-03 07:04:26 +08:00
|
|
|
/* Create new json object with given counted string content */
|
2022-07-06 12:03:52 +08:00
|
|
|
OPTEXPORT int NCJnewstringn(int sort, size_t len, const char* value, NCjson** jsonp);
|
2021-07-18 06:55:30 +08:00
|
|
|
|
2021-09-03 07:04:26 +08:00
|
|
|
/* Get dict key value by name */
|
2022-07-06 12:03:52 +08:00
|
|
|
OPTEXPORT int NCJdictget(const NCjson* dict, const char* key, NCjson** valuep);
|
2021-07-18 06:55:30 +08:00
|
|
|
|
2021-09-03 07:04:26 +08:00
|
|
|
/* Convert one json sort to value of another type; don't use union so we can know when to reclaim sval */
|
2022-07-06 12:03:52 +08:00
|
|
|
OPTEXPORT int NCJcvt(const NCjson* value, int outsort, struct NCJconst* output);
|
2021-07-18 06:55:30 +08:00
|
|
|
|
2021-09-03 07:04:26 +08:00
|
|
|
/* Insert an atomic value to an array or dict object. */
|
2022-07-06 12:03:52 +08:00
|
|
|
OPTEXPORT int NCJaddstring(NCjson* json, int sort, const char* s);
|
2021-07-18 06:55:30 +08:00
|
|
|
|
|
|
|
/* Append value to an array or dict object. */
|
2022-07-06 12:03:52 +08:00
|
|
|
OPTEXPORT int NCJappend(NCjson* object, NCjson* value);
|
2021-07-18 06:55:30 +08:00
|
|
|
|
|
|
|
/* Insert key-value pair into a dict object. key will be copied */
|
2022-07-06 12:03:52 +08:00
|
|
|
OPTEXPORT int NCJinsert(NCjson* object, char* key, NCjson* value);
|
2021-07-18 06:55:30 +08:00
|
|
|
|
|
|
|
/* Unparser to convert NCjson object to text in buffer */
|
2022-07-06 12:03:52 +08:00
|
|
|
OPTEXPORT int NCJunparse(const NCjson* json, unsigned flags, char** textp);
|
2021-07-18 06:55:30 +08:00
|
|
|
|
2021-09-03 07:04:26 +08:00
|
|
|
/* Deep clone a json object */
|
2022-07-06 12:03:52 +08:00
|
|
|
OPTEXPORT int NCJclone(const NCjson* json, NCjson** clonep);
|
2021-07-18 06:55:30 +08:00
|
|
|
|
2022-07-06 12:03:52 +08:00
|
|
|
#ifndef NETCDF_JSON_H
|
2021-07-18 06:55:30 +08:00
|
|
|
/* dump NCjson* object to output file */
|
2022-07-06 12:03:52 +08:00
|
|
|
OPTEXPORT void NCJdump(const NCjson* json, unsigned flags, FILE*);
|
2022-08-28 10:21:13 +08:00
|
|
|
/* convert NCjson* object to output string */
|
|
|
|
OPTEXPORT const char* NCJtotext(const NCjson* json);
|
2021-09-03 07:04:26 +08:00
|
|
|
#endif
|
2021-07-18 06:55:30 +08:00
|
|
|
|
2021-09-03 07:04:26 +08:00
|
|
|
#if defined(__cplusplus)
|
|
|
|
}
|
|
|
|
#endif
|
2021-07-18 06:55:30 +08:00
|
|
|
|
|
|
|
/* Getters */
|
|
|
|
#define NCJsort(x) ((x)->sort)
|
|
|
|
#define NCJstring(x) ((x)->string)
|
|
|
|
#define NCJlength(x) ((x)==NULL ? 0 : (x)->list.len)
|
|
|
|
#define NCJcontents(x) ((x)->list.contents)
|
|
|
|
#define NCJith(x,i) ((x)->list.contents[i])
|
|
|
|
|
|
|
|
/* Setters */
|
|
|
|
#define NCJsetsort(x,s) (x)->sort=(s)
|
|
|
|
#define NCJsetstring(x,y) (x)->string=(y)
|
|
|
|
#define NCJsetcontents(x,c) (x)->list.contents=(c)
|
|
|
|
#define NCJsetlength(x,l) (x)->list.len=(l)
|
|
|
|
|
|
|
|
/* Misc */
|
|
|
|
#define NCJisatomic(j) ((j)->sort != NCJ_ARRAY && (j)->sort != NCJ_DICT && (j)->sort != NCJ_NULL && (j)->sort != NCJ_UNDEF)
|
|
|
|
|
2021-09-03 07:04:26 +08:00
|
|
|
/**************************************************/
|
2021-07-18 06:55:30 +08:00
|
|
|
|
|
|
|
#endif /*NCJSON_H*/
|
2021-09-03 07:04:26 +08:00
|
|
|
|