mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-03-07 17:28:15 +00:00
util: xml: Extract implementation of xml property -> enum parsing to a common helper
virXMLPropTristateBool/virXMLPropTristateSwitch/virXMLPropEnum can be implemented using the same internal code. Extract it into a new function called virXMLPropEnumInternal, which will also simplify adding versions of these functions with a custom default value. This way we'll be able to always initialize @result so that unused value bugs can be prevented. Signed-off-by: Peter Krempa <pkrempa@redhat.com> Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
This commit is contained in:
parent
4ef4476d3a
commit
0420c325ce
@ -557,6 +557,40 @@ virXMLNodeContentString(xmlNodePtr node)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int
|
||||||
|
virXMLPropEnumInternal(xmlNodePtr node,
|
||||||
|
const char* name,
|
||||||
|
int (*strToInt)(const char*),
|
||||||
|
virXMLPropFlags flags,
|
||||||
|
unsigned int *result)
|
||||||
|
|
||||||
|
{
|
||||||
|
g_autofree char *tmp = NULL;
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
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;
|
||||||
|
}
|
||||||
|
|
||||||
|
ret = strToInt(tmp);
|
||||||
|
if (ret < 0 ||
|
||||||
|
((flags & VIR_XML_PROP_NONZERO) && (ret == 0))) {
|
||||||
|
virReportError(VIR_ERR_XML_ERROR,
|
||||||
|
_("Invalid value for attribute '%s' in element '%s': '%s'."),
|
||||||
|
name, node->name, NULLSTR(tmp));
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
*result = ret;
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* virXMLPropTristateBool:
|
* virXMLPropTristateBool:
|
||||||
@ -577,28 +611,10 @@ virXMLPropTristateBool(xmlNodePtr node,
|
|||||||
virXMLPropFlags flags,
|
virXMLPropFlags flags,
|
||||||
virTristateBool *result)
|
virTristateBool *result)
|
||||||
{
|
{
|
||||||
g_autofree char *tmp = NULL;
|
flags |= VIR_XML_PROP_NONZERO;
|
||||||
int val;
|
|
||||||
|
|
||||||
if (!(tmp = virXMLPropString(node, name))) {
|
return virXMLPropEnumInternal(node, name, virTristateBoolTypeFromString,
|
||||||
if (!(flags & VIR_XML_PROP_REQUIRED))
|
flags, result);
|
||||||
return 0;
|
|
||||||
|
|
||||||
virReportError(VIR_ERR_XML_ERROR,
|
|
||||||
_("Missing required attribute '%s' in element '%s'"),
|
|
||||||
name, node->name);
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ((val = virTristateBoolTypeFromString(tmp)) <= 0) {
|
|
||||||
virReportError(VIR_ERR_XML_ERROR,
|
|
||||||
_("Invalid value for attribute '%s' in element '%s': '%s'. Expected 'yes' or 'no'"),
|
|
||||||
name, node->name, tmp);
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
*result = val;
|
|
||||||
return 1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -621,28 +637,10 @@ virXMLPropTristateSwitch(xmlNodePtr node,
|
|||||||
virXMLPropFlags flags,
|
virXMLPropFlags flags,
|
||||||
virTristateSwitch *result)
|
virTristateSwitch *result)
|
||||||
{
|
{
|
||||||
g_autofree char *tmp = NULL;
|
flags |= VIR_XML_PROP_NONZERO;
|
||||||
int val;
|
|
||||||
|
|
||||||
if (!(tmp = virXMLPropString(node, name))) {
|
return virXMLPropEnumInternal(node, name, virTristateSwitchTypeFromString,
|
||||||
if (!(flags & VIR_XML_PROP_REQUIRED))
|
flags, result);
|
||||||
return 0;
|
|
||||||
|
|
||||||
virReportError(VIR_ERR_XML_ERROR,
|
|
||||||
_("Missing required attribute '%s' in element '%s'"),
|
|
||||||
name, node->name);
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ((val = virTristateSwitchTypeFromString(tmp)) <= 0) {
|
|
||||||
virReportError(VIR_ERR_XML_ERROR,
|
|
||||||
_("Invalid value for attribute '%s' in element '%s': '%s'. Expected 'on' or 'off'"),
|
|
||||||
name, node->name, tmp);
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
*result = val;
|
|
||||||
return 1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -833,32 +831,10 @@ virXMLPropEnum(xmlNodePtr node,
|
|||||||
virXMLPropFlags flags,
|
virXMLPropFlags flags,
|
||||||
unsigned int *result)
|
unsigned int *result)
|
||||||
{
|
{
|
||||||
g_autofree char *tmp = NULL;
|
return virXMLPropEnumInternal(node, name, strToInt, flags, result);
|
||||||
int ret;
|
|
||||||
|
|
||||||
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;
|
|
||||||
}
|
|
||||||
|
|
||||||
ret = strToInt(tmp);
|
|
||||||
if (ret < 0 ||
|
|
||||||
((flags & VIR_XML_PROP_NONZERO) && (ret == 0))) {
|
|
||||||
virReportError(VIR_ERR_XML_ERROR,
|
|
||||||
_("Invalid value for attribute '%s' in element '%s': '%s'."),
|
|
||||||
name, node->name, NULLSTR(tmp));
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
*result = ret;
|
|
||||||
return 1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* virXPathBoolean:
|
* virXPathBoolean:
|
||||||
* @xpath: the XPath string to evaluate
|
* @xpath: the XPath string to evaluate
|
||||||
|
Loading…
x
Reference in New Issue
Block a user