diff options
author | Jo-Philipp Wich <jow@openwrt.org> | 2009-07-09 15:05:29 +0000 |
---|---|---|
committer | Jo-Philipp Wich <jow@openwrt.org> | 2009-07-09 15:05:29 +0000 |
commit | 36542cbe1d07358e90063b70c99b8d0928d0265c (patch) | |
tree | dce2d526ccb4187b69c2428829b72f7e7bca1e05 | |
parent | f2b1b113dea96215b42727c2c00c757d2809a837 (diff) |
libs/web: use lmo in luci.i18n
-rw-r--r-- | libs/web/luasrc/i18n.lua | 22 |
1 files changed, 16 insertions, 6 deletions
diff --git a/libs/web/luasrc/i18n.lua b/libs/web/luasrc/i18n.lua index 082a60078..dcca13ec6 100644 --- a/libs/web/luasrc/i18n.lua +++ b/libs/web/luasrc/i18n.lua @@ -27,6 +27,7 @@ limitations under the License. --- LuCI translation library. module("luci.i18n", package.seeall) require("luci.util") +require("lmo") table = {} i18ndir = luci.util.libpath() .. "/i18n/" @@ -47,13 +48,22 @@ end function load(file, lang, force) lang = lang and lang:gsub("_", "-") or "" if force or not loaded[lang] or not loaded[lang][file] then - local f = loadfile(i18ndir .. file .. "." .. lang .. ".lua") or - loadfile(i18ndir .. file .. "." .. lang .. ".lua.gz") - + local f = lmo.open(i18ndir .. file .. "." .. lang .. ".lmo") if f then - table[lang] = table[lang] or {} - setfenv(f, table[lang]) - f() + if not table[lang] then + table[lang] = { 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][file] = true return true |