X-Git-Url: http://git.archive.openwrt.org/?p=project%2Ffirewall3.git;a=blobdiff_plain;f=ipsets.c;h=48aaa9c0100ede8b7d2aa4d5ca0938adeb38e653;hp=62877c8456622a2e9e8b615cd29d9d13a872e5ea;hb=eb2a20924afd979feb485298111ced679de42aa0;hpb=46536e5263c4bf57a91c38b5d08d78c774649dda diff --git a/ipsets.c b/ipsets.c index 62877c8..48aaa9c 100644 --- a/ipsets.c +++ b/ipsets.c @@ -296,7 +296,7 @@ create_ipset(struct fw3_ipset *ipset, struct fw3_state *state) if (ipset->external && *ipset->external) return; - info("Creating ipset %s", ipset->name); + info(" * Creating ipset %s", ipset->name); first = true; fw3_pr("create %s %s", ipset->name, methods[ipset->method]); @@ -373,22 +373,17 @@ fw3_create_ipsets(struct fw3_state *state) } void -fw3_destroy_ipsets(struct fw3_state *state) +fw3_destroy_ipsets(struct fw3_state *state, enum fw3_family family) { struct fw3_ipset *s, *tmp; - int mask = (1 << FW3_FAMILY_V4) | (1 << FW3_FAMILY_V6); list_for_each_entry_safe(s, tmp, &state->running_ipsets, running_list) { - if (!hasbit(state->defaults.flags, FW3_FAMILY_V4)) - delbit(s->flags, FW3_FAMILY_V4); + del(s->flags, family, family); - if (!hasbit(state->defaults.flags, FW3_FAMILY_V6)) - delbit(s->flags, FW3_FAMILY_V6); - - if (!(s->flags & mask)) + if (fw3_no_family(s->flags[family == FW3_FAMILY_V6])) { - info("Deleting ipset %s", s->name); + info(" * Deleting ipset %s", s->name); fw3_pr("flush %s\n", s->name); fw3_pr("destroy %s\n", s->name);