2013-09-10 21:18:57 -04:00
..
2013-09-10 21:18:57 -04:00
2013-09-10 21:18:57 -04:00
2013-09-10 21:18:57 -04:00
2013-09-10 21:18:57 -04:00
2013-09-10 21:18:57 -04:00
2013-09-10 21:18:57 -04:00

Minetest 0.4 mod: localisation
==============================

License of source code:
-----------------------
Copyright (C) 2011-2012 Jonjeg <jonathan.jegouzo@gmail.com>

This program is free software; you can redistribute it and/or modify
it under the terms of the GNU Lesser General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.

http://www.gnu.org/licenses/lgpl-2.1.html

Description:
------------
This mod allow mod devellopers to publish their mod in differents 
language with less work needed.

Usage:
------
The minetest setting 'language' is set to EN when this mod is first loaded.
You can modify this setting in your minetest.conf.
If no translation is found for a message, his english counterpart is used instead.
If no english counterpart are found, then no error are thrown but an error message is returned instead of the translation.

Exemple(Code lua) :
-------------------
	local translations = {
		EN = {
			message1 = "english version",
			message_with_parameter = "$1 will be replaced by the first additionnal parameter",
			message_existing_in_english_only = "lorem ipsum"
			...etc
		},
		FR = {
			message1 = "version française"
			message_with_parameter = "$1 va être remplacé par la 1ère valeur additionnelle"
			message_with_some_parameters = "$1,$2,$3"
		}
	}
    -- Registering the translations
    localisation.register_translations("your_mod_name",your_var_containing_translations)
    
	localisation.translate("your_mod_name:message1") -> "english version" -- si language = EN
	localisation.translate("your_mod_name:message1") -> "version française" -- si language = FR
	localisation.translate("your_mod_name:message1") -> "english version" -- si language = other than FR
	localisation.translate("your_mod_name:message_existing_in_english_only") -> "lorem ipsum"
	localisation.translate("your_mod_name:message_with_parameter","value") -> "value will be replaced by the first additionnal parameter" -- si language = EN
	localisation.translate("your_mod_name:message_with_parameter","value") -> "value va être remplacé par la 1ère valeur additionnelle" -- si language = FR
	localisation.translate("your_mod_name:message_with_some_parameters","value",2,3.5) -> "value,2,3.5"
	localisation.translate("your_mod_name:message_inexistant","value",2,3.5) -> "Translate(EN,message_inexistant) = No translations available" -- si language = EN
	localisation.translate("bad_message_without_mod_name","value",2,3.5) -> "No mod_name specified or other error message"
    
Language Patching
-----------------

If you want to translate a mod using this mod, it's possible.
Create a mod and/or specify the mod_name in the depends.txt and and register your translation with the mod_name.
The messages that wont be patched will be the messages that are used before the initialisation of the patch mod.

Exemple 
-------
If you want to add another language support(DE by exemple) to this mod(localisation), you can do it like that
local translations = {
    EN = {
        no_translation_available = "new english message, just because",
    },
    DE = {
        no_translation_available = "...",
        no_translation_registered_for_mod = "...",
    }
}
localisation.translate("localisation:no_translation_available") = <previous message>
localisation.register_translations("localisation",translations)
localisation.translate("localisation:no_translation_available") = "new english message, just because"