From b21f0072851bc6807fee04bd06ff2e4dd40e7372 Mon Sep 17 00:00:00 2001 From: Tomasz Bursztyka Date: Thu, 27 Oct 2011 10:24:54 +0300 Subject: tools: Add extensions options parsing for matches to iptables-test --- tools/iptables-test.c | 26 ++++++++++++++++++++++++-- 1 file changed, 24 insertions(+), 2 deletions(-) (limited to 'tools') diff --git a/tools/iptables-test.c b/tools/iptables-test.c index 9ccee9da..82e1dbb4 100644 --- a/tools/iptables-test.c +++ b/tools/iptables-test.c @@ -1375,8 +1375,8 @@ done: int main(int argc, char *argv[]) { struct connman_iptables *table; - struct xtables_rule_match *xt_rm; - struct xtables_match *xt_m; + struct xtables_rule_match *xt_rm, *tmp_xt_rm; + struct xtables_match *xt_m, *xt_m_t; struct xtables_target *xt_t; struct ipt_ip ip; char *table_name, *chain, *new_chain, *match_name, *target_name; @@ -1540,6 +1540,28 @@ int main(int argc, char *argv[]) XT_OPTION_OFFSET_SCALE)) { xtables_option_tpcall(c, argv, invert, xt_t, NULL); + + break; + } + + for (tmp_xt_rm = xt_rm; tmp_xt_rm != NULL; + tmp_xt_rm = tmp_xt_rm->next) { + xt_m_t = tmp_xt_rm->match; + + if (tmp_xt_rm->completed || + (xt_m_t->x6_parse == NULL && + xt_m_t->parse == NULL)) + continue; + + if (c < (int) xt_m_t->option_offset || + c >= (int) xt_m_t->option_offset + + XT_OPTION_OFFSET_SCALE) + continue; + + xtables_option_mpcall(c, argv, + invert, xt_m_t, NULL); + + break; } break; -- cgit v1.2.3