mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2024-10-30 09:53:10 +00:00
conf: Make virNetworkIPDefParseXML a little bit saner
Iterating over all child nodes when we only support one instance of each child is pretty weird. And it would even cause memory leaks if more than one <tftp> element was specified. Signed-off-by: Jiri Denemark <jdenemar@redhat.com>
This commit is contained in:
parent
9e9305542e
commit
770b1d2b56
@ -1501,7 +1501,8 @@ virNetworkIPDefParseXML(const char *networkName,
|
||||
* On failure clear it out, but don't free it.
|
||||
*/
|
||||
|
||||
xmlNodePtr cur, save;
|
||||
xmlNodePtr save;
|
||||
xmlNodePtr dhcp;
|
||||
char *address = NULL, *netmask = NULL;
|
||||
unsigned long prefix = 0;
|
||||
int prefixRc;
|
||||
@ -1603,29 +1604,20 @@ virNetworkIPDefParseXML(const char *networkName,
|
||||
goto cleanup;
|
||||
}
|
||||
|
||||
cur = node->children;
|
||||
while (cur != NULL) {
|
||||
if (cur->type == XML_ELEMENT_NODE &&
|
||||
xmlStrEqual(cur->name, BAD_CAST "dhcp")) {
|
||||
if (virNetworkDHCPDefParseXML(networkName, cur, def) < 0)
|
||||
goto cleanup;
|
||||
} else if (cur->type == XML_ELEMENT_NODE &&
|
||||
xmlStrEqual(cur->name, BAD_CAST "tftp")) {
|
||||
char *root;
|
||||
if ((dhcp = virXPathNode("./dhcp[1]", ctxt)) &&
|
||||
virNetworkDHCPDefParseXML(networkName, dhcp, def) < 0)
|
||||
goto cleanup;
|
||||
|
||||
if (!VIR_SOCKET_ADDR_IS_FAMILY(&def->address, AF_INET)) {
|
||||
virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
|
||||
_("Unsupported <tftp> element in an IPv6 element in network '%s'"),
|
||||
networkName);
|
||||
goto cleanup;
|
||||
}
|
||||
if (!(root = virXMLPropString(cur, "root"))) {
|
||||
cur = cur->next;
|
||||
continue;
|
||||
}
|
||||
def->tftproot = (char *)root;
|
||||
if (virXPathNode("./tftp[1]", ctxt)) {
|
||||
if (!VIR_SOCKET_ADDR_IS_FAMILY(&def->address, AF_INET)) {
|
||||
virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
|
||||
_("Unsupported <tftp> element in an IPv6 element "
|
||||
"in network '%s'"),
|
||||
networkName);
|
||||
goto cleanup;
|
||||
}
|
||||
cur = cur->next;
|
||||
|
||||
def->tftproot = virXPathString("string(./tftp[1]/@root)", ctxt);
|
||||
}
|
||||
|
||||
result = 0;
|
||||
|
Loading…
Reference in New Issue
Block a user