aboutsummaryrefslogtreecommitdiff
path: root/intllib.lua
diff options
context:
space:
mode:
authorJoshua <ehlodex@users.noreply.github.com>2018-05-15 09:14:10 -0400
committerGitHub <noreply@github.com>2018-05-15 09:14:10 -0400
commitc9a5f2931a150e6d2f76a70470646bb915cf2e99 (patch)
tree36266c0a91a9b2b68857fd5bc1895dd0347ea050 /intllib.lua
parent41765a0edb05545beb307222717ee90723061faf (diff)
parenta0841e83c29d57d3bc7cfd57216d173d3b4a003e (diff)
downloadehlphabet-c9a5f2931a150e6d2f76a70470646bb915cf2e99.tar.gz
ehlphabet-c9a5f2931a150e6d2f76a70470646bb915cf2e99.tar.bz2
ehlphabet-c9a5f2931a150e6d2f76a70470646bb915cf2e99.zip
Merge pull request #5 from codexp/add-intllib-support
Add intllib support
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