Improve resource load cache
-Added a new method in Resource: reset_state , used for reloading the same resource from disk -Added a new cache mode "replace" in ResourceLoader, which reuses existing loaded sub-resources but resets their data from disk (or replaces them if they chaged type) -Because the correct sub-resource paths are always loaded now, this fixes bugs with subresource folding or subresource ordering when saving.
This commit is contained in:
parent
e5bb89cdd5
commit
f8d03b98e7
|
@ -86,9 +86,9 @@ RES _ResourceLoader::load_threaded_get(const String &p_path) {
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
RES _ResourceLoader::load(const String &p_path, const String &p_type_hint, bool p_no_cache) {
|
RES _ResourceLoader::load(const String &p_path, const String &p_type_hint, CacheMode p_cache_mode) {
|
||||||
Error err = OK;
|
Error err = OK;
|
||||||
RES ret = ResourceLoader::load(p_path, p_type_hint, p_no_cache, &err);
|
RES ret = ResourceLoader::load(p_path, p_type_hint, ResourceFormatLoader::CacheMode(p_cache_mode), &err);
|
||||||
|
|
||||||
ERR_FAIL_COND_V_MSG(err != OK, ret, "Error loading resource: '" + p_path + "'.");
|
ERR_FAIL_COND_V_MSG(err != OK, ret, "Error loading resource: '" + p_path + "'.");
|
||||||
return ret;
|
return ret;
|
||||||
|
@ -135,7 +135,7 @@ void _ResourceLoader::_bind_methods() {
|
||||||
ClassDB::bind_method(D_METHOD("load_threaded_get_status", "path", "progress"), &_ResourceLoader::load_threaded_get_status, DEFVAL(Array()));
|
ClassDB::bind_method(D_METHOD("load_threaded_get_status", "path", "progress"), &_ResourceLoader::load_threaded_get_status, DEFVAL(Array()));
|
||||||
ClassDB::bind_method(D_METHOD("load_threaded_get", "path"), &_ResourceLoader::load_threaded_get);
|
ClassDB::bind_method(D_METHOD("load_threaded_get", "path"), &_ResourceLoader::load_threaded_get);
|
||||||
|
|
||||||
ClassDB::bind_method(D_METHOD("load", "path", "type_hint", "no_cache"), &_ResourceLoader::load, DEFVAL(""), DEFVAL(false));
|
ClassDB::bind_method(D_METHOD("load", "path", "type_hint", "no_cache"), &_ResourceLoader::load, DEFVAL(""), DEFVAL(CACHE_MODE_REUSE));
|
||||||
ClassDB::bind_method(D_METHOD("get_recognized_extensions_for_type", "type"), &_ResourceLoader::get_recognized_extensions_for_type);
|
ClassDB::bind_method(D_METHOD("get_recognized_extensions_for_type", "type"), &_ResourceLoader::get_recognized_extensions_for_type);
|
||||||
ClassDB::bind_method(D_METHOD("set_abort_on_missing_resources", "abort"), &_ResourceLoader::set_abort_on_missing_resources);
|
ClassDB::bind_method(D_METHOD("set_abort_on_missing_resources", "abort"), &_ResourceLoader::set_abort_on_missing_resources);
|
||||||
ClassDB::bind_method(D_METHOD("get_dependencies", "path"), &_ResourceLoader::get_dependencies);
|
ClassDB::bind_method(D_METHOD("get_dependencies", "path"), &_ResourceLoader::get_dependencies);
|
||||||
|
@ -146,6 +146,10 @@ void _ResourceLoader::_bind_methods() {
|
||||||
BIND_ENUM_CONSTANT(THREAD_LOAD_IN_PROGRESS);
|
BIND_ENUM_CONSTANT(THREAD_LOAD_IN_PROGRESS);
|
||||||
BIND_ENUM_CONSTANT(THREAD_LOAD_FAILED);
|
BIND_ENUM_CONSTANT(THREAD_LOAD_FAILED);
|
||||||
BIND_ENUM_CONSTANT(THREAD_LOAD_LOADED);
|
BIND_ENUM_CONSTANT(THREAD_LOAD_LOADED);
|
||||||
|
|
||||||
|
BIND_ENUM_CONSTANT(CACHE_MODE_IGNORE);
|
||||||
|
BIND_ENUM_CONSTANT(CACHE_MODE_REUSE);
|
||||||
|
BIND_ENUM_CONSTANT(CACHE_MODE_REPLACE);
|
||||||
}
|
}
|
||||||
|
|
||||||
////// _ResourceSaver //////
|
////// _ResourceSaver //////
|
||||||
|
|
|
@ -56,13 +56,19 @@ public:
|
||||||
THREAD_LOAD_LOADED
|
THREAD_LOAD_LOADED
|
||||||
};
|
};
|
||||||
|
|
||||||
|
enum CacheMode {
|
||||||
|
CACHE_MODE_IGNORE, //resource and subresources do not use path cache, no path is set into resource.
|
||||||
|
CACHE_MODE_REUSE, //resource and subresources use patch cache, reuse existing loaded resources instead of loading from disk when available
|
||||||
|
CACHE_MODE_REPLACE, //resource and and subresource use path cache, but replace existing loaded resources when available with information from disk
|
||||||
|
};
|
||||||
|
|
||||||
static _ResourceLoader *get_singleton() { return singleton; }
|
static _ResourceLoader *get_singleton() { return singleton; }
|
||||||
|
|
||||||
Error load_threaded_request(const String &p_path, const String &p_type_hint = "", bool p_use_sub_threads = false);
|
Error load_threaded_request(const String &p_path, const String &p_type_hint = "", bool p_use_sub_threads = false);
|
||||||
ThreadLoadStatus load_threaded_get_status(const String &p_path, Array r_progress = Array());
|
ThreadLoadStatus load_threaded_get_status(const String &p_path, Array r_progress = Array());
|
||||||
RES load_threaded_get(const String &p_path);
|
RES load_threaded_get(const String &p_path);
|
||||||
|
|
||||||
RES load(const String &p_path, const String &p_type_hint = "", bool p_no_cache = false);
|
RES load(const String &p_path, const String &p_type_hint = "", CacheMode p_cache_mode = CACHE_MODE_REUSE);
|
||||||
Vector<String> get_recognized_extensions_for_type(const String &p_type);
|
Vector<String> get_recognized_extensions_for_type(const String &p_type);
|
||||||
void set_abort_on_missing_resources(bool p_abort);
|
void set_abort_on_missing_resources(bool p_abort);
|
||||||
PackedStringArray get_dependencies(const String &p_path);
|
PackedStringArray get_dependencies(const String &p_path);
|
||||||
|
@ -73,6 +79,7 @@ public:
|
||||||
};
|
};
|
||||||
|
|
||||||
VARIANT_ENUM_CAST(_ResourceLoader::ThreadLoadStatus);
|
VARIANT_ENUM_CAST(_ResourceLoader::ThreadLoadStatus);
|
||||||
|
VARIANT_ENUM_CAST(_ResourceLoader::CacheMode);
|
||||||
|
|
||||||
class _ResourceSaver : public Object {
|
class _ResourceSaver : public Object {
|
||||||
GDCLASS(_ResourceSaver, Object);
|
GDCLASS(_ResourceSaver, Object);
|
||||||
|
|
|
@ -141,7 +141,7 @@ void Crypto::_bind_methods() {
|
||||||
|
|
||||||
/// Resource loader/saver
|
/// Resource loader/saver
|
||||||
|
|
||||||
RES ResourceFormatLoaderCrypto::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, bool p_no_cache) {
|
RES ResourceFormatLoaderCrypto::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, CacheMode p_cache_mode) {
|
||||||
String el = p_path.get_extension().to_lower();
|
String el = p_path.get_extension().to_lower();
|
||||||
if (el == "crt") {
|
if (el == "crt") {
|
||||||
X509Certificate *cert = X509Certificate::create();
|
X509Certificate *cert = X509Certificate::create();
|
||||||
|
|
|
@ -116,7 +116,7 @@ public:
|
||||||
|
|
||||||
class ResourceFormatLoaderCrypto : public ResourceFormatLoader {
|
class ResourceFormatLoaderCrypto : public ResourceFormatLoader {
|
||||||
public:
|
public:
|
||||||
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, bool p_no_cache = false);
|
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, CacheMode p_cache_mode = CACHE_MODE_REUSE);
|
||||||
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
||||||
virtual bool handles_type(const String &p_type) const;
|
virtual bool handles_type(const String &p_type) const;
|
||||||
virtual String get_resource_type(const String &p_path) const;
|
virtual String get_resource_type(const String &p_path) const;
|
||||||
|
|
|
@ -122,7 +122,7 @@ void ImageLoader::cleanup() {
|
||||||
|
|
||||||
/////////////////
|
/////////////////
|
||||||
|
|
||||||
RES ResourceFormatLoaderImage::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, bool p_no_cache) {
|
RES ResourceFormatLoaderImage::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, CacheMode p_cache_mode) {
|
||||||
FileAccess *f = FileAccess::open(p_path, FileAccess::READ);
|
FileAccess *f = FileAccess::open(p_path, FileAccess::READ);
|
||||||
if (!f) {
|
if (!f) {
|
||||||
if (r_error) {
|
if (r_error) {
|
||||||
|
|
|
@ -72,7 +72,7 @@ public:
|
||||||
|
|
||||||
class ResourceFormatLoaderImage : public ResourceFormatLoader {
|
class ResourceFormatLoaderImage : public ResourceFormatLoader {
|
||||||
public:
|
public:
|
||||||
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, bool p_no_cache = false);
|
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, CacheMode p_cache_mode = CACHE_MODE_REUSE);
|
||||||
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
||||||
virtual bool handles_type(const String &p_type) const;
|
virtual bool handles_type(const String &p_type) const;
|
||||||
virtual String get_resource_type(const String &p_path) const;
|
virtual String get_resource_type(const String &p_path) const;
|
||||||
|
|
|
@ -114,20 +114,18 @@ bool Resource::editor_can_reload_from_file() {
|
||||||
return true; //by default yes
|
return true; //by default yes
|
||||||
}
|
}
|
||||||
|
|
||||||
void Resource::reload_from_file() {
|
void Resource::reset_state() {
|
||||||
String path = get_path();
|
}
|
||||||
if (!path.is_resource_file()) {
|
Error Resource::copy_from(const Ref<Resource> &p_resource) {
|
||||||
return;
|
ERR_FAIL_COND_V(p_resource.is_null(), ERR_INVALID_PARAMETER);
|
||||||
|
if (get_class() != p_resource->get_class()) {
|
||||||
|
return ERR_INVALID_PARAMETER;
|
||||||
}
|
}
|
||||||
|
|
||||||
Ref<Resource> s = ResourceLoader::load(ResourceLoader::path_remap(path), get_class(), true);
|
reset_state(); //may want to reset state
|
||||||
|
|
||||||
if (!s.is_valid()) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
List<PropertyInfo> pi;
|
List<PropertyInfo> pi;
|
||||||
s->get_property_list(&pi);
|
p_resource->get_property_list(&pi);
|
||||||
|
|
||||||
for (List<PropertyInfo>::Element *E = pi.front(); E; E = E->next()) {
|
for (List<PropertyInfo>::Element *E = pi.front(); E; E = E->next()) {
|
||||||
if (!(E->get().usage & PROPERTY_USAGE_STORAGE)) {
|
if (!(E->get().usage & PROPERTY_USAGE_STORAGE)) {
|
||||||
|
@ -137,8 +135,23 @@ void Resource::reload_from_file() {
|
||||||
continue; //do not change path
|
continue; //do not change path
|
||||||
}
|
}
|
||||||
|
|
||||||
set(E->get().name, s->get(E->get().name));
|
set(E->get().name, p_resource->get(E->get().name));
|
||||||
}
|
}
|
||||||
|
return OK;
|
||||||
|
}
|
||||||
|
void Resource::reload_from_file() {
|
||||||
|
String path = get_path();
|
||||||
|
if (!path.is_resource_file()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
Ref<Resource> s = ResourceLoader::load(ResourceLoader::path_remap(path), get_class(), ResourceFormatLoader::CACHE_MODE_IGNORE);
|
||||||
|
|
||||||
|
if (!s.is_valid()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
copy_from(s);
|
||||||
}
|
}
|
||||||
|
|
||||||
Ref<Resource> Resource::duplicate_for_local_scene(Node *p_for_scene, Map<Ref<Resource>, Ref<Resource>> &remap_cache) {
|
Ref<Resource> Resource::duplicate_for_local_scene(Node *p_for_scene, Map<Ref<Resource>, Ref<Resource>> &remap_cache) {
|
||||||
|
|
|
@ -90,6 +90,8 @@ public:
|
||||||
static Node *(*_get_local_scene_func)(); //used by editor
|
static Node *(*_get_local_scene_func)(); //used by editor
|
||||||
|
|
||||||
virtual bool editor_can_reload_from_file();
|
virtual bool editor_can_reload_from_file();
|
||||||
|
virtual void reset_state(); //for resources that use variable amount of properties, either via _validate_property or _get_property_list, this function needs to be implemented to correctly clear state
|
||||||
|
virtual Error copy_from(const Ref<Resource> &p_resource);
|
||||||
virtual void reload_from_file();
|
virtual void reload_from_file();
|
||||||
|
|
||||||
void register_owner(Object *p_owner);
|
void register_owner(Object *p_owner);
|
||||||
|
|
|
@ -313,17 +313,12 @@ Error ResourceLoaderBinary::parse_variant(Variant &r_v) {
|
||||||
uint32_t index = f->get_32();
|
uint32_t index = f->get_32();
|
||||||
String path = res_path + "::" + itos(index);
|
String path = res_path + "::" + itos(index);
|
||||||
|
|
||||||
if (use_nocache) {
|
//always use internal cache for loading internal resources
|
||||||
if (!internal_index_cache.has(path)) {
|
if (!internal_index_cache.has(path)) {
|
||||||
WARN_PRINT(String("Couldn't load resource (no cache): " + path).utf8().get_data());
|
WARN_PRINT(String("Couldn't load resource (no cache): " + path).utf8().get_data());
|
||||||
}
|
r_v = Variant();
|
||||||
r_v = internal_index_cache[path];
|
|
||||||
} else {
|
} else {
|
||||||
RES res = ResourceLoader::load(path);
|
r_v = internal_index_cache[path];
|
||||||
if (res.is_null()) {
|
|
||||||
WARN_PRINT(String("Couldn't load resource: " + path).utf8().get_data());
|
|
||||||
}
|
|
||||||
r_v = res;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
} break;
|
} break;
|
||||||
|
@ -645,7 +640,7 @@ Error ResourceLoaderBinary::load() {
|
||||||
}
|
}
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
Error err = ResourceLoader::load_threaded_request(path, external_resources[i].type, use_sub_threads, local_path);
|
Error err = ResourceLoader::load_threaded_request(path, external_resources[i].type, use_sub_threads, ResourceFormatLoader::CACHE_MODE_REUSE, local_path);
|
||||||
if (err != OK) {
|
if (err != OK) {
|
||||||
if (!ResourceLoader::get_abort_on_missing_resources()) {
|
if (!ResourceLoader::get_abort_on_missing_resources()) {
|
||||||
ResourceLoader::notify_dependency_error(local_path, path, external_resources[i].type);
|
ResourceLoader::notify_dependency_error(local_path, path, external_resources[i].type);
|
||||||
|
@ -675,7 +670,7 @@ Error ResourceLoaderBinary::load() {
|
||||||
path = res_path + "::" + path;
|
path = res_path + "::" + path;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!use_nocache) {
|
if (cache_mode == ResourceFormatLoader::CACHE_MODE_REUSE) {
|
||||||
if (ResourceCache::has(path)) {
|
if (ResourceCache::has(path)) {
|
||||||
//already loaded, don't do anything
|
//already loaded, don't do anything
|
||||||
stage++;
|
stage++;
|
||||||
|
@ -684,7 +679,7 @@ Error ResourceLoaderBinary::load() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (!use_nocache && !ResourceCache::has(res_path)) {
|
if (cache_mode != ResourceFormatLoader::CACHE_MODE_IGNORE && !ResourceCache::has(res_path)) {
|
||||||
path = res_path;
|
path = res_path;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -695,26 +690,40 @@ Error ResourceLoaderBinary::load() {
|
||||||
|
|
||||||
String t = get_unicode_string();
|
String t = get_unicode_string();
|
||||||
|
|
||||||
Object *obj = ClassDB::instance(t);
|
RES res;
|
||||||
if (!obj) {
|
|
||||||
error = ERR_FILE_CORRUPT;
|
if (cache_mode == ResourceFormatLoader::CACHE_MODE_REPLACE && ResourceCache::has(path)) {
|
||||||
ERR_FAIL_V_MSG(ERR_FILE_CORRUPT, local_path + ":Resource of unrecognized type in file: " + t + ".");
|
//use the existing one
|
||||||
|
Resource *r = ResourceCache::get(path);
|
||||||
|
if (r->get_class() == t) {
|
||||||
|
r->reset_state();
|
||||||
|
res = Ref<Resource>(r);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Resource *r = Object::cast_to<Resource>(obj);
|
if (res.is_null()) {
|
||||||
if (!r) {
|
//did not replace
|
||||||
String obj_class = obj->get_class();
|
|
||||||
error = ERR_FILE_CORRUPT;
|
|
||||||
memdelete(obj); //bye
|
|
||||||
ERR_FAIL_V_MSG(ERR_FILE_CORRUPT, local_path + ":Resource type in resource field not a resource, type is: " + obj_class + ".");
|
|
||||||
}
|
|
||||||
|
|
||||||
RES res = RES(r);
|
Object *obj = ClassDB::instance(t);
|
||||||
|
if (!obj) {
|
||||||
|
error = ERR_FILE_CORRUPT;
|
||||||
|
ERR_FAIL_V_MSG(ERR_FILE_CORRUPT, local_path + ":Resource of unrecognized type in file: " + t + ".");
|
||||||
|
}
|
||||||
|
|
||||||
if (path != String()) {
|
Resource *r = Object::cast_to<Resource>(obj);
|
||||||
r->set_path(path);
|
if (!r) {
|
||||||
|
String obj_class = obj->get_class();
|
||||||
|
error = ERR_FILE_CORRUPT;
|
||||||
|
memdelete(obj); //bye
|
||||||
|
ERR_FAIL_V_MSG(ERR_FILE_CORRUPT, local_path + ":Resource type in resource field not a resource, type is: " + obj_class + ".");
|
||||||
|
}
|
||||||
|
|
||||||
|
res = RES(r);
|
||||||
|
if (path != String() && cache_mode != ResourceFormatLoader::CACHE_MODE_IGNORE) {
|
||||||
|
r->set_path(path, cache_mode == ResourceFormatLoader::CACHE_MODE_REPLACE); //if got here because the resource with same path has different type, replace it
|
||||||
|
}
|
||||||
|
r->set_subindex(subindex);
|
||||||
}
|
}
|
||||||
r->set_subindex(subindex);
|
|
||||||
|
|
||||||
if (!main) {
|
if (!main) {
|
||||||
internal_index_cache[path] = res;
|
internal_index_cache[path] = res;
|
||||||
|
@ -961,7 +970,7 @@ ResourceLoaderBinary::~ResourceLoaderBinary() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
RES ResourceFormatLoaderBinary::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, bool p_no_cache) {
|
RES ResourceFormatLoaderBinary::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, CacheMode p_cache_mode) {
|
||||||
if (r_error) {
|
if (r_error) {
|
||||||
*r_error = ERR_FILE_CANT_OPEN;
|
*r_error = ERR_FILE_CANT_OPEN;
|
||||||
}
|
}
|
||||||
|
@ -972,7 +981,7 @@ RES ResourceFormatLoaderBinary::load(const String &p_path, const String &p_origi
|
||||||
ERR_FAIL_COND_V_MSG(err != OK, RES(), "Cannot open file '" + p_path + "'.");
|
ERR_FAIL_COND_V_MSG(err != OK, RES(), "Cannot open file '" + p_path + "'.");
|
||||||
|
|
||||||
ResourceLoaderBinary loader;
|
ResourceLoaderBinary loader;
|
||||||
loader.use_nocache = p_no_cache;
|
loader.cache_mode = p_cache_mode;
|
||||||
loader.use_sub_threads = p_use_sub_threads;
|
loader.use_sub_threads = p_use_sub_threads;
|
||||||
loader.progress = r_progress;
|
loader.progress = r_progress;
|
||||||
String path = p_original_path != "" ? p_original_path : p_path;
|
String path = p_original_path != "" ? p_original_path : p_path;
|
||||||
|
|
|
@ -78,7 +78,7 @@ class ResourceLoaderBinary {
|
||||||
Map<String, String> remaps;
|
Map<String, String> remaps;
|
||||||
Error error = OK;
|
Error error = OK;
|
||||||
|
|
||||||
bool use_nocache = false;
|
ResourceFormatLoader::CacheMode cache_mode = ResourceFormatLoader::CACHE_MODE_REUSE;
|
||||||
|
|
||||||
friend class ResourceFormatLoaderBinary;
|
friend class ResourceFormatLoaderBinary;
|
||||||
|
|
||||||
|
@ -103,7 +103,7 @@ public:
|
||||||
|
|
||||||
class ResourceFormatLoaderBinary : public ResourceFormatLoader {
|
class ResourceFormatLoaderBinary : public ResourceFormatLoader {
|
||||||
public:
|
public:
|
||||||
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, bool p_no_cache = false);
|
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, CacheMode p_cache_mode = CACHE_MODE_REUSE);
|
||||||
virtual void get_recognized_extensions_for_type(const String &p_type, List<String> *p_extensions) const;
|
virtual void get_recognized_extensions_for_type(const String &p_type, List<String> *p_extensions) const;
|
||||||
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
||||||
virtual bool handles_type(const String &p_type) const;
|
virtual bool handles_type(const String &p_type) const;
|
||||||
|
|
|
@ -116,7 +116,7 @@ Error ResourceFormatImporter::_get_path_and_type(const String &p_path, PathAndTy
|
||||||
return OK;
|
return OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
RES ResourceFormatImporter::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, bool p_no_cache) {
|
RES ResourceFormatImporter::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, CacheMode p_cache_mode) {
|
||||||
PathAndType pat;
|
PathAndType pat;
|
||||||
Error err = _get_path_and_type(p_path, pat);
|
Error err = _get_path_and_type(p_path, pat);
|
||||||
|
|
||||||
|
@ -128,7 +128,7 @@ RES ResourceFormatImporter::load(const String &p_path, const String &p_original_
|
||||||
return RES();
|
return RES();
|
||||||
}
|
}
|
||||||
|
|
||||||
RES res = ResourceLoader::_load(pat.path, p_path, pat.type, p_no_cache, r_error, p_use_sub_threads, r_progress);
|
RES res = ResourceLoader::_load(pat.path, p_path, pat.type, p_cache_mode, r_error, p_use_sub_threads, r_progress);
|
||||||
|
|
||||||
#ifdef TOOLS_ENABLED
|
#ifdef TOOLS_ENABLED
|
||||||
if (res.is_valid()) {
|
if (res.is_valid()) {
|
||||||
|
|
|
@ -57,7 +57,7 @@ class ResourceFormatImporter : public ResourceFormatLoader {
|
||||||
|
|
||||||
public:
|
public:
|
||||||
static ResourceFormatImporter *get_singleton() { return singleton; }
|
static ResourceFormatImporter *get_singleton() { return singleton; }
|
||||||
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, bool p_no_cache = false);
|
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, CacheMode p_cache_mode = CACHE_MODE_REUSE);
|
||||||
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
||||||
virtual void get_recognized_extensions_for_type(const String &p_type, List<String> *p_extensions) const;
|
virtual void get_recognized_extensions_for_type(const String &p_type, List<String> *p_extensions) const;
|
||||||
virtual bool recognize_path(const String &p_path, const String &p_for_type = String()) const;
|
virtual bool recognize_path(const String &p_path, const String &p_for_type = String()) const;
|
||||||
|
|
|
@ -113,9 +113,9 @@ void ResourceFormatLoader::get_recognized_extensions(List<String> *p_extensions)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
RES ResourceFormatLoader::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, bool p_no_cache) {
|
RES ResourceFormatLoader::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, CacheMode p_cache_mode) {
|
||||||
if (get_script_instance() && get_script_instance()->has_method("load")) {
|
if (get_script_instance() && get_script_instance()->has_method("load")) {
|
||||||
Variant res = get_script_instance()->call("load", p_path, p_original_path, p_use_sub_threads);
|
Variant res = get_script_instance()->call("load", p_path, p_original_path, p_use_sub_threads, p_cache_mode);
|
||||||
|
|
||||||
if (res.get_type() == Variant::INT) {
|
if (res.get_type() == Variant::INT) {
|
||||||
if (r_error) {
|
if (r_error) {
|
||||||
|
@ -164,7 +164,7 @@ Error ResourceFormatLoader::rename_dependencies(const String &p_path, const Map<
|
||||||
|
|
||||||
void ResourceFormatLoader::_bind_methods() {
|
void ResourceFormatLoader::_bind_methods() {
|
||||||
{
|
{
|
||||||
MethodInfo info = MethodInfo(Variant::NIL, "load", PropertyInfo(Variant::STRING, "path"), PropertyInfo(Variant::STRING, "original_path"));
|
MethodInfo info = MethodInfo(Variant::NIL, "load", PropertyInfo(Variant::STRING, "path"), PropertyInfo(Variant::STRING, "original_path"), PropertyInfo(Variant::BOOL, "use_sub_threads"), PropertyInfo(Variant::INT, "cache_mode"));
|
||||||
info.return_val.usage |= PROPERTY_USAGE_NIL_IS_VARIANT;
|
info.return_val.usage |= PROPERTY_USAGE_NIL_IS_VARIANT;
|
||||||
ClassDB::add_virtual_method(get_class_static(), info);
|
ClassDB::add_virtual_method(get_class_static(), info);
|
||||||
}
|
}
|
||||||
|
@ -178,7 +178,7 @@ void ResourceFormatLoader::_bind_methods() {
|
||||||
|
|
||||||
///////////////////////////////////
|
///////////////////////////////////
|
||||||
|
|
||||||
RES ResourceLoader::_load(const String &p_path, const String &p_original_path, const String &p_type_hint, bool p_no_cache, Error *r_error, bool p_use_sub_threads, float *r_progress) {
|
RES ResourceLoader::_load(const String &p_path, const String &p_original_path, const String &p_type_hint, ResourceFormatLoader::CacheMode p_cache_mode, Error *r_error, bool p_use_sub_threads, float *r_progress) {
|
||||||
bool found = false;
|
bool found = false;
|
||||||
|
|
||||||
// Try all loaders and pick the first match for the type hint
|
// Try all loaders and pick the first match for the type hint
|
||||||
|
@ -187,7 +187,7 @@ RES ResourceLoader::_load(const String &p_path, const String &p_original_path, c
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
found = true;
|
found = true;
|
||||||
RES res = loader[i]->load(p_path, p_original_path != String() ? p_original_path : p_path, r_error, p_use_sub_threads, r_progress, p_no_cache);
|
RES res = loader[i]->load(p_path, p_original_path != String() ? p_original_path : p_path, r_error, p_use_sub_threads, r_progress, p_cache_mode);
|
||||||
if (res.is_null()) {
|
if (res.is_null()) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
@ -214,7 +214,7 @@ void ResourceLoader::_thread_load_function(void *p_userdata) {
|
||||||
//this is an actual thread, so wait for Ok fom semaphore
|
//this is an actual thread, so wait for Ok fom semaphore
|
||||||
thread_load_semaphore->wait(); //wait until its ok to start loading
|
thread_load_semaphore->wait(); //wait until its ok to start loading
|
||||||
}
|
}
|
||||||
load_task.resource = _load(load_task.remapped_path, load_task.remapped_path != load_task.local_path ? load_task.local_path : String(), load_task.type_hint, false, &load_task.error, load_task.use_sub_threads, &load_task.progress);
|
load_task.resource = _load(load_task.remapped_path, load_task.remapped_path != load_task.local_path ? load_task.local_path : String(), load_task.type_hint, load_task.cache_mode, &load_task.error, load_task.use_sub_threads, &load_task.progress);
|
||||||
|
|
||||||
load_task.progress = 1.0; //it was fully loaded at this point, so force progress to 1.0
|
load_task.progress = 1.0; //it was fully loaded at this point, so force progress to 1.0
|
||||||
|
|
||||||
|
@ -267,7 +267,7 @@ void ResourceLoader::_thread_load_function(void *p_userdata) {
|
||||||
thread_load_mutex->unlock();
|
thread_load_mutex->unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
Error ResourceLoader::load_threaded_request(const String &p_path, const String &p_type_hint, bool p_use_sub_threads, const String &p_source_resource) {
|
Error ResourceLoader::load_threaded_request(const String &p_path, const String &p_type_hint, bool p_use_sub_threads, ResourceFormatLoader::CacheMode p_cache_mode, const String &p_source_resource) {
|
||||||
String local_path;
|
String local_path;
|
||||||
if (p_path.is_rel_path()) {
|
if (p_path.is_rel_path()) {
|
||||||
local_path = "res://" + p_path;
|
local_path = "res://" + p_path;
|
||||||
|
@ -314,6 +314,7 @@ Error ResourceLoader::load_threaded_request(const String &p_path, const String &
|
||||||
load_task.remapped_path = _path_remap(local_path, &load_task.xl_remapped);
|
load_task.remapped_path = _path_remap(local_path, &load_task.xl_remapped);
|
||||||
load_task.local_path = local_path;
|
load_task.local_path = local_path;
|
||||||
load_task.type_hint = p_type_hint;
|
load_task.type_hint = p_type_hint;
|
||||||
|
load_task.cache_mode = p_cache_mode;
|
||||||
load_task.use_sub_threads = p_use_sub_threads;
|
load_task.use_sub_threads = p_use_sub_threads;
|
||||||
|
|
||||||
{ //must check if resource is already loaded before attempting to load it in a thread
|
{ //must check if resource is already loaded before attempting to load it in a thread
|
||||||
|
@ -501,7 +502,7 @@ RES ResourceLoader::load_threaded_get(const String &p_path, Error *r_error) {
|
||||||
return resource;
|
return resource;
|
||||||
}
|
}
|
||||||
|
|
||||||
RES ResourceLoader::load(const String &p_path, const String &p_type_hint, bool p_no_cache, Error *r_error) {
|
RES ResourceLoader::load(const String &p_path, const String &p_type_hint, ResourceFormatLoader::CacheMode p_cache_mode, Error *r_error) {
|
||||||
if (r_error) {
|
if (r_error) {
|
||||||
*r_error = ERR_CANT_OPEN;
|
*r_error = ERR_CANT_OPEN;
|
||||||
}
|
}
|
||||||
|
@ -513,7 +514,7 @@ RES ResourceLoader::load(const String &p_path, const String &p_type_hint, bool p
|
||||||
local_path = ProjectSettings::get_singleton()->localize_path(p_path);
|
local_path = ProjectSettings::get_singleton()->localize_path(p_path);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!p_no_cache) {
|
if (p_cache_mode == ResourceFormatLoader::CACHE_MODE_IGNORE) {
|
||||||
thread_load_mutex->lock();
|
thread_load_mutex->lock();
|
||||||
|
|
||||||
//Is it already being loaded? poll until done
|
//Is it already being loaded? poll until done
|
||||||
|
@ -561,6 +562,7 @@ RES ResourceLoader::load(const String &p_path, const String &p_type_hint, bool p
|
||||||
load_task.local_path = local_path;
|
load_task.local_path = local_path;
|
||||||
load_task.remapped_path = _path_remap(local_path, &load_task.xl_remapped);
|
load_task.remapped_path = _path_remap(local_path, &load_task.xl_remapped);
|
||||||
load_task.type_hint = p_type_hint;
|
load_task.type_hint = p_type_hint;
|
||||||
|
load_task.cache_mode = p_cache_mode; //ignore
|
||||||
load_task.loader_id = Thread::get_caller_id();
|
load_task.loader_id = Thread::get_caller_id();
|
||||||
|
|
||||||
thread_load_tasks[local_path] = load_task;
|
thread_load_tasks[local_path] = load_task;
|
||||||
|
@ -581,7 +583,7 @@ RES ResourceLoader::load(const String &p_path, const String &p_type_hint, bool p
|
||||||
|
|
||||||
print_verbose("Loading resource: " + path);
|
print_verbose("Loading resource: " + path);
|
||||||
float p;
|
float p;
|
||||||
RES res = _load(path, local_path, p_type_hint, p_no_cache, r_error, false, &p);
|
RES res = _load(path, local_path, p_type_hint, p_cache_mode, r_error, false, &p);
|
||||||
|
|
||||||
if (res.is_null()) {
|
if (res.is_null()) {
|
||||||
print_verbose("Failed loading resource: " + path);
|
print_verbose("Failed loading resource: " + path);
|
||||||
|
|
|
@ -38,11 +38,18 @@
|
||||||
class ResourceFormatLoader : public Reference {
|
class ResourceFormatLoader : public Reference {
|
||||||
GDCLASS(ResourceFormatLoader, Reference);
|
GDCLASS(ResourceFormatLoader, Reference);
|
||||||
|
|
||||||
|
public:
|
||||||
|
enum CacheMode {
|
||||||
|
CACHE_MODE_IGNORE, //resource and subresources do not use path cache, no path is set into resource.
|
||||||
|
CACHE_MODE_REUSE, //resource and subresources use patch cache, reuse existing loaded resources instead of loading from disk when available
|
||||||
|
CACHE_MODE_REPLACE, //resource and and subresource use path cache, but replace existing loaded resources when available with information from disk
|
||||||
|
};
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
static void _bind_methods();
|
static void _bind_methods();
|
||||||
|
|
||||||
public:
|
public:
|
||||||
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, bool p_no_cache = false);
|
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, CacheMode p_cache_mode = CACHE_MODE_REUSE);
|
||||||
virtual bool exists(const String &p_path) const;
|
virtual bool exists(const String &p_path) const;
|
||||||
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
||||||
virtual void get_recognized_extensions_for_type(const String &p_type, List<String> *p_extensions) const;
|
virtual void get_recognized_extensions_for_type(const String &p_type, List<String> *p_extensions) const;
|
||||||
|
@ -99,7 +106,7 @@ private:
|
||||||
friend class ResourceFormatImporter;
|
friend class ResourceFormatImporter;
|
||||||
friend class ResourceInteractiveLoader;
|
friend class ResourceInteractiveLoader;
|
||||||
//internal load function
|
//internal load function
|
||||||
static RES _load(const String &p_path, const String &p_original_path, const String &p_type_hint, bool p_no_cache, Error *r_error, bool p_use_sub_threads, float *r_progress);
|
static RES _load(const String &p_path, const String &p_original_path, const String &p_type_hint, ResourceFormatLoader::CacheMode p_cache_mode, Error *r_error, bool p_use_sub_threads, float *r_progress);
|
||||||
|
|
||||||
static ResourceLoadedCallback _loaded_callback;
|
static ResourceLoadedCallback _loaded_callback;
|
||||||
|
|
||||||
|
@ -114,6 +121,7 @@ private:
|
||||||
String type_hint;
|
String type_hint;
|
||||||
float progress = 0.0;
|
float progress = 0.0;
|
||||||
ThreadLoadStatus status = THREAD_LOAD_IN_PROGRESS;
|
ThreadLoadStatus status = THREAD_LOAD_IN_PROGRESS;
|
||||||
|
ResourceFormatLoader::CacheMode cache_mode = ResourceFormatLoader::CACHE_MODE_REUSE;
|
||||||
Error error = OK;
|
Error error = OK;
|
||||||
RES resource;
|
RES resource;
|
||||||
bool xl_remapped = false;
|
bool xl_remapped = false;
|
||||||
|
@ -136,11 +144,11 @@ private:
|
||||||
static float _dependency_get_progress(const String &p_path);
|
static float _dependency_get_progress(const String &p_path);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
static Error load_threaded_request(const String &p_path, const String &p_type_hint = "", bool p_use_sub_threads = false, const String &p_source_resource = String());
|
static Error load_threaded_request(const String &p_path, const String &p_type_hint = "", bool p_use_sub_threads = false, ResourceFormatLoader::CacheMode p_cache_mode = ResourceFormatLoader::CACHE_MODE_REUSE, const String &p_source_resource = String());
|
||||||
static ThreadLoadStatus load_threaded_get_status(const String &p_path, float *r_progress = nullptr);
|
static ThreadLoadStatus load_threaded_get_status(const String &p_path, float *r_progress = nullptr);
|
||||||
static RES load_threaded_get(const String &p_path, Error *r_error = nullptr);
|
static RES load_threaded_get(const String &p_path, Error *r_error = nullptr);
|
||||||
|
|
||||||
static RES load(const String &p_path, const String &p_type_hint = "", bool p_no_cache = false, Error *r_error = nullptr);
|
static RES load(const String &p_path, const String &p_type_hint = "", ResourceFormatLoader::CacheMode p_cache_mode = ResourceFormatLoader::CACHE_MODE_REUSE, Error *r_error = nullptr);
|
||||||
static bool exists(const String &p_path, const String &p_type_hint = "");
|
static bool exists(const String &p_path, const String &p_type_hint = "");
|
||||||
|
|
||||||
static void get_recognized_extensions_for_type(const String &p_type, List<String> *p_extensions);
|
static void get_recognized_extensions_for_type(const String &p_type, List<String> *p_extensions);
|
||||||
|
|
|
@ -277,7 +277,7 @@ RES TranslationLoaderPO::load_translation(FileAccess *f, Error *r_error) {
|
||||||
return translation;
|
return translation;
|
||||||
}
|
}
|
||||||
|
|
||||||
RES TranslationLoaderPO::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, bool p_no_cache) {
|
RES TranslationLoaderPO::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, CacheMode p_cache_mode) {
|
||||||
if (r_error) {
|
if (r_error) {
|
||||||
*r_error = ERR_CANT_OPEN;
|
*r_error = ERR_CANT_OPEN;
|
||||||
}
|
}
|
||||||
|
|
|
@ -38,7 +38,7 @@
|
||||||
class TranslationLoaderPO : public ResourceFormatLoader {
|
class TranslationLoaderPO : public ResourceFormatLoader {
|
||||||
public:
|
public:
|
||||||
static RES load_translation(FileAccess *f, Error *r_error = nullptr);
|
static RES load_translation(FileAccess *f, Error *r_error = nullptr);
|
||||||
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, bool p_no_cache = false);
|
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, CacheMode p_cache_mode = CACHE_MODE_REUSE);
|
||||||
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
||||||
virtual bool handles_type(const String &p_type) const;
|
virtual bool handles_type(const String &p_type) const;
|
||||||
virtual String get_resource_type(const String &p_path) const;
|
virtual String get_resource_type(const String &p_path) const;
|
||||||
|
|
|
@ -35,7 +35,7 @@
|
||||||
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
RES ResourceFormatDummyTexture::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, bool p_no_cache) {
|
RES ResourceFormatDummyTexture::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, CacheMode p_cache_mode) {
|
||||||
unsigned int width = 8;
|
unsigned int width = 8;
|
||||||
unsigned int height = 8;
|
unsigned int height = 8;
|
||||||
|
|
||||||
|
|
|
@ -36,7 +36,7 @@
|
||||||
|
|
||||||
class ResourceFormatDummyTexture : public ResourceFormatLoader {
|
class ResourceFormatDummyTexture : public ResourceFormatLoader {
|
||||||
public:
|
public:
|
||||||
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, bool p_no_cache = false);
|
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, CacheMode p_cache_mode = CACHE_MODE_REUSE);
|
||||||
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
||||||
virtual bool handles_type(const String &p_type) const;
|
virtual bool handles_type(const String &p_type) const;
|
||||||
virtual String get_resource_type(const String &p_path) const;
|
virtual String get_resource_type(const String &p_path) const;
|
||||||
|
|
|
@ -1193,7 +1193,7 @@ void EditorAudioBuses::_load_layout() {
|
||||||
void EditorAudioBuses::_load_default_layout() {
|
void EditorAudioBuses::_load_default_layout() {
|
||||||
String layout_path = ProjectSettings::get_singleton()->get("audio/default_bus_layout");
|
String layout_path = ProjectSettings::get_singleton()->get("audio/default_bus_layout");
|
||||||
|
|
||||||
Ref<AudioBusLayout> state = ResourceLoader::load(layout_path, "", true);
|
Ref<AudioBusLayout> state = ResourceLoader::load(layout_path, "", ResourceFormatLoader::CACHE_MODE_IGNORE);
|
||||||
if (state.is_null()) {
|
if (state.is_null()) {
|
||||||
EditorNode::get_singleton()->show_warning(vformat(TTR("There is no '%s' file."), layout_path));
|
EditorNode::get_singleton()->show_warning(vformat(TTR("There is no '%s' file."), layout_path));
|
||||||
return;
|
return;
|
||||||
|
@ -1209,7 +1209,7 @@ void EditorAudioBuses::_load_default_layout() {
|
||||||
|
|
||||||
void EditorAudioBuses::_file_dialog_callback(const String &p_string) {
|
void EditorAudioBuses::_file_dialog_callback(const String &p_string) {
|
||||||
if (file_dialog->get_file_mode() == EditorFileDialog::FILE_MODE_OPEN_FILE) {
|
if (file_dialog->get_file_mode() == EditorFileDialog::FILE_MODE_OPEN_FILE) {
|
||||||
Ref<AudioBusLayout> state = ResourceLoader::load(p_string, "", true);
|
Ref<AudioBusLayout> state = ResourceLoader::load(p_string, "", ResourceFormatLoader::CACHE_MODE_IGNORE);
|
||||||
if (state.is_null()) {
|
if (state.is_null()) {
|
||||||
EditorNode::get_singleton()->show_warning(TTR("Invalid file, not an audio bus layout."));
|
EditorNode::get_singleton()->show_warning(TTR("Invalid file, not an audio bus layout."));
|
||||||
return;
|
return;
|
||||||
|
@ -1330,7 +1330,7 @@ EditorAudioBuses::EditorAudioBuses() {
|
||||||
void EditorAudioBuses::open_layout(const String &p_path) {
|
void EditorAudioBuses::open_layout(const String &p_path) {
|
||||||
EditorNode::get_singleton()->make_bottom_panel_item_visible(this);
|
EditorNode::get_singleton()->make_bottom_panel_item_visible(this);
|
||||||
|
|
||||||
Ref<AudioBusLayout> state = ResourceLoader::load(p_path, "", true);
|
Ref<AudioBusLayout> state = ResourceLoader::load(p_path, "", ResourceFormatLoader::CACHE_MODE_IGNORE);
|
||||||
if (state.is_null()) {
|
if (state.is_null()) {
|
||||||
EditorNode::get_singleton()->show_warning(TTR("Invalid file, not an audio bus layout."));
|
EditorNode::get_singleton()->show_warning(TTR("Invalid file, not an audio bus layout."));
|
||||||
return;
|
return;
|
||||||
|
|
|
@ -259,13 +259,17 @@ void EditorFolding::_do_object_unfolds(Object *p_object, Set<RES> &resources) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
if (E->get().type == Variant::OBJECT) {
|
if (E->get().type == Variant::OBJECT) {
|
||||||
RES res = p_object->get(E->get().name);
|
RES res = p_object->get(E->get().name);
|
||||||
if (res.is_valid() && !resources.has(res) && res->get_path() != String() && !res->get_path().is_resource_file()) {
|
print_line("res: " + String(E->get().name) + " valid " + itos(res.is_valid()));
|
||||||
resources.insert(res);
|
if (res.is_valid()) {
|
||||||
_do_object_unfolds(res.ptr(), resources);
|
print_line("path " + res->get_path());
|
||||||
|
}
|
||||||
|
if (res.is_valid() && !resources.has(res) && res->get_path() != String() && !res->get_path().is_resource_file()) {
|
||||||
|
resources.insert(res);
|
||||||
|
_do_object_unfolds(res.ptr(), resources);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1003,7 +1003,7 @@ Error EditorNode::load_resource(const String &p_resource, bool p_ignore_broken_d
|
||||||
dependency_errors.clear();
|
dependency_errors.clear();
|
||||||
|
|
||||||
Error err;
|
Error err;
|
||||||
RES res = ResourceLoader::load(p_resource, "", false, &err);
|
RES res = ResourceLoader::load(p_resource, "", ResourceFormatLoader::CACHE_MODE_REUSE, &err);
|
||||||
ERR_FAIL_COND_V(!res.is_valid(), ERR_CANT_OPEN);
|
ERR_FAIL_COND_V(!res.is_valid(), ERR_CANT_OPEN);
|
||||||
|
|
||||||
if (!p_ignore_broken_deps && dependency_errors.has(p_resource)) {
|
if (!p_ignore_broken_deps && dependency_errors.has(p_resource)) {
|
||||||
|
@ -3452,7 +3452,7 @@ Error EditorNode::load_scene(const String &p_scene, bool p_ignore_broken_deps, b
|
||||||
dependency_errors.clear();
|
dependency_errors.clear();
|
||||||
|
|
||||||
Error err;
|
Error err;
|
||||||
Ref<PackedScene> sdata = ResourceLoader::load(lpath, "", true, &err);
|
Ref<PackedScene> sdata = ResourceLoader::load(lpath, "", ResourceFormatLoader::CACHE_MODE_REPLACE, &err);
|
||||||
if (!sdata.is_valid()) {
|
if (!sdata.is_valid()) {
|
||||||
_dialog_display_load_error(lpath, err);
|
_dialog_display_load_error(lpath, err);
|
||||||
opening_prev = false;
|
opening_prev = false;
|
||||||
|
@ -5274,6 +5274,8 @@ void EditorNode::_file_access_close_error_notify(const String &p_str) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void EditorNode::reload_scene(const String &p_path) {
|
void EditorNode::reload_scene(const String &p_path) {
|
||||||
|
/*
|
||||||
|
* No longer necesary since scenes now reset and reload their internal resource if needed.
|
||||||
//first of all, reload internal textures, materials, meshes, etc. as they might have changed on disk
|
//first of all, reload internal textures, materials, meshes, etc. as they might have changed on disk
|
||||||
|
|
||||||
List<Ref<Resource>> cached;
|
List<Ref<Resource>> cached;
|
||||||
|
@ -5291,6 +5293,8 @@ void EditorNode::reload_scene(const String &p_path) {
|
||||||
to_clear.pop_front();
|
to_clear.pop_front();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
*/
|
||||||
|
|
||||||
int scene_idx = -1;
|
int scene_idx = -1;
|
||||||
for (int i = 0; i < editor_data.get_edited_scene_count(); i++) {
|
for (int i = 0; i < editor_data.get_edited_scene_count(); i++) {
|
||||||
if (editor_data.get_scene_path(i) == p_path) {
|
if (editor_data.get_scene_path(i) == p_path) {
|
||||||
|
|
|
@ -964,7 +964,7 @@ void ResourceImporterScene::_make_external_resources(Node *p_node, const String
|
||||||
|
|
||||||
if (FileAccess::exists(ext_name) && p_keep_animations) {
|
if (FileAccess::exists(ext_name) && p_keep_animations) {
|
||||||
// Copy custom animation tracks from previously imported files.
|
// Copy custom animation tracks from previously imported files.
|
||||||
Ref<Animation> old_anim = ResourceLoader::load(ext_name, "Animation", true);
|
Ref<Animation> old_anim = ResourceLoader::load(ext_name, "Animation", ResourceFormatLoader::CACHE_MODE_IGNORE);
|
||||||
if (old_anim.is_valid()) {
|
if (old_anim.is_valid()) {
|
||||||
for (int i = 0; i < old_anim->get_track_count(); i++) {
|
for (int i = 0; i < old_anim->get_track_count(); i++) {
|
||||||
if (!old_anim->track_is_imported(i)) {
|
if (!old_anim->track_is_imported(i)) {
|
||||||
|
@ -1004,7 +1004,7 @@ void ResourceImporterScene::_make_external_resources(Node *p_node, const String
|
||||||
p_materials[mat] = ResourceLoader::load(ext_name);
|
p_materials[mat] = ResourceLoader::load(ext_name);
|
||||||
} else {
|
} else {
|
||||||
ResourceSaver::save(ext_name, mat, ResourceSaver::FLAG_CHANGE_PATH);
|
ResourceSaver::save(ext_name, mat, ResourceSaver::FLAG_CHANGE_PATH);
|
||||||
p_materials[mat] = ResourceLoader::load(ext_name, "", true); // disable loading from the cache.
|
p_materials[mat] = ResourceLoader::load(ext_name, "", ResourceFormatLoader::CACHE_MODE_IGNORE); // disable loading from the cache.
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1061,7 +1061,7 @@ void ResourceImporterScene::_make_external_resources(Node *p_node, const String
|
||||||
p_materials[mat] = ResourceLoader::load(ext_name);
|
p_materials[mat] = ResourceLoader::load(ext_name);
|
||||||
} else {
|
} else {
|
||||||
ResourceSaver::save(ext_name, mat, ResourceSaver::FLAG_CHANGE_PATH);
|
ResourceSaver::save(ext_name, mat, ResourceSaver::FLAG_CHANGE_PATH);
|
||||||
p_materials[mat] = ResourceLoader::load(ext_name, "", true); // disable loading from the cache.
|
p_materials[mat] = ResourceLoader::load(ext_name, "", ResourceFormatLoader::CACHE_MODE_IGNORE); // disable loading from the cache.
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -42,7 +42,7 @@ Error PackedSceneEditorTranslationParserPlugin::parse_file(const String &p_path,
|
||||||
// These properties are translated with the tr() function in the C++ code when being set or updated.
|
// These properties are translated with the tr() function in the C++ code when being set or updated.
|
||||||
|
|
||||||
Error err;
|
Error err;
|
||||||
RES loaded_res = ResourceLoader::load(p_path, "PackedScene", false, &err);
|
RES loaded_res = ResourceLoader::load(p_path, "PackedScene", ResourceFormatLoader::CACHE_MODE_REUSE, &err);
|
||||||
if (err) {
|
if (err) {
|
||||||
ERR_PRINT("Failed to load " + p_path);
|
ERR_PRINT("Failed to load " + p_path);
|
||||||
return err;
|
return err;
|
||||||
|
|
|
@ -894,7 +894,7 @@ void ScriptEditor::_reload_scripts() {
|
||||||
|
|
||||||
Ref<Script> script = edited_res;
|
Ref<Script> script = edited_res;
|
||||||
if (script != nullptr) {
|
if (script != nullptr) {
|
||||||
Ref<Script> rel_script = ResourceLoader::load(script->get_path(), script->get_class(), true);
|
Ref<Script> rel_script = ResourceLoader::load(script->get_path(), script->get_class(), ResourceFormatLoader::CACHE_MODE_IGNORE);
|
||||||
ERR_CONTINUE(!rel_script.is_valid());
|
ERR_CONTINUE(!rel_script.is_valid());
|
||||||
script->set_source_code(rel_script->get_source_code());
|
script->set_source_code(rel_script->get_source_code());
|
||||||
script->set_last_modified_time(rel_script->get_last_modified_time());
|
script->set_last_modified_time(rel_script->get_last_modified_time());
|
||||||
|
|
|
@ -688,7 +688,7 @@ void ScriptEditor::_update_modified_scripts_for_external_editor(Ref<Script> p_fo
|
||||||
uint64_t date = FileAccess::get_modified_time(script->get_path());
|
uint64_t date = FileAccess::get_modified_time(script->get_path());
|
||||||
|
|
||||||
if (last_date != date) {
|
if (last_date != date) {
|
||||||
Ref<Script> rel_script = ResourceLoader::load(script->get_path(), script->get_class(), true);
|
Ref<Script> rel_script = ResourceLoader::load(script->get_path(), script->get_class(), ResourceFormatLoader::CACHE_MODE_IGNORE);
|
||||||
ERR_CONTINUE(!rel_script.is_valid());
|
ERR_CONTINUE(!rel_script.is_valid());
|
||||||
script->set_source_code(rel_script->get_source_code());
|
script->set_source_code(rel_script->get_source_code());
|
||||||
script->set_last_modified_time(rel_script->get_last_modified_time());
|
script->set_last_modified_time(rel_script->get_last_modified_time());
|
||||||
|
|
|
@ -405,7 +405,7 @@ void ShaderEditor::_check_for_external_edit() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void ShaderEditor::_reload_shader_from_disk() {
|
void ShaderEditor::_reload_shader_from_disk() {
|
||||||
Ref<Shader> rel_shader = ResourceLoader::load(shader->get_path(), shader->get_class(), true);
|
Ref<Shader> rel_shader = ResourceLoader::load(shader->get_path(), shader->get_class(), ResourceFormatLoader::CACHE_MODE_IGNORE);
|
||||||
ERR_FAIL_COND(!rel_shader.is_valid());
|
ERR_FAIL_COND(!rel_shader.is_valid());
|
||||||
|
|
||||||
shader->set_code(rel_shader->get_code());
|
shader->set_code(rel_shader->get_code());
|
||||||
|
|
|
@ -94,7 +94,7 @@ static const DDSFormatInfo dds_format_info[DDS_MAX] = {
|
||||||
{ "GRAYSCALE_ALPHA", false, false, 1, 2, Image::FORMAT_LA8 }
|
{ "GRAYSCALE_ALPHA", false, false, 1, 2, Image::FORMAT_LA8 }
|
||||||
};
|
};
|
||||||
|
|
||||||
RES ResourceFormatDDS::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, bool p_no_cache) {
|
RES ResourceFormatDDS::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, CacheMode p_cache_mode) {
|
||||||
if (r_error) {
|
if (r_error) {
|
||||||
*r_error = ERR_CANT_OPEN;
|
*r_error = ERR_CANT_OPEN;
|
||||||
}
|
}
|
||||||
|
|
|
@ -36,7 +36,7 @@
|
||||||
|
|
||||||
class ResourceFormatDDS : public ResourceFormatLoader {
|
class ResourceFormatDDS : public ResourceFormatLoader {
|
||||||
public:
|
public:
|
||||||
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, bool p_no_cache = false);
|
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, CacheMode p_cache_mode = CACHE_MODE_REUSE);
|
||||||
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
||||||
virtual bool handles_type(const String &p_type) const;
|
virtual bool handles_type(const String &p_type) const;
|
||||||
virtual String get_resource_type(const String &p_path) const;
|
virtual String get_resource_type(const String &p_path) const;
|
||||||
|
|
|
@ -42,7 +42,7 @@ struct ETC1Header {
|
||||||
uint16_t origHeight = 0;
|
uint16_t origHeight = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
RES ResourceFormatPKM::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, bool p_no_cache) {
|
RES ResourceFormatPKM::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, CacheMode p_cache_mode) {
|
||||||
if (r_error) {
|
if (r_error) {
|
||||||
*r_error = ERR_CANT_OPEN;
|
*r_error = ERR_CANT_OPEN;
|
||||||
}
|
}
|
||||||
|
|
|
@ -36,7 +36,7 @@
|
||||||
|
|
||||||
class ResourceFormatPKM : public ResourceFormatLoader {
|
class ResourceFormatPKM : public ResourceFormatLoader {
|
||||||
public:
|
public:
|
||||||
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, bool p_no_cache = false);
|
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, CacheMode p_cache_mode = CACHE_MODE_REUSE);
|
||||||
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
||||||
virtual bool handles_type(const String &p_type) const;
|
virtual bool handles_type(const String &p_type) const;
|
||||||
virtual String get_resource_type(const String &p_path) const;
|
virtual String get_resource_type(const String &p_path) const;
|
||||||
|
|
|
@ -110,6 +110,16 @@ bool GDNativeLibrary::_get(const StringName &p_name, Variant &r_property) const
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void GDNativeLibrary::reset_state() {
|
||||||
|
config_file.instance();
|
||||||
|
current_library_path = "";
|
||||||
|
current_dependencies.clear();
|
||||||
|
symbol_prefix = default_symbol_prefix;
|
||||||
|
load_once = default_load_once;
|
||||||
|
singleton = default_singleton;
|
||||||
|
reloadable = default_reloadable;
|
||||||
|
}
|
||||||
|
|
||||||
void GDNativeLibrary::_get_property_list(List<PropertyInfo> *p_list) const {
|
void GDNativeLibrary::_get_property_list(List<PropertyInfo> *p_list) const {
|
||||||
// set entries
|
// set entries
|
||||||
List<String> entry_key_list;
|
List<String> entry_key_list;
|
||||||
|
@ -508,7 +518,7 @@ Error GDNative::get_symbol(StringName p_procedure_name, void *&r_handle, bool p_
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
RES GDNativeLibraryResourceLoader::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, bool p_no_cache) {
|
RES GDNativeLibraryResourceLoader::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, CacheMode p_cache_mode) {
|
||||||
Ref<GDNativeLibrary> lib;
|
Ref<GDNativeLibrary> lib;
|
||||||
lib.instance();
|
lib.instance();
|
||||||
|
|
||||||
|
|
|
@ -63,6 +63,8 @@ class GDNativeLibrary : public Resource {
|
||||||
bool reloadable;
|
bool reloadable;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
virtual void reset_state() override;
|
||||||
|
|
||||||
GDNativeLibrary();
|
GDNativeLibrary();
|
||||||
~GDNativeLibrary();
|
~GDNativeLibrary();
|
||||||
|
|
||||||
|
@ -166,7 +168,7 @@ public:
|
||||||
|
|
||||||
class GDNativeLibraryResourceLoader : public ResourceFormatLoader {
|
class GDNativeLibraryResourceLoader : public ResourceFormatLoader {
|
||||||
public:
|
public:
|
||||||
virtual RES load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads = false, float *r_progress = nullptr, bool p_no_cache = false);
|
virtual RES load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads = false, float *r_progress = nullptr, CacheMode p_cache_mode = CACHE_MODE_REUSE);
|
||||||
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
||||||
virtual bool handles_type(const String &p_type) const;
|
virtual bool handles_type(const String &p_type) const;
|
||||||
virtual String get_resource_type(const String &p_path) const;
|
virtual String get_resource_type(const String &p_path) const;
|
||||||
|
|
|
@ -1940,7 +1940,7 @@ void NativeReloadNode::_notification(int p_what) {
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
RES ResourceFormatLoaderNativeScript::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, bool p_no_cache) {
|
RES ResourceFormatLoaderNativeScript::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, CacheMode p_no_cache) {
|
||||||
return ResourceFormatLoaderText::singleton->load(p_path, p_original_path, r_error);
|
return ResourceFormatLoaderText::singleton->load(p_path, p_original_path, r_error);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -402,7 +402,7 @@ public:
|
||||||
|
|
||||||
class ResourceFormatLoaderNativeScript : public ResourceFormatLoader {
|
class ResourceFormatLoaderNativeScript : public ResourceFormatLoader {
|
||||||
public:
|
public:
|
||||||
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, bool p_no_cache = false);
|
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, CacheMode p_cache_mode = CACHE_MODE_REUSE);
|
||||||
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
||||||
virtual bool handles_type(const String &p_type) const;
|
virtual bool handles_type(const String &p_type) const;
|
||||||
virtual String get_resource_type(const String &p_path) const;
|
virtual String get_resource_type(const String &p_path) const;
|
||||||
|
|
|
@ -39,7 +39,7 @@ ResourceFormatLoaderPluginScript::ResourceFormatLoaderPluginScript(PluginScriptL
|
||||||
_language = language;
|
_language = language;
|
||||||
}
|
}
|
||||||
|
|
||||||
RES ResourceFormatLoaderPluginScript::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, bool p_no_cache) {
|
RES ResourceFormatLoaderPluginScript::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, CacheMode p_cache_mode) {
|
||||||
if (r_error) {
|
if (r_error) {
|
||||||
*r_error = ERR_FILE_CANT_OPEN;
|
*r_error = ERR_FILE_CANT_OPEN;
|
||||||
}
|
}
|
||||||
|
|
|
@ -43,7 +43,7 @@ class ResourceFormatLoaderPluginScript : public ResourceFormatLoader {
|
||||||
|
|
||||||
public:
|
public:
|
||||||
ResourceFormatLoaderPluginScript(PluginScriptLanguage *language);
|
ResourceFormatLoaderPluginScript(PluginScriptLanguage *language);
|
||||||
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, bool p_no_cache = false);
|
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, CacheMode p_cache_mode = CACHE_MODE_REUSE);
|
||||||
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
||||||
virtual bool handles_type(const String &p_type) const;
|
virtual bool handles_type(const String &p_type) const;
|
||||||
virtual String get_resource_type(const String &p_path) const;
|
virtual String get_resource_type(const String &p_path) const;
|
||||||
|
|
|
@ -360,7 +360,7 @@ void VideoStreamGDNative::set_audio_track(int p_track) {
|
||||||
|
|
||||||
/* --- NOTE ResourceFormatLoaderVideoStreamGDNative starts here. ----- */
|
/* --- NOTE ResourceFormatLoaderVideoStreamGDNative starts here. ----- */
|
||||||
|
|
||||||
RES ResourceFormatLoaderVideoStreamGDNative::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, bool p_no_cache) {
|
RES ResourceFormatLoaderVideoStreamGDNative::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, CacheMode p_cache_mode) {
|
||||||
FileAccess *f = FileAccess::open(p_path, FileAccess::READ);
|
FileAccess *f = FileAccess::open(p_path, FileAccess::READ);
|
||||||
if (!f) {
|
if (!f) {
|
||||||
if (r_error) {
|
if (r_error) {
|
||||||
|
|
|
@ -196,7 +196,7 @@ public:
|
||||||
|
|
||||||
class ResourceFormatLoaderVideoStreamGDNative : public ResourceFormatLoader {
|
class ResourceFormatLoaderVideoStreamGDNative : public ResourceFormatLoader {
|
||||||
public:
|
public:
|
||||||
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, bool p_no_cache = false);
|
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, CacheMode p_cache_mode = CACHE_MODE_REUSE);
|
||||||
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
||||||
virtual bool handles_type(const String &p_type) const;
|
virtual bool handles_type(const String &p_type) const;
|
||||||
virtual String get_resource_type(const String &p_path) const;
|
virtual String get_resource_type(const String &p_path) const;
|
||||||
|
|
|
@ -44,7 +44,7 @@ Error GDScriptEditorTranslationParserPlugin::parse_file(const String &p_path, Ve
|
||||||
// Search strings in AssignmentNode -> text = "__", hint_tooltip = "__" etc.
|
// Search strings in AssignmentNode -> text = "__", hint_tooltip = "__" etc.
|
||||||
|
|
||||||
Error err;
|
Error err;
|
||||||
RES loaded_res = ResourceLoader::load(p_path, "", false, &err);
|
RES loaded_res = ResourceLoader::load(p_path, "", ResourceFormatLoader::CACHE_MODE_REUSE, &err);
|
||||||
if (err) {
|
if (err) {
|
||||||
ERR_PRINT("Failed to load " + p_path);
|
ERR_PRINT("Failed to load " + p_path);
|
||||||
return err;
|
return err;
|
||||||
|
|
|
@ -2316,7 +2316,7 @@ Ref<GDScript> GDScriptLanguage::get_orphan_subclass(const String &p_qualified_na
|
||||||
|
|
||||||
/*************** RESOURCE ***************/
|
/*************** RESOURCE ***************/
|
||||||
|
|
||||||
RES ResourceFormatLoaderGDScript::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, bool p_no_cache) {
|
RES ResourceFormatLoaderGDScript::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, CacheMode p_cache_mode) {
|
||||||
if (r_error) {
|
if (r_error) {
|
||||||
*r_error = ERR_FILE_CANT_OPEN;
|
*r_error = ERR_FILE_CANT_OPEN;
|
||||||
}
|
}
|
||||||
|
|
|
@ -529,7 +529,7 @@ public:
|
||||||
|
|
||||||
class ResourceFormatLoaderGDScript : public ResourceFormatLoader {
|
class ResourceFormatLoaderGDScript : public ResourceFormatLoader {
|
||||||
public:
|
public:
|
||||||
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, bool p_no_cache = false);
|
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, CacheMode p_cache_mode = CACHE_MODE_REUSE);
|
||||||
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
||||||
virtual bool handles_type(const String &p_type) const;
|
virtual bool handles_type(const String &p_type) const;
|
||||||
virtual String get_resource_type(const String &p_path) const;
|
virtual String get_resource_type(const String &p_path) const;
|
||||||
|
|
|
@ -3644,7 +3644,7 @@ void CSharpScript::get_members(Set<StringName> *p_members) {
|
||||||
|
|
||||||
/*************** RESOURCE ***************/
|
/*************** RESOURCE ***************/
|
||||||
|
|
||||||
RES ResourceFormatLoaderCSharpScript::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, bool p_no_cache) {
|
RES ResourceFormatLoaderCSharpScript::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, CacheMode p_cache_mode) {
|
||||||
if (r_error) {
|
if (r_error) {
|
||||||
*r_error = ERR_FILE_CANT_OPEN;
|
*r_error = ERR_FILE_CANT_OPEN;
|
||||||
}
|
}
|
||||||
|
|
|
@ -542,7 +542,7 @@ public:
|
||||||
|
|
||||||
class ResourceFormatLoaderCSharpScript : public ResourceFormatLoader {
|
class ResourceFormatLoaderCSharpScript : public ResourceFormatLoader {
|
||||||
public:
|
public:
|
||||||
RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, bool p_no_cache = false) override;
|
RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, CacheMode p_cache_mode = CACHE_MODE_REUSE) override;
|
||||||
void get_recognized_extensions(List<String> *p_extensions) const override;
|
void get_recognized_extensions(List<String> *p_extensions) const override;
|
||||||
bool handles_type(const String &p_type) const override;
|
bool handles_type(const String &p_type) const override;
|
||||||
String get_resource_type(const String &p_path) const override;
|
String get_resource_type(const String &p_path) const override;
|
||||||
|
|
|
@ -46,7 +46,7 @@ enum PVRFLags {
|
||||||
PVR_VFLIP = 0x00010000
|
PVR_VFLIP = 0x00010000
|
||||||
};
|
};
|
||||||
|
|
||||||
RES ResourceFormatPVR::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, bool p_no_cache) {
|
RES ResourceFormatPVR::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, CacheMode p_cache_mode) {
|
||||||
if (r_error) {
|
if (r_error) {
|
||||||
*r_error = ERR_CANT_OPEN;
|
*r_error = ERR_CANT_OPEN;
|
||||||
}
|
}
|
||||||
|
|
|
@ -36,7 +36,7 @@
|
||||||
|
|
||||||
class ResourceFormatPVR : public ResourceFormatLoader {
|
class ResourceFormatPVR : public ResourceFormatLoader {
|
||||||
public:
|
public:
|
||||||
virtual RES load(const String &p_path, const String &p_original_path, Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, bool p_no_cache = false);
|
virtual RES load(const String &p_path, const String &p_original_path, Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, CacheMode p_cache_mode = CACHE_MODE_REUSE);
|
||||||
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
||||||
virtual bool handles_type(const String &p_type) const;
|
virtual bool handles_type(const String &p_type) const;
|
||||||
virtual String get_resource_type(const String &p_path) const;
|
virtual String get_resource_type(const String &p_path) const;
|
||||||
|
|
|
@ -677,7 +677,7 @@ void VideoStreamTheora::_bind_methods() {
|
||||||
|
|
||||||
////////////
|
////////////
|
||||||
|
|
||||||
RES ResourceFormatLoaderTheora::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, bool p_no_cache) {
|
RES ResourceFormatLoaderTheora::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, CacheMode p_cache_mode) {
|
||||||
FileAccess *f = FileAccess::open(p_path, FileAccess::READ);
|
FileAccess *f = FileAccess::open(p_path, FileAccess::READ);
|
||||||
if (!f) {
|
if (!f) {
|
||||||
if (r_error) {
|
if (r_error) {
|
||||||
|
|
|
@ -185,7 +185,7 @@ public:
|
||||||
|
|
||||||
class ResourceFormatLoaderTheora : public ResourceFormatLoader {
|
class ResourceFormatLoaderTheora : public ResourceFormatLoader {
|
||||||
public:
|
public:
|
||||||
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, bool p_no_cache = false);
|
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, CacheMode p_cache_mode = CACHE_MODE_REUSE);
|
||||||
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
||||||
virtual bool handles_type(const String &p_type) const;
|
virtual bool handles_type(const String &p_type) const;
|
||||||
virtual String get_resource_type(const String &p_path) const;
|
virtual String get_resource_type(const String &p_path) const;
|
||||||
|
|
|
@ -1506,6 +1506,19 @@ VisualScriptNodeInstance *VisualScriptExpression::instance(VisualScriptInstance
|
||||||
return instance;
|
return instance;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void VisualScriptExpression::reset_state() {
|
||||||
|
if (nodes) {
|
||||||
|
memdelete(nodes);
|
||||||
|
nodes = nullptr;
|
||||||
|
root = nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
error_str = String();
|
||||||
|
error_set = false;
|
||||||
|
str_ofs = 0;
|
||||||
|
inputs.clear();
|
||||||
|
}
|
||||||
|
|
||||||
VisualScriptExpression::VisualScriptExpression() {
|
VisualScriptExpression::VisualScriptExpression() {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -256,6 +256,8 @@ protected:
|
||||||
void _get_property_list(List<PropertyInfo> *p_list) const;
|
void _get_property_list(List<PropertyInfo> *p_list) const;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
virtual void reset_state() override;
|
||||||
|
|
||||||
virtual int get_output_sequence_port_count() const override;
|
virtual int get_output_sequence_port_count() const override;
|
||||||
virtual bool has_input_sequence_port() const override;
|
virtual bool has_input_sequence_port() const override;
|
||||||
|
|
||||||
|
|
|
@ -677,6 +677,10 @@ void VisualScriptSwitch::_get_property_list(List<PropertyInfo> *p_list) const {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void VisualScriptSwitch::reset_state() {
|
||||||
|
case_values.clear();
|
||||||
|
}
|
||||||
|
|
||||||
void VisualScriptSwitch::_bind_methods() {
|
void VisualScriptSwitch::_bind_methods() {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -202,6 +202,8 @@ protected:
|
||||||
static void _bind_methods();
|
static void _bind_methods();
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
virtual void reset_state() override;
|
||||||
|
|
||||||
virtual int get_output_sequence_port_count() const override;
|
virtual int get_output_sequence_port_count() const override;
|
||||||
virtual bool has_input_sequence_port() const override;
|
virtual bool has_input_sequence_port() const override;
|
||||||
|
|
||||||
|
|
|
@ -303,6 +303,14 @@ VisualScriptNodeInstance *VisualScriptFunction::instance(VisualScriptInstance *p
|
||||||
return instance;
|
return instance;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void VisualScriptFunction::reset_state() {
|
||||||
|
arguments.clear();
|
||||||
|
stack_size = 256;
|
||||||
|
stack_less = false;
|
||||||
|
sequenced = true;
|
||||||
|
rpc_mode = MultiplayerAPI::RPC_MODE_DISABLED;
|
||||||
|
}
|
||||||
|
|
||||||
VisualScriptFunction::VisualScriptFunction() {
|
VisualScriptFunction::VisualScriptFunction() {
|
||||||
stack_size = 256;
|
stack_size = 256;
|
||||||
stack_less = false;
|
stack_less = false;
|
||||||
|
@ -687,6 +695,13 @@ bool VisualScriptLists::is_sequenced() const {
|
||||||
return sequenced;
|
return sequenced;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void VisualScriptLists::reset_state() {
|
||||||
|
inputports.clear();
|
||||||
|
outputports.clear();
|
||||||
|
sequenced = false;
|
||||||
|
flags = 0;
|
||||||
|
}
|
||||||
|
|
||||||
VisualScriptLists::VisualScriptLists() {
|
VisualScriptLists::VisualScriptLists() {
|
||||||
// initialize
|
// initialize
|
||||||
sequenced = false;
|
sequenced = false;
|
||||||
|
|
|
@ -99,6 +99,8 @@ public:
|
||||||
|
|
||||||
virtual VisualScriptNodeInstance *instance(VisualScriptInstance *p_instance) override;
|
virtual VisualScriptNodeInstance *instance(VisualScriptInstance *p_instance) override;
|
||||||
|
|
||||||
|
virtual void reset_state() override;
|
||||||
|
|
||||||
VisualScriptFunction();
|
VisualScriptFunction();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -134,6 +136,8 @@ protected:
|
||||||
static void _bind_methods();
|
static void _bind_methods();
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
virtual void reset_state() override;
|
||||||
|
|
||||||
virtual bool is_output_port_editable() const;
|
virtual bool is_output_port_editable() const;
|
||||||
virtual bool is_output_port_name_editable() const;
|
virtual bool is_output_port_name_editable() const;
|
||||||
virtual bool is_output_port_type_editable() const;
|
virtual bool is_output_port_type_editable() const;
|
||||||
|
|
|
@ -429,7 +429,7 @@ void VideoStreamWebm::set_audio_track(int p_track) {
|
||||||
|
|
||||||
////////////
|
////////////
|
||||||
|
|
||||||
RES ResourceFormatLoaderWebm::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, bool p_no_cache) {
|
RES ResourceFormatLoaderWebm::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, CacheMode p_cache_mode) {
|
||||||
FileAccess *f = FileAccess::open(p_path, FileAccess::READ);
|
FileAccess *f = FileAccess::open(p_path, FileAccess::READ);
|
||||||
if (!f) {
|
if (!f) {
|
||||||
if (r_error) {
|
if (r_error) {
|
||||||
|
|
|
@ -126,7 +126,7 @@ public:
|
||||||
|
|
||||||
class ResourceFormatLoaderWebm : public ResourceFormatLoader {
|
class ResourceFormatLoaderWebm : public ResourceFormatLoader {
|
||||||
public:
|
public:
|
||||||
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, bool p_no_cache = false);
|
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, CacheMode p_cache_mode = CACHE_MODE_REUSE);
|
||||||
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
||||||
virtual bool handles_type(const String &p_type) const;
|
virtual bool handles_type(const String &p_type) const;
|
||||||
virtual String get_resource_type(const String &p_path) const;
|
virtual String get_resource_type(const String &p_path) const;
|
||||||
|
|
|
@ -1121,6 +1121,13 @@ void AnimationNodeBlendTree::_get_property_list(List<PropertyInfo> *p_list) cons
|
||||||
p_list->push_back(PropertyInfo(Variant::ARRAY, "node_connections", PROPERTY_HINT_NONE, "", PROPERTY_USAGE_NOEDITOR));
|
p_list->push_back(PropertyInfo(Variant::ARRAY, "node_connections", PROPERTY_HINT_NONE, "", PROPERTY_USAGE_NOEDITOR));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void AnimationNodeBlendTree::reset_state() {
|
||||||
|
graph_offset = Vector2();
|
||||||
|
nodes.clear();
|
||||||
|
emit_changed();
|
||||||
|
emit_signal("tree_changed");
|
||||||
|
}
|
||||||
|
|
||||||
void AnimationNodeBlendTree::_tree_changed() {
|
void AnimationNodeBlendTree::_tree_changed() {
|
||||||
emit_signal("tree_changed");
|
emit_signal("tree_changed");
|
||||||
}
|
}
|
||||||
|
|
|
@ -351,6 +351,8 @@ protected:
|
||||||
bool _get(const StringName &p_name, Variant &r_ret) const;
|
bool _get(const StringName &p_name, Variant &r_ret) const;
|
||||||
void _get_property_list(List<PropertyInfo> *p_list) const;
|
void _get_property_list(List<PropertyInfo> *p_list) const;
|
||||||
|
|
||||||
|
virtual void reset_state() override;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
enum ConnectionError {
|
enum ConnectionError {
|
||||||
CONNECTION_OK,
|
CONNECTION_OK,
|
||||||
|
|
|
@ -914,6 +914,18 @@ void AnimationNodeStateMachine::_get_property_list(List<PropertyInfo> *p_list) c
|
||||||
p_list->push_back(PropertyInfo(Variant::VECTOR2, "graph_offset", PROPERTY_HINT_NONE, "", PROPERTY_USAGE_NOEDITOR));
|
p_list->push_back(PropertyInfo(Variant::VECTOR2, "graph_offset", PROPERTY_HINT_NONE, "", PROPERTY_USAGE_NOEDITOR));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void AnimationNodeStateMachine::reset_state() {
|
||||||
|
states.clear();
|
||||||
|
transitions.clear();
|
||||||
|
playback = "playback";
|
||||||
|
start_node = StringName();
|
||||||
|
end_node = StringName();
|
||||||
|
graph_offset = Vector2();
|
||||||
|
|
||||||
|
emit_changed();
|
||||||
|
emit_signal("tree_changed");
|
||||||
|
}
|
||||||
|
|
||||||
void AnimationNodeStateMachine::set_node_position(const StringName &p_name, const Vector2 &p_position) {
|
void AnimationNodeStateMachine::set_node_position(const StringName &p_name, const Vector2 &p_position) {
|
||||||
ERR_FAIL_COND(!states.has(p_name));
|
ERR_FAIL_COND(!states.has(p_name));
|
||||||
states[p_name].position = p_position;
|
states[p_name].position = p_position;
|
||||||
|
|
|
@ -171,6 +171,8 @@ protected:
|
||||||
bool _get(const StringName &p_name, Variant &r_ret) const;
|
bool _get(const StringName &p_name, Variant &r_ret) const;
|
||||||
void _get_property_list(List<PropertyInfo> *p_list) const;
|
void _get_property_list(List<PropertyInfo> *p_list) const;
|
||||||
|
|
||||||
|
virtual void reset_state() override;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
virtual void get_parameter_list(List<PropertyInfo> *r_list) const override;
|
virtual void get_parameter_list(List<PropertyInfo> *r_list) const override;
|
||||||
virtual Variant get_parameter_default_value(const StringName &p_parameter) const override;
|
virtual Variant get_parameter_default_value(const StringName &p_parameter) const override;
|
||||||
|
|
|
@ -580,6 +580,10 @@ void Animation::_get_property_list(List<PropertyInfo> *p_list) const {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Animation::reset_state() {
|
||||||
|
clear();
|
||||||
|
}
|
||||||
|
|
||||||
int Animation::add_track(TrackType p_type, int p_at_pos) {
|
int Animation::add_track(TrackType p_type, int p_at_pos) {
|
||||||
if (p_at_pos < 0 || p_at_pos >= tracks.size()) {
|
if (p_at_pos < 0 || p_at_pos >= tracks.size()) {
|
||||||
p_at_pos = tracks.size();
|
p_at_pos = tracks.size();
|
||||||
|
|
|
@ -252,6 +252,8 @@ protected:
|
||||||
bool _get(const StringName &p_name, Variant &r_ret) const;
|
bool _get(const StringName &p_name, Variant &r_ret) const;
|
||||||
void _get_property_list(List<PropertyInfo> *p_list) const;
|
void _get_property_list(List<PropertyInfo> *p_list) const;
|
||||||
|
|
||||||
|
virtual void reset_state() override;
|
||||||
|
|
||||||
static void _bind_methods();
|
static void _bind_methods();
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
|
@ -177,6 +177,14 @@ void FontData::_get_property_list(List<PropertyInfo> *p_list) const {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void FontData::reset_state() {
|
||||||
|
if (rid != RID()) {
|
||||||
|
TS->free(rid);
|
||||||
|
}
|
||||||
|
base_size = 16;
|
||||||
|
path = String();
|
||||||
|
}
|
||||||
|
|
||||||
RID FontData::get_rid() const {
|
RID FontData::get_rid() const {
|
||||||
return rid;
|
return rid;
|
||||||
}
|
}
|
||||||
|
@ -588,6 +596,14 @@ void Font::_get_property_list(List<PropertyInfo> *p_list) const {
|
||||||
p_list->push_back(PropertyInfo(Variant::OBJECT, "data/" + itos(data.size()), PROPERTY_HINT_RESOURCE_TYPE, "FontData"));
|
p_list->push_back(PropertyInfo(Variant::OBJECT, "data/" + itos(data.size()), PROPERTY_HINT_RESOURCE_TYPE, "FontData"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Font::reset_state() {
|
||||||
|
spacing_top = 0;
|
||||||
|
spacing_bottom = 0;
|
||||||
|
cache.clear();
|
||||||
|
cache_wrap.clear();
|
||||||
|
data.clear();
|
||||||
|
}
|
||||||
|
|
||||||
void Font::add_data(const Ref<FontData> &p_data) {
|
void Font::add_data(const Ref<FontData> &p_data) {
|
||||||
ERR_FAIL_COND(p_data.is_null());
|
ERR_FAIL_COND(p_data.is_null());
|
||||||
data.push_back(p_data);
|
data.push_back(p_data);
|
||||||
|
@ -951,7 +967,7 @@ Font::~Font() {
|
||||||
|
|
||||||
/*************************************************************************/
|
/*************************************************************************/
|
||||||
|
|
||||||
RES ResourceFormatLoaderFont::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, bool p_no_cache) {
|
RES ResourceFormatLoaderFont::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, CacheMode p_cache_mode) {
|
||||||
if (r_error) {
|
if (r_error) {
|
||||||
*r_error = ERR_FILE_CANT_OPEN;
|
*r_error = ERR_FILE_CANT_OPEN;
|
||||||
}
|
}
|
||||||
|
@ -1006,7 +1022,7 @@ String ResourceFormatLoaderFont::get_resource_type(const String &p_path) const {
|
||||||
|
|
||||||
#ifndef DISABLE_DEPRECATED
|
#ifndef DISABLE_DEPRECATED
|
||||||
|
|
||||||
RES ResourceFormatLoaderCompatFont::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, bool p_no_cache) {
|
RES ResourceFormatLoaderCompatFont::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, CacheMode p_cache_mode) {
|
||||||
if (r_error) {
|
if (r_error) {
|
||||||
*r_error = ERR_FILE_CANT_OPEN;
|
*r_error = ERR_FILE_CANT_OPEN;
|
||||||
}
|
}
|
||||||
|
|
|
@ -53,6 +53,8 @@ protected:
|
||||||
bool _get(const StringName &p_name, Variant &r_ret) const;
|
bool _get(const StringName &p_name, Variant &r_ret) const;
|
||||||
void _get_property_list(List<PropertyInfo> *p_list) const;
|
void _get_property_list(List<PropertyInfo> *p_list) const;
|
||||||
|
|
||||||
|
virtual void reset_state() override;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
virtual RID get_rid() const override;
|
virtual RID get_rid() const override;
|
||||||
|
|
||||||
|
@ -151,6 +153,8 @@ protected:
|
||||||
bool _get(const StringName &p_name, Variant &r_ret) const;
|
bool _get(const StringName &p_name, Variant &r_ret) const;
|
||||||
void _get_property_list(List<PropertyInfo> *p_list) const;
|
void _get_property_list(List<PropertyInfo> *p_list) const;
|
||||||
|
|
||||||
|
virtual void reset_state() override;
|
||||||
|
|
||||||
void _data_changed();
|
void _data_changed();
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
@ -201,7 +205,7 @@ VARIANT_ENUM_CAST(Font::SpacingType);
|
||||||
|
|
||||||
class ResourceFormatLoaderFont : public ResourceFormatLoader {
|
class ResourceFormatLoaderFont : public ResourceFormatLoader {
|
||||||
public:
|
public:
|
||||||
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, bool p_no_cache = false);
|
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, CacheMode p_cache_mode = CACHE_MODE_REUSE);
|
||||||
virtual void get_recognized_extensions_for_type(const String &p_type, List<String> *p_extensions) const;
|
virtual void get_recognized_extensions_for_type(const String &p_type, List<String> *p_extensions) const;
|
||||||
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
||||||
virtual bool handles_type(const String &p_type) const;
|
virtual bool handles_type(const String &p_type) const;
|
||||||
|
@ -212,7 +216,7 @@ public:
|
||||||
|
|
||||||
class ResourceFormatLoaderCompatFont : public ResourceFormatLoader {
|
class ResourceFormatLoaderCompatFont : public ResourceFormatLoader {
|
||||||
public:
|
public:
|
||||||
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, bool p_no_cache = false);
|
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, CacheMode p_cache_mode = CACHE_MODE_REUSE);
|
||||||
virtual void get_recognized_extensions_for_type(const String &p_type, List<String> *p_extensions) const;
|
virtual void get_recognized_extensions_for_type(const String &p_type, List<String> *p_extensions) const;
|
||||||
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
||||||
virtual bool handles_type(const String &p_type) const;
|
virtual bool handles_type(const String &p_type) const;
|
||||||
|
|
|
@ -1095,6 +1095,15 @@ bool ArrayMesh::_get(const StringName &p_name, Variant &r_ret) const {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void ArrayMesh::reset_state() {
|
||||||
|
clear_surfaces();
|
||||||
|
clear_blend_shapes();
|
||||||
|
|
||||||
|
aabb = AABB();
|
||||||
|
blend_shape_mode = BLEND_SHAPE_MODE_RELATIVE;
|
||||||
|
custom_aabb = AABB();
|
||||||
|
}
|
||||||
|
|
||||||
void ArrayMesh::_get_property_list(List<PropertyInfo> *p_list) const {
|
void ArrayMesh::_get_property_list(List<PropertyInfo> *p_list) const {
|
||||||
if (_is_generated()) {
|
if (_is_generated()) {
|
||||||
return;
|
return;
|
||||||
|
|
|
@ -207,6 +207,8 @@ protected:
|
||||||
bool _get(const StringName &p_name, Variant &r_ret) const;
|
bool _get(const StringName &p_name, Variant &r_ret) const;
|
||||||
void _get_property_list(List<PropertyInfo> *p_list) const;
|
void _get_property_list(List<PropertyInfo> *p_list) const;
|
||||||
|
|
||||||
|
virtual void reset_state() override;
|
||||||
|
|
||||||
static void _bind_methods();
|
static void _bind_methods();
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
|
@ -264,6 +264,9 @@ Array MeshLibrary::_get_item_shapes(int p_item) const {
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void MeshLibrary::reset_state() {
|
||||||
|
clear();
|
||||||
|
}
|
||||||
void MeshLibrary::_bind_methods() {
|
void MeshLibrary::_bind_methods() {
|
||||||
ClassDB::bind_method(D_METHOD("create_item", "id"), &MeshLibrary::create_item);
|
ClassDB::bind_method(D_METHOD("create_item", "id"), &MeshLibrary::create_item);
|
||||||
ClassDB::bind_method(D_METHOD("set_item_name", "id", "name"), &MeshLibrary::set_item_name);
|
ClassDB::bind_method(D_METHOD("set_item_name", "id", "name"), &MeshLibrary::set_item_name);
|
||||||
|
|
|
@ -65,6 +65,7 @@ protected:
|
||||||
bool _get(const StringName &p_name, Variant &r_ret) const;
|
bool _get(const StringName &p_name, Variant &r_ret) const;
|
||||||
void _get_property_list(List<PropertyInfo> *p_list) const;
|
void _get_property_list(List<PropertyInfo> *p_list) const;
|
||||||
|
|
||||||
|
virtual void reset_state() override;
|
||||||
static void _bind_methods();
|
static void _bind_methods();
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
|
@ -1661,6 +1661,9 @@ void PackedScene::set_path(const String &p_path, bool p_take_over) {
|
||||||
Resource::set_path(p_path, p_take_over);
|
Resource::set_path(p_path, p_take_over);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void PackedScene::reset_state() {
|
||||||
|
clear();
|
||||||
|
}
|
||||||
void PackedScene::_bind_methods() {
|
void PackedScene::_bind_methods() {
|
||||||
ClassDB::bind_method(D_METHOD("pack", "path"), &PackedScene::pack);
|
ClassDB::bind_method(D_METHOD("pack", "path"), &PackedScene::pack);
|
||||||
ClassDB::bind_method(D_METHOD("instance", "edit_state"), &PackedScene::instance, DEFVAL(GEN_EDIT_STATE_DISABLED));
|
ClassDB::bind_method(D_METHOD("instance", "edit_state"), &PackedScene::instance, DEFVAL(GEN_EDIT_STATE_DISABLED));
|
||||||
|
|
|
@ -200,6 +200,7 @@ class PackedScene : public Resource {
|
||||||
protected:
|
protected:
|
||||||
virtual bool editor_can_reload_from_file() override { return false; } // this is handled by editor better
|
virtual bool editor_can_reload_from_file() override { return false; } // this is handled by editor better
|
||||||
static void _bind_methods();
|
static void _bind_methods();
|
||||||
|
virtual void reset_state() override;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
enum GenEditState {
|
enum GenEditState {
|
||||||
|
|
|
@ -114,23 +114,8 @@ Error ResourceLoaderText::_parse_sub_resource(VariantParser::Stream *p_stream, R
|
||||||
}
|
}
|
||||||
|
|
||||||
int index = token.value;
|
int index = token.value;
|
||||||
|
ERR_FAIL_COND_V(!int_resources.has(index), ERR_INVALID_PARAMETER);
|
||||||
if (use_nocache) {
|
r_res = int_resources[index];
|
||||||
r_res = int_resources[index];
|
|
||||||
} else {
|
|
||||||
String path = local_path + "::" + itos(index);
|
|
||||||
|
|
||||||
if (!ignore_resource_parsing) {
|
|
||||||
if (!ResourceCache::has(path)) {
|
|
||||||
r_err_str = "Can't load cached sub-resource: " + path;
|
|
||||||
return ERR_PARSE_ERROR;
|
|
||||||
}
|
|
||||||
|
|
||||||
r_res = RES(ResourceCache::get(path));
|
|
||||||
} else {
|
|
||||||
r_res = RES();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
VariantParser::get_token(p_stream, token, line, r_err_str);
|
VariantParser::get_token(p_stream, token, line, r_err_str);
|
||||||
if (token.type != VariantParser::TK_PARENTHESIS_CLOSE) {
|
if (token.type != VariantParser::TK_PARENTHESIS_CLOSE) {
|
||||||
|
@ -440,7 +425,7 @@ Error ResourceLoaderText::load() {
|
||||||
er.type = type;
|
er.type = type;
|
||||||
|
|
||||||
if (use_sub_threads) {
|
if (use_sub_threads) {
|
||||||
Error err = ResourceLoader::load_threaded_request(path, type, use_sub_threads, local_path);
|
Error err = ResourceLoader::load_threaded_request(path, type, use_sub_threads, ResourceFormatLoader::CACHE_MODE_REUSE, local_path);
|
||||||
|
|
||||||
if (err != OK) {
|
if (err != OK) {
|
||||||
if (ResourceLoader::get_abort_on_missing_resources()) {
|
if (ResourceLoader::get_abort_on_missing_resources()) {
|
||||||
|
@ -517,29 +502,44 @@ Error ResourceLoaderText::load() {
|
||||||
//bool exists=ResourceCache::has(path);
|
//bool exists=ResourceCache::has(path);
|
||||||
|
|
||||||
Ref<Resource> res;
|
Ref<Resource> res;
|
||||||
|
bool do_assign = false;
|
||||||
|
|
||||||
if (use_nocache || !ResourceCache::has(path)) { //only if it doesn't exist
|
if (cache_mode == ResourceFormatLoader::CACHE_MODE_REPLACE && ResourceCache::has(path)) {
|
||||||
|
//reuse existing
|
||||||
Object *obj = ClassDB::instance(type);
|
Resource *r = ResourceCache::get(path);
|
||||||
if (!obj) {
|
if (r && r->get_class() == type) {
|
||||||
error_text += "Can't create sub resource of type: " + type;
|
res = Ref<Resource>(r);
|
||||||
_printerr();
|
res->reset_state();
|
||||||
error = ERR_FILE_CORRUPT;
|
do_assign = true;
|
||||||
return error;
|
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
Resource *r = Object::cast_to<Resource>(obj);
|
if (res.is_null()) { //not reuse
|
||||||
if (!r) {
|
if (cache_mode != ResourceFormatLoader::CACHE_MODE_IGNORE && ResourceCache::has(path)) { //only if it doesn't exist
|
||||||
error_text += "Can't create sub resource of type, because not a resource: " + type;
|
//cached, do not assign
|
||||||
_printerr();
|
Resource *r = ResourceCache::get(path);
|
||||||
error = ERR_FILE_CORRUPT;
|
res = Ref<Resource>(r);
|
||||||
return error;
|
} else {
|
||||||
}
|
//create
|
||||||
|
|
||||||
res = Ref<Resource>(r);
|
Object *obj = ClassDB::instance(type);
|
||||||
int_resources[id] = res;
|
if (!obj) {
|
||||||
if (!use_nocache) {
|
error_text += "Can't create sub resource of type: " + type;
|
||||||
res->set_path(path);
|
_printerr();
|
||||||
|
error = ERR_FILE_CORRUPT;
|
||||||
|
return error;
|
||||||
|
}
|
||||||
|
|
||||||
|
Resource *r = Object::cast_to<Resource>(obj);
|
||||||
|
if (!r) {
|
||||||
|
error_text += "Can't create sub resource of type, because not a resource: " + type;
|
||||||
|
_printerr();
|
||||||
|
error = ERR_FILE_CORRUPT;
|
||||||
|
return error;
|
||||||
|
}
|
||||||
|
|
||||||
|
res = Ref<Resource>(r);
|
||||||
|
do_assign = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -557,7 +557,7 @@ Error ResourceLoaderText::load() {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (assign != String()) {
|
if (assign != String()) {
|
||||||
if (res.is_valid()) {
|
if (do_assign) {
|
||||||
res->set(assign, value);
|
res->set(assign, value);
|
||||||
}
|
}
|
||||||
//it's assignment
|
//it's assignment
|
||||||
|
@ -572,6 +572,11 @@ Error ResourceLoaderText::load() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int_resources[id] = res; //always assign int resources
|
||||||
|
if (do_assign && cache_mode != ResourceFormatLoader::CACHE_MODE_IGNORE) {
|
||||||
|
res->set_path(path, cache_mode == ResourceFormatLoader::CACHE_MODE_REPLACE);
|
||||||
|
}
|
||||||
|
|
||||||
if (progress && resources_total > 0) {
|
if (progress && resources_total > 0) {
|
||||||
*progress = resource_current / float(resources_total);
|
*progress = resource_current / float(resources_total);
|
||||||
}
|
}
|
||||||
|
@ -589,23 +594,33 @@ Error ResourceLoaderText::load() {
|
||||||
return error;
|
return error;
|
||||||
}
|
}
|
||||||
|
|
||||||
Object *obj = ClassDB::instance(res_type);
|
if (cache_mode == ResourceFormatLoader::CACHE_MODE_REPLACE && ResourceCache::has(local_path)) {
|
||||||
if (!obj) {
|
Resource *r = ResourceCache::get(local_path);
|
||||||
error_text += "Can't create sub resource of type: " + res_type;
|
if (r->get_class() == res_type) {
|
||||||
_printerr();
|
r->reset_state();
|
||||||
error = ERR_FILE_CORRUPT;
|
resource = Ref<Resource>(r);
|
||||||
return error;
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Resource *r = Object::cast_to<Resource>(obj);
|
if (!resource.is_valid()) {
|
||||||
if (!r) {
|
Object *obj = ClassDB::instance(res_type);
|
||||||
error_text += "Can't create sub resource of type, because not a resource: " + res_type;
|
if (!obj) {
|
||||||
_printerr();
|
error_text += "Can't create sub resource of type: " + res_type;
|
||||||
error = ERR_FILE_CORRUPT;
|
_printerr();
|
||||||
return error;
|
error = ERR_FILE_CORRUPT;
|
||||||
}
|
return error;
|
||||||
|
}
|
||||||
|
|
||||||
resource = Ref<Resource>(r);
|
Resource *r = Object::cast_to<Resource>(obj);
|
||||||
|
if (!r) {
|
||||||
|
error_text += "Can't create sub resource of type, because not a resource: " + res_type;
|
||||||
|
_printerr();
|
||||||
|
error = ERR_FILE_CORRUPT;
|
||||||
|
return error;
|
||||||
|
}
|
||||||
|
|
||||||
|
resource = Ref<Resource>(r);
|
||||||
|
}
|
||||||
|
|
||||||
resource_current++;
|
resource_current++;
|
||||||
|
|
||||||
|
@ -620,7 +635,7 @@ Error ResourceLoaderText::load() {
|
||||||
_printerr();
|
_printerr();
|
||||||
} else {
|
} else {
|
||||||
error = OK;
|
error = OK;
|
||||||
if (!use_nocache) {
|
if (cache_mode != ResourceFormatLoader::CACHE_MODE_IGNORE) {
|
||||||
if (!ResourceCache::has(res_path)) {
|
if (!ResourceCache::has(res_path)) {
|
||||||
resource->set_path(res_path);
|
resource->set_path(res_path);
|
||||||
}
|
}
|
||||||
|
@ -668,7 +683,7 @@ Error ResourceLoaderText::load() {
|
||||||
error = OK;
|
error = OK;
|
||||||
//get it here
|
//get it here
|
||||||
resource = packed_scene;
|
resource = packed_scene;
|
||||||
if (!use_nocache && !ResourceCache::has(res_path)) {
|
if (cache_mode != ResourceFormatLoader::CACHE_MODE_IGNORE && !ResourceCache::has(res_path)) {
|
||||||
packed_scene->set_path(res_path);
|
packed_scene->set_path(res_path);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1241,7 +1256,7 @@ String ResourceLoaderText::recognize(FileAccess *p_f) {
|
||||||
|
|
||||||
/////////////////////
|
/////////////////////
|
||||||
|
|
||||||
RES ResourceFormatLoaderText::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, bool p_no_cache) {
|
RES ResourceFormatLoaderText::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, CacheMode p_cache_mode) {
|
||||||
if (r_error) {
|
if (r_error) {
|
||||||
*r_error = ERR_CANT_OPEN;
|
*r_error = ERR_CANT_OPEN;
|
||||||
}
|
}
|
||||||
|
@ -1254,7 +1269,7 @@ RES ResourceFormatLoaderText::load(const String &p_path, const String &p_origina
|
||||||
|
|
||||||
ResourceLoaderText loader;
|
ResourceLoaderText loader;
|
||||||
String path = p_original_path != "" ? p_original_path : p_path;
|
String path = p_original_path != "" ? p_original_path : p_path;
|
||||||
loader.use_nocache = p_no_cache;
|
loader.cache_mode = p_cache_mode;
|
||||||
loader.use_sub_threads = p_use_sub_threads;
|
loader.use_sub_threads = p_use_sub_threads;
|
||||||
loader.local_path = ProjectSettings::get_singleton()->localize_path(path);
|
loader.local_path = ProjectSettings::get_singleton()->localize_path(path);
|
||||||
loader.progress = r_progress;
|
loader.progress = r_progress;
|
||||||
|
|
|
@ -69,7 +69,7 @@ class ResourceLoaderText {
|
||||||
|
|
||||||
VariantParser::Tag next_tag;
|
VariantParser::Tag next_tag;
|
||||||
|
|
||||||
bool use_nocache = false;
|
ResourceFormatLoader::CacheMode cache_mode = ResourceFormatLoader::CACHE_MODE_REUSE;
|
||||||
|
|
||||||
bool use_sub_threads = false;
|
bool use_sub_threads = false;
|
||||||
float *progress = nullptr;
|
float *progress = nullptr;
|
||||||
|
@ -134,7 +134,7 @@ public:
|
||||||
class ResourceFormatLoaderText : public ResourceFormatLoader {
|
class ResourceFormatLoaderText : public ResourceFormatLoader {
|
||||||
public:
|
public:
|
||||||
static ResourceFormatLoaderText *singleton;
|
static ResourceFormatLoaderText *singleton;
|
||||||
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, bool p_no_cache = false);
|
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, CacheMode p_cache_mode = CACHE_MODE_REUSE);
|
||||||
virtual void get_recognized_extensions_for_type(const String &p_type, List<String> *p_extensions) const;
|
virtual void get_recognized_extensions_for_type(const String &p_type, List<String> *p_extensions) const;
|
||||||
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
||||||
virtual bool handles_type(const String &p_type) const;
|
virtual bool handles_type(const String &p_type) const;
|
||||||
|
|
|
@ -161,7 +161,7 @@ Shader::~Shader() {
|
||||||
|
|
||||||
////////////
|
////////////
|
||||||
|
|
||||||
RES ResourceFormatLoaderShader::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, bool p_no_cache) {
|
RES ResourceFormatLoaderShader::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, CacheMode p_cache_mode) {
|
||||||
if (r_error) {
|
if (r_error) {
|
||||||
*r_error = ERR_FILE_CANT_OPEN;
|
*r_error = ERR_FILE_CANT_OPEN;
|
||||||
}
|
}
|
||||||
|
|
|
@ -102,7 +102,7 @@ VARIANT_ENUM_CAST(Shader::Mode);
|
||||||
|
|
||||||
class ResourceFormatLoaderShader : public ResourceFormatLoader {
|
class ResourceFormatLoaderShader : public ResourceFormatLoader {
|
||||||
public:
|
public:
|
||||||
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, bool p_no_cache = false);
|
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, CacheMode p_cache_mode = CACHE_MODE_REUSE);
|
||||||
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
||||||
virtual bool handles_type(const String &p_type) const;
|
virtual bool handles_type(const String &p_type) const;
|
||||||
virtual String get_resource_type(const String &p_path) const;
|
virtual String get_resource_type(const String &p_path) const;
|
||||||
|
|
|
@ -81,6 +81,10 @@ void Skin::clear_binds() {
|
||||||
emit_changed();
|
emit_changed();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Skin::reset_state() {
|
||||||
|
clear_binds();
|
||||||
|
}
|
||||||
|
|
||||||
bool Skin::_set(const StringName &p_name, const Variant &p_value) {
|
bool Skin::_set(const StringName &p_name, const Variant &p_value) {
|
||||||
String name = p_name;
|
String name = p_name;
|
||||||
if (name == "bind_count") {
|
if (name == "bind_count") {
|
||||||
|
|
|
@ -52,6 +52,7 @@ protected:
|
||||||
bool _get(const StringName &p_name, Variant &r_ret) const;
|
bool _get(const StringName &p_name, Variant &r_ret) const;
|
||||||
void _get_property_list(List<PropertyInfo> *p_list) const;
|
void _get_property_list(List<PropertyInfo> *p_list) const;
|
||||||
|
|
||||||
|
virtual void reset_state() override;
|
||||||
static void _bind_methods();
|
static void _bind_methods();
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
|
@ -736,7 +736,7 @@ StreamTexture2D::~StreamTexture2D() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
RES ResourceFormatLoaderStreamTexture2D::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, bool p_no_cache) {
|
RES ResourceFormatLoaderStreamTexture2D::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, CacheMode p_cache_mode) {
|
||||||
Ref<StreamTexture2D> st;
|
Ref<StreamTexture2D> st;
|
||||||
st.instance();
|
st.instance();
|
||||||
Error err = st->load(p_path);
|
Error err = st->load(p_path);
|
||||||
|
@ -1034,7 +1034,7 @@ StreamTexture3D::~StreamTexture3D() {
|
||||||
|
|
||||||
/////////////////////////////
|
/////////////////////////////
|
||||||
|
|
||||||
RES ResourceFormatLoaderStreamTexture3D::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, bool p_no_cache) {
|
RES ResourceFormatLoaderStreamTexture3D::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, CacheMode p_cache_mode) {
|
||||||
Ref<StreamTexture3D> st;
|
Ref<StreamTexture3D> st;
|
||||||
st.instance();
|
st.instance();
|
||||||
Error err = st->load(p_path);
|
Error err = st->load(p_path);
|
||||||
|
@ -2432,7 +2432,7 @@ StreamTextureLayered::~StreamTextureLayered() {
|
||||||
|
|
||||||
/////////////////////////////////////////////////
|
/////////////////////////////////////////////////
|
||||||
|
|
||||||
RES ResourceFormatLoaderStreamTextureLayered::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, bool p_no_cache) {
|
RES ResourceFormatLoaderStreamTextureLayered::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, CacheMode p_cache_mode) {
|
||||||
Ref<StreamTextureLayered> st;
|
Ref<StreamTextureLayered> st;
|
||||||
if (p_path.get_extension().to_lower() == "stexarray") {
|
if (p_path.get_extension().to_lower() == "stexarray") {
|
||||||
Ref<StreamTexture2DArray> s;
|
Ref<StreamTexture2DArray> s;
|
||||||
|
|
|
@ -211,7 +211,7 @@ public:
|
||||||
|
|
||||||
class ResourceFormatLoaderStreamTexture2D : public ResourceFormatLoader {
|
class ResourceFormatLoaderStreamTexture2D : public ResourceFormatLoader {
|
||||||
public:
|
public:
|
||||||
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, bool p_no_cache = false);
|
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, CacheMode p_cache_mode = CACHE_MODE_REUSE);
|
||||||
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
||||||
virtual bool handles_type(const String &p_type) const;
|
virtual bool handles_type(const String &p_type) const;
|
||||||
virtual String get_resource_type(const String &p_path) const;
|
virtual String get_resource_type(const String &p_path) const;
|
||||||
|
@ -513,7 +513,7 @@ public:
|
||||||
|
|
||||||
class ResourceFormatLoaderStreamTextureLayered : public ResourceFormatLoader {
|
class ResourceFormatLoaderStreamTextureLayered : public ResourceFormatLoader {
|
||||||
public:
|
public:
|
||||||
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, bool p_no_cache = false);
|
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, CacheMode p_cache_mode = CACHE_MODE_REUSE);
|
||||||
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
||||||
virtual bool handles_type(const String &p_type) const;
|
virtual bool handles_type(const String &p_type) const;
|
||||||
virtual String get_resource_type(const String &p_path) const;
|
virtual String get_resource_type(const String &p_path) const;
|
||||||
|
@ -631,7 +631,7 @@ public:
|
||||||
|
|
||||||
class ResourceFormatLoaderStreamTexture3D : public ResourceFormatLoader {
|
class ResourceFormatLoaderStreamTexture3D : public ResourceFormatLoader {
|
||||||
public:
|
public:
|
||||||
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, bool p_no_cache = false);
|
virtual RES load(const String &p_path, const String &p_original_path = "", Error *r_error = nullptr, bool p_use_sub_threads = false, float *r_progress = nullptr, CacheMode p_cache_mode = CACHE_MODE_REUSE);
|
||||||
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
||||||
virtual bool handles_type(const String &p_type) const;
|
virtual bool handles_type(const String &p_type) const;
|
||||||
virtual String get_resource_type(const String &p_path) const;
|
virtual String get_resource_type(const String &p_path) const;
|
||||||
|
|
|
@ -930,6 +930,9 @@ void Theme::get_type_list(List<StringName> *p_list) const {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Theme::reset_state() {
|
||||||
|
clear();
|
||||||
|
}
|
||||||
void Theme::_bind_methods() {
|
void Theme::_bind_methods() {
|
||||||
ClassDB::bind_method(D_METHOD("set_icon", "name", "node_type", "texture"), &Theme::set_icon);
|
ClassDB::bind_method(D_METHOD("set_icon", "name", "node_type", "texture"), &Theme::set_icon);
|
||||||
ClassDB::bind_method(D_METHOD("get_icon", "name", "node_type"), &Theme::get_icon);
|
ClassDB::bind_method(D_METHOD("get_icon", "name", "node_type"), &Theme::get_icon);
|
||||||
|
|
|
@ -80,6 +80,8 @@ protected:
|
||||||
|
|
||||||
static void _bind_methods();
|
static void _bind_methods();
|
||||||
|
|
||||||
|
virtual void reset_state() override;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
static Ref<Theme> get_default();
|
static Ref<Theme> get_default();
|
||||||
static void set_default(const Ref<Theme> &p_default);
|
static void set_default(const Ref<Theme> &p_default);
|
||||||
|
|
|
@ -1076,6 +1076,10 @@ int TileSet::find_tile_by_name(const String &p_name) const {
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void TileSet::reset_state() {
|
||||||
|
clear();
|
||||||
|
}
|
||||||
|
|
||||||
void TileSet::clear() {
|
void TileSet::clear() {
|
||||||
tile_map.clear();
|
tile_map.clear();
|
||||||
notify_property_list_changed();
|
notify_property_list_changed();
|
||||||
|
|
|
@ -136,6 +136,8 @@ protected:
|
||||||
|
|
||||||
static void _bind_methods();
|
static void _bind_methods();
|
||||||
|
|
||||||
|
virtual void reset_state() override;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
void create_tile(int p_id);
|
void create_tile(int p_id);
|
||||||
|
|
||||||
|
|
|
@ -1095,6 +1095,12 @@ bool VisualShader::_get(const StringName &p_name, Variant &r_ret) const {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void VisualShader::reset_state() {
|
||||||
|
#ifndef _MSC_VER
|
||||||
|
#warning everything needs to be cleared here
|
||||||
|
#endif
|
||||||
|
emit_changed();
|
||||||
|
}
|
||||||
void VisualShader::_get_property_list(List<PropertyInfo> *p_list) const {
|
void VisualShader::_get_property_list(List<PropertyInfo> *p_list) const {
|
||||||
//mode
|
//mode
|
||||||
p_list->push_back(PropertyInfo(Variant::INT, "mode", PROPERTY_HINT_ENUM, "Node3D,CanvasItem,Particles,Sky"));
|
p_list->push_back(PropertyInfo(Variant::INT, "mode", PROPERTY_HINT_ENUM, "Node3D,CanvasItem,Particles,Sky"));
|
||||||
|
|
|
@ -126,6 +126,8 @@ protected:
|
||||||
bool _get(const StringName &p_name, Variant &r_ret) const;
|
bool _get(const StringName &p_name, Variant &r_ret) const;
|
||||||
void _get_property_list(List<PropertyInfo> *p_list) const;
|
void _get_property_list(List<PropertyInfo> *p_list) const;
|
||||||
|
|
||||||
|
virtual void reset_state() override;
|
||||||
|
|
||||||
public: // internal methods
|
public: // internal methods
|
||||||
void set_shader_type(Type p_type);
|
void set_shader_type(Type p_type);
|
||||||
Type get_shader_type() const;
|
Type get_shader_type() const;
|
||||||
|
|
Loading…
Reference in New Issue