A quick walkthrough thru the basics of localization.
Providing multi-language support is vital for a successful plugin. Icicle provides an easy-to-use system with a built-in script language similar to Excel's.
Localization is done through the TranslationService
.
StringProviders
are the ones that provide the TranslationService
with a string for a key from a file. With this abstraction, the developers can implement any kind of source they can think of, be it a simple file-based one, or maybe a remote solution.
Built-in solutions are the following:
FileStringProvider --> Used for switching between multiple LanguageFiles
If you want to set up your own, do it like this:
LanguageProviders
are the ones responsible for providing a language code for a Player
. Sources can be databases, geolocation, or just a fallback fixed language.
If you want to use the built-in providers, they are the following:
ConstantLanguageProvider --> Always returns a pre-set language (used as fallback)
PlayerLanguageGeoProvider --> returning language-based of geolocation (experimental, relies on external API!!!)
Planned: DatabaseLanguageProvider
If you've decided you want a custom implementation, you can do so like this:
The TranslationService
must be auto-wired. By default - if no providers have been set up - it will use "en" as the language, and will only use the default values.
When first getting keys, the service will automatically append the default values to a translation file of choice (StringProvider
must be set up for this).
By default, the TranslationService does not parse color codes, as it's in the core module, and the core does not depend on Bukkit.
StringCode
is a special Excel formula-like script language, that provides translators with the ability to write logic inside a string, therefore making language-specific tasks easier.
Code must be written between {}, escaping with \ is supported.
The following table shows all the functions you can use & their purpose.
These are just the built-in functions. The system is completely expandable.
TRUE()
Constant true value.
FALSE()
Constant false value.
IF(statement, true, false)
If the statement is true, then the value inside true will be returned, otherwise the value inside false.
OR(statement1, [statement2], ...)
If any of the statements inside the function return true, then the function will return true, otherwise false.
NOT(statement)
Returns the logical opposite of the statement.
AND(statement1, [statement2], ...)
This function will only return true, if all of the statements inside it return true.
EW(value, test, [test2], ...)
Tests whether the value ends with the supplied test values. Will return true/false accordingly.
SW(value, test, [test2], ...)
Tests whether the value starts with the supplied test values. Will return true/false accordingly.
NE(value1, value2)
This function will return true if value1 and value2 do not match.
EQ(value1, value2)
This function will return true if value1 is equal to value2.
LTEQ(number1, number2)
Tests whether number1 is equal to or less than the second number2.
LT(number1, number2)
Tests whether number1 is less than the second number.
GTEQ(number1, number2)
Tests whether number1 is equal to or greater than the second number2.
GT(number1, number2)
Tests whether numbe1 is greater than the second number.
CONCAT(value, [value2], ...)
Concatonates the values inside the function, and returns them.
JOIN(separator, value, [value2], ...)
Joines the values inside the function together with the supplied separator.
SUB(number1, number2)
Subtracts number2 from number1.
ADD(number1, number2)
Adds the two numbers together, and returns the result.
MUL(number1, number2)
Multiplies the two numbers together, and returns the result.
MOD(number1, number2)
Returns the remainder of number1 divided by number2.
DIV(number1, number2)
Divides the first number with the second.