fix null pointer dereferences found by coverity

This commit is contained in:
Max Bruckner 2017-02-07 19:07:18 +01:00
parent 2f712c7456
commit 9ed906758e
2 changed files with 22 additions and 7 deletions

18
cJSON.c
View File

@ -1789,14 +1789,18 @@ static cJSON *create_reference(const cJSON *item)
}
/* Add item to array/object. */
void cJSON_AddItemToArray(cJSON *array, cJSON *item)
void cJSON_AddItemToArray(cJSON *array, cJSON *item)
{
cJSON *c = array->child;
if (!item)
cJSON *child = NULL;
if ((item == NULL) || (array == NULL))
{
return;
}
if (!c)
child = array->child;
if (child == NULL)
{
/* list is empty, start new one */
array->child = item;
@ -1804,11 +1808,11 @@ void cJSON_AddItemToArray(cJSON *array, cJSON *item)
else
{
/* append to the end */
while (c->next)
while (child->next)
{
c = c->next;
child = child->next;
}
suffix_object(c, item);
suffix_object(child, item);
}
}

View File

@ -494,6 +494,12 @@ static int cJSONUtils_ApplyPatch(cJSON *object, cJSON *patch)
int cJSONUtils_ApplyPatches(cJSON *object, cJSON *patches)
{
int err = 0;
if (patches == NULL)
{
return 1;
}
if ((patches->type & 0xFF) != cJSON_Array)
{
/* malformed patches. */
@ -544,6 +550,11 @@ void cJSONUtils_AddPatchToArray(cJSON *array, const char *op, const char *path,
static void cJSONUtils_CompareToPatch(cJSON *patches, const unsigned char *path, cJSON *from, cJSON *to)
{
if ((from == NULL) || (to == NULL))
{
return;
}
if ((from->type & 0xFF) != (to->type & 0xFF))
{
cJSONUtils_GeneratePatch(patches, (const unsigned char*)"replace", path, 0, to);