From ca3898fd7e8fa97d8b609b9a5578ef7d8af5e54d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E6=9C=80=E8=90=8C=E5=B0=8F=E6=B1=90?= Date: Sat, 29 Dec 2018 13:42:16 +0800 Subject: =?UTF-8?q?=E6=94=AF=E6=8C=81=E7=94=A8id=E6=8C=87=E5=AE=9A?= =?UTF-8?q?=E7=BF=BB=E8=AF=91=E5=8F=82=E6=95=B0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- server/src/language.lua | 85 ++++++++++++++++++++++++++++++++----------------- 1 file changed, 56 insertions(+), 29 deletions(-) (limited to 'server') diff --git a/server/src/language.lua b/server/src/language.lua index bf549132..ea5c01ae 100644 --- a/server/src/language.lua +++ b/server/src/language.lua @@ -44,6 +44,47 @@ local function loadFileByLanguage(name, language) return tbl end +local function formatAsArray(str, ...) + local index = 0 + local args = {...} + return str:gsub('%{(.-)%}', function (pat) + local id, fmt + local pos = pat:find(':', 1, true) + if pos then + id = pat:sub(1, pos-1) + fmt = pat:sub(pos+1) + else + id = pat + fmt = 's' + end + id = tonumber(id) + if not id then + index = index + 1 + id = index + end + return ('%'..fmt):format(args[id]) + end) +end + +local function formatAsTable(str, ...) + local args = ... + return str:gsub('%{(.-)%}', function (pat) + local id, fmt + local pos = pat:find(':', 1, true) + if pos then + id = pat:sub(1, pos-1) + fmt = pat:sub(pos+1) + else + id = pat + fmt = 's' + end + if not id then + return + end + return ('%'..fmt):format(args[id]) + end) +end + local function loadLang(name, language) local tbl = loadFileByLanguage(name, 'en-US') if language ~= 'en-US' then @@ -59,35 +100,21 @@ local function loadLang(name, language) end, __call = function (self, key, ...) local str = self[key] - local index = 0 - local args = {...} - return str:gsub('%{(.-)%}', function (pat) - local id, fmt - local pos = pat:find(':', 1, true) - if pos then - id = pat:sub(1, pos-1) - fmt = pat:sub(pos+1) - else - id = pat - fmt = 's' - end - id = tonumber(id) - if not id then - index = index + 1 - id = index - end - local v = args[id] - local suc, res = pcall(string.format, '%'..fmt, v) - if suc then - return res - else - -- 这里不能使用翻译,以免死循环 - log.warn(('[%s][%s-%s]{%s} formated error.'):format( - language, name, key, pat - )) - return nil - end - end) + local suc, res + if type(...) == 'table' then + suc, res = pcall(formatAsTable, str, ...) + else + suc, res = pcall(formatAsArray, str, ...) + end + if suc then + return res + else + -- 这里不能使用翻译,以免死循环 + log.warn(('[%s][%s-%s] formated error: %s'):format( + language, name, key, str + )) + return str + end end, }) end -- cgit v1.2.3