diff options
author | Pablo M. Bermudo Garay <pablombg@gmail.com> | 2017-06-23 18:38:24 +0200 |
---|---|---|
committer | Pablo Neira Ayuso <pablo@netfilter.org> | 2017-06-26 18:57:03 +0200 |
commit | f9d3e2e15b7ad968f30643ca6da55b75f03686fd (patch) | |
tree | 62209af9432b459d3a716d89c1cd6b9a4b82b7f0 /src/main.c | |
parent | 8750c928cf2a250065a4a0e7948b961be3c46a52 (diff) |
src: add new generic context structure nft_ctx
The new structure nft_ctx is meant to be used as a generic container of
context information.
This is a preparatory patch. So at the moment the struct just carry
output_ctx on his path through main.c and cli.c.
Based on original idea from Eric Leblond.
Signed-off-by: Pablo M. Bermudo Garay <pablombg@gmail.com>
Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
Diffstat (limited to 'src/main.c')
-rw-r--r-- | src/main.c | 26 |
1 files changed, 13 insertions, 13 deletions
@@ -28,7 +28,7 @@ #include <iface.h> #include <cli.h> -static struct output_ctx octx; +static struct nft_ctx nft; unsigned int max_errors = 10; #ifdef DEBUG unsigned int debug_level; @@ -175,8 +175,8 @@ static const struct input_descriptor indesc_cmdline = { .name = "<cmdline>", }; -static int nft_netlink(struct parser_state *state, struct list_head *msgs, - struct output_ctx *octx) +static int nft_netlink(struct nft_ctx *nft, struct parser_state *state, + struct list_head *msgs) { struct nftnl_batch *batch; struct netlink_ctx ctx; @@ -196,7 +196,7 @@ static int nft_netlink(struct parser_state *state, struct list_head *msgs, ctx.seqnum = cmd->seqnum = mnl_seqnum_alloc(); ctx.batch = batch; ctx.batch_supported = batch_supported; - ctx.octx = octx; + ctx.octx = &nft->output; init_list_head(&ctx.list); ret = do_command(&ctx, cmd); if (ret < 0) @@ -230,8 +230,8 @@ out: return ret; } -int nft_run(void *scanner, struct parser_state *state, struct list_head *msgs, - struct output_ctx *octx) +int nft_run(struct nft_ctx *nft, void *scanner, struct parser_state *state, + struct list_head *msgs) { struct cmd *cmd, *next; int ret; @@ -245,7 +245,7 @@ int nft_run(void *scanner, struct parser_state *state, struct list_head *msgs, list_for_each_entry(cmd, &state->cmds, list) nft_cmd_expand(cmd); - ret = nft_netlink(state, msgs, octx); + ret = nft_netlink(nft, state, msgs); err1: list_for_each_entry_safe(cmd, next, &state->cmds, list) { list_del(&cmd->list); @@ -294,7 +294,7 @@ int main(int argc, char * const *argv) include_paths[num_include_paths++] = optarg; break; case OPT_NUMERIC: - if (++octx.numeric > NUMERIC_ALL) { + if (++nft.output.numeric > NUMERIC_ALL) { fprintf(stderr, "Too many numeric options " "used, max. %u\n", NUMERIC_ALL); @@ -302,10 +302,10 @@ int main(int argc, char * const *argv) } break; case OPT_STATELESS: - octx.stateless++; + nft.output.stateless++; break; case OPT_IP2NAME: - octx.ip2name++; + nft.output.ip2name++; break; #ifdef DEBUG case OPT_DEBUG: @@ -337,7 +337,7 @@ int main(int argc, char * const *argv) break; #endif case OPT_HANDLE_OUTPUT: - octx.handle++; + nft.output.handle++; break; case OPT_INVALID: exit(NFT_EXIT_FAILURE); @@ -368,7 +368,7 @@ int main(int argc, char * const *argv) if (scanner_read_file(scanner, filename, &internal_location) < 0) goto out; } else if (interactive) { - if (cli_init(&state, &octx) < 0) { + if (cli_init(&nft, &state) < 0) { fprintf(stderr, "%s: interactive CLI not supported in this build\n", argv[0]); exit(NFT_EXIT_FAILURE); @@ -379,7 +379,7 @@ int main(int argc, char * const *argv) exit(NFT_EXIT_FAILURE); } - if (nft_run(scanner, &state, &msgs, &octx) != 0) + if (nft_run(&nft, scanner, &state, &msgs) != 0) rc = NFT_EXIT_FAILURE; out: scanner_destroy(scanner); |