Fix non working action names containing whitespaces

Now the action name is quoted if it contains spaces. Also, quotation
mark (") is added to the forbidden character list for action names, as
it was also a bug.

Fix #17322

(cherry picked from commit ea94a82596)
This commit is contained in:
robfram 2018-03-12 21:28:41 +01:00 committed by Hein-Pieter van Braam
parent 72350eebb2
commit 141e389c3f
2 changed files with 8 additions and 5 deletions

View File

@ -692,7 +692,10 @@ Error ProjectSettings::_save_settings_text(const String &p_file, const Map<Strin
String vstr; String vstr;
VariantWriter::write_to_string(value, vstr); VariantWriter::write_to_string(value, vstr);
file->store_string(F->get() + "=" + vstr + "\n"); if (F->get().find(" ") != -1)
file->store_string(F->get().quote() + "=" + vstr + "\n");
else
file->store_string(F->get() + "=" + vstr + "\n");
} }
} }

View File

@ -137,12 +137,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 == "") { if (new_name.find("/") != -1 || new_name.find(":") != -1 || new_name.find("\"") != -1 || 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 (anything goes but '/', ':' or '\"')."));
message->popup_centered(Size2(300, 100) * EDSCALE); message->popup_centered(Size2(300, 100) * EDSCALE);
return; return;
} }
@ -830,9 +830,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) { if (p_action.find("/") != -1 || p_action.find(":") != -1 || p_action.find("\"") != -1) {
action_add_error->set_text(TTR("Can't contain '/' or ':'")); action_add_error->set_text(TTR("Can't contain '/', ':' or '\"'"));
action_add_error->show(); action_add_error->show();
action_add->set_disabled(true); action_add->set_disabled(true);
return; return;