@@ -665,7 +665,7 @@ static int nft_ruleset_xml_parse(const void *xml, struct nft_parse_err *err,
tree = nft_mxml_build_tree(xml, "nftables", err, input);
if (tree == NULL)
- goto err;
+ goto err1;
ctx.xml = tree;
@@ -673,16 +673,17 @@ static int nft_ruleset_xml_parse(const void *xml, struct nft_parse_err *err,
while (nodecmd != NULL) {
cmd = nodecmd->value.opaque;
if (nft_ruleset_xml_parse_cmd(cmd, err, &ctx) < 0)
- goto err;
+ goto err2;
nodecmd = mxmlWalkNext(tree, tree, MXML_NO_DESCEND);
}
nft_set_list_free(ctx.set_list);
mxmlDelete(tree);
return 0;
-err:
- nft_set_list_free(ctx.set_list);
+err2:
mxmlDelete(tree);
+err1:
+ nft_set_list_free(ctx.set_list);
return -1;
#else
errno = EOPNOTSUPP;