Display an error message in settings when autoload name is invalid

This commit is contained in:
jmb462 2021-09-13 22:54:20 +02:00
parent 8c8b634d23
commit 645cc71be4
2 changed files with 22 additions and 7 deletions

View file

@ -64,7 +64,12 @@ void EditorAutoloadSettings::_notification(int p_what) {
bool EditorAutoloadSettings::_autoload_name_is_valid(const String &p_name, String *r_error) { bool EditorAutoloadSettings::_autoload_name_is_valid(const String &p_name, String *r_error) {
if (!p_name.is_valid_identifier()) { if (!p_name.is_valid_identifier()) {
if (r_error) { if (r_error) {
*r_error = TTR("Invalid name.") + "\n" + TTR("Valid characters:") + " a-z, A-Z, 0-9 or _"; *r_error = TTR("Invalid name.") + " ";
if (p_name.size() > 0 && p_name.left(1).is_numeric()) {
*r_error += TTR("Cannot begin with a digit.");
} else {
*r_error += TTR("Valid characters:") + " a-z, A-Z, 0-9 or _";
}
} }
return false; return false;
@ -72,7 +77,7 @@ bool EditorAutoloadSettings::_autoload_name_is_valid(const String &p_name, Strin
if (ClassDB::class_exists(p_name)) { if (ClassDB::class_exists(p_name)) {
if (r_error) { if (r_error) {
*r_error = TTR("Invalid name.") + "\n" + TTR("Must not collide with an existing engine class name."); *r_error = TTR("Invalid name.") + " " + TTR("Must not collide with an existing engine class name.");
} }
return false; return false;
@ -89,7 +94,7 @@ bool EditorAutoloadSettings::_autoload_name_is_valid(const String &p_name, Strin
for (int i = 0; i < Variant::VARIANT_MAX; i++) { for (int i = 0; i < Variant::VARIANT_MAX; i++) {
if (Variant::get_type_name(Variant::Type(i)) == p_name) { if (Variant::get_type_name(Variant::Type(i)) == p_name) {
if (r_error) { if (r_error) {
*r_error = TTR("Invalid name.") + "\n" + TTR("Must not collide with an existing built-in type name."); *r_error = TTR("Invalid name.") + " " + TTR("Must not collide with an existing built-in type name.");
} }
return false; return false;
@ -99,7 +104,7 @@ bool EditorAutoloadSettings::_autoload_name_is_valid(const String &p_name, Strin
for (int i = 0; i < CoreConstants::get_global_constant_count(); i++) { for (int i = 0; i < CoreConstants::get_global_constant_count(); i++) {
if (CoreConstants::get_global_constant_name(i) == p_name) { if (CoreConstants::get_global_constant_name(i) == p_name) {
if (r_error) { if (r_error) {
*r_error = TTR("Invalid name.") + "\n" + TTR("Must not collide with an existing global constant name."); *r_error = TTR("Invalid name.") + " " + TTR("Must not collide with an existing global constant name.");
} }
return false; return false;
@ -112,7 +117,7 @@ bool EditorAutoloadSettings::_autoload_name_is_valid(const String &p_name, Strin
for (const String &E : keywords) { for (const String &E : keywords) {
if (E == p_name) { if (E == p_name) {
if (r_error) { if (r_error) {
*r_error = TTR("Invalid name.") + "\n" + TTR("Keyword cannot be used as an autoload name."); *r_error = TTR("Invalid name.") + " " + TTR("Keyword cannot be used as an autoload name.");
} }
return false; return false;
@ -346,8 +351,11 @@ void EditorAutoloadSettings::_autoload_path_text_changed(const String p_path) {
} }
void EditorAutoloadSettings::_autoload_text_changed(const String p_name) { void EditorAutoloadSettings::_autoload_text_changed(const String p_name) {
add_autoload->set_disabled( String error_string;
autoload_add_path->get_text() == "" || !_autoload_name_is_valid(p_name, nullptr)); bool is_name_valid = _autoload_name_is_valid(p_name, &error_string);
add_autoload->set_disabled(autoload_add_path->get_text() == "" || !is_name_valid);
error_message->set_text(error_string);
error_message->set_visible(autoload_add_name->get_text() != "" && !is_name_valid);
} }
Node *EditorAutoloadSettings::_create_autoload(const String &p_path) { Node *EditorAutoloadSettings::_create_autoload(const String &p_path) {
@ -828,6 +836,12 @@ EditorAutoloadSettings::EditorAutoloadSettings() {
HBoxContainer *hbc = memnew(HBoxContainer); HBoxContainer *hbc = memnew(HBoxContainer);
add_child(hbc); add_child(hbc);
error_message = memnew(Label);
error_message->hide();
error_message->set_align(Label::Align::ALIGN_RIGHT);
error_message->add_theme_color_override("font_color", EditorNode::get_singleton()->get_gui_base()->get_theme_color(SNAME("error_color"), SNAME("Editor")));
add_child(error_message);
Label *l = memnew(Label); Label *l = memnew(Label);
l->set_text(TTR("Path:")); l->set_text(TTR("Path:"));
hbc->add_child(l); hbc->add_child(l);

View file

@ -70,6 +70,7 @@ class EditorAutoloadSettings : public VBoxContainer {
LineEdit *autoload_add_name; LineEdit *autoload_add_name;
Button *add_autoload; Button *add_autoload;
LineEdit *autoload_add_path; LineEdit *autoload_add_path;
Label *error_message;
Button *browse_button; Button *browse_button;
EditorFileDialog *file_dialog; EditorFileDialog *file_dialog;