| 1 | /**************************************************************************/ | 
|---|
| 2 | /*  project_settings.h                                                    */ | 
|---|
| 3 | /**************************************************************************/ | 
|---|
| 4 | /*                         This file is part of:                          */ | 
|---|
| 5 | /*                             GODOT ENGINE                               */ | 
|---|
| 6 | /*                        https://godotengine.org                         */ | 
|---|
| 7 | /**************************************************************************/ | 
|---|
| 8 | /* Copyright (c) 2014-present Godot Engine contributors (see AUTHORS.md). */ | 
|---|
| 9 | /* Copyright (c) 2007-2014 Juan Linietsky, Ariel Manzur.                  */ | 
|---|
| 10 | /*                                                                        */ | 
|---|
| 11 | /* Permission is hereby granted, free of charge, to any person obtaining  */ | 
|---|
| 12 | /* a copy of this software and associated documentation files (the        */ | 
|---|
| 13 | /* "Software"), to deal in the Software without restriction, including    */ | 
|---|
| 14 | /* without limitation the rights to use, copy, modify, merge, publish,    */ | 
|---|
| 15 | /* distribute, sublicense, and/or sell copies of the Software, and to     */ | 
|---|
| 16 | /* permit persons to whom the Software is furnished to do so, subject to  */ | 
|---|
| 17 | /* the following conditions:                                              */ | 
|---|
| 18 | /*                                                                        */ | 
|---|
| 19 | /* The above copyright notice and this permission notice shall be         */ | 
|---|
| 20 | /* included in all copies or substantial portions of the Software.        */ | 
|---|
| 21 | /*                                                                        */ | 
|---|
| 22 | /* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,        */ | 
|---|
| 23 | /* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF     */ | 
|---|
| 24 | /* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. */ | 
|---|
| 25 | /* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY   */ | 
|---|
| 26 | /* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,   */ | 
|---|
| 27 | /* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE      */ | 
|---|
| 28 | /* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.                 */ | 
|---|
| 29 | /**************************************************************************/ | 
|---|
| 30 |  | 
|---|
| 31 | #ifndef PROJECT_SETTINGS_H | 
|---|
| 32 | #define PROJECT_SETTINGS_H | 
|---|
| 33 |  | 
|---|
| 34 | #include "core/object/class_db.h" | 
|---|
| 35 | #include "core/os/thread_safe.h" | 
|---|
| 36 | #include "core/templates/hash_map.h" | 
|---|
| 37 | #include "core/templates/local_vector.h" | 
|---|
| 38 | #include "core/templates/rb_set.h" | 
|---|
| 39 |  | 
|---|
| 40 | template <typename T> | 
|---|
| 41 | class TypedArray; | 
|---|
| 42 |  | 
|---|
| 43 | class ProjectSettings : public Object { | 
|---|
| 44 | GDCLASS(ProjectSettings, Object); | 
|---|
| 45 | _THREAD_SAFE_CLASS_ | 
|---|
| 46 | friend class TestProjectSettingsInternalsAccessor; | 
|---|
| 47 |  | 
|---|
| 48 | bool is_changed = false; | 
|---|
| 49 |  | 
|---|
| 50 | public: | 
|---|
| 51 | typedef HashMap<String, Variant> CustomMap; | 
|---|
| 52 | static const String PROJECT_DATA_DIR_NAME_SUFFIX; | 
|---|
| 53 |  | 
|---|
| 54 | enum { | 
|---|
| 55 | // Properties that are not for built in values begin from this value, so builtin ones are displayed first. | 
|---|
| 56 | NO_BUILTIN_ORDER_BASE = 1 << 16 | 
|---|
| 57 | }; | 
|---|
| 58 |  | 
|---|
| 59 | #ifdef TOOLS_ENABLED | 
|---|
| 60 | const static PackedStringArray get_required_features(); | 
|---|
| 61 | const static PackedStringArray get_unsupported_features(const PackedStringArray &p_project_features); | 
|---|
| 62 | #endif // TOOLS_ENABLED | 
|---|
| 63 |  | 
|---|
| 64 | struct AutoloadInfo { | 
|---|
| 65 | StringName name; | 
|---|
| 66 | String path; | 
|---|
| 67 | bool is_singleton = false; | 
|---|
| 68 | }; | 
|---|
| 69 |  | 
|---|
| 70 | protected: | 
|---|
| 71 | struct VariantContainer { | 
|---|
| 72 | int order = 0; | 
|---|
| 73 | bool persist = false; | 
|---|
| 74 | bool basic = false; | 
|---|
| 75 | bool internal = false; | 
|---|
| 76 | Variant variant; | 
|---|
| 77 | Variant initial; | 
|---|
| 78 | bool hide_from_editor = false; | 
|---|
| 79 | bool restart_if_changed = false; | 
|---|
| 80 | #ifdef DEBUG_METHODS_ENABLED | 
|---|
| 81 | bool ignore_value_in_docs = false; | 
|---|
| 82 | #endif | 
|---|
| 83 |  | 
|---|
| 84 | VariantContainer() {} | 
|---|
| 85 |  | 
|---|
| 86 | VariantContainer(const Variant &p_variant, int p_order, bool p_persist = false) : | 
|---|
| 87 | order(p_order), | 
|---|
| 88 | persist(p_persist), | 
|---|
| 89 | variant(p_variant) { | 
|---|
| 90 | } | 
|---|
| 91 | }; | 
|---|
| 92 |  | 
|---|
| 93 | int last_order = NO_BUILTIN_ORDER_BASE; | 
|---|
| 94 | int last_builtin_order = 0; | 
|---|
| 95 | uint64_t last_save_time = 0; | 
|---|
| 96 |  | 
|---|
| 97 | RBMap<StringName, VariantContainer> props; // NOTE: Key order is used e.g. in the save_custom method. | 
|---|
| 98 | String resource_path; | 
|---|
| 99 | HashMap<StringName, PropertyInfo> custom_prop_info; | 
|---|
| 100 | bool using_datapack = false; | 
|---|
| 101 | bool project_loaded = false; | 
|---|
| 102 | List<String> input_presets; | 
|---|
| 103 |  | 
|---|
| 104 | HashSet<String> custom_features; | 
|---|
| 105 | HashMap<StringName, LocalVector<Pair<StringName, StringName>>> feature_overrides; | 
|---|
| 106 |  | 
|---|
| 107 | LocalVector<String> hidden_prefixes; | 
|---|
| 108 | HashMap<StringName, AutoloadInfo> autoloads; | 
|---|
| 109 |  | 
|---|
| 110 | Array global_class_list; | 
|---|
| 111 | bool is_global_class_list_loaded = false; | 
|---|
| 112 |  | 
|---|
| 113 | String project_data_dir_name; | 
|---|
| 114 |  | 
|---|
| 115 | bool _set(const StringName &p_name, const Variant &p_value); | 
|---|
| 116 | bool _get(const StringName &p_name, Variant &r_ret) const; | 
|---|
| 117 | void _get_property_list(List<PropertyInfo> *p_list) const; | 
|---|
| 118 | bool _property_can_revert(const StringName &p_name) const; | 
|---|
| 119 | bool _property_get_revert(const StringName &p_name, Variant &r_property) const; | 
|---|
| 120 |  | 
|---|
| 121 | void _queue_changed(); | 
|---|
| 122 | void _emit_changed(); | 
|---|
| 123 |  | 
|---|
| 124 | static ProjectSettings *singleton; | 
|---|
| 125 |  | 
|---|
| 126 | Error _load_settings_text(const String &p_path); | 
|---|
| 127 | Error _load_settings_binary(const String &p_path); | 
|---|
| 128 | Error _load_settings_text_or_binary(const String &p_text_path, const String &p_bin_path); | 
|---|
| 129 |  | 
|---|
| 130 | Error _save_settings_text(const String &p_file, const RBMap<String, List<String>> &props, const CustomMap &p_custom = CustomMap(), const String &p_custom_features = String()); | 
|---|
| 131 | Error _save_settings_binary(const String &p_file, const RBMap<String, List<String>> &props, const CustomMap &p_custom = CustomMap(), const String &p_custom_features = String()); | 
|---|
| 132 |  | 
|---|
| 133 | Error _save_custom_bnd(const String &p_file); | 
|---|
| 134 |  | 
|---|
| 135 | #ifdef TOOLS_ENABLED | 
|---|
| 136 | const static PackedStringArray _get_supported_features(); | 
|---|
| 137 | const static PackedStringArray _trim_to_supported_features(const PackedStringArray &p_project_features); | 
|---|
| 138 | #endif // TOOLS_ENABLED | 
|---|
| 139 |  | 
|---|
| 140 | void _convert_to_last_version(int p_from_version); | 
|---|
| 141 |  | 
|---|
| 142 | bool _load_resource_pack(const String &p_pack, bool p_replace_files = true, int p_offset = 0); | 
|---|
| 143 |  | 
|---|
| 144 | void _add_property_info_bind(const Dictionary &p_info); | 
|---|
| 145 |  | 
|---|
| 146 | Error _setup(const String &p_path, const String &p_main_pack, bool p_upwards = false, bool p_ignore_override = false); | 
|---|
| 147 |  | 
|---|
| 148 | void _add_builtin_input_map(); | 
|---|
| 149 |  | 
|---|
| 150 | protected: | 
|---|
| 151 | static void _bind_methods(); | 
|---|
| 152 |  | 
|---|
| 153 | public: | 
|---|
| 154 | static const int CONFIG_VERSION = 5; | 
|---|
| 155 |  | 
|---|
| 156 | void set_setting(const String &p_setting, const Variant &p_value); | 
|---|
| 157 | Variant get_setting(const String &p_setting, const Variant &p_default_value = Variant()) const; | 
|---|
| 158 | TypedArray<Dictionary> get_global_class_list(); | 
|---|
| 159 | void store_global_class_list(const Array &p_classes); | 
|---|
| 160 | String get_global_class_list_path() const; | 
|---|
| 161 |  | 
|---|
| 162 | bool has_setting(String p_var) const; | 
|---|
| 163 | String localize_path(const String &p_path) const; | 
|---|
| 164 | String globalize_path(const String &p_path) const; | 
|---|
| 165 |  | 
|---|
| 166 | void set_initial_value(const String &p_name, const Variant &p_value); | 
|---|
| 167 | void set_as_basic(const String &p_name, bool p_basic); | 
|---|
| 168 | void set_as_internal(const String &p_name, bool p_internal); | 
|---|
| 169 | void set_restart_if_changed(const String &p_name, bool p_restart); | 
|---|
| 170 | void set_ignore_value_in_docs(const String &p_name, bool p_ignore); | 
|---|
| 171 | bool get_ignore_value_in_docs(const String &p_name) const; | 
|---|
| 172 | void add_hidden_prefix(const String &p_prefix); | 
|---|
| 173 |  | 
|---|
| 174 | String get_project_data_dir_name() const; | 
|---|
| 175 | String get_project_data_path() const; | 
|---|
| 176 | String get_resource_path() const; | 
|---|
| 177 | String get_imported_files_path() const; | 
|---|
| 178 |  | 
|---|
| 179 | static ProjectSettings *get_singleton(); | 
|---|
| 180 |  | 
|---|
| 181 | void clear(const String &p_name); | 
|---|
| 182 | int get_order(const String &p_name) const; | 
|---|
| 183 | void set_order(const String &p_name, int p_order); | 
|---|
| 184 | void set_builtin_order(const String &p_name); | 
|---|
| 185 | bool is_builtin_setting(const String &p_name) const; | 
|---|
| 186 |  | 
|---|
| 187 | Error setup(const String &p_path, const String &p_main_pack, bool p_upwards = false, bool p_ignore_override = false); | 
|---|
| 188 |  | 
|---|
| 189 | Error load_custom(const String &p_path); | 
|---|
| 190 | Error save_custom(const String &p_path = "", const CustomMap &p_custom = CustomMap(), const Vector<String> &p_custom_features = Vector<String>(), bool p_merge_with_current = true); | 
|---|
| 191 | Error save(); | 
|---|
| 192 | void set_custom_property_info(const PropertyInfo &p_info); | 
|---|
| 193 | const HashMap<StringName, PropertyInfo> &get_custom_property_info() const; | 
|---|
| 194 | uint64_t get_last_saved_time() { return last_save_time; } | 
|---|
| 195 |  | 
|---|
| 196 | List<String> get_input_presets() const { return input_presets; } | 
|---|
| 197 |  | 
|---|
| 198 | Variant get_setting_with_override(const StringName &p_name) const; | 
|---|
| 199 |  | 
|---|
| 200 | bool is_using_datapack() const; | 
|---|
| 201 | bool is_project_loaded() const; | 
|---|
| 202 |  | 
|---|
| 203 | bool has_custom_feature(const String &p_feature) const; | 
|---|
| 204 |  | 
|---|
| 205 | const HashMap<StringName, AutoloadInfo> &get_autoload_list() const; | 
|---|
| 206 | void add_autoload(const AutoloadInfo &p_autoload); | 
|---|
| 207 | void remove_autoload(const StringName &p_autoload); | 
|---|
| 208 | bool has_autoload(const StringName &p_autoload) const; | 
|---|
| 209 | AutoloadInfo get_autoload(const StringName &p_name) const; | 
|---|
| 210 |  | 
|---|
| 211 | ProjectSettings(); | 
|---|
| 212 | ~ProjectSettings(); | 
|---|
| 213 | }; | 
|---|
| 214 |  | 
|---|
| 215 | // Not a macro any longer. | 
|---|
| 216 | Variant _GLOBAL_DEF(const String &p_var, const Variant &p_default, bool p_restart_if_changed = false, bool p_ignore_value_in_docs = false, bool p_basic = false, bool p_internal = false); | 
|---|
| 217 | Variant _GLOBAL_DEF(const PropertyInfo &p_info, const Variant &p_default, bool p_restart_if_changed = false, bool p_ignore_value_in_docs = false, bool p_basic = false, bool p_internal = false); | 
|---|
| 218 |  | 
|---|
| 219 | #define GLOBAL_DEF(m_var, m_value) _GLOBAL_DEF(m_var, m_value) | 
|---|
| 220 | #define GLOBAL_DEF_RST(m_var, m_value) _GLOBAL_DEF(m_var, m_value, true) | 
|---|
| 221 | #define GLOBAL_DEF_NOVAL(m_var, m_value) _GLOBAL_DEF(m_var, m_value, false, true) | 
|---|
| 222 | #define GLOBAL_DEF_RST_NOVAL(m_var, m_value) _GLOBAL_DEF(m_var, m_value, true, true) | 
|---|
| 223 | #define GLOBAL_GET(m_var) ProjectSettings::get_singleton()->get_setting_with_override(m_var) | 
|---|
| 224 |  | 
|---|
| 225 | #define GLOBAL_DEF_BASIC(m_var, m_value) _GLOBAL_DEF(m_var, m_value, false, false, true) | 
|---|
| 226 | #define GLOBAL_DEF_RST_BASIC(m_var, m_value) _GLOBAL_DEF(m_var, m_value, true, false, true) | 
|---|
| 227 | #define GLOBAL_DEF_NOVAL_BASIC(m_var, m_value) _GLOBAL_DEF(m_var, m_value, false, true, true) | 
|---|
| 228 | #define GLOBAL_DEF_RST_NOVAL_BASIC(m_var, m_value) _GLOBAL_DEF(m_var, m_value, true, true, true) | 
|---|
| 229 |  | 
|---|
| 230 | #define GLOBAL_DEF_INTERNAL(m_var, m_value) _GLOBAL_DEF(m_var, m_value, false, false, false, true) | 
|---|
| 231 |  | 
|---|
| 232 | #endif // PROJECT_SETTINGS_H | 
|---|
| 233 |  | 
|---|