From: Phil Sutter Date: Fri, 12 Oct 2018 11:22:55 +0000 (+0200) Subject: libnftables: Fix memleak in nft_parse_bison_filename() X-Git-Tag: v0.9.1~227 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=a56fe55dbd3232e70514610a1c2df1d6b15b931f;p=thirdparty%2Fnftables.git libnftables: Fix memleak in nft_parse_bison_filename() Allocated scanner object leaks when returning to caller. For some odd reason, this was missed by the commit referenced below. Fixes: bd82e03e15df8 ("libnftables: Move scanner object into struct nft_ctx") Signed-off-by: Phil Sutter Signed-off-by: Pablo Neira Ayuso --- diff --git a/src/libnftables.c b/src/libnftables.c index 656b0a1c..97776379 100644 --- a/src/libnftables.c +++ b/src/libnftables.c @@ -420,15 +420,14 @@ static int nft_parse_bison_filename(struct nft_ctx *nft, const char *filename, struct list_head *msgs, struct list_head *cmds) { struct cmd *cmd; - void *scanner; int ret; parser_init(nft, nft->state, msgs, cmds); - scanner = scanner_init(nft->state); - if (scanner_read_file(scanner, filename, &internal_location) < 0) + nft->scanner = scanner_init(nft->state); + if (scanner_read_file(nft->scanner, filename, &internal_location) < 0) return -1; - ret = nft_parse(nft, scanner, nft->state); + ret = nft_parse(nft, nft->scanner, nft->state); if (ret != 0 || nft->state->nerrs > 0) return -1;