X-Git-Url: http://git.openwrt.org/?p=project%2Fluci.git;a=blobdiff_plain;f=libs%2Fcore%2Fluasrc%2Fmodel%2Fnetwork.lua;h=54008b54b3b5317dfa5c1432d87211ba6a73461c;hp=bb98f822338ccafbbd1fbc349d6162dadb34cd9a;hb=0a8fa4e4a53d5b75961d286cf503536a51b072d6;hpb=b3b708a585759ca506e857ce5030d83ddd190b1e;ds=sidebyside diff --git a/libs/core/luasrc/model/network.lua b/libs/core/luasrc/model/network.lua index bb98f82233..54008b54b3 100644 --- a/libs/core/luasrc/model/network.lua +++ b/libs/core/luasrc/model/network.lua @@ -102,7 +102,7 @@ function _set(c, s, o, v) if type(v) == "boolean" then v = v and "1" or "0" end return uci_r:set(c, s, o, v) else - return uci_r:del(c, s, o, v) + return uci_r:delete(c, s, o) end end @@ -372,10 +372,21 @@ end function get_interfaces(self) local iface local ifaces = { } + local seen = { } -- find normal interfaces + uci_r:foreach("network", "interface", + function(s) + for iface in utl.imatch(s.ifname) do + if not _iface_ignore(iface) and not _wifi_iface(iface) then + seen[iface] = true + ifaces[#ifaces+1] = interface(iface) + end + end + end) + for iface in utl.kspairs(ifs) do - if not _iface_ignore(iface) and not _wifi_iface(iface) then + if not (seen[iface] or _iface_ignore(iface) or _wifi_iface(iface)) then ifaces[#ifaces+1] = interface(iface) end end