mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-10 14:57:42 +00:00
util: json: add helper to iterate and steal members of json array
Simplifies cases where JSON array members need to be transferred to a different structure.
This commit is contained in:
parent
c6b6e737e8
commit
edf33d1a65
@ -1766,6 +1766,7 @@ virISCSIScanTargets;
|
|||||||
|
|
||||||
# util/virjson.h
|
# util/virjson.h
|
||||||
virJSONValueArrayAppend;
|
virJSONValueArrayAppend;
|
||||||
|
virJSONValueArrayForeachSteal;
|
||||||
virJSONValueArrayGet;
|
virJSONValueArrayGet;
|
||||||
virJSONValueArraySize;
|
virJSONValueArraySize;
|
||||||
virJSONValueArraySteal;
|
virJSONValueArraySteal;
|
||||||
|
@ -949,6 +949,61 @@ virJSONValueArraySteal(virJSONValuePtr array,
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* virJSONValueArrayForeachSteal:
|
||||||
|
* @array: array to iterate
|
||||||
|
* @cb: callback called on every member of the array
|
||||||
|
* @opaque: custom data for the callback
|
||||||
|
*
|
||||||
|
* Iterates members of the array and calls the callback on every single member.
|
||||||
|
* The return codes of the callback are interpreted as follows:
|
||||||
|
* 0: callback claims ownership of the array element and is responsible for
|
||||||
|
* freeing it
|
||||||
|
* 1: callback doesn't claim ownership of the element
|
||||||
|
* -1: callback doesn't claim ownership of the element and iteration does not
|
||||||
|
* continue
|
||||||
|
*
|
||||||
|
* Returns 0 if all members were iterated and/or stolen by the callback; -1
|
||||||
|
* on callback failure or if the JSON value object is not an array.
|
||||||
|
* The rest of the members stay in possession of the array and it's condensed.
|
||||||
|
*/
|
||||||
|
int
|
||||||
|
virJSONValueArrayForeachSteal(virJSONValuePtr array,
|
||||||
|
virJSONArrayIteratorFunc cb,
|
||||||
|
void *opaque)
|
||||||
|
{
|
||||||
|
size_t i;
|
||||||
|
size_t j = 0;
|
||||||
|
int ret = 0;
|
||||||
|
int rc;
|
||||||
|
|
||||||
|
if (array->type != VIR_JSON_TYPE_ARRAY)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
for (i = 0; i < array->data.array.nvalues; i++) {
|
||||||
|
if ((rc = cb(i, array->data.array.values[i], opaque)) < 0) {
|
||||||
|
ret = -1;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (rc == 0)
|
||||||
|
array->data.array.values[i] = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* condense the remaining entries at the beginning */
|
||||||
|
for (i = 0; i < array->data.array.nvalues; i++) {
|
||||||
|
if (!array->data.array.values[i])
|
||||||
|
continue;
|
||||||
|
|
||||||
|
array->data.array.values[j++] = array->data.array.values[i];
|
||||||
|
}
|
||||||
|
|
||||||
|
array->data.array.nvalues = j;
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
const char *
|
const char *
|
||||||
virJSONValueGetString(virJSONValuePtr string)
|
virJSONValueGetString(virJSONValuePtr string)
|
||||||
{
|
{
|
||||||
|
@ -117,6 +117,12 @@ bool virJSONValueIsArray(virJSONValuePtr array);
|
|||||||
ssize_t virJSONValueArraySize(const virJSONValue *array);
|
ssize_t virJSONValueArraySize(const virJSONValue *array);
|
||||||
virJSONValuePtr virJSONValueArrayGet(virJSONValuePtr object, unsigned int element);
|
virJSONValuePtr virJSONValueArrayGet(virJSONValuePtr object, unsigned int element);
|
||||||
virJSONValuePtr virJSONValueArraySteal(virJSONValuePtr object, unsigned int element);
|
virJSONValuePtr virJSONValueArraySteal(virJSONValuePtr object, unsigned int element);
|
||||||
|
typedef int (*virJSONArrayIteratorFunc)(size_t pos,
|
||||||
|
virJSONValuePtr item,
|
||||||
|
void *opaque);
|
||||||
|
int virJSONValueArrayForeachSteal(virJSONValuePtr array,
|
||||||
|
virJSONArrayIteratorFunc cb,
|
||||||
|
void *opaque);
|
||||||
|
|
||||||
int virJSONValueObjectKeysNumber(virJSONValuePtr object);
|
int virJSONValueObjectKeysNumber(virJSONValuePtr object);
|
||||||
const char *virJSONValueObjectGetKey(virJSONValuePtr object, unsigned int n);
|
const char *virJSONValueObjectGetKey(virJSONValuePtr object, unsigned int n);
|
||||||
|
Loading…
Reference in New Issue
Block a user