summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDoug Goldstein <cardoe@cardoe.com>2013-11-18 17:02:49 -0500
committerDaniel P. Berrange <berrange@redhat.com>2013-11-22 15:58:06 +0000
commit4d083fbf60531c2d3882367b419bf826c6488e16 (patch)
treedd4057c6dad9a6461cb5f9d8915b266aab5d824f
parentac89e8177dc7c373d9938c849731f30fc139eeea (diff)
downloadlibvirt-python-v9-4d083fbf60531c2d3882367b419bf826c6488e16.tar.gz
libvirt-python-v9-4d083fbf60531c2d3882367b419bf826c6488e16.tar.xz
libvirt-python-v9-4d083fbf60531c2d3882367b419bf826c6488e16.zip
Import some virTypedParams* APIs from libvirt
virTypedParamsClear() and virTypedParamsFree() were introduced in libvirt 1.0.2. In an effort to keep the code clean bring these two functions to libvirt-python if we're building against a version of libvirt that's older than 1.0.2
-rw-r--r--libvirt-utils.c46
-rw-r--r--libvirt-utils.h6
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__ */