[backfire] merge r26740
[openwrt-10.03/.git] / package / firewall / files / lib / core_interface.sh
index aff66418079f0934530c75907217e478d8f39f69..bc9eb96ddedc2faa349ccc40d72fa63203229a00 100644 (file)
@@ -4,7 +4,11 @@ fw__uci_state_add() {
        local var="$1"
        local item="$2"
 
-       local val="$(uci_get_state firewall core $var)"
+       local val=" $(uci_get_state firewall core $var) "
+       val="${val// $item / }"
+       val="${val# }"
+       val="${val% }"
+       uci_revert_state firewall core $var
        uci_set_state firewall core $var "${val:+$val }$item"
 }
 
@@ -16,6 +20,7 @@ fw__uci_state_del() {
        val="${val// $item / }"
        val="${val# }"
        val="${val% }"
+       uci_revert_state firewall core $var
        uci_set_state firewall core $var "$val"
 }