bool validate)
{
g_autoptr(xmlDoc) xml = NULL;
- virNetworkDef *def = NULL;
+ g_autoptr(xmlXPathContext) ctxt = NULL;
int keepBlanksDefault = xmlKeepBlanksDefault(0);
- if ((xml = virXMLParse(filename, xmlStr, _("(network_definition)"),
- NULL, NULL, "network.rng", validate)))
- def = virNetworkDefParseNode(xml, xmlDocGetRootElement(xml), xmlopt);
-
+ xml = virXMLParse(filename, xmlStr, _("(network_definition)"),
+ "network", &ctxt, "network.rng", validate);
xmlKeepBlanksDefault(keepBlanksDefault);
- return def;
+
+ if (!xml)
+ return NULL;
+
+ return virNetworkDefParseXML(ctxt, xmlopt);
}
}
-virNetworkDef *
-virNetworkDefParseNode(xmlDocPtr xml,
- xmlNodePtr root,
- virNetworkXMLOption *xmlopt)
-{
- g_autoptr(xmlXPathContext) ctxt = NULL;
-
- if (!virXMLNodeNameEqual(root, "network")) {
- virReportError(VIR_ERR_XML_ERROR,
- _("unexpected root element <%s>, "
- "expecting <network>"),
- root->name);
- return NULL;
- }
-
- if (!(ctxt = virXMLXPathContextNew(xml)))
- return NULL;
-
- ctxt->node = root;
- return virNetworkDefParseXML(ctxt, xmlopt);
-}
-
-
static int
virNetworkDNSDefFormat(virBuffer *buf,
const virNetworkDNSDef *def)
virNetworkDefParseFile(const char *filename,
virNetworkXMLOption *xmlopt);
-virNetworkDef *
-virNetworkDefParseNode(xmlDocPtr xml,
- xmlNodePtr root,
- virNetworkXMLOption *xmlopt);
-
char *
virNetworkDefFormat(const virNetworkDef *def,
virNetworkXMLOption *xmlopt,
const char *file,
xmlXPathContextPtr ctxt)
{
+ VIR_XPATH_NODE_AUTORESTORE(ctxt)
int num;
size_t i;
virNetworkObj *obj;
for (i = 0; i < num; i++) {
g_autoptr(virNetworkDef) def = NULL;
- xmlNodePtr node = testParseXMLDocFromFile(nodes[i], file);
- if (!node)
+
+ if (!(ctxt->node = testParseXMLDocFromFile(nodes[i], file)))
return -1;
- def = virNetworkDefParseNode(ctxt->doc, node, NULL);
- if (!def)
+ if (!(def = virNetworkDefParseXML(ctxt, NULL)))
return -1;
if (!(obj = virNetworkObjAssignDef(privconn->networks, def, 0)))