const struct nft_data_delinearize *nld,
enum nft_registers dreg);
-extern int netlink_linearize_rule(struct netlink_ctx *ctx,
- struct nft_rule *nlr,
- const struct rule *rule);
+extern void netlink_linearize_rule(struct netlink_ctx *ctx,
+ struct nft_rule *nlr,
+ const struct rule *rule);
extern struct rule *netlink_delinearize_rule(struct netlink_ctx *ctx,
const struct nft_rule *r);
int err;
nlr = alloc_nft_rule(&rule->handle);
- err = netlink_linearize_rule(ctx, nlr, rule);
- if (err == 0) {
- err = mnl_nft_rule_batch_add(nlr, flags | NLM_F_EXCL,
- ctx->seqnum);
- if (err < 0)
- netlink_io_error(ctx, &rule->location,
- "Could not add rule to batch: %s",
- strerror(errno));
- }
+ netlink_linearize_rule(ctx, nlr, rule);
+ err = mnl_nft_rule_batch_add(nlr, flags | NLM_F_EXCL, ctx->seqnum);
nft_rule_free(nlr);
+ if (err < 0) {
+ netlink_io_error(ctx, &rule->location,
+ "Could not add rule to batch: %s",
+ strerror(errno));
+ }
return err;
}
}
}
-int netlink_linearize_rule(struct netlink_ctx *ctx, struct nft_rule *nlr,
- const struct rule *rule)
+void netlink_linearize_rule(struct netlink_ctx *ctx, struct nft_rule *nlr,
+ const struct rule *rule)
{
struct netlink_linearize_ctx lctx;
const struct stmt *stmt;
netlink_gen_stmt(&lctx, stmt);
netlink_dump_rule(nlr);
- return 0;
}