summaryrefslogtreecommitdiff
path: root/intllib.lua
diff options
context:
space:
mode:
authorVanessa Ezekowitz <vanessaezekowitz@gmail.com>2017-08-12 16:28:58 -0400
committerGitHub <noreply@github.com>2017-08-12 16:28:58 -0400
commitf6b8c941c304a1bbbccdfd03f8d987643001f6fc (patch)
tree59e54b92f6a558ddfe284ee6192f14b0c87deb6a /intllib.lua
parent217ea08cac5e8e68ed09e149f987e5f4ca0c09ca (diff)
parent96161c18dcaa5706f1235ee69f34da6466e3eee6 (diff)
downloadsigns_lib-f6b8c941c304a1bbbccdfd03f8d987643001f6fc.tar
signs_lib-f6b8c941c304a1bbbccdfd03f8d987643001f6fc.tar.gz
signs_lib-f6b8c941c304a1bbbccdfd03f8d987643001f6fc.tar.bz2
signs_lib-f6b8c941c304a1bbbccdfd03f8d987643001f6fc.tar.xz
signs_lib-f6b8c941c304a1bbbccdfd03f8d987643001f6fc.zip
Merge pull request #21 from fat115/master
updated intllib method (po/pot files)
Diffstat (limited to 'intllib.lua')
-rw-r--r--intllib.lua45
1 files changed, 45 insertions, 0 deletions
diff --git a/intllib.lua b/intllib.lua
new file mode 100644
index 0000000..6669d72
--- /dev/null
+++ b/intllib.lua
@@ -0,0 +1,45 @@
+
+-- Fallback functions for when `intllib` is not installed.
+-- Code released under Unlicense <http://unlicense.org>.
+
+-- Get the latest version of this file at:
+-- https://raw.githubusercontent.com/minetest-mods/intllib/master/lib/intllib.lua
+
+local function format(str, ...)
+ local args = { ... }
+ local function repl(escape, open, num, close)
+ if escape == "" then
+ local replacement = tostring(args[tonumber(num)])
+ if open == "" then
+ replacement = replacement..close
+ end
+ return replacement
+ else
+ return "@"..open..num..close
+ end
+ end
+ return (str:gsub("(@?)@(%(?)(%d+)(%)?)", repl))
+end
+
+local gettext, ngettext
+if minetest.get_modpath("intllib") then
+ if intllib.make_gettext_pair then
+ -- New method using gettext.
+ gettext, ngettext = intllib.make_gettext_pair()
+ else
+ -- Old method using text files.
+ gettext = intllib.Getter()
+ end
+end
+
+-- Fill in missing functions.
+
+gettext = gettext or function(msgid, ...)
+ return format(msgid, ...)
+end
+
+ngettext = ngettext or function(msgid, msgid_plural, n, ...)
+ return format(n==1 and msgid or msgid_plural, ...)
+end
+
+return gettext, ngettext