cJSON_Utils: Use new helper function

This commit is contained in:
Max Bruckner 2017-04-12 11:21:21 +02:00
parent b470d918f3
commit 3056d85f01

View File

@ -278,6 +278,39 @@ static cJSON_bool decode_array_index_from_pointer(const unsigned char * const po
return 1; return 1;
} }
/* non-broken cJSON_DetachItemFromArray */
static cJSON *detach_item_from_array(cJSON *array, size_t which)
{
cJSON *c = array->child;
while (c && (which > 0))
{
c = c->next;
which--;
}
if (!c)
{
/* item doesn't exist */
return NULL;
}
if (c->prev)
{
/* not the first element */
c->prev->next = c->next;
}
if (c->next)
{
c->next->prev = c->prev;
}
if (c==array->child)
{
array->child = c->next;
}
/* make sure the detached item doesn't point anywhere anymore */
c->prev = c->next = NULL;
return c;
}
static cJSON *cJSONUtils_PatchDetach(cJSON *object, const unsigned char *path) static cJSON *cJSONUtils_PatchDetach(cJSON *object, const unsigned char *path)
{ {
unsigned char *parentptr = NULL; unsigned char *parentptr = NULL;
@ -310,7 +343,13 @@ static cJSON *cJSONUtils_PatchDetach(cJSON *object, const unsigned char *path)
} }
else if (cJSON_IsArray(parent)) else if (cJSON_IsArray(parent))
{ {
ret = cJSON_DetachItemFromArray(parent, atoi((char*)childptr)); size_t index = 0;
if (!decode_array_index_from_pointer(childptr, &index))
{
free(parentptr);
return NULL;
}
ret = detach_item_from_array(parent, index);
} }
else if (cJSON_IsObject(parent)) else if (cJSON_IsObject(parent))
{ {