summaryrefslogtreecommitdiff
path: root/editor
diff options
context:
space:
mode:
Diffstat (limited to 'editor')
-rw-r--r--editor/editor_settings.cpp978
-rw-r--r--editor/editor_settings.h87
2 files changed, 530 insertions, 535 deletions
diff --git a/editor/editor_settings.cpp b/editor/editor_settings.cpp
index 78cc215421..5ce6884a9e 100644
--- a/editor/editor_settings.cpp
+++ b/editor/editor_settings.cpp
@@ -47,12 +47,11 @@
#include "scene/main/scene_tree.h"
#include "scene/main/viewport.h"
-Ref<EditorSettings> EditorSettings::singleton = NULL;
+// PRIVATE METHODS
-EditorSettings *EditorSettings::get_singleton() {
+Ref<EditorSettings> EditorSettings::singleton = NULL;
- return singleton.ptr();
-}
+// Properties
bool EditorSettings::_set(const StringName &p_name, const Variant &p_value, bool p_emit_signal) {
@@ -195,347 +194,26 @@ void EditorSettings::_get_property_list(List<PropertyInfo> *p_list) const {
p_list->push_back(PropertyInfo(Variant::ARRAY, "shortcuts", PROPERTY_HINT_NONE, "", PROPERTY_USAGE_NOEDITOR)); //do not edit
}
-void EditorSettings::set_setting(const String &p_setting, const Variant &p_value) {
- _THREAD_SAFE_METHOD_
- set(p_setting, p_value);
-}
-
-Variant EditorSettings::get_setting(const String &p_setting) const {
- _THREAD_SAFE_METHOD_
- return get(p_setting);
-}
-
-bool EditorSettings::has_setting(String p_var) const {
-
- _THREAD_SAFE_METHOD_
-
- return props.has(p_var);
-}
-
-void EditorSettings::erase(String p_var) {
-
- _THREAD_SAFE_METHOD_
-
- props.erase(p_var);
-}
-
-void EditorSettings::raise_order(const String &p_name) {
- _THREAD_SAFE_METHOD_
-
- ERR_FAIL_COND(!props.has(p_name));
- props[p_name].order = ++last_order;
-}
-
-Variant _EDITOR_DEF(const String &p_var, const Variant &p_default) {
-
- if (EditorSettings::get_singleton()->has_setting(p_var))
- return EditorSettings::get_singleton()->get(p_var);
- EditorSettings::get_singleton()->set(p_var, p_default);
- EditorSettings::get_singleton()->set_initial_value(p_var, p_default);
-
- return p_default;
-}
-
-Variant _EDITOR_GET(const String &p_var) {
-
- ERR_FAIL_COND_V(!EditorSettings::get_singleton()->has_setting(p_var), Variant())
- return EditorSettings::get_singleton()->get(p_var);
-}
-
-static Dictionary _get_builtin_script_templates() {
- Dictionary templates;
-
- //No Comments
- templates["no_comments.gd"] =
- "extends %BASE%\n"
- "\n"
- "func _ready():\n"
- "%TS%pass\n";
-
- //Empty
- templates["empty.gd"] =
- "extends %BASE%"
- "\n"
- "\n";
-
- return templates;
-}
-
-static void _create_script_templates(const String &p_path) {
-
- Dictionary templates = _get_builtin_script_templates();
- List<Variant> keys;
- templates.get_key_list(&keys);
- FileAccess *file = FileAccess::create(FileAccess::ACCESS_FILESYSTEM);
-
- DirAccess *dir = DirAccess::create(DirAccess::ACCESS_FILESYSTEM);
- dir->change_dir(p_path);
- for (int i = 0; i < keys.size(); i++) {
- if (!dir->file_exists(keys[i])) {
- Error err = file->reopen(p_path.plus_file((String)keys[i]), FileAccess::WRITE);
- ERR_FAIL_COND(err != OK);
- file->store_string(templates[keys[i]]);
- file->close();
- }
- }
-
- memdelete(dir);
- memdelete(file);
-}
-
-void EditorSettings::create() {
-
- if (singleton.ptr())
- return; //pointless
-
- DirAccess *dir = NULL;
- Variant meta;
-
- String config_path;
- String config_dir;
- Ref<ConfigFile> extra_config = memnew(ConfigFile);
-
- String exe_path = OS::get_singleton()->get_executable_path().get_base_dir();
- DirAccess *d = DirAccess::create_for_path(exe_path);
- bool self_contained = false;
-
- if (d->file_exists(exe_path + "/._sc_")) {
- self_contained = true;
- extra_config->load(exe_path + "/._sc_");
- } else if (d->file_exists(exe_path + "/_sc_")) {
- self_contained = true;
- extra_config->load(exe_path + "/_sc_");
- }
- memdelete(d);
-
- if (self_contained) {
- // editor is self contained
- config_path = exe_path;
- config_dir = "editor_data";
- } else {
-
- if (OS::get_singleton()->has_environment("APPDATA")) {
- // Most likely under windows, save here
- config_path = OS::get_singleton()->get_environment("APPDATA");
- config_dir = String(_MKSTR(VERSION_SHORT_NAME)).capitalize();
- } else if (OS::get_singleton()->has_environment("HOME")) {
-
- config_path = OS::get_singleton()->get_environment("HOME");
- config_dir = "." + String(_MKSTR(VERSION_SHORT_NAME)).to_lower();
- }
- };
-
- ClassDB::register_class<EditorSettings>(); //otherwise it can't be unserialized
- String config_file_path;
-
- if (config_path != "") {
-
- dir = DirAccess::create(DirAccess::ACCESS_FILESYSTEM);
- if (dir->change_dir(config_path) != OK) {
- ERR_PRINT("Cannot find path for config directory!");
- memdelete(dir);
- goto fail;
- }
-
- if (dir->change_dir(config_dir) != OK) {
- dir->make_dir(config_dir);
- if (dir->change_dir(config_dir) != OK) {
- ERR_PRINT("Cannot create config directory!");
- memdelete(dir);
- goto fail;
- }
- }
-
- if (dir->change_dir("templates") != OK) {
- dir->make_dir("templates");
- } else {
-
- dir->change_dir("..");
- }
-
- if (dir->change_dir("text_editor_themes") != OK) {
- dir->make_dir("text_editor_themes");
- } else {
- dir->change_dir("..");
- }
-
- if (dir->change_dir("script_templates") != OK) {
- dir->make_dir("script_templates");
- } else {
- dir->change_dir("..");
- }
- _create_script_templates(dir->get_current_dir() + "/script_templates");
-
- if (dir->change_dir("tmp") != OK) {
- dir->make_dir("tmp");
- } else {
-
- dir->change_dir("..");
- }
-
- if (dir->change_dir("config") != OK) {
- dir->make_dir("config");
- } else {
-
- dir->change_dir("..");
- }
-
- dir->change_dir("config");
-
- String pcp = ProjectSettings::get_singleton()->get_resource_path();
- if (pcp.ends_with("/"))
- pcp = config_path.substr(0, pcp.size() - 1);
- pcp = pcp.get_file() + "-" + pcp.md5_text();
-
- if (dir->change_dir(pcp)) {
- dir->make_dir(pcp);
- } else {
- dir->change_dir("..");
- }
-
- dir->change_dir("..");
-
- // path at least is validated, so validate config file
-
- String config_file_name = "editor_settings-" + String(_MKSTR(VERSION_MAJOR)) + ".tres";
- config_file_path = config_path + "/" + config_dir + "/" + config_file_name;
-
- String open_path = config_file_path;
-
- if (!dir->file_exists(config_file_name)) {
-
- goto fail;
- }
-
- memdelete(dir);
-
- singleton = ResourceLoader::load(open_path, "EditorSettings");
-
- if (singleton.is_null()) {
- WARN_PRINT("Could not open config file.");
- goto fail;
- }
-
- singleton->save_changed_setting = true;
- singleton->config_file_path = config_file_path;
- singleton->project_config_path = pcp;
- singleton->settings_path = config_path + "/" + config_dir;
-
- if (OS::get_singleton()->is_stdout_verbose()) {
-
- print_line("EditorSettings: Load OK!");
- }
-
- singleton->setup_language();
- singleton->setup_network();
- singleton->load_favorites();
- singleton->list_text_editor_themes();
-
- return;
- }
-
-fail:
-
- // patch init projects
- if (extra_config->has_section("init_projects")) {
- Vector<String> list = extra_config->get_value("init_projects", "list");
- for (int i = 0; i < list.size(); i++) {
-
- list[i] = exe_path + "/" + list[i];
- };
- extra_config->set_value("init_projects", "list", list);
- };
-
- singleton = Ref<EditorSettings>(memnew(EditorSettings));
- singleton->save_changed_setting = true;
- singleton->config_file_path = config_file_path;
- singleton->settings_path = config_path + "/" + config_dir;
- singleton->_load_defaults(extra_config);
- singleton->setup_language();
- singleton->setup_network();
- singleton->list_text_editor_themes();
-}
-
-String EditorSettings::get_settings_path() const {
-
- return settings_path;
-}
-
-void EditorSettings::setup_language() {
-
- String lang = get("interface/editor/editor_language");
- if (lang == "en")
- return; //none to do
-
- for (int i = 0; i < translations.size(); i++) {
- if (translations[i]->get_locale() == lang) {
- TranslationServer::get_singleton()->set_tool_translation(translations[i]);
- break;
- }
- }
-}
-
-void EditorSettings::setup_network() {
-
- List<IP_Address> local_ip;
- IP::get_singleton()->get_local_addresses(&local_ip);
- String lip = "127.0.0.1";
- String hint;
- String current = has_setting("network/debug/remote_host") ? get("network/debug/remote_host") : "";
- int port = has_setting("network/debug/remote_port") ? (int)get("network/debug/remote_port") : 6007;
-
- for (List<IP_Address>::Element *E = local_ip.front(); E; E = E->next()) {
-
- String ip = E->get();
-
- // link-local IPv6 addresses don't work, skipping them
- if (ip.begins_with("fe80:0:0:0:")) // fe80::/64
- continue;
- if (ip == current)
- lip = current; //so it saves
- if (hint != "")
- hint += ",";
- hint += ip;
- }
-
- set("network/debug/remote_host", lip);
- add_property_hint(PropertyInfo(Variant::STRING, "network/debug/remote_host", PROPERTY_HINT_ENUM, hint));
-
- set("network/debug/remote_port", port);
- add_property_hint(PropertyInfo(Variant::INT, "network/debug/remote_port", PROPERTY_HINT_RANGE, "1,65535,1"));
-}
-
-void EditorSettings::save() {
-
- //_THREAD_SAFE_METHOD_
-
- if (!singleton.ptr())
- return;
+void EditorSettings::_add_property_info_bind(const Dictionary &p_info) {
- if (singleton->config_file_path == "") {
- ERR_PRINT("Cannot save EditorSettings config, no valid path");
- return;
- }
+ ERR_FAIL_COND(!p_info.has("name"));
+ ERR_FAIL_COND(!p_info.has("type"));
- Error err = ResourceSaver::save(singleton->config_file_path, singleton);
+ PropertyInfo pinfo;
+ pinfo.name = p_info["name"];
+ ERR_FAIL_COND(!props.has(pinfo.name));
+ pinfo.type = Variant::Type(p_info["type"].operator int());
+ ERR_FAIL_INDEX(pinfo.type, Variant::VARIANT_MAX);
- if (err != OK) {
- ERR_PRINT("Can't Save!");
- return;
- }
+ if (p_info.has("hint"))
+ pinfo.hint = PropertyHint(p_info["hint"].operator int());
+ if (p_info.has("hint_string"))
+ pinfo.hint_string = p_info["hint_string"];
- if (OS::get_singleton()->is_stdout_verbose()) {
- print_line("EditorSettings Save OK!");
- }
+ add_property_hint(pinfo);
}
-void EditorSettings::destroy() {
-
- if (!singleton.ptr())
- return;
- save();
- singleton = Ref<EditorSettings>();
-}
+// Default configs
void EditorSettings::_load_defaults(Ref<ConfigFile> p_extra_config) {
@@ -857,41 +535,418 @@ void EditorSettings::_load_default_text_editor_theme() {
_initial_set("text_editor/highlighting/search_result_border_color", Color(0.1, 0.45, 0.1, 1));
}
-void EditorSettings::notify_changes() {
+bool EditorSettings::_save_text_editor_theme(String p_file) {
+ String theme_section = "color_theme";
+ Ref<ConfigFile> cf = memnew(ConfigFile); // hex is better?
+ cf->set_value(theme_section, "background_color", ((Color)get("text_editor/highlighting/background_color")).to_html());
+ cf->set_value(theme_section, "completion_background_color", ((Color)get("text_editor/highlighting/completion_background_color")).to_html());
+ cf->set_value(theme_section, "completion_selected_color", ((Color)get("text_editor/highlighting/completion_selected_color")).to_html());
+ cf->set_value(theme_section, "completion_existing_color", ((Color)get("text_editor/highlighting/completion_existing_color")).to_html());
+ cf->set_value(theme_section, "completion_scroll_color", ((Color)get("text_editor/highlighting/completion_scroll_color")).to_html());
+ cf->set_value(theme_section, "completion_font_color", ((Color)get("text_editor/highlighting/completion_font_color")).to_html());
+ cf->set_value(theme_section, "caret_color", ((Color)get("text_editor/highlighting/caret_color")).to_html());
+ cf->set_value(theme_section, "caret_background_color", ((Color)get("text_editor/highlighting/caret_background_color")).to_html());
+ cf->set_value(theme_section, "line_number_color", ((Color)get("text_editor/highlighting/line_number_color")).to_html());
+ cf->set_value(theme_section, "text_color", ((Color)get("text_editor/highlighting/text_color")).to_html());
+ cf->set_value(theme_section, "text_selected_color", ((Color)get("text_editor/highlighting/text_selected_color")).to_html());
+ cf->set_value(theme_section, "keyword_color", ((Color)get("text_editor/highlighting/keyword_color")).to_html());
+ cf->set_value(theme_section, "base_type_color", ((Color)get("text_editor/highlighting/base_type_color")).to_html());
+ cf->set_value(theme_section, "engine_type_color", ((Color)get("text_editor/highlighting/engine_type_color")).to_html());
+ cf->set_value(theme_section, "function_color", ((Color)get("text_editor/highlighting/function_color")).to_html());
+ cf->set_value(theme_section, "member_variable_color", ((Color)get("text_editor/highlighting/member_variable_color")).to_html());
+ cf->set_value(theme_section, "comment_color", ((Color)get("text_editor/highlighting/comment_color")).to_html());
+ cf->set_value(theme_section, "string_color", ((Color)get("text_editor/highlighting/string_color")).to_html());
+ cf->set_value(theme_section, "number_color", ((Color)get("text_editor/highlighting/number_color")).to_html());
+ cf->set_value(theme_section, "symbol_color", ((Color)get("text_editor/highlighting/symbol_color")).to_html());
+ cf->set_value(theme_section, "selection_color", ((Color)get("text_editor/highlighting/selection_color")).to_html());
+ cf->set_value(theme_section, "brace_mismatch_color", ((Color)get("text_editor/highlighting/brace_mismatch_color")).to_html());
+ cf->set_value(theme_section, "current_line_color", ((Color)get("text_editor/highlighting/current_line_color")).to_html());
+ cf->set_value(theme_section, "line_length_guideline_color", ((Color)get("text_editor/highlighting/line_length_guideline_color")).to_html());
+ cf->set_value(theme_section, "mark_color", ((Color)get("text_editor/highlighting/mark_color")).to_html());
+ cf->set_value(theme_section, "breakpoint_color", ((Color)get("text_editor/highlighting/breakpoint_color")).to_html());
+ cf->set_value(theme_section, "word_highlighted_color", ((Color)get("text_editor/highlighting/word_highlighted_color")).to_html());
+ cf->set_value(theme_section, "search_result_color", ((Color)get("text_editor/highlighting/search_result_color")).to_html());
+ cf->set_value(theme_section, "search_result_border_color", ((Color)get("text_editor/highlighting/search_result_border_color")).to_html());
- _THREAD_SAFE_METHOD_
+ Error err = cf->save(p_file);
- SceneTree *sml = Object::cast_to<SceneTree>(OS::get_singleton()->get_main_loop());
+ if (err == OK) {
+ return true;
+ }
+ return false;
+}
+
+static Dictionary _get_builtin_script_templates() {
+ Dictionary templates;
+
+ //No Comments
+ templates["no_comments.gd"] =
+ "extends %BASE%\n"
+ "\n"
+ "func _ready():\n"
+ "%TS%pass\n";
+
+ //Empty
+ templates["empty.gd"] =
+ "extends %BASE%"
+ "\n"
+ "\n";
+
+ return templates;
+}
+
+static void _create_script_templates(const String &p_path) {
+
+ Dictionary templates = _get_builtin_script_templates();
+ List<Variant> keys;
+ templates.get_key_list(&keys);
+ FileAccess *file = FileAccess::create(FileAccess::ACCESS_FILESYSTEM);
+
+ DirAccess *dir = DirAccess::create(DirAccess::ACCESS_FILESYSTEM);
+ dir->change_dir(p_path);
+ for (int i = 0; i < keys.size(); i++) {
+ if (!dir->file_exists(keys[i])) {
+ Error err = file->reopen(p_path.plus_file((String)keys[i]), FileAccess::WRITE);
+ ERR_FAIL_COND(err != OK);
+ file->store_string(templates[keys[i]]);
+ file->close();
+ }
+ }
+
+ memdelete(dir);
+ memdelete(file);
+}
+
+// PUBLIC METHODS
+
+EditorSettings *EditorSettings::get_singleton() {
+
+ return singleton.ptr();
+}
+
+void EditorSettings::create() {
+
+ if (singleton.ptr())
+ return; //pointless
+
+ DirAccess *dir = NULL;
+ Variant meta;
+
+ String config_path;
+ String config_dir;
+ Ref<ConfigFile> extra_config = memnew(ConfigFile);
+
+ String exe_path = OS::get_singleton()->get_executable_path().get_base_dir();
+ DirAccess *d = DirAccess::create_for_path(exe_path);
+ bool self_contained = false;
+
+ if (d->file_exists(exe_path + "/._sc_")) {
+ self_contained = true;
+ extra_config->load(exe_path + "/._sc_");
+ } else if (d->file_exists(exe_path + "/_sc_")) {
+ self_contained = true;
+ extra_config->load(exe_path + "/_sc_");
+ }
+ memdelete(d);
+
+ if (self_contained) {
+ // editor is self contained
+ config_path = exe_path;
+ config_dir = "editor_data";
+ } else {
+
+ if (OS::get_singleton()->has_environment("APPDATA")) {
+ // Most likely under windows, save here
+ config_path = OS::get_singleton()->get_environment("APPDATA");
+ config_dir = String(_MKSTR(VERSION_SHORT_NAME)).capitalize();
+ } else if (OS::get_singleton()->has_environment("HOME")) {
+
+ config_path = OS::get_singleton()->get_environment("HOME");
+ config_dir = "." + String(_MKSTR(VERSION_SHORT_NAME)).to_lower();
+ }
+ };
+
+ ClassDB::register_class<EditorSettings>(); //otherwise it can't be unserialized
+ String config_file_path;
+
+ if (config_path != "") {
+
+ dir = DirAccess::create(DirAccess::ACCESS_FILESYSTEM);
+ if (dir->change_dir(config_path) != OK) {
+ ERR_PRINT("Cannot find path for config directory!");
+ memdelete(dir);
+ goto fail;
+ }
+
+ if (dir->change_dir(config_dir) != OK) {
+ dir->make_dir(config_dir);
+ if (dir->change_dir(config_dir) != OK) {
+ ERR_PRINT("Cannot create config directory!");
+ memdelete(dir);
+ goto fail;
+ }
+ }
+
+ if (dir->change_dir("templates") != OK) {
+ dir->make_dir("templates");
+ } else {
+
+ dir->change_dir("..");
+ }
+
+ if (dir->change_dir("text_editor_themes") != OK) {
+ dir->make_dir("text_editor_themes");
+ } else {
+ dir->change_dir("..");
+ }
+
+ if (dir->change_dir("script_templates") != OK) {
+ dir->make_dir("script_templates");
+ } else {
+ dir->change_dir("..");
+ }
+ _create_script_templates(dir->get_current_dir() + "/script_templates");
+
+ if (dir->change_dir("tmp") != OK) {
+ dir->make_dir("tmp");
+ } else {
+
+ dir->change_dir("..");
+ }
+
+ if (dir->change_dir("config") != OK) {
+ dir->make_dir("config");
+ } else {
+
+ dir->change_dir("..");
+ }
+
+ dir->change_dir("config");
+
+ String pcp = ProjectSettings::get_singleton()->get_resource_path();
+ if (pcp.ends_with("/"))
+ pcp = config_path.substr(0, pcp.size() - 1);
+ pcp = pcp.get_file() + "-" + pcp.md5_text();
+
+ if (dir->change_dir(pcp)) {
+ dir->make_dir(pcp);
+ } else {
+ dir->change_dir("..");
+ }
+
+ dir->change_dir("..");
+
+ // path at least is validated, so validate config file
+
+ String config_file_name = "editor_settings-" + String(_MKSTR(VERSION_MAJOR)) + ".tres";
+ config_file_path = config_path + "/" + config_dir + "/" + config_file_name;
+
+ String open_path = config_file_path;
+
+ if (!dir->file_exists(config_file_name)) {
+
+ goto fail;
+ }
+
+ memdelete(dir);
+
+ singleton = ResourceLoader::load(open_path, "EditorSettings");
+
+ if (singleton.is_null()) {
+ WARN_PRINT("Could not open config file.");
+ goto fail;
+ }
+
+ singleton->save_changed_setting = true;
+ singleton->config_file_path = config_file_path;
+ singleton->project_config_path = pcp;
+ singleton->settings_path = config_path + "/" + config_dir;
+
+ if (OS::get_singleton()->is_stdout_verbose()) {
+
+ print_line("EditorSettings: Load OK!");
+ }
+
+ singleton->setup_language();
+ singleton->setup_network();
+ singleton->load_favorites();
+ singleton->list_text_editor_themes();
- if (!sml) {
return;
}
- Node *root = sml->get_root()->get_child(0);
+fail:
- if (!root) {
+ // patch init projects
+ if (extra_config->has_section("init_projects")) {
+ Vector<String> list = extra_config->get_value("init_projects", "list");
+ for (int i = 0; i < list.size(); i++) {
+
+ list[i] = exe_path + "/" + list[i];
+ };
+ extra_config->set_value("init_projects", "list", list);
+ };
+
+ singleton = Ref<EditorSettings>(memnew(EditorSettings));
+ singleton->save_changed_setting = true;
+ singleton->config_file_path = config_file_path;
+ singleton->settings_path = config_path + "/" + config_dir;
+ singleton->_load_defaults(extra_config);
+ singleton->setup_language();
+ singleton->setup_network();
+ singleton->list_text_editor_themes();
+}
+
+void EditorSettings::setup_language() {
+
+ String lang = get("interface/editor/editor_language");
+ if (lang == "en")
+ return; //none to do
+
+ for (int i = 0; i < translations.size(); i++) {
+ if (translations[i]->get_locale() == lang) {
+ TranslationServer::get_singleton()->set_tool_translation(translations[i]);
+ break;
+ }
+ }
+}
+
+void EditorSettings::setup_network() {
+
+ List<IP_Address> local_ip;
+ IP::get_singleton()->get_local_addresses(&local_ip);
+ String lip = "127.0.0.1";
+ String hint;
+ String current = has_setting("network/debug/remote_host") ? get("network/debug/remote_host") : "";
+ int port = has_setting("network/debug/remote_port") ? (int)get("network/debug/remote_port") : 6007;
+
+ for (List<IP_Address>::Element *E = local_ip.front(); E; E = E->next()) {
+
+ String ip = E->get();
+
+ // link-local IPv6 addresses don't work, skipping them
+ if (ip.begins_with("fe80:0:0:0:")) // fe80::/64
+ continue;
+ if (ip == current)
+ lip = current; //so it saves
+ if (hint != "")
+ hint += ",";
+ hint += ip;
+ }
+
+ set("network/debug/remote_host", lip);
+ add_property_hint(PropertyInfo(Variant::STRING, "network/debug/remote_host", PROPERTY_HINT_ENUM, hint));
+
+ set("network/debug/remote_port", port);
+ add_property_hint(PropertyInfo(Variant::INT, "network/debug/remote_port", PROPERTY_HINT_RANGE, "1,65535,1"));
+}
+
+void EditorSettings::save() {
+
+ //_THREAD_SAFE_METHOD_
+
+ if (!singleton.ptr())
+ return;
+
+ if (singleton->config_file_path == "") {
+ ERR_PRINT("Cannot save EditorSettings config, no valid path");
return;
}
- root->propagate_notification(NOTIFICATION_EDITOR_SETTINGS_CHANGED);
+
+ Error err = ResourceSaver::save(singleton->config_file_path, singleton);
+
+ if (err != OK) {
+ ERR_PRINT("Can't Save!");
+ return;
+ }
+
+ if (OS::get_singleton()->is_stdout_verbose()) {
+ print_line("EditorSettings Save OK!");
+ }
}
-void EditorSettings::_add_property_info_bind(const Dictionary &p_info) {
+void EditorSettings::destroy() {
- ERR_FAIL_COND(!p_info.has("name"));
- ERR_FAIL_COND(!p_info.has("type"));
+ if (!singleton.ptr())
+ return;
+ save();
+ singleton = Ref<EditorSettings>();
+}
- PropertyInfo pinfo;
- pinfo.name = p_info["name"];
- ERR_FAIL_COND(!props.has(pinfo.name));
- pinfo.type = Variant::Type(p_info["type"].operator int());
- ERR_FAIL_INDEX(pinfo.type, Variant::VARIANT_MAX);
+void EditorSettings::set_optimize_save(bool p_optimize) {
- if (p_info.has("hint"))
- pinfo.hint = PropertyHint(p_info["hint"].operator int());
- if (p_info.has("hint_string"))
- pinfo.hint_string = p_info["hint_string"];
+ optimize_save = p_optimize;
+}
- add_property_hint(pinfo);
+// Properties
+
+void EditorSettings::set_setting(const String &p_setting, const Variant &p_value) {
+ _THREAD_SAFE_METHOD_
+ set(p_setting, p_value);
+}
+
+Variant EditorSettings::get_setting(const String &p_setting) const {
+ _THREAD_SAFE_METHOD_
+ return get(p_setting);
+}
+
+bool EditorSettings::has_setting(String p_var) const {
+
+ _THREAD_SAFE_METHOD_
+
+ return props.has(p_var);
+}
+
+void EditorSettings::erase(String p_var) {
+
+ _THREAD_SAFE_METHOD_
+
+ props.erase(p_var);
+}
+
+void EditorSettings::raise_order(const String &p_name) {
+ _THREAD_SAFE_METHOD_
+
+ ERR_FAIL_COND(!props.has(p_name));
+ props[p_name].order = ++last_order;
+}
+
+void EditorSettings::set_initial_value(const StringName &p_name, const Variant &p_value) {
+
+ ERR_FAIL_COND(!props.has(p_name));
+ props[p_name].initial = p_value;
+}
+
+Variant _EDITOR_DEF(const String &p_var, const Variant &p_default) {
+
+ if (EditorSettings::get_singleton()->has_setting(p_var))
+ return EditorSettings::get_singleton()->get(p_var);
+ EditorSettings::get_singleton()->set(p_var, p_default);
+ EditorSettings::get_singleton()->set_initial_value(p_var, p_default);
+
+ return p_default;
+}
+
+Variant _EDITOR_GET(const String &p_var) {
+
+ ERR_FAIL_COND_V(!EditorSettings::get_singleton()->has_setting(p_var), Variant())
+ return EditorSettings::get_singleton()->get(p_var);
+}
+
+bool EditorSettings::property_can_revert(const String &p_name) {
+
+ if (!props.has(p_name))
+ return false;
+
+ return props[p_name].initial != props[p_name].variant;
+}
+
+Variant EditorSettings::property_get_revert(const String &p_name) {
+
+ if (!props.has(p_name))
+ return Variant();
+
+ return props[p_name].initial;
}
void EditorSettings::add_property_hint(const PropertyInfo &p_hint) {
@@ -901,6 +956,36 @@ void EditorSettings::add_property_hint(const PropertyInfo &p_hint) {
hints[p_hint.name] = p_hint;
}
+// Settings paths and saved metadata
+
+String EditorSettings::get_settings_path() const {
+
+ return settings_path;
+}
+
+String EditorSettings::get_project_settings_path() const {
+
+ return get_settings_path().plus_file("config").plus_file(project_config_path);
+}
+
+void EditorSettings::set_project_metadata(const String &p_section, const String &p_key, Variant p_data) {
+ Ref<ConfigFile> cf = memnew(ConfigFile);
+ String path = get_project_settings_path().plus_file("project_metadata.cfg");
+ cf->load(path);
+ cf->set_value(p_section, p_key, p_data);
+ cf->save(path);
+}
+
+Variant EditorSettings::get_project_metadata(const String &p_section, const String &p_key, Variant p_default) {
+ Ref<ConfigFile> cf = memnew(ConfigFile);
+ String path = get_project_settings_path().plus_file("project_metadata.cfg");
+ Error err = cf->load(path);
+ if (err != OK) {
+ return p_default;
+ }
+ return cf->get_value(p_section, p_key, p_default);
+}
+
void EditorSettings::set_favorite_dirs(const Vector<String> &p_favorites_dirs) {
favorite_dirs = p_favorites_dirs;
@@ -933,11 +1018,6 @@ Vector<String> EditorSettings::get_recent_dirs() const {
return recent_dirs;
}
-String EditorSettings::get_project_settings_path() const {
-
- return get_settings_path().plus_file("config").plus_file(project_config_path);
-}
-
void EditorSettings::load_favorites() {
FileAccess *f = FileAccess::open(get_project_settings_path().plus_file("favorite_dirs"), FileAccess::READ);
@@ -1086,46 +1166,7 @@ Vector<String> EditorSettings::get_script_templates(const String &p_extension) {
return templates;
}
-bool EditorSettings::_save_text_editor_theme(String p_file) {
- String theme_section = "color_theme";
- Ref<ConfigFile> cf = memnew(ConfigFile); // hex is better?
- cf->set_value(theme_section, "background_color", ((Color)get("text_editor/highlighting/background_color")).to_html());
- cf->set_value(theme_section, "completion_background_color", ((Color)get("text_editor/highlighting/completion_background_color")).to_html());
- cf->set_value(theme_section, "completion_selected_color", ((Color)get("text_editor/highlighting/completion_selected_color")).to_html());
- cf->set_value(theme_section, "completion_existing_color", ((Color)get("text_editor/highlighting/completion_existing_color")).to_html());
- cf->set_value(theme_section, "completion_scroll_color", ((Color)get("text_editor/highlighting/completion_scroll_color")).to_html());
- cf->set_value(theme_section, "completion_font_color", ((Color)get("text_editor/highlighting/completion_font_color")).to_html());
- cf->set_value(theme_section, "caret_color", ((Color)get("text_editor/highlighting/caret_color")).to_html());
- cf->set_value(theme_section, "caret_background_color", ((Color)get("text_editor/highlighting/caret_background_color")).to_html());
- cf->set_value(theme_section, "line_number_color", ((Color)get("text_editor/highlighting/line_number_color")).to_html());
- cf->set_value(theme_section, "text_color", ((Color)get("text_editor/highlighting/text_color")).to_html());
- cf->set_value(theme_section, "text_selected_color", ((Color)get("text_editor/highlighting/text_selected_color")).to_html());
- cf->set_value(theme_section, "keyword_color", ((Color)get("text_editor/highlighting/keyword_color")).to_html());
- cf->set_value(theme_section, "base_type_color", ((Color)get("text_editor/highlighting/base_type_color")).to_html());
- cf->set_value(theme_section, "engine_type_color", ((Color)get("text_editor/highlighting/engine_type_color")).to_html());
- cf->set_value(theme_section, "function_color", ((Color)get("text_editor/highlighting/function_color")).to_html());
- cf->set_value(theme_section, "member_variable_color", ((Color)get("text_editor/highlighting/member_variable_color")).to_html());
- cf->set_value(theme_section, "comment_color", ((Color)get("text_editor/highlighting/comment_color")).to_html());
- cf->set_value(theme_section, "string_color", ((Color)get("text_editor/highlighting/string_color")).to_html());
- cf->set_value(theme_section, "number_color", ((Color)get("text_editor/highlighting/number_color")).to_html());
- cf->set_value(theme_section, "symbol_color", ((Color)get("text_editor/highlighting/symbol_color")).to_html());
- cf->set_value(theme_section, "selection_color", ((Color)get("text_editor/highlighting/selection_color")).to_html());
- cf->set_value(theme_section, "brace_mismatch_color", ((Color)get("text_editor/highlighting/brace_mismatch_color")).to_html());
- cf->set_value(theme_section, "current_line_color", ((Color)get("text_editor/highlighting/current_line_color")).to_html());
- cf->set_value(theme_section, "line_length_guideline_color", ((Color)get("text_editor/highlighting/line_length_guideline_color")).to_html());
- cf->set_value(theme_section, "mark_color", ((Color)get("text_editor/highlighting/mark_color")).to_html());
- cf->set_value(theme_section, "breakpoint_color", ((Color)get("text_editor/highlighting/breakpoint_color")).to_html());
- cf->set_value(theme_section, "word_highlighted_color", ((Color)get("text_editor/highlighting/word_highlighted_color")).to_html());
- cf->set_value(theme_section, "search_result_color", ((Color)get("text_editor/highlighting/search_result_color")).to_html());
- cf->set_value(theme_section, "search_result_border_color", ((Color)get("text_editor/highlighting/search_result_border_color")).to_html());
-
- Error err = cf->save(p_file);
-
- if (err == OK) {
- return true;
- }
- return false;
-}
+// Shortcuts
void EditorSettings::add_shortcut(const String &p_name, Ref<ShortCut> &p_shortcut) {
@@ -1160,49 +1201,64 @@ void EditorSettings::get_shortcut_list(List<String> *r_shortcuts) {
}
}
-void EditorSettings::set_optimize_save(bool p_optimize) {
+Ref<ShortCut> ED_GET_SHORTCUT(const String &p_path) {
- optimize_save = p_optimize;
+ Ref<ShortCut> sc = EditorSettings::get_singleton()->get_shortcut(p_path);
+ if (!sc.is_valid()) {
+ ERR_EXPLAIN("Used ED_GET_SHORTCUT with invalid shortcut: " + p_path);
+ ERR_FAIL_COND_V(!sc.is_valid(), sc);
+ }
+
+ return sc;
}
-Variant EditorSettings::get_project_metadata(const String &p_section, const String &p_key, Variant p_default) {
- Ref<ConfigFile> cf = memnew(ConfigFile);
- String path = get_project_settings_path().plus_file("project_metadata.cfg");
- Error err = cf->load(path);
- if (err != OK) {
- return p_default;
+Ref<ShortCut> ED_SHORTCUT(const String &p_path, const String &p_name, uint32_t p_keycode) {
+
+ Ref<InputEventKey> ie;
+ if (p_keycode) {
+ ie.instance();
+
+ ie->set_unicode(p_keycode & KEY_CODE_MASK);
+ ie->set_scancode(p_keycode & KEY_CODE_MASK);
+ ie->set_shift(bool(p_keycode & KEY_MASK_SHIFT));
+ ie->set_alt(bool(p_keycode & KEY_MASK_ALT));
+ ie->set_control(bool(p_keycode & KEY_MASK_CTRL));
+ ie->set_metakey(bool(p_keycode & KEY_MASK_META));
}
- return cf->get_value(p_section, p_key, p_default);
-}
-void EditorSettings::set_project_metadata(const String &p_section, const String &p_key, Variant p_data) {
- Ref<ConfigFile> cf = memnew(ConfigFile);
- String path = get_project_settings_path().plus_file("project_metadata.cfg");
- cf->load(path);
- cf->set_value(p_section, p_key, p_data);
- cf->save(path);
-}
+ Ref<ShortCut> sc = EditorSettings::get_singleton()->get_shortcut(p_path);
+ if (sc.is_valid()) {
-bool EditorSettings::property_can_revert(const String &p_name) {
+ sc->set_name(p_name); //keep name (the ones that come from disk have no name)
+ sc->set_meta("original", ie); //to compare against changes
+ return sc;
+ }
- if (!props.has(p_name))
- return false;
+ sc.instance();
+ sc->set_name(p_name);
+ sc->set_shortcut(ie);
+ sc->set_meta("original", ie); //to compare against changes
+ EditorSettings::get_singleton()->add_shortcut(p_path, sc);
- return props[p_name].initial != props[p_name].variant;
+ return sc;
}
-Variant EditorSettings::property_get_revert(const String &p_name) {
+void EditorSettings::notify_changes() {
- if (!props.has(p_name))
- return Variant();
+ _THREAD_SAFE_METHOD_
- return props[p_name].initial;
-}
+ SceneTree *sml = Object::cast_to<SceneTree>(OS::get_singleton()->get_main_loop());
-void EditorSettings::set_initial_value(const StringName &p_name, const Variant &p_value) {
+ if (!sml) {
+ return;
+ }
- ERR_FAIL_COND(!props.has(p_name));
- props[p_name].initial = p_value;
+ Node *root = sml->get_root()->get_child(0);
+
+ if (!root) {
+ return;
+ }
+ root->propagate_notification(NOTIFICATION_EDITOR_SETTINGS_CHANGED);
}
void EditorSettings::_bind_methods() {
@@ -1210,24 +1266,20 @@ void EditorSettings::_bind_methods() {
ClassDB::bind_method(D_METHOD("has_setting", "name"), &EditorSettings::has_setting);
ClassDB::bind_method(D_METHOD("set_setting", "name", "value"), &EditorSettings::set_setting);
ClassDB::bind_method(D_METHOD("get_setting", "name"), &EditorSettings::get_setting);
-
ClassDB::bind_method(D_METHOD("erase", "property"), &EditorSettings::erase);
+ ClassDB::bind_method(D_METHOD("set_initial_value", "name", "value"), &EditorSettings::set_initial_value);
+ ClassDB::bind_method(D_METHOD("property_can_revert", "name"), &EditorSettings::property_can_revert);
+ ClassDB::bind_method(D_METHOD("property_get_revert", "name"), &EditorSettings::property_get_revert);
+ ClassDB::bind_method(D_METHOD("add_property_info", "info"), &EditorSettings::_add_property_info_bind);
+
ClassDB::bind_method(D_METHOD("get_settings_path"), &EditorSettings::get_settings_path);
ClassDB::bind_method(D_METHOD("get_project_settings_path"), &EditorSettings::get_project_settings_path);
- ClassDB::bind_method(D_METHOD("add_property_info", "info"), &EditorSettings::_add_property_info_bind);
-
ClassDB::bind_method(D_METHOD("set_favorite_dirs", "dirs"), &EditorSettings::set_favorite_dirs);
ClassDB::bind_method(D_METHOD("get_favorite_dirs"), &EditorSettings::get_favorite_dirs);
-
ClassDB::bind_method(D_METHOD("set_recent_dirs", "dirs"), &EditorSettings::set_recent_dirs);
ClassDB::bind_method(D_METHOD("get_recent_dirs"), &EditorSettings::get_recent_dirs);
- ClassDB::bind_method(D_METHOD("property_can_revert", "name"), &EditorSettings::property_can_revert);
- ClassDB::bind_method(D_METHOD("property_get_revert", "name"), &EditorSettings::property_get_revert);
-
- ClassDB::bind_method(D_METHOD("set_initial_value", "name", "value"), &EditorSettings::set_initial_value);
-
ADD_SIGNAL(MethodInfo("settings_changed"));
}
@@ -1263,45 +1315,3 @@ EditorSettings::EditorSettings() {
EditorSettings::~EditorSettings() {
}
-
-Ref<ShortCut> ED_GET_SHORTCUT(const String &p_path) {
-
- Ref<ShortCut> sc = EditorSettings::get_singleton()->get_shortcut(p_path);
- if (!sc.is_valid()) {
- ERR_EXPLAIN("Used ED_GET_SHORTCUT with invalid shortcut: " + p_path);
- ERR_FAIL_COND_V(!sc.is_valid(), sc);
- }
-
- return sc;
-}
-
-Ref<ShortCut> ED_SHORTCUT(const String &p_path, const String &p_name, uint32_t p_keycode) {
-
- Ref<InputEventKey> ie;
- if (p_keycode) {
- ie.instance();
-
- ie->set_unicode(p_keycode & KEY_CODE_MASK);
- ie->set_scancode(p_keycode & KEY_CODE_MASK);
- ie->set_shift(bool(p_keycode & KEY_MASK_SHIFT));
- ie->set_alt(bool(p_keycode & KEY_MASK_ALT));
- ie->set_control(bool(p_keycode & KEY_MASK_CTRL));
- ie->set_metakey(bool(p_keycode & KEY_MASK_META));
- }
-
- Ref<ShortCut> sc = EditorSettings::get_singleton()->get_shortcut(p_path);
- if (sc.is_valid()) {
-
- sc->set_name(p_name); //keep name (the ones that come from disk have no name)
- sc->set_meta("original", ie); //to compare against changes
- return sc;
- }
-
- sc.instance();
- sc->set_name(p_name);
- sc->set_shortcut(ie);
- sc->set_meta("original", ie); //to compare against changes
- EditorSettings::get_singleton()->add_shortcut(p_path, sc);
-
- return sc;
-}
diff --git a/editor/editor_settings.h b/editor/editor_settings.h
index c5d2670650..cb6981f9e1 100644
--- a/editor/editor_settings.h
+++ b/editor/editor_settings.h
@@ -80,44 +80,37 @@ private:
}
};
+ static Ref<EditorSettings> singleton;
+
HashMap<String, PropertyInfo> hints;
- int last_order;
HashMap<String, VariantContainer> props;
- String resource_path;
-
- bool _set(const StringName &p_name, const Variant &p_value, bool p_emit_signal = true);
- bool _get(const StringName &p_name, Variant &r_ret) const;
- void _get_property_list(List<PropertyInfo> *p_list) const;
-
- void _initial_set(const StringName &p_name, const Variant &p_value);
+ int last_order;
- static Ref<EditorSettings> singleton;
+ Ref<Resource> clipboard;
+ Vector<Ref<Translation> > translations;
+ Map<String, Ref<ShortCut> > shortcuts;
+ String resource_path;
String config_file_path;
String settings_path;
+ String project_config_path;
- Ref<Resource> clipboard;
+ Vector<String> favorite_dirs;
+ Vector<String> recent_dirs;
bool save_changed_setting;
-
bool optimize_save; //do not save stuff that came from config but was not set from engine
+ bool _set(const StringName &p_name, const Variant &p_value, bool p_emit_signal = true);
+ bool _get(const StringName &p_name, Variant &r_ret) const;
+ void _initial_set(const StringName &p_name, const Variant &p_value);
+ void _get_property_list(List<PropertyInfo> *p_list) const;
+ void _add_property_info_bind(const Dictionary &p_info);
+
void _load_defaults(Ref<ConfigFile> p_extra_config = NULL);
void _load_default_text_editor_theme();
-
bool _save_text_editor_theme(String p_file);
- String project_config_path;
-
- Vector<String> favorite_dirs;
- Vector<String> recent_dirs;
-
- Vector<Ref<Translation> > translations;
-
- Map<String, Ref<ShortCut> > shortcuts;
-
- void _add_property_info_bind(const Dictionary &p_info);
-
protected:
static void _bind_methods();
@@ -126,41 +119,41 @@ public:
NOTIFICATION_EDITOR_SETTINGS_CHANGED = 10000
};
- void set_manually(const StringName &p_name, const Variant &p_value, bool p_emit_signal = false) {
- _set(p_name, p_value, p_emit_signal);
- }
-
- void set_setting(const String &p_setting, const Variant &p_value);
- Variant get_setting(const String &p_setting) const;
-
- bool has_setting(String p_var) const;
static EditorSettings *get_singleton();
- void erase(String p_var);
- String get_settings_path() const;
- //String get_global_settings_path() const;
- String get_project_settings_path() const;
+ static void create();
void setup_language();
void setup_network();
-
- void raise_order(const String &p_name);
- static void create();
static void save();
static void destroy();
+ void set_optimize_save(bool p_optimize);
- void notify_changes();
+ void set_setting(const String &p_setting, const Variant &p_value);
+ Variant get_setting(const String &p_setting) const;
+ bool has_setting(String p_var) const;
+ void erase(String p_var);
+ void raise_order(const String &p_name);
+ void set_initial_value(const StringName &p_name, const Variant &p_value);
+ void set_manually(const StringName &p_name, const Variant &p_value, bool p_emit_signal = false) {
+ _set(p_name, p_value, p_emit_signal);
+ }
+ bool property_can_revert(const String &p_name);
+ Variant property_get_revert(const String &p_name);
+ void add_property_hint(const PropertyInfo &p_hint);
void set_resource_clipboard(const Ref<Resource> &p_resource) { clipboard = p_resource; }
Ref<Resource> get_resource_clipboard() const { return clipboard; }
- void add_property_hint(const PropertyInfo &p_hint);
+ String get_settings_path() const;
+ String get_project_settings_path() const;
+
+ void set_project_metadata(const String &p_section, const String &p_key, Variant p_data);
+ Variant get_project_metadata(const String &p_section, const String &p_key, Variant p_default);
void set_favorite_dirs(const Vector<String> &p_favorites_dirs);
Vector<String> get_favorite_dirs() const;
-
void set_recent_dirs(const Vector<String> &p_recent_dirs);
Vector<String> get_recent_dirs() const;
-
void load_favorites();
void list_text_editor_themes();
@@ -176,15 +169,7 @@ public:
Ref<ShortCut> get_shortcut(const String &p_name) const;
void get_shortcut_list(List<String> *r_shortcuts);
- void set_optimize_save(bool p_optimize);
-
- Variant get_project_metadata(const String &p_section, const String &p_key, Variant p_default);
- void set_project_metadata(const String &p_section, const String &p_key, Variant p_data);
-
- bool property_can_revert(const String &p_name);
- Variant property_get_revert(const String &p_name);
-
- void set_initial_value(const StringName &p_name, const Variant &p_value);
+ void notify_changes();
EditorSettings();
~EditorSettings();