util: Resolve memory leaks in virLogParse{Output|Filter}

In both virLogParseOutput and virLogParseFilter, rather than returning
NULL, goto cleanup since it's possible that for each the first condition
passes, but the || condition doesn't and thus we leak memory.
This commit is contained in:
John Ferlan 2016-10-10 07:18:30 -04:00
parent 95e66fcedf
commit 6de78c63a4

View File

@ -1466,7 +1466,7 @@ virLogParseOutput(const char *src)
if (!(tokens = virStringSplitCount(src, ":", 0, &count)) || count < 2) { if (!(tokens = virStringSplitCount(src, ":", 0, &count)) || count < 2) {
virReportError(VIR_ERR_INVALID_ARG, virReportError(VIR_ERR_INVALID_ARG,
_("Malformed format for output '%s'"), src); _("Malformed format for output '%s'"), src);
return NULL; goto cleanup;
} }
if (virStrToLong_uip(tokens[0], NULL, 10, &prio) < 0 || if (virStrToLong_uip(tokens[0], NULL, 10, &prio) < 0 ||
@ -1575,7 +1575,7 @@ virLogParseFilter(const char *src)
if (!(tokens = virStringSplitCount(src, ":", 0, &count)) || count != 2) { if (!(tokens = virStringSplitCount(src, ":", 0, &count)) || count != 2) {
virReportError(VIR_ERR_INVALID_ARG, virReportError(VIR_ERR_INVALID_ARG,
_("Malformed format for filter '%s'"), src); _("Malformed format for filter '%s'"), src);
return NULL; goto cleanup;
} }
if (virStrToLong_uip(tokens[0], NULL, 10, &prio) < 0 || if (virStrToLong_uip(tokens[0], NULL, 10, &prio) < 0 ||