From: Jo-Philipp Wich Date: Tue, 4 Nov 2008 23:50:14 +0000 (+0000) Subject: * luci-0.8: merge r3710 X-Git-Tag: 0.8.2~48 X-Git-Url: https://git.librecmc.org/?a=commitdiff_plain;h=cfdfa4ea1aa7c958ddadf6d6ec1932201cb2bcb8;p=oweals%2Fluci.git * luci-0.8: merge r3710 --- diff --git a/libs/uvl/luasrc/uvl.lua b/libs/uvl/luasrc/uvl.lua index 3b3186eb2..b34f66bc1 100644 --- a/libs/uvl/luasrc/uvl.lua +++ b/libs/uvl/luasrc/uvl.lua @@ -295,7 +295,11 @@ function UVL._validate_option( self, option, nodeps ) if not nodeps then local ok, err = dependencies.check( self, option ) if not ok then - if not err:is_all(ERR.ERR_DEP_NOTEQUAL,ERR.ERR_DEP_NOVALUE) then + if not err:is_all( + ERR.ERR_OPT_REQUIRED, + ERR.ERR_DEP_NOTEQUAL, + ERR.ERR_DEP_NOVALUE + ) then option:error(err) return false, option:errors() else @@ -361,16 +365,22 @@ function UVL._validate_option( self, option, nodeps ) end end - v = tonumber(v) - + local w = tonumber(v) + if option:scheme('minimum') then - if not v or v < option:scheme('minimum') then + if not w or w < option:scheme('minimum') then return false, option:error(ERR.OPT_RANGE(option)) end end if option:scheme('maximum') then - if not v or v > option:scheme('maximum') then + if not w or w > option:scheme('maximum') then + return false, option:error(ERR.OPT_RANGE(option)) + end + end + + if option:scheme('max_nil') then + if v and (not w or w > tonumber(option:scheme('max_nil'))) then return false, option:error(ERR.OPT_RANGE(option)) end end diff --git a/libs/uvl/luasrc/uvl/errors.lua b/libs/uvl/luasrc/uvl/errors.lua index a575f4059..614100fce 100644 --- a/libs/uvl/luasrc/uvl/errors.lua +++ b/libs/uvl/luasrc/uvl/errors.lua @@ -193,7 +193,11 @@ function error.is_all(self, ...) else local equal = false for _, c in ipairs(self.childs) do - equal = util.contains(codes, c.code) + if c.childs then + equal = c:is_all(...) + else + equal = util.contains(codes, c.code) + end end return equal end