mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-24 06:03:52 +03:00
virTypedParamsGetStringList: Ensure that returned array is NULL if there are no matching fields
'virTypedParamsGetStringList' fills the returned array only with string parameters with matching name. The filtering code though leaves the possibility that all items are filtered out but the return array is still (over)allocated. Since 'virTypedParamsFilter()' now also allows filtering by type we can move the filtering there ensuring that we always allocate the right number of elements and more importantly the returned array will be NULL if none elements are present. Rework the code and adjust docs. Signed-off-by: Peter Krempa <pkrempa@redhat.com> Reviewed-by: Pavel Hrdina <phrdina@redhat.com>
This commit is contained in:
parent
b74fed0173
commit
7933310ce9
@ -439,7 +439,8 @@ virTypedParamsFilter(virTypedParameterPtr params,
|
||||
* @values: array of returned values
|
||||
*
|
||||
* Finds all parameters with desired @name within @params and
|
||||
* store their values into @values.
|
||||
* store their values into @values. If none of the @params are strings named
|
||||
* @name the returned @values will be NULL.
|
||||
*
|
||||
* Important: The strings in the returned string list @values are borrowed from
|
||||
* @params and thus caller must free only the pointer returned as @values, but
|
||||
@ -454,13 +455,12 @@ virTypedParamsGetStringList(virTypedParameterPtr params,
|
||||
const char ***values)
|
||||
{
|
||||
size_t i;
|
||||
size_t n = 0;
|
||||
size_t nfiltered;
|
||||
g_autofree virTypedParameterPtr *filtered = NULL;
|
||||
|
||||
*values = NULL;
|
||||
|
||||
nfiltered = virTypedParamsFilter(params, nparams, name, 0, &filtered);
|
||||
nfiltered = virTypedParamsFilter(params, nparams, name, VIR_TYPED_PARAM_STRING, &filtered);
|
||||
|
||||
if (nfiltered == 0)
|
||||
return 0;
|
||||
@ -468,11 +468,10 @@ virTypedParamsGetStringList(virTypedParameterPtr params,
|
||||
*values = g_new0(const char *, nfiltered);
|
||||
|
||||
for (i = 0; i < nfiltered; i++) {
|
||||
if (filtered[i]->type == VIR_TYPED_PARAM_STRING)
|
||||
(*values)[n++] = filtered[i]->value.s;
|
||||
(*values)[i] = filtered[i]->value.s;
|
||||
}
|
||||
|
||||
return n;
|
||||
return nfiltered;
|
||||
}
|
||||
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user