virxml: Add virXMLPropUInt

Convenience function to return the value of an unsigned integer XML attribute.

Signed-off-by: Tim Wiederhake <twiederh@redhat.com>
Reviewed-by: Peter Krempa <pkrempa@redhat.com>
This commit is contained in:
Tim Wiederhake 2021-04-16 11:41:48 +02:00 committed by Peter Krempa
parent de17e0d30d
commit 68cda45b57
3 changed files with 70 additions and 0 deletions

View File

@ -3553,6 +3553,7 @@ virXMLPropString;
virXMLPropStringLimit;
virXMLPropTristateBool;
virXMLPropTristateSwitch;
virXMLPropUInt;
virXMLSaveFile;
virXMLValidateAgainstSchema;
virXMLValidatorFree;

View File

@ -699,6 +699,66 @@ virXMLPropInt(xmlNodePtr node,
}
/**
* virXMLPropUInt:
* @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 unsigned 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
virXMLPropUInt(xmlNodePtr node,
const char* name,
int base,
virXMLPropFlags flags,
unsigned int *result)
{
g_autofree char *tmp = NULL;
int ret;
unsigned 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 (flags & VIR_XML_PROP_WRAPNEGATIVE) {
ret = virStrToLong_ui(tmp, NULL, base, &val);
} else {
ret = virStrToLong_uip(tmp, NULL, base, &val);
}
if (ret < 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

View File

@ -38,6 +38,7 @@ 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 */
VIR_XML_PROP_WRAPNEGATIVE = 1 << 2, /* Wrap around negative values */
} virXMLPropFlags;
@ -126,6 +127,14 @@ virXMLPropInt(xmlNodePtr node,
int *result)
ATTRIBUTE_NONNULL(0) ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(4);
int
virXMLPropUInt(xmlNodePtr node,
const char* name,
int base,
virXMLPropFlags flags,
unsigned int *result)
ATTRIBUTE_NONNULL(0) ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(4);
/* Internal function; prefer the macros below. */
xmlDocPtr
virXMLParseHelper(int domcode,