diff options
-rw-r--r-- | libvirt-utils.c | 46 | ||||
-rw-r--r-- | libvirt-utils.h | 6 |
2 files changed, 52 insertions, 0 deletions
diff --git a/libvirt-utils.c b/libvirt-utils.c index 9c29a1c..d1f6e70 100644 --- a/libvirt-utils.c +++ b/libvirt-utils.c @@ -23,6 +23,7 @@ #include <stddef.h> #include <stdlib.h> #include <unistd.h> +#include <libvirt/libvirt.h> #include "libvirt-utils.h" /** @@ -138,3 +139,48 @@ int virFileClose(int *fdptr) return rc; } + +#if ! LIBVIR_CHECK_VERSION(1, 0, 2) +/** + * virTypedParamsClear: + * @params: the array of the typed parameters + * @nparams: number of parameters in the @params array + * + * Frees all memory used by string parameters. The memory occupied by @params + * is not free; use virTypedParamsFree if you want it to be freed too. + * + * Returns nothing. + */ +void +virTypedParamsClear(virTypedParameterPtr params, + int nparams) +{ + size_t i; + + if (!params) + return; + + for (i = 0; i < nparams; i++) { + if (params[i].type == VIR_TYPED_PARAM_STRING) + VIR_FREE(params[i].value.s); + } +} + +/** + * virTypedParamsFree: + * @params: the array of the typed parameters + * @nparams: number of parameters in the @params array + * + * Frees all memory used by string parameters and the memory occuiped by + * @params. + * + * Returns nothing. + */ +void +virTypedParamsFree(virTypedParameterPtr params, + int nparams) +{ + virTypedParamsClear(params, nparams); + VIR_FREE(params); +} +#endif /* ! LIBVIR_CHECK_VERSION(1, 0, 2) */ diff --git a/libvirt-utils.h b/libvirt-utils.h index 447e81f..0517f9c 100644 --- a/libvirt-utils.h +++ b/libvirt-utils.h @@ -200,4 +200,10 @@ int virFileClose(int *fdptr) # define VIR_FORCE_CLOSE(FD) \ ignore_value(virFileClose(&(FD))) +# if ! LIBVIR_CHECK_VERSION(1, 0, 2) +void virTypedParamsClear(virTypedParameterPtr params, int nparams); + +void virTypedParamsFree(virTypedParameterPtr params, int nparams); +# endif /* ! LIBVIR_CHECK_VERSION(1, 0, 2) */ + #endif /* __LIBVIRT_UTILS_H__ */ |