Add autocompletion for TranslationServer
This commit is contained in:
parent
26b1fd0d84
commit
ffd498c57d
2 changed files with 27 additions and 0 deletions
|
@ -983,6 +983,29 @@ bool TranslationServer::is_placeholder(String &p_message, int p_index) const {
|
|||
p_message[p_index + 1] == 'o' || p_message[p_index + 1] == 'x' || p_message[p_index + 1] == 'X' || p_message[p_index + 1] == 'f');
|
||||
}
|
||||
|
||||
#ifdef TOOLS_ENABLED
|
||||
void TranslationServer::get_argument_options(const StringName &p_function, int p_idx, List<String> *r_options) const {
|
||||
const String pf = p_function;
|
||||
if (p_idx == 0) {
|
||||
HashMap<String, String> *target_hash_map = nullptr;
|
||||
if (pf == "get_language_name") {
|
||||
target_hash_map = &language_map;
|
||||
} else if (pf == "get_script_name") {
|
||||
target_hash_map = &script_map;
|
||||
} else if (pf == "get_country_name") {
|
||||
target_hash_map = &country_name_map;
|
||||
}
|
||||
|
||||
if (target_hash_map) {
|
||||
for (const KeyValue<String, String> &E : *target_hash_map) {
|
||||
r_options->push_back(E.key.quote());
|
||||
}
|
||||
}
|
||||
}
|
||||
Object::get_argument_options(p_function, p_idx, r_options);
|
||||
}
|
||||
#endif // TOOLS_ENABLED
|
||||
|
||||
void TranslationServer::_bind_methods() {
|
||||
ClassDB::bind_method(D_METHOD("set_locale", "locale"), &TranslationServer::set_locale);
|
||||
ClassDB::bind_method(D_METHOD("get_locale"), &TranslationServer::get_locale);
|
||||
|
|
|
@ -185,6 +185,10 @@ public:
|
|||
|
||||
void load_translations();
|
||||
|
||||
#ifdef TOOLS_ENABLED
|
||||
virtual void get_argument_options(const StringName &p_function, int p_idx, List<String> *r_options) const override;
|
||||
#endif // TOOLS_ENABLED
|
||||
|
||||
TranslationServer();
|
||||
};
|
||||
|
||||
|
|
Loading…
Reference in a new issue