aboutsummaryrefslogtreecommitdiff
path: root/intllib.lua
diff options
context:
space:
mode:
authorGabriel Pérez-Cerezo <gabriel@gpcf.eu>2018-05-30 18:53:44 +0200
committerGabriel Pérez-Cerezo <gabriel@gpcf.eu>2018-05-30 18:53:44 +0200
commit25d743b7e702613735fb5aeeaff2e14d50c0eb8e (patch)
tree045849b2ad73168d6e77bb9b95a6cf3859fa2f26 /intllib.lua
parente463c23587af4b9be3c42583d3713d729d908aca (diff)
parentbb3fd1a928c730c9a99a341ec4aa9969f99c0195 (diff)
downloadcurrency-25d743b7e702613735fb5aeeaff2e14d50c0eb8e.tar.gz
currency-25d743b7e702613735fb5aeeaff2e14d50c0eb8e.tar.bz2
currency-25d743b7e702613735fb5aeeaff2e14d50c0eb8e.zip
Merge branch 'master' of https://github.com/minetest-mods/currency
Also removed 50 MG note, since it doesn't make much sense on my server.
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