123 lines
3.8 KiB
Diff
123 lines
3.8 KiB
Diff
|
|
From 0d94495d109537d7d266071e42e13de9a1539752 Mon Sep 17 00:00:00 2001
|
||
|
|
From: Tim Wiederhake <twiederh@redhat.com>
|
||
|
|
Date: Fri, 16 Apr 2021 11:41:47 +0200
|
||
|
|
Subject: [PATCH] virxml: Add virXMLPropInt
|
||
|
|
|
||
|
|
Convenience function to return the value of an integer XML attribute.
|
||
|
|
|
||
|
|
Signed-off-by: Tim Wiederhake <twiederh@redhat.com>
|
||
|
|
Reviewed-by: Peter Krempa <pkrempa@redhat.com>
|
||
|
|
Reviewed-by: Shaokun Wei <weishaokun@kylinos.cn>
|
||
|
|
---
|
||
|
|
src/libvirt_private.syms | 1 +
|
||
|
|
src/util/virxml.c | 53 ++++++++++++++++++++++++++++++++++++++++
|
||
|
|
src/util/virxml.h | 9 +++++++
|
||
|
|
3 files changed, 63 insertions(+)
|
||
|
|
|
||
|
|
diff --git a/src/libvirt_private.syms b/src/libvirt_private.syms
|
||
|
|
index 15924e69a5..4720bb0ab0 100644
|
||
|
|
--- a/src/libvirt_private.syms
|
||
|
|
+++ b/src/libvirt_private.syms
|
||
|
|
@@ -3480,6 +3480,7 @@ virXMLNodeSanitizeNamespaces;
|
||
|
|
virXMLNodeToString;
|
||
|
|
virXMLParseHelper;
|
||
|
|
virXMLPickShellSafeComment;
|
||
|
|
+virXMLPropInt;
|
||
|
|
virXMLPropString;
|
||
|
|
virXMLPropStringLimit;
|
||
|
|
virXMLPropTristateBool;
|
||
|
|
diff --git a/src/util/virxml.c b/src/util/virxml.c
|
||
|
|
index b7f8063497..f6f028896e 100644
|
||
|
|
--- a/src/util/virxml.c
|
||
|
|
+++ b/src/util/virxml.c
|
||
|
|
@@ -647,6 +647,59 @@ virXMLPropTristateSwitch(xmlNodePtr node,
|
||
|
|
}
|
||
|
|
|
||
|
|
|
||
|
|
+/**
|
||
|
|
+ * virXMLPropInt:
|
||
|
|
+ * @node: XML dom node pointer
|
||
|
|
+ * @name: Name of the property (attribute) to get
|
||
|
|
+ * @base: Number base, see strtol
|
||
|
|
+ * @flags: Bitwise or of virXMLPropFlags
|
||
|
|
+ * @result: The returned value
|
||
|
|
+ *
|
||
|
|
+ * Convenience function to return value of an integer attribute.
|
||
|
|
+ *
|
||
|
|
+ * Returns 1 in case of success in which case @result is set,
|
||
|
|
+ * or 0 if the attribute is not present,
|
||
|
|
+ * or -1 and reports an error on failure.
|
||
|
|
+ */
|
||
|
|
+int
|
||
|
|
+virXMLPropInt(xmlNodePtr node,
|
||
|
|
+ const char *name,
|
||
|
|
+ int base,
|
||
|
|
+ virXMLPropFlags flags,
|
||
|
|
+ int *result)
|
||
|
|
+{
|
||
|
|
+ g_autofree char *tmp = NULL;
|
||
|
|
+ int val;
|
||
|
|
+
|
||
|
|
+ if (!(tmp = virXMLPropString(node, name))) {
|
||
|
|
+ if (!(flags & VIR_XML_PROP_REQUIRED))
|
||
|
|
+ return 0;
|
||
|
|
+
|
||
|
|
+ virReportError(VIR_ERR_XML_ERROR,
|
||
|
|
+ _("Missing required attribute '%s' in element '%s'"),
|
||
|
|
+ name, node->name);
|
||
|
|
+ return -1;
|
||
|
|
+ }
|
||
|
|
+
|
||
|
|
+ if (virStrToLong_i(tmp, NULL, base, &val) < 0) {
|
||
|
|
+ virReportError(VIR_ERR_XML_ERROR,
|
||
|
|
+ _("Invalid value for attribute '%s' in element '%s': '%s'. Expected integer value"),
|
||
|
|
+ name, node->name, tmp);
|
||
|
|
+ return -1;
|
||
|
|
+ }
|
||
|
|
+
|
||
|
|
+ if ((flags & VIR_XML_PROP_NONZERO) && (val == 0)) {
|
||
|
|
+ virReportError(VIR_ERR_XML_ERROR,
|
||
|
|
+ _("Invalid value for attribute '%s' in element '%s': Zero is not permitted"),
|
||
|
|
+ name, node->name);
|
||
|
|
+ return -1;
|
||
|
|
+ }
|
||
|
|
+
|
||
|
|
+ *result = val;
|
||
|
|
+ return 1;
|
||
|
|
+}
|
||
|
|
+
|
||
|
|
+
|
||
|
|
/**
|
||
|
|
* virXPathBoolean:
|
||
|
|
* @xpath: the XPath string to evaluate
|
||
|
|
diff --git a/src/util/virxml.h b/src/util/virxml.h
|
||
|
|
index 0cf293d5ae..28538fe035 100644
|
||
|
|
--- a/src/util/virxml.h
|
||
|
|
+++ b/src/util/virxml.h
|
||
|
|
@@ -37,6 +37,7 @@ xmlXPathContextPtr virXMLXPathContextNew(xmlDocPtr xml)
|
||
|
|
typedef enum {
|
||
|
|
VIR_XML_PROP_OPTIONAL = 0, /* Attribute may be absent */
|
||
|
|
VIR_XML_PROP_REQUIRED = 1 << 0, /* Attribute may not be absent */
|
||
|
|
+ VIR_XML_PROP_NONZERO = 1 << 1, /* Attribute may not be zero */
|
||
|
|
} virXMLPropFlags;
|
||
|
|
|
||
|
|
|
||
|
|
@@ -101,6 +102,14 @@ virXMLPropTristateSwitch(xmlNodePtr node,
|
||
|
|
virTristateSwitch *result)
|
||
|
|
ATTRIBUTE_NONNULL(0) ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(3);
|
||
|
|
|
||
|
|
+int
|
||
|
|
+virXMLPropInt(xmlNodePtr node,
|
||
|
|
+ const char *name,
|
||
|
|
+ int base,
|
||
|
|
+ virXMLPropFlags flags,
|
||
|
|
+ int *result)
|
||
|
|
+ ATTRIBUTE_NONNULL(0) ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(4);
|
||
|
|
+
|
||
|
|
/* Internal function; prefer the macros below. */
|
||
|
|
xmlDocPtr virXMLParseHelper(int domcode,
|
||
|
|
const char *filename,
|
||
|
|
--
|
||
|
|
2.27.0
|
||
|
|
|