Merge pull request #17490 from robfram/homogenize-check-prop-names

Fix non-valid characters for `input_action`
This commit is contained in:
Rémi Verschelde 2018-03-23 11:29:26 +01:00 committed by GitHub
commit 1d07830182
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -123,6 +123,15 @@ void ProjectSettingsEditor::_notification(int p_what) {
} }
} }
static bool _validate_action_name(const String &p_name) {
const CharType *cstr = p_name.c_str();
for (int i = 0; cstr[i]; i++)
if (cstr[i] == '/' || cstr[i] == ':' || cstr[i] == '"' ||
cstr[i] == '=' || cstr[i] == '\\' || cstr[i] < 32)
return false;
return true;
}
void ProjectSettingsEditor::_action_selected() { void ProjectSettingsEditor::_action_selected() {
TreeItem *ti = input_editor->get_selected(); TreeItem *ti = input_editor->get_selected();
@ -145,12 +154,12 @@ void ProjectSettingsEditor::_action_edited() {
if (new_name == old_name) if (new_name == old_name)
return; return;
if (new_name.find("/") != -1 || new_name.find(":") != -1 || new_name.find("\"") != -1 || new_name == "") { if (new_name == "" || !_validate_action_name(new_name)) {
ti->set_text(0, old_name); ti->set_text(0, old_name);
add_at = "input/" + old_name; add_at = "input/" + old_name;
message->set_text(TTR("Invalid action (anything goes but '/', ':' or '\"').")); message->set_text(TTR("Invalid action name. it cannot be empty nor contain '/', ':', '=', '\\' or '\"'"));
message->popup_centered(Size2(300, 100) * EDSCALE); message->popup_centered(Size2(300, 100) * EDSCALE);
return; return;
} }
@ -838,9 +847,9 @@ void ProjectSettingsEditor::_action_check(String p_action) {
action_add->set_disabled(true); action_add->set_disabled(true);
} else { } else {
if (p_action.find("/") != -1 || p_action.find(":") != -1 || p_action.find("\"") != -1) { if (!_validate_action_name(p_action)) {
action_add_error->set_text(TTR("Can't contain '/', ':' or '\"'")); action_add_error->set_text(TTR("Invalid action name. it cannot be empty nor contain '/', ':', '=', '\\' or '\"'"));
action_add_error->show(); action_add_error->show();
action_add->set_disabled(true); action_add->set_disabled(true);
return; return;