2017-09-12 20:42:36 +00:00
<?xml version="1.0" encoding="UTF-8" ?>
2023-07-06 08:08:05 +00:00
<class name= "TranslationServer" inherits= "Object" xmlns:xsi= "http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation= "../class.xsd" >
2017-09-12 20:42:36 +00:00
<brief_description >
2023-04-30 14:26:09 +00:00
The server responsible for language translations.
2017-09-12 20:42:36 +00:00
</brief_description>
<description >
2024-08-15 01:14:41 +00:00
The translation server is the API backend that manages all language translations.
Translations are stored in [TranslationDomain]s, which can be accessed by name. The most commonly used translation domain is the main translation domain, which always exists and can be accessed using an empty [StringName]. The translation server provides wrapper methods for accessing the master translation domain directly, without having to fetch the main translation domain first.
2017-09-12 20:42:36 +00:00
</description>
<tutorials >
2021-11-15 09:43:07 +00:00
<link title= "Internationalizing games" > $DOCS_URL/tutorials/i18n/internationalizing_games.html</link>
<link title= "Locales" > $DOCS_URL/tutorials/i18n/locales.html</link>
2017-09-12 20:42:36 +00:00
</tutorials>
<methods >
<method name= "add_translation" >
2021-07-30 13:28:05 +00:00
<return type= "void" />
2022-08-06 18:11:48 +00:00
<param index= "0" name= "translation" type= "Translation" />
2017-09-12 20:42:36 +00:00
<description >
2024-08-15 01:14:41 +00:00
Adds a translation to the main translation domain.
2017-09-12 20:42:36 +00:00
</description>
</method>
<method name= "clear" >
2021-07-30 13:28:05 +00:00
<return type= "void" />
2017-09-12 20:42:36 +00:00
<description >
2024-08-15 01:14:41 +00:00
Removes all translations from the main translation domain.
2017-09-12 20:42:36 +00:00
</description>
</method>
2021-09-23 11:08:50 +00:00
<method name= "compare_locales" qualifiers= "const" >
<return type= "int" />
2022-08-06 18:11:48 +00:00
<param index= "0" name= "locale_a" type= "String" />
<param index= "1" name= "locale_b" type= "String" />
2021-09-23 11:08:50 +00:00
<description >
2023-04-30 14:26:09 +00:00
Compares two locales and returns a similarity score between [code]0[/code] (no match) and [code]10[/code] (full match).
2021-09-23 11:08:50 +00:00
</description>
</method>
<method name= "get_all_countries" qualifiers= "const" >
<return type= "PackedStringArray" />
<description >
2023-04-30 14:26:09 +00:00
Returns an array of known country codes.
2021-09-23 11:08:50 +00:00
</description>
</method>
<method name= "get_all_languages" qualifiers= "const" >
<return type= "PackedStringArray" />
<description >
Returns array of known language codes.
</description>
</method>
<method name= "get_all_scripts" qualifiers= "const" >
<return type= "PackedStringArray" />
<description >
2023-04-30 14:26:09 +00:00
Returns an array of known script codes.
2021-09-23 11:08:50 +00:00
</description>
</method>
<method name= "get_country_name" qualifiers= "const" >
<return type= "String" />
2022-08-06 18:11:48 +00:00
<param index= "0" name= "country" type= "String" />
2021-09-23 11:08:50 +00:00
<description >
2023-04-30 14:26:09 +00:00
Returns a readable country name for the [param country] code.
2021-09-23 11:08:50 +00:00
</description>
</method>
<method name= "get_language_name" qualifiers= "const" >
<return type= "String" />
2022-08-06 18:11:48 +00:00
<param index= "0" name= "language" type= "String" />
2021-09-23 11:08:50 +00:00
<description >
2023-04-30 14:26:09 +00:00
Returns a readable language name for the [param language] code.
2021-09-23 11:08:50 +00:00
</description>
</method>
2019-04-27 17:11:39 +00:00
<method name= "get_loaded_locales" qualifiers= "const" >
2022-08-07 22:52:20 +00:00
<return type= "PackedStringArray" />
2019-04-27 17:11:39 +00:00
<description >
2021-09-16 07:27:56 +00:00
Returns an array of all loaded locales of the project.
2019-04-27 17:11:39 +00:00
</description>
</method>
2017-09-12 20:42:36 +00:00
<method name= "get_locale" qualifiers= "const" >
2021-07-30 13:28:05 +00:00
<return type= "String" />
2017-09-12 20:42:36 +00:00
<description >
2021-09-16 07:27:56 +00:00
Returns the current locale of the project.
See also [method OS.get_locale] and [method OS.get_locale_language] to query the locale of the user system.
2017-09-12 20:42:36 +00:00
</description>
</method>
2017-10-29 11:09:14 +00:00
<method name= "get_locale_name" qualifiers= "const" >
2021-07-30 13:28:05 +00:00
<return type= "String" />
2022-08-06 18:11:48 +00:00
<param index= "0" name= "locale" type= "String" />
2017-10-29 11:09:14 +00:00
<description >
2019-06-21 23:04:47 +00:00
Returns a locale's language and its variant (e.g. [code]"en_US"[/code] would return [code]"English (United States)"[/code]).
2017-10-29 11:09:14 +00:00
</description>
</method>
2024-08-15 01:14:41 +00:00
<method name= "get_or_add_domain" >
<return type= "TranslationDomain" />
<param index= "0" name= "domain" type= "StringName" />
<description >
Returns the translation domain with the specified name. An empty translation domain will be created and added if it does not exist.
</description>
</method>
2021-09-23 11:08:50 +00:00
<method name= "get_script_name" qualifiers= "const" >
<return type= "String" />
2022-08-06 18:11:48 +00:00
<param index= "0" name= "script" type= "String" />
2021-09-23 11:08:50 +00:00
<description >
2023-04-30 14:26:09 +00:00
Returns a readable script name for the [param script] code.
2021-09-23 11:08:50 +00:00
</description>
</method>
2022-02-08 07:49:14 +00:00
<method name= "get_tool_locale" >
<return type= "String" />
<description >
Returns the current locale of the editor.
[b]Note:[/b] When called from an exported project returns the same value as [method get_locale].
</description>
</method>
2020-08-07 11:17:12 +00:00
<method name= "get_translation_object" >
2021-07-30 13:28:05 +00:00
<return type= "Translation" />
2022-08-06 18:11:48 +00:00
<param index= "0" name= "locale" type= "String" />
2020-08-07 11:17:12 +00:00
<description >
2024-08-15 01:14:41 +00:00
Returns the [Translation] instance that best matches [param locale] in the main translation domain. Returns [code]null[/code] if there are no matches.
</description>
</method>
<method name= "has_domain" qualifiers= "const" >
<return type= "bool" />
<param index= "0" name= "domain" type= "StringName" />
<description >
Returns [code]true[/code] if a translation domain with the specified name exists.
2020-08-07 11:17:12 +00:00
</description>
</method>
2021-08-08 15:07:57 +00:00
<method name= "pseudolocalize" qualifiers= "const" >
<return type= "StringName" />
2022-08-06 18:11:48 +00:00
<param index= "0" name= "message" type= "StringName" />
2021-08-08 15:07:57 +00:00
<description >
2022-08-09 15:19:47 +00:00
Returns the pseudolocalized string based on the [param message] passed in.
2021-08-08 15:07:57 +00:00
</description>
</method>
<method name= "reload_pseudolocalization" >
<return type= "void" />
<description >
Reparses the pseudolocalization options and reloads the translation.
</description>
</method>
2024-08-15 01:14:41 +00:00
<method name= "remove_domain" >
<return type= "void" />
<param index= "0" name= "domain" type= "StringName" />
<description >
Removes the translation domain with the specified name.
[b]Note:[/b] Trying to remove the main translation domain is an error.
</description>
</method>
2017-09-12 20:42:36 +00:00
<method name= "remove_translation" >
2021-07-30 13:28:05 +00:00
<return type= "void" />
2022-08-06 18:11:48 +00:00
<param index= "0" name= "translation" type= "Translation" />
2017-09-12 20:42:36 +00:00
<description >
2024-08-15 01:14:41 +00:00
Removes the given translation from the main translation domain.
2017-09-12 20:42:36 +00:00
</description>
</method>
<method name= "set_locale" >
2021-07-30 13:28:05 +00:00
<return type= "void" />
2022-08-06 18:11:48 +00:00
<param index= "0" name= "locale" type= "String" />
2017-09-12 20:42:36 +00:00
<description >
2022-08-09 15:19:47 +00:00
Sets the locale of the project. The [param locale] string will be standardized to match known locales (e.g. [code]en-US[/code] would be matched to [code]en_US[/code]).
2021-09-16 07:27:56 +00:00
If translations have been loaded beforehand for the new locale, they will be applied.
2017-09-12 20:42:36 +00:00
</description>
</method>
2021-09-23 11:08:50 +00:00
<method name= "standardize_locale" qualifiers= "const" >
<return type= "String" />
2022-08-06 18:11:48 +00:00
<param index= "0" name= "locale" type= "String" />
2021-09-23 11:08:50 +00:00
<description >
2023-04-30 14:26:09 +00:00
Returns a [param locale] string standardized to match known locales (e.g. [code]en-US[/code] would be matched to [code]en_US[/code]).
2021-09-23 11:08:50 +00:00
</description>
</method>
2017-09-12 20:42:36 +00:00
<method name= "translate" qualifiers= "const" >
2021-07-30 13:28:05 +00:00
<return type= "StringName" />
2022-08-06 18:11:48 +00:00
<param index= "0" name= "message" type= "StringName" />
2024-01-30 20:03:28 +00:00
<param index= "1" name= "context" type= "StringName" default= "&""" />
2020-08-07 11:17:12 +00:00
<description >
2024-08-15 01:14:41 +00:00
Returns the current locale's translation for the given message and context.
[b]Note:[/b] This method always uses the main translation domain.
2020-08-07 11:17:12 +00:00
</description>
</method>
<method name= "translate_plural" qualifiers= "const" >
2021-07-30 13:28:05 +00:00
<return type= "StringName" />
2022-08-06 18:11:48 +00:00
<param index= "0" name= "message" type= "StringName" />
<param index= "1" name= "plural_message" type= "StringName" />
<param index= "2" name= "n" type= "int" />
2024-01-30 20:03:28 +00:00
<param index= "3" name= "context" type= "StringName" default= "&""" />
2017-09-12 20:42:36 +00:00
<description >
2024-08-15 01:14:41 +00:00
Returns the current locale's translation for the given message, plural message and context.
2022-08-09 15:19:47 +00:00
The number [param n] is the number or quantity of the plural object. It will be used to guide the translation system to fetch the correct plural form for the selected language.
2024-08-15 01:14:41 +00:00
[b]Note:[/b] This method always uses the main translation domain.
2017-09-12 20:42:36 +00:00
</description>
</method>
</methods>
2021-08-08 15:07:57 +00:00
<members >
<member name= "pseudolocalization_enabled" type= "bool" setter= "set_pseudolocalization_enabled" getter= "is_pseudolocalization_enabled" default= "false" >
If [code]true[/code], enables the use of pseudolocalization. See [member ProjectSettings.internationalization/pseudolocalization/use_pseudolocalization] for details.
</member>
</members>
2017-09-12 20:42:36 +00:00
</class>