upgrade cJSON and move customizations to komodo_cJSON
This commit is contained in:
@@ -72,7 +72,7 @@ public:
|
||||
|
||||
#include "komodo_globals.h"
|
||||
#include "komodo_utils.h"
|
||||
#include "cJSON.c"
|
||||
#include "komodo_cJSON.c"
|
||||
#include "komodo_notary.h"
|
||||
|
||||
void komodo_stateupdate(int32_t height,uint8_t notarypubs[][33],uint8_t numnotaries,uint8_t notaryid,uint256 txhash,uint64_t voutmask,uint8_t numvouts,uint32_t *pvals,uint8_t numpvals,int32_t KMDheight,uint32_t KMDtimestamp,uint64_t opretvalue,uint8_t *opretbuf,uint16_t opretlen,uint16_t vout)
|
||||
|
||||
3577
src/cJSON.c
Executable file → Normal file
3577
src/cJSON.c
Executable file → Normal file
File diff suppressed because it is too large
Load Diff
451
src/cJSON.h
Executable file → Normal file
451
src/cJSON.h
Executable file → Normal file
@@ -1,27 +1,24 @@
|
||||
/*
|
||||
Copyright (c) 2009 Dave Gamble
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
of this software and associated documentation files (the "Software"), to deal
|
||||
in the Software without restriction, including without limitation the rights
|
||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
copies of the Software, and to permit persons to whom the Software is
|
||||
furnished to do so, subject to the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be included in
|
||||
all copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||
THE SOFTWARE.
|
||||
*/
|
||||
Copyright (c) 2009-2017 Dave Gamble and cJSON contributors
|
||||
|
||||
#ifndef cJSON__h
|
||||
#define cJSON__h
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
of this software and associated documentation files (the "Software"), to deal
|
||||
in the Software without restriction, including without limitation the rights
|
||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
copies of the Software, and to permit persons to whom the Software is
|
||||
furnished to do so, subject to the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be included in
|
||||
all copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||
THE SOFTWARE.
|
||||
*/
|
||||
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
@@ -31,199 +28,241 @@
|
||||
#include <float.h>
|
||||
#include <memory.h>
|
||||
|
||||
//#include "../crypto777/OS_portable.h"
|
||||
|
||||
#define MAX_JSON_FIELD 4096 // on the big side
|
||||
#ifndef cJSON__h
|
||||
#define cJSON__h
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C"
|
||||
{
|
||||
#endif
|
||||
|
||||
/* cJSON Types: */
|
||||
#define cJSON_False 0
|
||||
#define cJSON_True 1
|
||||
#define cJSON_NULL 2
|
||||
#define cJSON_Number 3
|
||||
#define cJSON_String 4
|
||||
#define cJSON_Array 5
|
||||
#define cJSON_Object 6
|
||||
|
||||
#define is_cJSON_Null(json) ((json) != 0 && ((json)->type & 0xff) == cJSON_NULL)
|
||||
#define is_cJSON_Array(json) ((json) != 0 && ((json)->type & 0xff) == cJSON_Array)
|
||||
#define is_cJSON_String(json) ((json) != 0 && ((json)->type & 0xff) == cJSON_String)
|
||||
#define is_cJSON_Number(json) ((json) != 0 && ((json)->type & 0xff) == cJSON_Number)
|
||||
#define is_cJSON_Object(json) ((json) != 0 && ((json)->type & 0xff) == cJSON_Object)
|
||||
#define is_cJSON_True(json) ((json) != 0 && ((json)->type & 0xff) == cJSON_True)
|
||||
#define is_cJSON_False(json) ((json) != 0 && ((json)->type & 0xff) == cJSON_False)
|
||||
|
||||
|
||||
/* project version */
|
||||
#define CJSON_VERSION_MAJOR 1
|
||||
#define CJSON_VERSION_MINOR 5
|
||||
#define CJSON_VERSION_PATCH 9
|
||||
|
||||
#include <stddef.h>
|
||||
|
||||
/* cJSON Types: */
|
||||
#define cJSON_Invalid (0)
|
||||
#define cJSON_False (1 << 0)
|
||||
#define cJSON_True (1 << 1)
|
||||
#define cJSON_NULL (1 << 2)
|
||||
#define cJSON_Number (1 << 3)
|
||||
#define cJSON_String (1 << 4)
|
||||
#define cJSON_Array (1 << 5)
|
||||
#define cJSON_Object (1 << 6)
|
||||
#define cJSON_Raw (1 << 7) /* raw json */
|
||||
|
||||
#define cJSON_IsReference 256
|
||||
|
||||
/* The cJSON structure: */
|
||||
typedef struct cJSON {
|
||||
struct cJSON *next,*prev; /* next/prev allow you to walk array/object chains. Alternatively, use GetArraySize/GetArrayItem/GetObjectItem */
|
||||
struct cJSON *child; /* An array or object item will have a child pointer pointing to a chain of the items in the array/object. */
|
||||
|
||||
int32_t type; /* The type of the item, as above. */
|
||||
|
||||
char *valuestring; /* The item's string, if type==cJSON_String */
|
||||
int64_t valueint; /* The item's number, if type==cJSON_Number */
|
||||
double valuedouble; /* The item's number, if type==cJSON_Number */
|
||||
|
||||
char *string; /* The item's name string, if this item is the child of, or is in the list of subitems of an object. */
|
||||
} cJSON;
|
||||
|
||||
typedef struct cJSON_Hooks {
|
||||
void *(*malloc_fn)(size_t sz);
|
||||
void (*free_fn)(void *ptr);
|
||||
} cJSON_Hooks;
|
||||
|
||||
/* Supply malloc, realloc and free functions to cJSON */
|
||||
extern void cJSON_InitHooks(cJSON_Hooks* hooks);
|
||||
|
||||
|
||||
/* Supply a block of JSON, and this returns a cJSON object you can interrogate. Call cJSON_Delete when finished. */
|
||||
extern cJSON *cJSON_Parse(const char *value);
|
||||
/* Render a cJSON entity to text for transfer/storage. Free the char* when finished. */
|
||||
extern char *cJSON_Print(cJSON *item);
|
||||
/* Render a cJSON entity to text for transfer/storage without any formatting. Free the char* when finished. */
|
||||
extern char *cJSON_PrintUnformatted(cJSON *item);
|
||||
/* Delete a cJSON entity and all subentities. */
|
||||
extern void cJSON_Delete(cJSON *c);
|
||||
|
||||
/* Returns the number of items in an array (or object). */
|
||||
extern int cJSON_GetArraySize(cJSON *array);
|
||||
/* Retrieve item number "item" from array "array". Returns NULL if unsuccessful. */
|
||||
extern cJSON *cJSON_GetArrayItem(cJSON *array,int32_t item);
|
||||
/* Get item "string" from object. Case insensitive. */
|
||||
extern cJSON *cJSON_GetObjectItem(cJSON *object,const char *string);
|
||||
|
||||
/* For analysing failed parses. This returns a pointer to the parse error. You'll probably need to look a few chars back to make sense of it. Defined when cJSON_Parse() returns 0. 0 when cJSON_Parse() succeeds. */
|
||||
extern const char *cJSON_GetErrorPtr(void);
|
||||
|
||||
/* These calls create a cJSON item of the appropriate type. */
|
||||
extern cJSON *cJSON_CreateNull(void);
|
||||
extern cJSON *cJSON_CreateTrue(void);
|
||||
extern cJSON *cJSON_CreateFalse(void);
|
||||
extern cJSON *cJSON_CreateBool(int32_t b);
|
||||
extern cJSON *cJSON_CreateNumber(double num);
|
||||
extern cJSON *cJSON_CreateString(const char *string);
|
||||
extern cJSON *cJSON_CreateArray(void);
|
||||
extern cJSON *cJSON_CreateObject(void);
|
||||
|
||||
/* These utilities create an Array of count items. */
|
||||
extern cJSON *cJSON_CreateIntArray(int64_t *numbers,int32_t count);
|
||||
extern cJSON *cJSON_CreateFloatArray(float *numbers,int32_t count);
|
||||
extern cJSON *cJSON_CreateDoubleArray(double *numbers,int32_t count);
|
||||
extern cJSON *cJSON_CreateStringArray(char **strings,int32_t count);
|
||||
|
||||
/* Append item to the specified array/object. */
|
||||
extern void cJSON_AddItemToArray(cJSON *array, cJSON *item);
|
||||
extern void cJSON_AddItemToObject(cJSON *object,const char *string,cJSON *item);
|
||||
/* Append reference to item to the specified array/object. Use this when you want to add an existing cJSON to a new cJSON, but don't want to corrupt your existing cJSON. */
|
||||
extern void cJSON_AddItemReferenceToArray(cJSON *array, cJSON *item);
|
||||
extern void cJSON_AddItemReferenceToObject(cJSON *object,const char *string,cJSON *item);
|
||||
|
||||
/* Remove/Detatch items from Arrays/Objects. */
|
||||
extern cJSON *cJSON_DetachItemFromArray(cJSON *array,int32_t which);
|
||||
extern void cJSON_DeleteItemFromArray(cJSON *array,int32_t which);
|
||||
extern cJSON *cJSON_DetachItemFromObject(cJSON *object,const char *string);
|
||||
extern void cJSON_DeleteItemFromObject(cJSON *object,const char *string);
|
||||
|
||||
/* Update array items. */
|
||||
extern void cJSON_ReplaceItemInArray(cJSON *array,int32_t which,cJSON *newitem);
|
||||
extern void cJSON_ReplaceItemInObject(cJSON *object,const char *string,cJSON *newitem);
|
||||
|
||||
/* Duplicate a cJSON item */
|
||||
extern cJSON *cJSON_Duplicate(cJSON *item,int32_t recurse);
|
||||
/* Duplicate will create a new, identical cJSON item to the one you pass, in new memory that will
|
||||
need to be released. With recurse!=0, it will duplicate any children connected to the item.
|
||||
The item->next and ->prev pointers are always zero on return from Duplicate. */
|
||||
|
||||
/* ParseWithOpts allows you to require (and check) that the JSON is null terminated, and to retrieve the pointer to the final byte parsed. */
|
||||
extern cJSON *cJSON_ParseWithOpts(const char *value,const char **return_parse_end,int32_t require_null_terminated);
|
||||
|
||||
extern void cJSON_Minify(char *json);
|
||||
|
||||
/* Macros for creating things quickly. */
|
||||
#define cJSON_AddNullToObject(object,name) cJSON_AddItemToObject(object, name, cJSON_CreateNull())
|
||||
#define cJSON_AddTrueToObject(object,name) cJSON_AddItemToObject(object, name, cJSON_CreateTrue())
|
||||
#define cJSON_AddFalseToObject(object,name) cJSON_AddItemToObject(object, name, cJSON_CreateFalse())
|
||||
#define cJSON_AddBoolToObject(object,name,b) cJSON_AddItemToObject(object, name, cJSON_CreateBool(b))
|
||||
#define cJSON_AddNumberToObject(object,name,n) cJSON_AddItemToObject(object, name, cJSON_CreateNumber(n))
|
||||
#define cJSON_AddStringToObject(object,name,s) cJSON_AddItemToObject(object, name, cJSON_CreateString(s))
|
||||
|
||||
struct destbuf { char buf[MAX_JSON_FIELD]; };
|
||||
|
||||
/* When assigning an integer value, it needs to be propagated to valuedouble too. */
|
||||
#define cJSON_SetIntValue(object,val) ((object)?(object)->valueint=(object)->valuedouble=(val):(val))
|
||||
#define jfieldstr get_cJSON_fieldname
|
||||
|
||||
char *cJSON_str(cJSON *json);
|
||||
char *jstr(cJSON *json,char *field);
|
||||
char *jprint(cJSON *json,int32_t freeflag);
|
||||
int32_t jint(cJSON *json,char *field);
|
||||
uint32_t juint(cJSON *json,char *field);
|
||||
char *jstri(cJSON *json,int32_t i);
|
||||
int32_t jinti(cJSON *json,int32_t i);
|
||||
uint32_t juinti(cJSON *json,int32_t i);
|
||||
uint64_t j64bitsi(cJSON *json,int32_t i);
|
||||
double jdoublei(cJSON *json,int32_t i);
|
||||
double jdouble(cJSON *json,char *field);
|
||||
cJSON *jobj(cJSON *json,char *field);
|
||||
cJSON *jarray(int32_t *nump,cJSON *json,char *field);
|
||||
cJSON *jitem(cJSON *array,int32_t i);
|
||||
uint64_t j64bits(cJSON *json,char *field);
|
||||
void jadd(cJSON *json,char *field,cJSON *item);
|
||||
void jaddstr(cJSON *json,char *field,char *str);
|
||||
void jaddnum(cJSON *json,char *field,double num);
|
||||
void jadd64bits(cJSON *json,char *field,uint64_t nxt64bits);
|
||||
void jaddi(cJSON *json,cJSON *item);
|
||||
void jaddistr(cJSON *json,char *str);
|
||||
void jaddinum(cJSON *json,double num);
|
||||
void jaddi64bits(cJSON *json,uint64_t nxt64bits);
|
||||
void jdelete(cJSON *object,char *string);
|
||||
cJSON *jduplicate(cJSON *json);
|
||||
int32_t jnum(cJSON *obj,char *field);
|
||||
|
||||
bits256 jbits256(cJSON *json,char *field);
|
||||
bits256 jbits256i(cJSON *json,int32_t i);
|
||||
void jaddbits256(cJSON *json,char *field,bits256 hash);
|
||||
void jaddibits256(cJSON *json,bits256 hash);
|
||||
void copy_cJSON(struct destbuf *dest,cJSON *obj);
|
||||
void copy_cJSON2(char *dest,int32_t maxlen,cJSON *obj);
|
||||
cJSON *gen_list_json(char **list);
|
||||
int32_t extract_cJSON_str(char *dest,int32_t max,cJSON *json,char *field);
|
||||
#define cJSON_StringIsConst 512
|
||||
|
||||
void free_json(cJSON *json);
|
||||
int64_t _conv_cJSON_float(cJSON *json);
|
||||
int64_t conv_cJSON_float(cJSON *json,char *field);
|
||||
int64_t get_cJSON_int(cJSON *json,char *field);
|
||||
void add_satoshis_json(cJSON *json,char *field,uint64_t satoshis);
|
||||
uint64_t get_satoshi_obj(cJSON *json,char *field);
|
||||
|
||||
int32_t get_API_int(cJSON *obj,int32_t val);
|
||||
uint32_t get_API_uint(cJSON *obj,uint32_t val);
|
||||
uint64_t get_API_nxt64bits(cJSON *obj);
|
||||
double get_API_float(cJSON *obj);
|
||||
char *get_cJSON_fieldname(cJSON *obj);
|
||||
void ensure_jsonitem(cJSON *json,char *field,char *value);
|
||||
int32_t in_jsonarray(cJSON *array,char *value);
|
||||
char *bitcoind_RPC(char **retstrp,char *debugstr,char *url,char *userpass,char *command,char *params);
|
||||
uint64_t calc_nxt64bits(const char *str);
|
||||
int32_t expand_nxt64bits(char *str,uint64_t nxt64bits);
|
||||
char *nxt64str(uint64_t nxt64bits);
|
||||
char *nxt64str2(uint64_t nxt64bits);
|
||||
cJSON *addrs_jsonarray(uint64_t *addrs,int32_t num);
|
||||
int32_t myatoi(char *str,int32_t range);
|
||||
/* The cJSON structure: */
|
||||
typedef struct cJSON
|
||||
{
|
||||
/* next/prev allow you to walk array/object chains. Alternatively, use GetArraySize/GetArrayItem/GetObjectItem */
|
||||
struct cJSON *next;
|
||||
struct cJSON *prev;
|
||||
/* An array or object item will have a child pointer pointing to a chain of the items in the array/object. */
|
||||
struct cJSON *child;
|
||||
|
||||
char *stringifyM(char *str);
|
||||
#define replace_backslashquotes unstringify
|
||||
char *unstringify(char *str);
|
||||
#define jtrue cJSON_CreateTrue
|
||||
#define jfalse cJSON_CreateFalse
|
||||
/* The type of the item, as above. */
|
||||
int type;
|
||||
|
||||
#define jfieldname get_cJSON_fieldname
|
||||
/* The item's string, if type==cJSON_String and type == cJSON_Raw */
|
||||
char *valuestring;
|
||||
/* writing to valueint is DEPRECATED, use cJSON_SetNumberValue instead */
|
||||
int valueint;
|
||||
/* The item's number, if type==cJSON_Number */
|
||||
double valuedouble;
|
||||
|
||||
/* The item's name string, if this item is the child of, or is in the list of subitems of an object. */
|
||||
char *string;
|
||||
} cJSON;
|
||||
|
||||
typedef struct cJSON_Hooks
|
||||
{
|
||||
void *(*malloc_fn)(size_t sz);
|
||||
void (*free_fn)(void *ptr);
|
||||
} cJSON_Hooks;
|
||||
|
||||
typedef int cJSON_bool;
|
||||
|
||||
#if !defined(__WINDOWS__) && (defined(WIN32) || defined(WIN64) || defined(_MSC_VER) || defined(_WIN32))
|
||||
#define __WINDOWS__
|
||||
#endif
|
||||
#ifdef __WINDOWS__
|
||||
|
||||
/* When compiling for windows, we specify a specific calling convention to avoid issues where we are being called from a project with a different default calling convention. For windows you have 2 define options:
|
||||
|
||||
CJSON_HIDE_SYMBOLS - Define this in the case where you don't want to ever dllexport symbols
|
||||
CJSON_EXPORT_SYMBOLS - Define this on library build when you want to dllexport symbols (default)
|
||||
CJSON_IMPORT_SYMBOLS - Define this if you want to dllimport symbol
|
||||
|
||||
For *nix builds that support visibility attribute, you can define similar behavior by
|
||||
|
||||
setting default visibility to hidden by adding
|
||||
-fvisibility=hidden (for gcc)
|
||||
or
|
||||
-xldscope=hidden (for sun cc)
|
||||
to CFLAGS
|
||||
|
||||
then using the CJSON_API_VISIBILITY flag to "export" the same symbols the way CJSON_EXPORT_SYMBOLS does
|
||||
|
||||
*/
|
||||
|
||||
/* export symbols by default, this is necessary for copy pasting the C and header file */
|
||||
#if !defined(CJSON_HIDE_SYMBOLS) && !defined(CJSON_IMPORT_SYMBOLS) && !defined(CJSON_EXPORT_SYMBOLS)
|
||||
#define CJSON_EXPORT_SYMBOLS
|
||||
#endif
|
||||
|
||||
#if defined(CJSON_HIDE_SYMBOLS)
|
||||
#define CJSON_PUBLIC(type) type __stdcall
|
||||
#elif defined(CJSON_EXPORT_SYMBOLS)
|
||||
#define CJSON_PUBLIC(type) __declspec(dllexport) type __stdcall
|
||||
#elif defined(CJSON_IMPORT_SYMBOLS)
|
||||
#define CJSON_PUBLIC(type) __declspec(dllimport) type __stdcall
|
||||
#endif
|
||||
#else /* !WIN32 */
|
||||
#if (defined(__GNUC__) || defined(__SUNPRO_CC) || defined (__SUNPRO_C)) && defined(CJSON_API_VISIBILITY)
|
||||
#define CJSON_PUBLIC(type) __attribute__((visibility("default"))) type
|
||||
#else
|
||||
#define CJSON_PUBLIC(type) type
|
||||
#endif
|
||||
#endif
|
||||
|
||||
/* Limits how deeply nested arrays/objects can be before cJSON rejects to parse them.
|
||||
* This is to prevent stack overflows. */
|
||||
#ifndef CJSON_NESTING_LIMIT
|
||||
#define CJSON_NESTING_LIMIT 1000
|
||||
#endif
|
||||
|
||||
/* returns the version of cJSON as a string */
|
||||
CJSON_PUBLIC(const char*) cJSON_Version(void);
|
||||
|
||||
/* Supply malloc, realloc and free functions to cJSON */
|
||||
CJSON_PUBLIC(void) cJSON_InitHooks(cJSON_Hooks* hooks);
|
||||
|
||||
/* Memory Management: the caller is always responsible to free the results from all variants of cJSON_Parse (with cJSON_Delete) and cJSON_Print (with stdlib free, cJSON_Hooks.free_fn, or cJSON_free as appropriate). The exception is cJSON_PrintPreallocated, where the caller has full responsibility of the buffer. */
|
||||
/* Supply a block of JSON, and this returns a cJSON object you can interrogate. */
|
||||
CJSON_PUBLIC(cJSON *) cJSON_Parse(const char *value);
|
||||
/* ParseWithOpts allows you to require (and check) that the JSON is null terminated, and to retrieve the pointer to the final byte parsed. */
|
||||
/* If you supply a ptr in return_parse_end and parsing fails, then return_parse_end will contain a pointer to the error so will match cJSON_GetErrorPtr(). */
|
||||
CJSON_PUBLIC(cJSON *) cJSON_ParseWithOpts(const char *value, const char **return_parse_end, cJSON_bool require_null_terminated);
|
||||
|
||||
/* Render a cJSON entity to text for transfer/storage. */
|
||||
CJSON_PUBLIC(char *) cJSON_Print(const cJSON *item);
|
||||
/* Render a cJSON entity to text for transfer/storage without any formatting. */
|
||||
CJSON_PUBLIC(char *) cJSON_PrintUnformatted(const cJSON *item);
|
||||
/* Render a cJSON entity to text using a buffered strategy. prebuffer is a guess at the final size. guessing well reduces reallocation. fmt=0 gives unformatted, =1 gives formatted */
|
||||
CJSON_PUBLIC(char *) cJSON_PrintBuffered(const cJSON *item, int prebuffer, cJSON_bool fmt);
|
||||
/* Render a cJSON entity to text using a buffer already allocated in memory with given length. Returns 1 on success and 0 on failure. */
|
||||
/* NOTE: cJSON is not always 100% accurate in estimating how much memory it will use, so to be safe allocate 5 bytes more than you actually need */
|
||||
CJSON_PUBLIC(cJSON_bool) cJSON_PrintPreallocated(cJSON *item, char *buffer, const int length, const cJSON_bool format);
|
||||
/* Delete a cJSON entity and all subentities. */
|
||||
CJSON_PUBLIC(void) cJSON_Delete(cJSON *c);
|
||||
|
||||
/* Returns the number of items in an array (or object). */
|
||||
CJSON_PUBLIC(int) cJSON_GetArraySize(const cJSON *array);
|
||||
/* Retrieve item number "item" from array "array". Returns NULL if unsuccessful. */
|
||||
CJSON_PUBLIC(cJSON *) cJSON_GetArrayItem(const cJSON *array, int index);
|
||||
/* Get item "string" from object. Case insensitive. */
|
||||
CJSON_PUBLIC(cJSON *) cJSON_GetObjectItem(const cJSON * const object, const char * const string);
|
||||
CJSON_PUBLIC(cJSON *) cJSON_GetObjectItemCaseSensitive(const cJSON * const object, const char * const string);
|
||||
CJSON_PUBLIC(cJSON_bool) cJSON_HasObjectItem(const cJSON *object, const char *string);
|
||||
/* For analysing failed parses. This returns a pointer to the parse error. You'll probably need to look a few chars back to make sense of it. Defined when cJSON_Parse() returns 0. 0 when cJSON_Parse() succeeds. */
|
||||
CJSON_PUBLIC(const char *) cJSON_GetErrorPtr(void);
|
||||
|
||||
/* These functions check the type of an item */
|
||||
CJSON_PUBLIC(cJSON_bool) cJSON_IsInvalid(const cJSON * const item);
|
||||
CJSON_PUBLIC(cJSON_bool) cJSON_IsFalse(const cJSON * const item);
|
||||
CJSON_PUBLIC(cJSON_bool) cJSON_IsTrue(const cJSON * const item);
|
||||
CJSON_PUBLIC(cJSON_bool) cJSON_IsBool(const cJSON * const item);
|
||||
CJSON_PUBLIC(cJSON_bool) cJSON_IsNull(const cJSON * const item);
|
||||
CJSON_PUBLIC(cJSON_bool) cJSON_IsNumber(const cJSON * const item);
|
||||
CJSON_PUBLIC(cJSON_bool) cJSON_IsString(const cJSON * const item);
|
||||
CJSON_PUBLIC(cJSON_bool) cJSON_IsArray(const cJSON * const item);
|
||||
CJSON_PUBLIC(cJSON_bool) cJSON_IsObject(const cJSON * const item);
|
||||
CJSON_PUBLIC(cJSON_bool) cJSON_IsRaw(const cJSON * const item);
|
||||
|
||||
/* These calls create a cJSON item of the appropriate type. */
|
||||
CJSON_PUBLIC(cJSON *) cJSON_CreateNull(void);
|
||||
CJSON_PUBLIC(cJSON *) cJSON_CreateTrue(void);
|
||||
CJSON_PUBLIC(cJSON *) cJSON_CreateFalse(void);
|
||||
CJSON_PUBLIC(cJSON *) cJSON_CreateBool(cJSON_bool boolean);
|
||||
CJSON_PUBLIC(cJSON *) cJSON_CreateNumber(double num);
|
||||
CJSON_PUBLIC(cJSON *) cJSON_CreateString(const char *string);
|
||||
/* raw json */
|
||||
CJSON_PUBLIC(cJSON *) cJSON_CreateRaw(const char *raw);
|
||||
CJSON_PUBLIC(cJSON *) cJSON_CreateArray(void);
|
||||
CJSON_PUBLIC(cJSON *) cJSON_CreateObject(void);
|
||||
|
||||
/* These utilities create an Array of count items. */
|
||||
CJSON_PUBLIC(cJSON *) cJSON_CreateIntArray(const int *numbers, int count);
|
||||
CJSON_PUBLIC(cJSON *) cJSON_CreateFloatArray(const float *numbers, int count);
|
||||
CJSON_PUBLIC(cJSON *) cJSON_CreateDoubleArray(const double *numbers, int count);
|
||||
CJSON_PUBLIC(cJSON *) cJSON_CreateStringArray(const char **strings, int count);
|
||||
|
||||
/* Append item to the specified array/object. */
|
||||
CJSON_PUBLIC(void) cJSON_AddItemToArray(cJSON *array, cJSON *item);
|
||||
CJSON_PUBLIC(void) cJSON_AddItemToObject(cJSON *object, const char *string, cJSON *item);
|
||||
/* Use this when string is definitely const (i.e. a literal, or as good as), and will definitely survive the cJSON object.
|
||||
* WARNING: When this function was used, make sure to always check that (item->type & cJSON_StringIsConst) is zero before
|
||||
* writing to `item->string` */
|
||||
CJSON_PUBLIC(void) cJSON_AddItemToObjectCS(cJSON *object, const char *string, cJSON *item);
|
||||
/* Append reference to item to the specified array/object. Use this when you want to add an existing cJSON to a new cJSON, but don't want to corrupt your existing cJSON. */
|
||||
CJSON_PUBLIC(void) cJSON_AddItemReferenceToArray(cJSON *array, cJSON *item);
|
||||
CJSON_PUBLIC(void) cJSON_AddItemReferenceToObject(cJSON *object, const char *string, cJSON *item);
|
||||
|
||||
/* Remove/Detatch items from Arrays/Objects. */
|
||||
CJSON_PUBLIC(cJSON *) cJSON_DetachItemViaPointer(cJSON *parent, cJSON * const item);
|
||||
CJSON_PUBLIC(cJSON *) cJSON_DetachItemFromArray(cJSON *array, int which);
|
||||
CJSON_PUBLIC(void) cJSON_DeleteItemFromArray(cJSON *array, int which);
|
||||
CJSON_PUBLIC(cJSON *) cJSON_DetachItemFromObject(cJSON *object, const char *string);
|
||||
CJSON_PUBLIC(cJSON *) cJSON_DetachItemFromObjectCaseSensitive(cJSON *object, const char *string);
|
||||
CJSON_PUBLIC(void) cJSON_DeleteItemFromObject(cJSON *object, const char *string);
|
||||
CJSON_PUBLIC(void) cJSON_DeleteItemFromObjectCaseSensitive(cJSON *object, const char *string);
|
||||
|
||||
/* Update array items. */
|
||||
CJSON_PUBLIC(void) cJSON_InsertItemInArray(cJSON *array, int which, cJSON *newitem); /* Shifts pre-existing items to the right. */
|
||||
CJSON_PUBLIC(cJSON_bool) cJSON_ReplaceItemViaPointer(cJSON * const parent, cJSON * const item, cJSON * replacement);
|
||||
CJSON_PUBLIC(void) cJSON_ReplaceItemInArray(cJSON *array, int which, cJSON *newitem);
|
||||
CJSON_PUBLIC(void) cJSON_ReplaceItemInObject(cJSON *object,const char *string,cJSON *newitem);
|
||||
CJSON_PUBLIC(void) cJSON_ReplaceItemInObjectCaseSensitive(cJSON *object,const char *string,cJSON *newitem);
|
||||
|
||||
/* Duplicate a cJSON item */
|
||||
CJSON_PUBLIC(cJSON *) cJSON_Duplicate(const cJSON *item, cJSON_bool recurse);
|
||||
/* Duplicate will create a new, identical cJSON item to the one you pass, in new memory that will
|
||||
need to be released. With recurse!=0, it will duplicate any children connected to the item.
|
||||
The item->next and ->prev pointers are always zero on return from Duplicate. */
|
||||
/* Recursively compare two cJSON items for equality. If either a or b is NULL or invalid, they will be considered unequal.
|
||||
* case_sensitive determines if object keys are treated case sensitive (1) or case insensitive (0) */
|
||||
CJSON_PUBLIC(cJSON_bool) cJSON_Compare(const cJSON * const a, const cJSON * const b, const cJSON_bool case_sensitive);
|
||||
|
||||
|
||||
CJSON_PUBLIC(void) cJSON_Minify(char *json);
|
||||
|
||||
/* Macros for creating things quickly. */
|
||||
#define cJSON_AddNullToObject(object,name) cJSON_AddItemToObject(object, name, cJSON_CreateNull())
|
||||
#define cJSON_AddTrueToObject(object,name) cJSON_AddItemToObject(object, name, cJSON_CreateTrue())
|
||||
#define cJSON_AddFalseToObject(object,name) cJSON_AddItemToObject(object, name, cJSON_CreateFalse())
|
||||
#define cJSON_AddBoolToObject(object,name,b) cJSON_AddItemToObject(object, name, cJSON_CreateBool(b))
|
||||
#define cJSON_AddNumberToObject(object,name,n) cJSON_AddItemToObject(object, name, cJSON_CreateNumber(n))
|
||||
#define cJSON_AddStringToObject(object,name,s) cJSON_AddItemToObject(object, name, cJSON_CreateString(s))
|
||||
#define cJSON_AddRawToObject(object,name,s) cJSON_AddItemToObject(object, name, cJSON_CreateRaw(s))
|
||||
|
||||
/* When assigning an integer value, it needs to be propagated to valuedouble too. */
|
||||
#define cJSON_SetIntValue(object, number) ((object) ? (object)->valueint = (object)->valuedouble = (number) : (number))
|
||||
/* helper for the cJSON_SetNumberValue macro */
|
||||
CJSON_PUBLIC(double) cJSON_SetNumberHelper(cJSON *object, double number);
|
||||
#define cJSON_SetNumberValue(object, number) ((object != NULL) ? cJSON_SetNumberHelper(object, (double)number) : (number))
|
||||
|
||||
/* Macro for iterating over an array or object */
|
||||
#define cJSON_ArrayForEach(element, array) for(element = (array != NULL) ? (array)->child : NULL; element != NULL; element = element->next)
|
||||
|
||||
/* malloc/free objects using the malloc/free functions that have been set with cJSON_InitHooks */
|
||||
CJSON_PUBLIC(void *) cJSON_malloc(size_t size);
|
||||
CJSON_PUBLIC(void) cJSON_free(void *object);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
|
||||
@@ -42,7 +42,7 @@ void komodo_connectblock(CBlockIndex *pindex,CBlock& block);
|
||||
#include "komodo_utils.h"
|
||||
#include "komodo_curve25519.h"
|
||||
|
||||
#include "cJSON.c"
|
||||
#include "komodo_cJSON.c"
|
||||
#include "komodo_bitcoind.h"
|
||||
#include "komodo_interest.h"
|
||||
#include "komodo_pax.h"
|
||||
|
||||
559
src/komodo_cJSON.c
Executable file
559
src/komodo_cJSON.c
Executable file
@@ -0,0 +1,559 @@
|
||||
|
||||
/*
|
||||
Copyright (c) 2009 Dave Gamble
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
of this software and associated documentation files (the "Software"), to deal
|
||||
in the Software without restriction, including without limitation the rights
|
||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
copies of the Software, and to permit persons to whom the Software is
|
||||
furnished to do so, subject to the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be included in
|
||||
all copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||
THE SOFTWARE.
|
||||
*/
|
||||
|
||||
/* cJSON */
|
||||
/* JSON parser in C. */
|
||||
#include <math.h>
|
||||
|
||||
#include "cJSON.h"
|
||||
#include "komodo_cJSON.h"
|
||||
#include "cJSON.c"
|
||||
|
||||
#ifndef DBL_EPSILON
|
||||
#define DBL_EPSILON 2.2204460492503131E-16
|
||||
#endif
|
||||
|
||||
static const char *ep;
|
||||
|
||||
long stripquotes(char *str)
|
||||
{
|
||||
long len,offset;
|
||||
if ( str == 0 )
|
||||
return(0);
|
||||
len = strlen(str);
|
||||
if ( str[0] == '"' && str[len-1] == '"' )
|
||||
str[len-1] = 0, offset = 1;
|
||||
else offset = 0;
|
||||
return(offset);
|
||||
}
|
||||
|
||||
static int32_t cJSON_strcasecmp(const char *s1,const char *s2)
|
||||
{
|
||||
if (!s1) return (s1==s2)?0:1;if (!s2) return 1;
|
||||
for(; tolower((int32_t)(*s1)) == tolower((int32_t)(*s2)); ++s1, ++s2) if(*s1 == 0) return 0;
|
||||
return tolower((int32_t)(*(const unsigned char *)s1)) - tolower((int32_t)(*(const unsigned char *)s2));
|
||||
}
|
||||
|
||||
// the following written by jl777
|
||||
/******************************************************************************
|
||||
* Copyright © 2014-2017 The SuperNET Developers. *
|
||||
* *
|
||||
* See the AUTHORS, DEVELOPER-AGREEMENT and LICENSE files at *
|
||||
* the top-level directory of this distribution for the individual copyright *
|
||||
* holder information and the developer policies on copyright and licensing. *
|
||||
* *
|
||||
* Unless otherwise agreed in a custom licensing agreement, no part of the *
|
||||
* SuperNET software, including this file may be copied, modified, propagated *
|
||||
* or distributed except according to the terms contained in the LICENSE file *
|
||||
* *
|
||||
* Removal or modification of this copyright notice is prohibited. *
|
||||
* *
|
||||
******************************************************************************/
|
||||
|
||||
void copy_cJSON(struct destbuf *dest,cJSON *obj)
|
||||
{
|
||||
char *str;
|
||||
int i;
|
||||
long offset;
|
||||
dest->buf[0] = 0;
|
||||
if ( obj != 0 )
|
||||
{
|
||||
str = cJSON_Print(obj);
|
||||
if ( str != 0 )
|
||||
{
|
||||
offset = stripquotes(str);
|
||||
//strcpy(dest,str+offset);
|
||||
for (i=0; i<MAX_JSON_FIELD-1; i++)
|
||||
if ( (dest->buf[i]= str[offset+i]) == 0 )
|
||||
break;
|
||||
dest->buf[i] = 0;
|
||||
free(str);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void copy_cJSON2(char *dest,int32_t maxlen,cJSON *obj)
|
||||
{
|
||||
struct destbuf tmp;
|
||||
maxlen--;
|
||||
dest[0] = 0;
|
||||
if ( maxlen > sizeof(tmp.buf) )
|
||||
maxlen = sizeof(tmp.buf);
|
||||
copy_cJSON(&tmp,obj);
|
||||
if ( strlen(tmp.buf) < maxlen )
|
||||
strcpy(dest,tmp.buf);
|
||||
else dest[0] = 0;
|
||||
}
|
||||
|
||||
int64_t _get_cJSON_int(cJSON *json)
|
||||
{
|
||||
struct destbuf tmp;
|
||||
if ( json != 0 )
|
||||
{
|
||||
copy_cJSON(&tmp,json);
|
||||
if ( tmp.buf[0] != 0 )
|
||||
return(calc_nxt64bits(tmp.buf));
|
||||
}
|
||||
return(0);
|
||||
}
|
||||
|
||||
int64_t get_cJSON_int(cJSON *json,char *field)
|
||||
{
|
||||
cJSON *numjson;
|
||||
if ( json != 0 )
|
||||
{
|
||||
numjson = cJSON_GetObjectItem(json,field);
|
||||
if ( numjson != 0 )
|
||||
return(_get_cJSON_int(numjson));
|
||||
}
|
||||
return(0);
|
||||
}
|
||||
|
||||
int64_t conv_floatstr(char *numstr)
|
||||
{
|
||||
double val,corr;
|
||||
val = atof(numstr);
|
||||
corr = (val < 0.) ? -0.50000000001 : 0.50000000001;
|
||||
return((int64_t)(val * SATOSHIDEN + corr));
|
||||
}
|
||||
|
||||
int64_t _conv_cJSON_float(cJSON *json)
|
||||
{
|
||||
int64_t conv_floatstr(char *);
|
||||
struct destbuf tmp;
|
||||
if ( json != 0 )
|
||||
{
|
||||
copy_cJSON(&tmp,json);
|
||||
return(conv_floatstr(tmp.buf));
|
||||
}
|
||||
return(0);
|
||||
}
|
||||
|
||||
int64_t conv_cJSON_float(cJSON *json,char *field)
|
||||
{
|
||||
if ( json != 0 )
|
||||
return(_conv_cJSON_float(cJSON_GetObjectItem(json,field)));
|
||||
return(0);
|
||||
}
|
||||
|
||||
int32_t extract_cJSON_str(char *dest,int32_t max,cJSON *json,char *field)
|
||||
{
|
||||
int32_t safecopy(char *dest,char *src,long len);
|
||||
char *str;
|
||||
cJSON *obj;
|
||||
int32_t len;
|
||||
long offset;
|
||||
dest[0] = 0;
|
||||
obj = cJSON_GetObjectItem(json,field);
|
||||
if ( obj != 0 )
|
||||
{
|
||||
str = cJSON_Print(obj);
|
||||
offset = stripquotes(str);
|
||||
len = safecopy(dest,str+offset,max);
|
||||
free(str);
|
||||
return(len);
|
||||
}
|
||||
return(0);
|
||||
}
|
||||
|
||||
cJSON *gen_list_json(char **list)
|
||||
{
|
||||
cJSON *array,*item;
|
||||
array = cJSON_CreateArray();
|
||||
while ( list != 0 && *list != 0 && *list[0] != 0 )
|
||||
{
|
||||
item = cJSON_CreateString(*list++);
|
||||
cJSON_AddItemToArray(array,item);
|
||||
}
|
||||
return(array);
|
||||
}
|
||||
|
||||
uint64_t get_API_nxt64bits(cJSON *obj)
|
||||
{
|
||||
uint64_t nxt64bits = 0;
|
||||
struct destbuf tmp;
|
||||
if ( obj != 0 )
|
||||
{
|
||||
if ( cJSON_IsNumber(obj) != 0 )
|
||||
return((uint64_t)obj->valuedouble);
|
||||
copy_cJSON(&tmp,obj);
|
||||
nxt64bits = calc_nxt64bits(tmp.buf);
|
||||
}
|
||||
return(nxt64bits);
|
||||
}
|
||||
uint64_t j64bits(cJSON *json,char *field) { if ( field == 0 ) return(get_API_nxt64bits(json)); return(get_API_nxt64bits(cJSON_GetObjectItem(json,field))); }
|
||||
uint64_t j64bitsi(cJSON *json,int32_t i) { return(get_API_nxt64bits(cJSON_GetArrayItem(json,i))); }
|
||||
|
||||
uint64_t get_satoshi_obj(cJSON *json,char *field)
|
||||
{
|
||||
int32_t i,n;
|
||||
uint64_t prev,satoshis,mult = 1;
|
||||
struct destbuf numstr,checkstr;
|
||||
cJSON *numjson;
|
||||
numjson = cJSON_GetObjectItem(json,field);
|
||||
copy_cJSON(&numstr,numjson);
|
||||
satoshis = prev = 0; mult = 1; n = (int32_t)strlen(numstr.buf);
|
||||
for (i=n-1; i>=0; i--,mult*=10)
|
||||
{
|
||||
satoshis += (mult * (numstr.buf[i] - '0'));
|
||||
if ( satoshis < prev )
|
||||
printf("get_satoshi_obj numstr.(%s) i.%d prev.%llu vs satoshis.%llu\n",numstr.buf,i,(unsigned long long)prev,(unsigned long long)satoshis);
|
||||
prev = satoshis;
|
||||
}
|
||||
sprintf(checkstr.buf,"%llu",(long long)satoshis);
|
||||
if ( strcmp(checkstr.buf,numstr.buf) != 0 )
|
||||
{
|
||||
printf("SATOSHI GREMLIN?? numstr.(%s) -> %.8f -> (%s)\n",numstr.buf,dstr(satoshis),checkstr.buf);
|
||||
}
|
||||
return(satoshis);
|
||||
}
|
||||
|
||||
void add_satoshis_json(cJSON *json,char *field,uint64_t satoshis)
|
||||
{
|
||||
cJSON *obj;
|
||||
char numstr[64];
|
||||
sprintf(numstr,"%lld",(long long)satoshis);
|
||||
obj = cJSON_CreateString(numstr);
|
||||
cJSON_AddItemToObject(json,field,obj);
|
||||
if ( satoshis != get_satoshi_obj(json,field) )
|
||||
printf("error adding satoshi obj %ld -> %ld\n",(unsigned long)satoshis,(unsigned long)get_satoshi_obj(json,field));
|
||||
}
|
||||
|
||||
char *cJSON_str(cJSON *json)
|
||||
{
|
||||
if ( json != 0 && cJSON_IsString(json) != 0 )
|
||||
return(json->valuestring);
|
||||
return(0);
|
||||
}
|
||||
|
||||
void jadd(cJSON *json,char *field,cJSON *item) { if ( json != 0 )cJSON_AddItemToObject(json,field,item); }
|
||||
void jaddstr(cJSON *json,char *field,char *str) { if ( json != 0 && str != 0 ) cJSON_AddItemToObject(json,field,cJSON_CreateString(str)); }
|
||||
void jaddnum(cJSON *json,char *field,double num) { if ( json != 0 )cJSON_AddItemToObject(json,field,cJSON_CreateNumber(num)); }
|
||||
void jadd64bits(cJSON *json,char *field,uint64_t nxt64bits) { char numstr[64]; sprintf(numstr,"%llu",(long long)nxt64bits), jaddstr(json,field,numstr); }
|
||||
void jaddi(cJSON *json,cJSON *item) { if ( json != 0 ) cJSON_AddItemToArray(json,item); }
|
||||
void jaddistr(cJSON *json,char *str) { if ( json != 0 ) cJSON_AddItemToArray(json,cJSON_CreateString(str)); }
|
||||
void jaddinum(cJSON *json,double num) { if ( json != 0 ) cJSON_AddItemToArray(json,cJSON_CreateNumber(num)); }
|
||||
void jaddi64bits(cJSON *json,uint64_t nxt64bits) { char numstr[64]; sprintf(numstr,"%llu",(long long)nxt64bits), jaddistr(json,numstr); }
|
||||
char *jstr(cJSON *json,char *field) { if ( json == 0 ) return(0); if ( field == 0 ) return(cJSON_str(json)); return(cJSON_str(cJSON_GetObjectItem(json,field))); }
|
||||
|
||||
char *jstri(cJSON *json,int32_t i) { return(cJSON_str(cJSON_GetArrayItem(json,i))); }
|
||||
char *jprint(cJSON *json,int32_t freeflag)
|
||||
{
|
||||
char *str;
|
||||
/*static portable_mutex_t mutex; static int32_t initflag;
|
||||
if ( initflag == 0 )
|
||||
{
|
||||
portable_mutex_init(&mutex);
|
||||
initflag = 1;
|
||||
}*/
|
||||
if ( json == 0 )
|
||||
return(clonestr((char *)"{}"));
|
||||
//portable_mutex_lock(&mutex);
|
||||
//usleep(5000);
|
||||
str = cJSON_Print(json), _stripwhite(str,' ');
|
||||
if ( freeflag != 0 )
|
||||
free_json(json);
|
||||
//portable_mutex_unlock(&mutex);
|
||||
return(str);
|
||||
}
|
||||
|
||||
bits256 get_API_bits256(cJSON *obj)
|
||||
{
|
||||
bits256 hash; char *str;
|
||||
memset(hash.bytes,0,sizeof(hash));
|
||||
if ( obj != 0 )
|
||||
{
|
||||
if ( cJSON_IsString(obj) != 0 && (str= obj->valuestring) != 0 && strlen(str) == 64 )
|
||||
decode_hex(hash.bytes,sizeof(hash),str);
|
||||
}
|
||||
return(hash);
|
||||
}
|
||||
bits256 jbits256(cJSON *json,char *field) { if ( field == 0 ) return(get_API_bits256(json)); return(get_API_bits256(cJSON_GetObjectItem(json,field))); }
|
||||
bits256 jbits256i(cJSON *json,int32_t i) { return(get_API_bits256(cJSON_GetArrayItem(json,i))); }
|
||||
void jaddbits256(cJSON *json,char *field,bits256 hash) { char str[65]; bits256_str(str,hash), jaddstr(json,field,str); }
|
||||
void jaddibits256(cJSON *json,bits256 hash) { char str[65]; bits256_str(str,hash), jaddistr(json,str); }
|
||||
|
||||
char *get_cJSON_fieldname(cJSON *obj)
|
||||
{
|
||||
if ( obj != 0 )
|
||||
{
|
||||
if ( obj->child != 0 && obj->child->string != 0 )
|
||||
return(obj->child->string);
|
||||
else if ( obj->string != 0 )
|
||||
return(obj->string);
|
||||
}
|
||||
return((char *)"<no cJSON string field>");
|
||||
}
|
||||
|
||||
int32_t jnum(cJSON *obj,char *field)
|
||||
{
|
||||
char *str; int32_t polarity = 1;
|
||||
if ( field != 0 )
|
||||
obj = jobj(obj,field);
|
||||
if ( obj != 0 )
|
||||
{
|
||||
if ( cJSON_IsNumber(obj) != 0 )
|
||||
return(obj->valuedouble);
|
||||
else if ( cJSON_IsString(obj) != 0 && (str= jstr(obj,0)) != 0 )
|
||||
{
|
||||
if ( str[0] == '-' )
|
||||
polarity = -1, str++;
|
||||
return(polarity * (int32_t)calc_nxt64bits(str));
|
||||
}
|
||||
}
|
||||
return(0);
|
||||
}
|
||||
|
||||
void ensure_jsonitem(cJSON *json,char *field,char *value)
|
||||
{
|
||||
cJSON *obj = cJSON_GetObjectItem(json,field);
|
||||
if ( obj == 0 )
|
||||
cJSON_AddItemToObject(json,field,cJSON_CreateString(value));
|
||||
else cJSON_ReplaceItemInObject(json,field,cJSON_CreateString(value));
|
||||
}
|
||||
|
||||
int32_t in_jsonarray(cJSON *array,char *value)
|
||||
{
|
||||
int32_t i,n;
|
||||
struct destbuf remote;
|
||||
if ( array != 0 && cJSON_IsArray(array) != 0 )
|
||||
{
|
||||
n = cJSON_GetArraySize(array);
|
||||
for (i=0; i<n; i++)
|
||||
{
|
||||
if ( array == 0 || n == 0 )
|
||||
break;
|
||||
copy_cJSON(&remote,cJSON_GetArrayItem(array,i));
|
||||
if ( strcmp(remote.buf,value) == 0 )
|
||||
return(1);
|
||||
}
|
||||
}
|
||||
return(0);
|
||||
}
|
||||
|
||||
int32_t myatoi(char *str,int32_t range)
|
||||
{
|
||||
long x; char *ptr;
|
||||
x = strtol(str,&ptr,10);
|
||||
if ( range != 0 && x >= range )
|
||||
x = (range - 1);
|
||||
return((int32_t)x);
|
||||
}
|
||||
|
||||
int32_t get_API_int(cJSON *obj,int32_t val)
|
||||
{
|
||||
struct destbuf buf;
|
||||
if ( obj != 0 )
|
||||
{
|
||||
if ( cJSON_IsNumber(obj) != 0 )
|
||||
return((int32_t)obj->valuedouble);
|
||||
copy_cJSON(&buf,obj);
|
||||
val = myatoi(buf.buf,0);
|
||||
if ( val < 0 )
|
||||
val = 0;
|
||||
}
|
||||
return(val);
|
||||
}
|
||||
|
||||
int32_t jint(cJSON *json,char *field) { if ( json == 0 ) return(0); if ( field == 0 ) return(get_API_int(json,0)); return(get_API_int(cJSON_GetObjectItem(json,field),0)); }
|
||||
int32_t jinti(cJSON *json,int32_t i) { if ( json == 0 ) return(0); return(get_API_int(cJSON_GetArrayItem(json,i),0)); }
|
||||
|
||||
uint32_t get_API_uint(cJSON *obj,uint32_t val)
|
||||
{
|
||||
struct destbuf buf;
|
||||
if ( obj != 0 )
|
||||
{
|
||||
if ( cJSON_IsNumber(obj) != 0 )
|
||||
return((uint32_t)obj->valuedouble);
|
||||
copy_cJSON(&buf,obj);
|
||||
val = myatoi(buf.buf,0);
|
||||
}
|
||||
return(val);
|
||||
}
|
||||
uint32_t juint(cJSON *json,char *field) { if ( json == 0 ) return(0); if ( field == 0 ) return(get_API_uint(json,0)); return(get_API_uint(cJSON_GetObjectItem(json,field),0)); }
|
||||
uint32_t juinti(cJSON *json,int32_t i) { if ( json == 0 ) return(0); return(get_API_uint(cJSON_GetArrayItem(json,i),0)); }
|
||||
|
||||
double get_API_float(cJSON *obj)
|
||||
{
|
||||
double val = 0.;
|
||||
struct destbuf buf;
|
||||
if ( obj != 0 )
|
||||
{
|
||||
if ( cJSON_IsNumber(obj) != 0 )
|
||||
return(obj->valuedouble);
|
||||
copy_cJSON(&buf,obj);
|
||||
val = atof(buf.buf);
|
||||
}
|
||||
return(val);
|
||||
}
|
||||
|
||||
double jdouble(cJSON *json,char *field)
|
||||
{
|
||||
if ( json != 0 )
|
||||
{
|
||||
if ( field == 0 )
|
||||
return(get_API_float(json));
|
||||
else return(get_API_float(cJSON_GetObjectItem(json,field)));
|
||||
} else return(0.);
|
||||
}
|
||||
|
||||
double jdoublei(cJSON *json,int32_t i)
|
||||
{
|
||||
if ( json != 0 )
|
||||
return(get_API_float(cJSON_GetArrayItem(json,i)));
|
||||
else return(0.);
|
||||
}
|
||||
|
||||
cJSON *jobj(cJSON *json,char *field) { if ( json != 0 ) return(cJSON_GetObjectItem(json,field)); return(0); }
|
||||
|
||||
void jdelete(cJSON *json,char *field)
|
||||
{
|
||||
if ( jobj(json,field) != 0 )
|
||||
cJSON_DeleteItemFromObject(json,field);
|
||||
}
|
||||
|
||||
cJSON *jduplicate(cJSON *json) { return(cJSON_Duplicate(json,1)); }
|
||||
|
||||
cJSON *jitem(cJSON *array,int32_t i) { if ( array != 0 && cJSON_IsArray(array) != 0 && cJSON_GetArraySize(array) > i ) return(cJSON_GetArrayItem(array,i)); return(0); }
|
||||
cJSON *jarray(int32_t *nump,cJSON *json,char *field)
|
||||
{
|
||||
cJSON *array;
|
||||
if ( json != 0 )
|
||||
{
|
||||
if ( field == 0 )
|
||||
array = json;
|
||||
else array = cJSON_GetObjectItem(json,field);
|
||||
if ( array != 0 && cJSON_IsArray(array) != 0 && (*nump= cJSON_GetArraySize(array)) > 0 )
|
||||
return(array);
|
||||
}
|
||||
*nump = 0;
|
||||
return(0);
|
||||
}
|
||||
|
||||
int32_t expand_nxt64bits(char *NXTaddr,uint64_t nxt64bits)
|
||||
{
|
||||
int32_t i,n;
|
||||
uint64_t modval;
|
||||
char rev[64];
|
||||
for (i=0; nxt64bits!=0; i++)
|
||||
{
|
||||
modval = nxt64bits % 10;
|
||||
rev[i] = (char)(modval + '0');
|
||||
nxt64bits /= 10;
|
||||
}
|
||||
n = i;
|
||||
for (i=0; i<n; i++)
|
||||
NXTaddr[i] = rev[n-1-i];
|
||||
NXTaddr[i] = 0;
|
||||
return(n);
|
||||
}
|
||||
|
||||
char *nxt64str(uint64_t nxt64bits)
|
||||
{
|
||||
static char NXTaddr[64];
|
||||
expand_nxt64bits(NXTaddr,nxt64bits);
|
||||
return(NXTaddr);
|
||||
}
|
||||
|
||||
char *nxt64str2(uint64_t nxt64bits)
|
||||
{
|
||||
static char NXTaddr[64];
|
||||
expand_nxt64bits(NXTaddr,nxt64bits);
|
||||
return(NXTaddr);
|
||||
}
|
||||
|
||||
int32_t cmp_nxt64bits(const char *str,uint64_t nxt64bits)
|
||||
{
|
||||
char expanded[64];
|
||||
if ( str == 0 )//|| str[0] == 0 || nxt64bits == 0 )
|
||||
return(-1);
|
||||
if ( nxt64bits == 0 && str[0] == 0 )
|
||||
return(0);
|
||||
expand_nxt64bits(expanded,nxt64bits);
|
||||
return(strcmp(str,expanded));
|
||||
}
|
||||
|
||||
uint64_t calc_nxt64bits(const char *NXTaddr)
|
||||
{
|
||||
int32_t c;
|
||||
int64_t n,i,polarity = 1;
|
||||
uint64_t lastval,mult,nxt64bits = 0;
|
||||
if ( NXTaddr == 0 )
|
||||
{
|
||||
printf("calling calc_nxt64bits with null ptr!\n");
|
||||
return(0);
|
||||
}
|
||||
n = strlen(NXTaddr);
|
||||
if ( n >= 22 )
|
||||
{
|
||||
printf("calc_nxt64bits: illegal NXTaddr.(%s) too long\n",NXTaddr);
|
||||
return(0);
|
||||
}
|
||||
else if ( strcmp(NXTaddr,"0") == 0 || strcmp(NXTaddr,"false") == 0 )
|
||||
{
|
||||
// printf("zero address?\n"); getchar();
|
||||
return(0);
|
||||
}
|
||||
if ( NXTaddr[0] == '-' )
|
||||
polarity = -1, NXTaddr++, n--;
|
||||
mult = 1;
|
||||
lastval = 0;
|
||||
for (i=n-1; i>=0; i--,mult*=10)
|
||||
{
|
||||
c = NXTaddr[i];
|
||||
if ( c < '0' || c > '9' )
|
||||
{
|
||||
printf("calc_nxt64bits: illegal char.(%c %d) in (%s).%d\n",c,c,NXTaddr,(int32_t)i);
|
||||
#ifdef __APPLE__
|
||||
//while ( 1 )
|
||||
{
|
||||
//sleep(60);
|
||||
printf("calc_nxt64bits: illegal char.(%c %d) in (%s).%d\n",c,c,NXTaddr,(int32_t)i);
|
||||
}
|
||||
#endif
|
||||
return(0);
|
||||
}
|
||||
nxt64bits += mult * (c - '0');
|
||||
if ( nxt64bits < lastval )
|
||||
printf("calc_nxt64bits: warning: 64bit overflow %llx < %llx\n",(long long)nxt64bits,(long long)lastval);
|
||||
lastval = nxt64bits;
|
||||
}
|
||||
while ( *NXTaddr == '0' && *NXTaddr != 0 )
|
||||
NXTaddr++;
|
||||
if ( cmp_nxt64bits(NXTaddr,nxt64bits) != 0 )
|
||||
printf("error calculating nxt64bits: %s -> %llx -> %s\n",NXTaddr,(long long)nxt64bits,nxt64str(nxt64bits));
|
||||
if ( polarity < 0 )
|
||||
return(-(int64_t)nxt64bits);
|
||||
return(nxt64bits);
|
||||
}
|
||||
|
||||
cJSON *addrs_jsonarray(uint64_t *addrs,int32_t num)
|
||||
{
|
||||
int32_t j; cJSON *array;
|
||||
array = cJSON_CreateArray();
|
||||
for (j=0; j<num; j++)
|
||||
jaddi64bits(array,addrs[j]);
|
||||
return(array);
|
||||
}
|
||||
|
||||
void free_json(cJSON *json) { if ( json != 0 ) cJSON_Delete(json); }
|
||||
127
src/komodo_cJSON.h
Executable file
127
src/komodo_cJSON.h
Executable file
@@ -0,0 +1,127 @@
|
||||
/*
|
||||
Copyright (c) 2009 Dave Gamble
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
of this software and associated documentation files (the "Software"), to deal
|
||||
in the Software without restriction, including without limitation the rights
|
||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
copies of the Software, and to permit persons to whom the Software is
|
||||
furnished to do so, subject to the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be included in
|
||||
all copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||
THE SOFTWARE.
|
||||
*/
|
||||
|
||||
#ifndef komodo_cJSON__h
|
||||
#define komodo_cJSON__h
|
||||
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <stdint.h>
|
||||
#include <math.h>
|
||||
#include <ctype.h>
|
||||
#include <float.h>
|
||||
#include <memory.h>
|
||||
|
||||
#include "cJSON.h"
|
||||
|
||||
//#include "../crypto777/OS_portable.h"
|
||||
|
||||
#define MAX_JSON_FIELD 4096 // on the big side
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C"
|
||||
{
|
||||
#endif
|
||||
|
||||
/* Macros for creating things quickly. */
|
||||
#define cJSON_AddNullToObject(object,name) cJSON_AddItemToObject(object, name, cJSON_CreateNull())
|
||||
#define cJSON_AddTrueToObject(object,name) cJSON_AddItemToObject(object, name, cJSON_CreateTrue())
|
||||
#define cJSON_AddFalseToObject(object,name) cJSON_AddItemToObject(object, name, cJSON_CreateFalse())
|
||||
#define cJSON_AddBoolToObject(object,name,b) cJSON_AddItemToObject(object, name, cJSON_CreateBool(b))
|
||||
#define cJSON_AddNumberToObject(object,name,n) cJSON_AddItemToObject(object, name, cJSON_CreateNumber(n))
|
||||
#define cJSON_AddStringToObject(object,name,s) cJSON_AddItemToObject(object, name, cJSON_CreateString(s))
|
||||
|
||||
struct destbuf { char buf[MAX_JSON_FIELD]; };
|
||||
|
||||
#define jfieldstr get_cJSON_fieldname
|
||||
|
||||
char *cJSON_str(cJSON *json);
|
||||
char *jstr(cJSON *json,char *field);
|
||||
char *jprint(cJSON *json,int32_t freeflag);
|
||||
int32_t jint(cJSON *json,char *field);
|
||||
uint32_t juint(cJSON *json,char *field);
|
||||
char *jstri(cJSON *json,int32_t i);
|
||||
int32_t jinti(cJSON *json,int32_t i);
|
||||
uint32_t juinti(cJSON *json,int32_t i);
|
||||
uint64_t j64bitsi(cJSON *json,int32_t i);
|
||||
double jdoublei(cJSON *json,int32_t i);
|
||||
double jdouble(cJSON *json,char *field);
|
||||
cJSON *jobj(cJSON *json,char *field);
|
||||
cJSON *jarray(int32_t *nump,cJSON *json,char *field);
|
||||
cJSON *jitem(cJSON *array,int32_t i);
|
||||
uint64_t j64bits(cJSON *json,char *field);
|
||||
void jadd(cJSON *json,char *field,cJSON *item);
|
||||
void jaddstr(cJSON *json,char *field,char *str);
|
||||
void jaddnum(cJSON *json,char *field,double num);
|
||||
void jadd64bits(cJSON *json,char *field,uint64_t nxt64bits);
|
||||
void jaddi(cJSON *json,cJSON *item);
|
||||
void jaddistr(cJSON *json,char *str);
|
||||
void jaddinum(cJSON *json,double num);
|
||||
void jaddi64bits(cJSON *json,uint64_t nxt64bits);
|
||||
void jdelete(cJSON *object,char *string);
|
||||
cJSON *jduplicate(cJSON *json);
|
||||
int32_t jnum(cJSON *obj,char *field);
|
||||
|
||||
bits256 jbits256(cJSON *json,char *field);
|
||||
bits256 jbits256i(cJSON *json,int32_t i);
|
||||
void jaddbits256(cJSON *json,char *field,bits256 hash);
|
||||
void jaddibits256(cJSON *json,bits256 hash);
|
||||
void copy_cJSON(struct destbuf *dest,cJSON *obj);
|
||||
void copy_cJSON2(char *dest,int32_t maxlen,cJSON *obj);
|
||||
cJSON *gen_list_json(char **list);
|
||||
int32_t extract_cJSON_str(char *dest,int32_t max,cJSON *json,char *field);
|
||||
|
||||
void free_json(cJSON *json);
|
||||
int64_t _conv_cJSON_float(cJSON *json);
|
||||
int64_t conv_cJSON_float(cJSON *json,char *field);
|
||||
int64_t get_cJSON_int(cJSON *json,char *field);
|
||||
void add_satoshis_json(cJSON *json,char *field,uint64_t satoshis);
|
||||
uint64_t get_satoshi_obj(cJSON *json,char *field);
|
||||
|
||||
int32_t get_API_int(cJSON *obj,int32_t val);
|
||||
uint32_t get_API_uint(cJSON *obj,uint32_t val);
|
||||
uint64_t get_API_nxt64bits(cJSON *obj);
|
||||
double get_API_float(cJSON *obj);
|
||||
char *get_cJSON_fieldname(cJSON *obj);
|
||||
void ensure_jsonitem(cJSON *json,char *field,char *value);
|
||||
int32_t in_jsonarray(cJSON *array,char *value);
|
||||
char *bitcoind_RPC(char **retstrp,char *debugstr,char *url,char *userpass,char *command,char *params);
|
||||
uint64_t calc_nxt64bits(const char *str);
|
||||
int32_t expand_nxt64bits(char *str,uint64_t nxt64bits);
|
||||
char *nxt64str(uint64_t nxt64bits);
|
||||
char *nxt64str2(uint64_t nxt64bits);
|
||||
cJSON *addrs_jsonarray(uint64_t *addrs,int32_t num);
|
||||
int32_t myatoi(char *str,int32_t range);
|
||||
|
||||
char *stringifyM(char *str);
|
||||
#define replace_backslashquotes unstringify
|
||||
char *unstringify(char *str);
|
||||
#define jtrue cJSON_CreateTrue
|
||||
#define jfalse cJSON_CreateFalse
|
||||
|
||||
#define jfieldname get_cJSON_fieldname
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
||||
@@ -141,7 +141,7 @@ int32_t Jumblr_depositaddradd(char *depositaddr) // external
|
||||
{
|
||||
if ( (retjson= cJSON_Parse(retstr)) != 0 )
|
||||
{
|
||||
if ( (ismine= jobj(retjson,(char *)"ismine")) != 0 && is_cJSON_True(ismine) != 0 )
|
||||
if ( (ismine= jobj(retjson,(char *)"ismine")) != 0 && cJSON_IsTrue(ismine) != 0 )
|
||||
{
|
||||
retval = 0;
|
||||
safecopy(Jumblr_deposit,depositaddr,sizeof(Jumblr_deposit));
|
||||
@@ -149,7 +149,7 @@ int32_t Jumblr_depositaddradd(char *depositaddr) // external
|
||||
else
|
||||
{
|
||||
retval = JUMBLR_ERROR_NOTINWALLET;
|
||||
printf("%s not in wallet: ismine.%p %d %s\n",depositaddr,ismine,is_cJSON_True(ismine),jprint(retjson,0));
|
||||
printf("%s not in wallet: ismine.%p %d %s\n",depositaddr,ismine,cJSON_IsTrue(ismine),jprint(retjson,0));
|
||||
}
|
||||
free_json(retjson);
|
||||
}
|
||||
@@ -366,7 +366,7 @@ int64_t jumblr_balance(char *addr)
|
||||
//printf("jumblr.[%s].(%s)\n","KMD",retstr);
|
||||
if ( (retjson= cJSON_Parse(retstr)) != 0 )
|
||||
{
|
||||
if ( (n= cJSON_GetArraySize(retjson)) > 0 && is_cJSON_Array(retjson) != 0 )
|
||||
if ( (n= cJSON_GetArraySize(retjson)) > 0 && cJSON_IsArray(retjson) != 0 )
|
||||
for (i=0; i<n; i++)
|
||||
balance += SATOSHIDEN * jdouble(jitem(retjson,i),(char *)"amount");
|
||||
free_json(retjson);
|
||||
@@ -436,7 +436,7 @@ void jumblr_opidupdate(struct jumblr_item *ptr)
|
||||
{
|
||||
if ( (retjson= cJSON_Parse(retstr)) != 0 )
|
||||
{
|
||||
if ( cJSON_GetArraySize(retjson) == 1 && is_cJSON_Array(retjson) != 0 )
|
||||
if ( cJSON_GetArraySize(retjson) == 1 && cJSON_IsArray(retjson) != 0 )
|
||||
{
|
||||
item = jitem(retjson,0);
|
||||
//printf("%s\n",jprint(item,0));
|
||||
@@ -496,6 +496,10 @@ void jumblr_prune(struct jumblr_item *ptr)
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
bits256 jbits256(cJSON *json,char *field);
|
||||
|
||||
|
||||
void jumblr_zaddrinit(char *zaddr)
|
||||
{
|
||||
struct jumblr_item *ptr; char *retstr,*totalstr; cJSON *item,*array; double total; bits256 txid; char txidstr[65],t_z,z_z;
|
||||
@@ -508,7 +512,7 @@ void jumblr_zaddrinit(char *zaddr)
|
||||
if ( (array= cJSON_Parse(retstr)) != 0 )
|
||||
{
|
||||
t_z = z_z = 0;
|
||||
if ( cJSON_GetArraySize(array) == 1 && is_cJSON_Array(array) != 0 )
|
||||
if ( cJSON_GetArraySize(array) == 1 && cJSON_IsArray(array) != 0 )
|
||||
{
|
||||
item = jitem(array,0);
|
||||
if ( (uint64_t)((total+0.0000000049) * SATOSHIDEN) == (uint64_t)((jdouble(item,(char *)"amount")+0.0000000049) * SATOSHIDEN) )
|
||||
@@ -559,7 +563,7 @@ void jumblr_opidsupdate()
|
||||
{
|
||||
if ( (array= cJSON_Parse(retstr)) != 0 )
|
||||
{
|
||||
if ( (n= cJSON_GetArraySize(array)) > 0 && is_cJSON_Array(array) != 0 )
|
||||
if ( (n= cJSON_GetArraySize(array)) > 0 && cJSON_IsArray(array) != 0 )
|
||||
{
|
||||
//printf("%s -> n%d\n",retstr,n);
|
||||
for (i=0; i<n; i++)
|
||||
@@ -631,7 +635,7 @@ void jumblr_iteration()
|
||||
{
|
||||
if ( (array= cJSON_Parse(retstr)) != 0 )
|
||||
{
|
||||
if ( (n= cJSON_GetArraySize(array)) > 0 && is_cJSON_Array(array) != 0 )
|
||||
if ( (n= cJSON_GetArraySize(array)) > 0 && cJSON_IsArray(array) != 0 )
|
||||
{
|
||||
for (i=0; i<n; i++)
|
||||
jumblr_zaddrinit(jstri(array,i));
|
||||
|
||||
@@ -13,6 +13,8 @@
|
||||
* *
|
||||
******************************************************************************/
|
||||
|
||||
#include "komodo_cJSON.h"
|
||||
|
||||
#define KOMODO_MAINNET_START 178999
|
||||
|
||||
const char *Notaries_genesis[][2] =
|
||||
|
||||
Reference in New Issue
Block a user