mirror of
https://github.com/minetest-mods/intllib.git
synced 2025-01-23 08:20:19 +01:00
Use optional dependencies to only load once and re-add support for escapes
This commit is contained in:
parent
5de9bcea76
commit
af31d71d1a
36
README.txt
36
README.txt
@ -12,20 +12,17 @@ it at the beginning of your source file(s):
|
|||||||
|
|
||||||
-- Boilerplate to support localized strings if intllib mod is installed.
|
-- Boilerplate to support localized strings if intllib mod is installed.
|
||||||
local S
|
local S
|
||||||
if (minetest.get_modpath("intllib")) then
|
if intllib then
|
||||||
dofile(minetest.get_modpath("intllib").."/intllib.lua")
|
S = intllib.Getter()
|
||||||
S = intllib.Getter(minetest.get_current_modname())
|
|
||||||
else
|
else
|
||||||
S = function(s) return s end
|
S = function(s) return s end
|
||||||
end
|
end
|
||||||
|
|
||||||
Note that by using this snippet, you don't need to depend on `intllib'. In
|
You will also need to optionally depend on intllib, to do so add "intllib?" to
|
||||||
fact, the mod's `init.lua' is a no-op; you need to explicitly execute intllib's
|
a empty line in your depends.txt. Also note that if intllib is not installed,
|
||||||
`intllib.lua' file.
|
the S() function is defined so it returns the string unchanged. This is done
|
||||||
Also note that if the intllib "mod" is not installed, the S() function is
|
so you don't have to sprinkle tons of 'if's (or similar constructs) to check
|
||||||
defined so it returns the string unchanged. This is done so you don't have to
|
if the lib is actually installed.
|
||||||
sprinkle tons of `if's (or similar constructs) to check if the lib is actually
|
|
||||||
installed.
|
|
||||||
|
|
||||||
Next, for each "translatable" string in your sources, use the S() function
|
Next, for each "translatable" string in your sources, use the S() function
|
||||||
(defined in the snippet) to return the translated string. For example:
|
(defined in the snippet) to return the translated string. For example:
|
||||||
@ -42,9 +39,8 @@ support. Here's an example for a Spanish locale file (`es.txt'):
|
|||||||
# Lines beginning with a pound sign are comments and are effectively ignored
|
# Lines beginning with a pound sign are comments and are effectively ignored
|
||||||
# by the reader. Note that comments only span until the end of the line;
|
# by the reader. Note that comments only span until the end of the line;
|
||||||
# there's no support for multiline comments.
|
# there's no support for multiline comments.
|
||||||
Blank lines not containing an equals sign are also ignored.
|
|
||||||
Hello, World! = Hola, Mundo!
|
Hello, World! = Hola, Mundo!
|
||||||
String with\nnewlines and \ttabs = Cadena con\nsaltos de linea y\ttabuladores
|
String with\nnewlines = Cadena con\nsaltos de linea
|
||||||
String with an \= equals sign = Cadena con un signo de \= igualdad
|
String with an \= equals sign = Cadena con un signo de \= igualdad
|
||||||
|
|
||||||
Since there's currently no portable way to detect the language, this library
|
Since there's currently no portable way to detect the language, this library
|
||||||
@ -71,22 +67,6 @@ Also note that there are some problems with using accented, and in general
|
|||||||
non-latin characters in strings. Until a fix is found, please limit yourself
|
non-latin characters in strings. Until a fix is found, please limit yourself
|
||||||
to using only US-ASCII characters.
|
to using only US-ASCII characters.
|
||||||
|
|
||||||
Frequently Asked Questions
|
|
||||||
--------------------------
|
|
||||||
Q: Were you bored when you did this?
|
|
||||||
A: Yes.
|
|
||||||
|
|
||||||
Q: Why are my texts are not translated?
|
|
||||||
A: RTFM...or ask in the topic 8-----)
|
|
||||||
|
|
||||||
Q: How come the README is bigger than the actual code?
|
|
||||||
A: Because I'm adding silly unfunny questions here...and because there are
|
|
||||||
some users that are too lazy to understand how the code works, so I have
|
|
||||||
to document things.
|
|
||||||
|
|
||||||
Q: I don't like this sh*t!
|
|
||||||
A: That's not a question.
|
|
||||||
|
|
||||||
Thanks for reading up to this point.
|
Thanks for reading up to this point.
|
||||||
Should you have any comments/suggestions, please post them in the forum topic.
|
Should you have any comments/suggestions, please post them in the forum topic.
|
||||||
|
|
||||||
|
70
init.lua
70
init.lua
@ -0,0 +1,70 @@
|
|||||||
|
|
||||||
|
-- Support the old multi-load method
|
||||||
|
intllib = intllib or {}
|
||||||
|
|
||||||
|
local strings = {}
|
||||||
|
|
||||||
|
local LANG = minetest.setting_get("language") or os.getenv("LANG") or "en"
|
||||||
|
LANG = LANG:sub(1, 2)
|
||||||
|
|
||||||
|
local escapes = {
|
||||||
|
["\\"] = "\\",
|
||||||
|
["n"] = "\n",
|
||||||
|
["="] = "=",
|
||||||
|
}
|
||||||
|
|
||||||
|
local function unescape(s)
|
||||||
|
return s:gsub("([\\]?)\\(.)", function(slash, what)
|
||||||
|
if slash and (slash ~= "") then
|
||||||
|
return "\\"..what
|
||||||
|
else
|
||||||
|
return escapes[what] or what
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
local function find_eq(s)
|
||||||
|
for slashes, pos in s:gmatch("([\\]*)=()") do
|
||||||
|
if (slashes:len() % 2) == 0 then
|
||||||
|
return pos - 1
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
function load_strings(modname)
|
||||||
|
local modpath = minetest.get_modpath(modname)
|
||||||
|
local file, err = io.open(modpath.."/locale/"..LANG..".txt", "r")
|
||||||
|
if not file then
|
||||||
|
return nil
|
||||||
|
end
|
||||||
|
local strings = {}
|
||||||
|
for line in file:lines() do
|
||||||
|
line = line:trim()
|
||||||
|
if line ~= "" and line:sub(1, 1) ~= "#" then
|
||||||
|
local pos = find_eq(line)
|
||||||
|
if pos then
|
||||||
|
local msgid = unescape(line:sub(1, pos - 1):trim())
|
||||||
|
strings[msgid] = unescape(line:sub(pos + 1):trim())
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
file:close()
|
||||||
|
return strings
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Support the old multi-load method
|
||||||
|
intllib.getters = intllib.getters or {}
|
||||||
|
|
||||||
|
function intllib.Getter(modname)
|
||||||
|
modname = modname or minetest.get_current_modname()
|
||||||
|
if not intllib.getters[modname] then
|
||||||
|
local msgstr = load_strings(modname) or {}
|
||||||
|
intllib.getters[modname] = function (s)
|
||||||
|
return msgstr[s] or s
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return intllib.getters[modname]
|
||||||
|
end
|
||||||
|
|
67
intllib.lua
67
intllib.lua
@ -1,66 +1,3 @@
|
|||||||
|
-- Support for the old multi-load method
|
||||||
|
dofile(minetest.get_modpath("intllib").."/init.lua")
|
||||||
|
|
||||||
intllib = { };
|
|
||||||
|
|
||||||
local strings = { };
|
|
||||||
|
|
||||||
local INTLLIB_DEBUG = true;
|
|
||||||
|
|
||||||
local LANG = minetest.setting_get("language") or os.getenv("LANG") or "en";
|
|
||||||
LANG = LANG:sub(1, 2);
|
|
||||||
|
|
||||||
local TRACE;
|
|
||||||
|
|
||||||
if (INTLLIB_DEBUG) then
|
|
||||||
TRACE = function ( s )
|
|
||||||
print("*** DEBUG: "..s);
|
|
||||||
end
|
|
||||||
else
|
|
||||||
TRACE = function ( ) end
|
|
||||||
end
|
|
||||||
|
|
||||||
local function do_load_strings ( f )
|
|
||||||
local msgstr = { };
|
|
||||||
for line in f:lines() do
|
|
||||||
line = line:trim();
|
|
||||||
if ((line ~= "") and (line:sub(1, 1) ~= "#")) then
|
|
||||||
local pos = line:find("=", 1, true);
|
|
||||||
if (pos) then
|
|
||||||
local msgid = line:sub(1, pos - 1):trim();
|
|
||||||
msgstr[msgid] = line:sub(pos + 1):trim();
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
return msgstr;
|
|
||||||
end
|
|
||||||
|
|
||||||
function load_strings ( modname, lang )
|
|
||||||
lang = lang or LANG;
|
|
||||||
local f, e = io.open(minetest.get_modpath(modname).."/locale/"..lang..".txt");
|
|
||||||
if (not f) then
|
|
||||||
f, e = io.open(minetest.get_modpath("intllib").."/locale/"..modname.."/"..lang..".txt");
|
|
||||||
if (not f) then
|
|
||||||
return nil;
|
|
||||||
end
|
|
||||||
end
|
|
||||||
local strings;
|
|
||||||
strings = do_load_strings(f);
|
|
||||||
f:close();
|
|
||||||
return strings;
|
|
||||||
end
|
|
||||||
|
|
||||||
local getters = { };
|
|
||||||
|
|
||||||
function intllib.Getter ( modname )
|
|
||||||
if (not modname) then modname = minetest.get_current_modname(); end
|
|
||||||
if (not getters[modname]) then
|
|
||||||
local msgstr = load_strings(modname, lang) or { };
|
|
||||||
getters[modname] = function ( s )
|
|
||||||
return msgstr[repr(s)] or s;
|
|
||||||
end;
|
|
||||||
end
|
|
||||||
return getters[modname];
|
|
||||||
end
|
|
||||||
|
|
||||||
function intllib.get_current_language ( )
|
|
||||||
return LANG;
|
|
||||||
end
|
|
||||||
|
Loading…
Reference in New Issue
Block a user