libs/web: use lmo in luci.i18n
This commit is contained in:
parent
f2b1b113de
commit
36542cbe1d
1 changed files with 16 additions and 6 deletions
|
@ -27,6 +27,7 @@ limitations under the License.
|
||||||
--- LuCI translation library.
|
--- LuCI translation library.
|
||||||
module("luci.i18n", package.seeall)
|
module("luci.i18n", package.seeall)
|
||||||
require("luci.util")
|
require("luci.util")
|
||||||
|
require("lmo")
|
||||||
|
|
||||||
table = {}
|
table = {}
|
||||||
i18ndir = luci.util.libpath() .. "/i18n/"
|
i18ndir = luci.util.libpath() .. "/i18n/"
|
||||||
|
@ -47,13 +48,22 @@ end
|
||||||
function load(file, lang, force)
|
function load(file, lang, force)
|
||||||
lang = lang and lang:gsub("_", "-") or ""
|
lang = lang and lang:gsub("_", "-") or ""
|
||||||
if force or not loaded[lang] or not loaded[lang][file] then
|
if force or not loaded[lang] or not loaded[lang][file] then
|
||||||
local f = loadfile(i18ndir .. file .. "." .. lang .. ".lua") or
|
local f = lmo.open(i18ndir .. file .. "." .. lang .. ".lmo")
|
||||||
loadfile(i18ndir .. file .. "." .. lang .. ".lua.gz")
|
|
||||||
|
|
||||||
if f then
|
if f then
|
||||||
table[lang] = table[lang] or {}
|
if not table[lang] then
|
||||||
setfenv(f, table[lang])
|
table[lang] = { f }
|
||||||
f()
|
setmetatable(table[lang], {
|
||||||
|
__index = function(tbl, key)
|
||||||
|
for i = 1, #tbl do
|
||||||
|
local s = rawget(tbl, i):lookup(key)
|
||||||
|
if s then return s end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
})
|
||||||
|
else
|
||||||
|
table[lang][#table[lang]+1] = f
|
||||||
|
end
|
||||||
|
|
||||||
loaded[lang] = loaded[lang] or {}
|
loaded[lang] = loaded[lang] or {}
|
||||||
loaded[lang][file] = true
|
loaded[lang][file] = true
|
||||||
return true
|
return true
|
||||||
|
|
Loading…
Reference in a new issue