Skip to content

Commit

Permalink
Change all internal sizes to size_t
Browse files Browse the repository at this point in the history
  • Loading branch information
FSMaxB committed Feb 3, 2017
1 parent 28b9ba4 commit ecd5678
Show file tree
Hide file tree
Showing 2 changed files with 84 additions and 43 deletions.
111 changes: 76 additions & 35 deletions cJSON.c
Original file line number Diff line number Diff line change
Expand Up @@ -255,16 +255,23 @@ static int pow2gt (int x)
typedef struct
{
unsigned char *buffer;
int length;
int offset;
size_t length;
size_t offset;
cjbool noalloc;
} printbuffer;

/* realloc printbuffer if necessary to have at least "needed" bytes more */
static unsigned char* ensure(printbuffer *p, int needed)
static unsigned char* ensure(printbuffer *p, size_t needed)
{
unsigned char *newbuffer = NULL;
int newsize = 0;
size_t newsize = 0;

if (needed > INT_MAX)
{
/* sizes bigger than INT_MAX are currently not supported */
return NULL;
}

if (!p || !p->buffer)
{
return NULL;
Expand Down Expand Up @@ -301,7 +308,7 @@ static unsigned char* ensure(printbuffer *p, int needed)
}

/* calculate the new length of the string in a printbuffer */
static int update(const printbuffer *p)
static size_t update(const printbuffer *p)
{
unsigned char *str = NULL;
if (!p || !p->buffer)
Expand Down Expand Up @@ -493,7 +500,7 @@ static const unsigned char *parse_string(cJSON *item, const unsigned char *str,
const unsigned char *end_ptr =str + 1;
unsigned char *ptr2 = NULL;
unsigned char *out = NULL;
int len = 0;
size_t len = 0;
unsigned uc = 0;
unsigned uc2 = 0;

Expand Down Expand Up @@ -673,7 +680,7 @@ static unsigned char *print_string_ptr(const unsigned char *str, printbuffer *p)
const unsigned char *ptr = NULL;
unsigned char *ptr2 = NULL;
unsigned char *out = NULL;
int len = 0;
size_t len = 0;
cjbool flag = false;
unsigned char token = '\0';

Expand Down Expand Up @@ -821,11 +828,11 @@ static unsigned char *print_string(const cJSON *item, printbuffer *p)

/* Predeclare these prototypes. */
static const unsigned char *parse_value(cJSON *item, const unsigned char *value, const unsigned char **ep);
static unsigned char *print_value(const cJSON *item, int depth, cjbool fmt, printbuffer *p);
static unsigned char *print_value(const cJSON *item, size_t depth, cjbool fmt, printbuffer *p);
static const unsigned char *parse_array(cJSON *item, const unsigned char *value, const unsigned char **ep);
static unsigned char *print_array(const cJSON *item, int depth, cjbool fmt, printbuffer *p);
static unsigned char *print_array(const cJSON *item, size_t depth, cjbool fmt, printbuffer *p);
static const unsigned char *parse_object(cJSON *item, const unsigned char *value, const unsigned char **ep);
static unsigned char *print_object(const cJSON *item, int depth, cjbool fmt, printbuffer *p);
static unsigned char *print_object(const cJSON *item, size_t depth, cjbool fmt, printbuffer *p);

/* Utility to jump whitespace and cr/lf */
static const unsigned char *skip(const unsigned char *in)
Expand Down Expand Up @@ -969,7 +976,7 @@ static const unsigned char *parse_value(cJSON *item, const unsigned char *value
}

/* Render a value to text. */
static unsigned char *print_value(const cJSON *item, int depth, cjbool fmt, printbuffer *p)
static unsigned char *print_value(const cJSON *item, size_t depth, cjbool fmt, printbuffer *p)
{
unsigned char *out = NULL;

Expand Down Expand Up @@ -1145,16 +1152,16 @@ static const unsigned char *parse_array(cJSON *item, const unsigned char *value,
}

/* Render an array to text */
static unsigned char *print_array(const cJSON *item, int depth, cjbool fmt, printbuffer *p)
static unsigned char *print_array(const cJSON *item, size_t depth, cjbool fmt, printbuffer *p)
{
unsigned char **entries;
unsigned char *out = NULL;
unsigned char *ptr = NULL;
unsigned char *ret = NULL;
int len = 5;
size_t len = 5;
cJSON *child = item->child;
int numentries = 0;
int i = 0;
size_t numentries = 0;
size_t i = 0;
cjbool fail = false;
size_t tmplen = 0;

Expand Down Expand Up @@ -1409,19 +1416,19 @@ static const unsigned char *parse_object(cJSON *item, const unsigned char *value
}

/* Render an object to text. */
static unsigned char *print_object(const cJSON *item, int depth, cjbool fmt, printbuffer *p)
static unsigned char *print_object(const cJSON *item, size_t depth, cjbool fmt, printbuffer *p)
{
unsigned char **entries = NULL;
unsigned char **names = NULL;
unsigned char *out = NULL;
unsigned char *ptr = NULL;
unsigned char *ret = NULL;
unsigned char *str = NULL;
int len = 7;
int i = 0;
int j = 0;
size_t len = 7;
size_t i = 0;
size_t j = 0;
cJSON *child = item->child;
int numentries = 0;
size_t numentries = 0;
cjbool fail = false;
size_t tmplen = 0;

Expand Down Expand Up @@ -1693,12 +1700,15 @@ static unsigned char *print_object(const cJSON *item, int depth, cjbool fmt, pri
int cJSON_GetArraySize(const cJSON *array)
{
cJSON *c = array->child;
int i = 0;
size_t i = 0;
while(c)
{
i++;
c = c->next;
}

/* FIXME: Can overflow here. Cannot be fixed without breaking the API */

return i;
}

Expand Down Expand Up @@ -1860,7 +1870,7 @@ void cJSON_DeleteItemFromArray(cJSON *array, int which)

cJSON *cJSON_DetachItemFromObject(cJSON *object, const char *string)
{
int i = 0;
size_t i = 0;
cJSON *c = object->child;
while (c && cJSON_strcasecmp((unsigned char*)c->string, (const unsigned char*)string))
{
Expand Down Expand Up @@ -1939,7 +1949,7 @@ void cJSON_ReplaceItemInArray(cJSON *array, int which, cJSON *newitem)

void cJSON_ReplaceItemInObject(cJSON *object, const char *string, cJSON *newitem)
{
int i = 0;
size_t i = 0;
cJSON *c = object->child;
while(c && cJSON_strcasecmp((unsigned char*)c->string, (const unsigned char*)string))
{
Expand Down Expand Up @@ -2076,11 +2086,18 @@ cJSON *cJSON_CreateObject(void)
/* Create Arrays: */
cJSON *cJSON_CreateIntArray(const int *numbers, int count)
{
int i = 0;
size_t i = 0;
cJSON *n = NULL;
cJSON *p = NULL;
cJSON *a = cJSON_CreateArray();
for(i = 0; a && (i < count); i++)
cJSON *a = NULL;

if (count < 0)
{
return NULL;
}

a = cJSON_CreateArray();
for(i = 0; a && (i < (size_t)count); i++)
{
n = cJSON_CreateNumber(numbers[i]);
if (!n)
Expand All @@ -2104,11 +2121,19 @@ cJSON *cJSON_CreateIntArray(const int *numbers, int count)

cJSON *cJSON_CreateFloatArray(const float *numbers, int count)
{
int i = 0;
size_t i = 0;
cJSON *n = NULL;
cJSON *p = NULL;
cJSON *a = cJSON_CreateArray();
for(i = 0; a && (i < count); i++)
cJSON *a = NULL;

if (count < 0)
{
return NULL;
}

a = cJSON_CreateArray();

for(i = 0; a && (i < (size_t)count); i++)
{
n = cJSON_CreateNumber(numbers[i]);
if(!n)
Expand All @@ -2132,11 +2157,19 @@ cJSON *cJSON_CreateFloatArray(const float *numbers, int count)

cJSON *cJSON_CreateDoubleArray(const double *numbers, int count)
{
int i = 0;
size_t i = 0;
cJSON *n = NULL;
cJSON *p = NULL;
cJSON *a = cJSON_CreateArray();
for(i = 0;a && (i < count); i++)
cJSON *a = NULL;

if (count < 0)
{
return NULL;
}

a = cJSON_CreateArray();

for(i = 0;a && (i < (size_t)count); i++)
{
n = cJSON_CreateNumber(numbers[i]);
if(!n)
Expand All @@ -2160,11 +2193,19 @@ cJSON *cJSON_CreateDoubleArray(const double *numbers, int count)

cJSON *cJSON_CreateStringArray(const char **strings, int count)
{
int i = 0;
size_t i = 0;
cJSON *n = NULL;
cJSON *p = NULL;
cJSON *a = cJSON_CreateArray();
for (i = 0; a && (i < count); i++)
cJSON *a = NULL;

if (count < 0)
{
return NULL;
}

a = cJSON_CreateArray();

for (i = 0; a && (i < (size_t)count); i++)
{
n = cJSON_CreateString(strings[i]);
if(!n)
Expand Down
16 changes: 8 additions & 8 deletions cJSON_Utils.c
Original file line number Diff line number Diff line change
Expand Up @@ -76,9 +76,9 @@ static int cJSONUtils_Pstrcasecmp(const unsigned char *a, const unsigned char *e
return 0;
}

static int cJSONUtils_PointerEncodedstrlen(const unsigned char *s)
static size_t cJSONUtils_PointerEncodedstrlen(const unsigned char *s)
{
int l = 0;
size_t l = 0;
for (; *s; s++, l++)
{
if ((*s == '~') || (*s == '/'))
Expand Down Expand Up @@ -116,7 +116,7 @@ static void cJSONUtils_PointerEncodedstrcpy(unsigned char *d, const unsigned cha
char *cJSONUtils_FindPointerFromObjectTo(cJSON *object, cJSON *target)
{
int type = object->type;
int c = 0;
size_t c = 0;
cJSON *obj = 0;

if (object == target)
Expand All @@ -135,7 +135,7 @@ char *cJSONUtils_FindPointerFromObjectTo(cJSON *object, cJSON *target)
{
/* reserve enough memory for a 64 bit integer + '/' and '\0' */
unsigned char *ret = (unsigned char*)malloc(strlen((char*)found) + 23);
sprintf((char*)ret, "/%d%s", c, found); /* /<array_index><path> */
sprintf((char*)ret, "/%lu%s", c, found); /* /<array_index><path> */
free(found);

return (char*)ret;
Expand Down Expand Up @@ -168,7 +168,7 @@ cJSON *cJSONUtils_GetPointer(cJSON *object, const char *pointer)
{
if ((object->type & 0xFF) == cJSON_Array)
{
int which = 0;
size_t which = 0;
/* parse array index */
while ((*pointer >= '0') && (*pointer <= '9'))
{
Expand Down Expand Up @@ -562,18 +562,18 @@ static void cJSONUtils_CompareToPatch(cJSON *patches, const unsigned char *path,

case cJSON_Array:
{
int c = 0;
size_t c = 0;
unsigned char *newpath = (unsigned char*)malloc(strlen((const char*)path) + 23); /* Allow space for 64bit int. */
/* generate patches for all array elements that exist in "from" and "to" */
for (c = 0, from = from->child, to = to->child; from && to; from = from->next, to = to->next, c++)
{
sprintf((char*)newpath, "%s/%d", path, c); /* path of the current array element */
sprintf((char*)newpath, "%s/%lu", path, c); /* path of the current array element */
cJSONUtils_CompareToPatch(patches, newpath, from, to);
}
/* remove leftover elements from 'from' that are not in 'to' */
for (; from; from = from->next, c++)
{
sprintf((char*)newpath, "%d", c);
sprintf((char*)newpath, "%lu", c);
cJSONUtils_GeneratePatch(patches, (const unsigned char*)"remove", path, newpath, 0);
}
/* add new elements in 'to' that were not in 'from' */
Expand Down

0 comments on commit ecd5678

Please sign in to comment.