aboutsummaryrefslogtreecommitdiff
path: root/core/io/resource_loader.cpp
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--core/io/resource_loader.cpp198
1 files changed, 84 insertions, 114 deletions
diff --git a/core/io/resource_loader.cpp b/core/io/resource_loader.cpp
index c14389eef..5d8ec57ee 100644
--- a/core/io/resource_loader.cpp
+++ b/core/io/resource_loader.cpp
@@ -27,81 +27,76 @@
/* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
/*************************************************************************/
#include "resource_loader.h"
-#include "print_string.h"
#include "global_config.h"
-#include "path_remap.h"
#include "os/file_access.h"
#include "os/os.h"
+#include "path_remap.h"
+#include "print_string.h"
ResourceFormatLoader *ResourceLoader::loader[MAX_LOADERS];
-int ResourceLoader::loader_count=0;
-
+int ResourceLoader::loader_count = 0;
Error ResourceInteractiveLoader::wait() {
Error err = poll();
- while (err==OK) {
- err=poll();
+ while (err == OK) {
+ err = poll();
}
return err;
}
-bool ResourceFormatLoader::recognize_path(const String& p_path,const String& p_for_type) const {
-
+bool ResourceFormatLoader::recognize_path(const String &p_path, const String &p_for_type) const {
String extension = p_path.get_extension();
List<String> extensions;
- if (p_for_type==String()) {
+ if (p_for_type == String()) {
get_recognized_extensions(&extensions);
} else {
- get_recognized_extensions_for_type(p_for_type,&extensions);
+ get_recognized_extensions_for_type(p_for_type, &extensions);
}
- for (List<String>::Element *E=extensions.front();E;E=E->next()) {
-
+ for (List<String>::Element *E = extensions.front(); E; E = E->next()) {
- if (E->get().nocasecmp_to(extension)==0)
+ if (E->get().nocasecmp_to(extension) == 0)
return true;
}
return false;
-
}
+void ResourceFormatLoader::get_recognized_extensions_for_type(const String &p_type, List<String> *p_extensions) const {
-void ResourceFormatLoader::get_recognized_extensions_for_type(const String& p_type,List<String> *p_extensions) const {
-
- if (p_type=="" || handles_type(p_type))
+ if (p_type == "" || handles_type(p_type))
get_recognized_extensions(p_extensions);
}
-void ResourceLoader::get_recognized_extensions_for_type(const String& p_type,List<String> *p_extensions) {
+void ResourceLoader::get_recognized_extensions_for_type(const String &p_type, List<String> *p_extensions) {
- for (int i=0;i<loader_count;i++) {
- loader[i]->get_recognized_extensions_for_type(p_type,p_extensions);
+ for (int i = 0; i < loader_count; i++) {
+ loader[i]->get_recognized_extensions_for_type(p_type, p_extensions);
}
-
}
void ResourceInteractiveLoader::_bind_methods() {
- ClassDB::bind_method(D_METHOD("get_resource"),&ResourceInteractiveLoader::get_resource);
- ClassDB::bind_method(D_METHOD("poll"),&ResourceInteractiveLoader::poll);
- ClassDB::bind_method(D_METHOD("wait"),&ResourceInteractiveLoader::wait);
- ClassDB::bind_method(D_METHOD("get_stage"),&ResourceInteractiveLoader::get_stage);
- ClassDB::bind_method(D_METHOD("get_stage_count"),&ResourceInteractiveLoader::get_stage_count);
+ ClassDB::bind_method(D_METHOD("get_resource"), &ResourceInteractiveLoader::get_resource);
+ ClassDB::bind_method(D_METHOD("poll"), &ResourceInteractiveLoader::poll);
+ ClassDB::bind_method(D_METHOD("wait"), &ResourceInteractiveLoader::wait);
+ ClassDB::bind_method(D_METHOD("get_stage"), &ResourceInteractiveLoader::get_stage);
+ ClassDB::bind_method(D_METHOD("get_stage_count"), &ResourceInteractiveLoader::get_stage_count);
}
class ResourceInteractiveLoaderDefault : public ResourceInteractiveLoader {
- GDCLASS( ResourceInteractiveLoaderDefault, ResourceInteractiveLoader );
-public:
+ GDCLASS(ResourceInteractiveLoaderDefault, ResourceInteractiveLoader);
+public:
Ref<Resource> resource;
- virtual void set_local_path(const String& p_local_path) { /*scene->set_filename(p_local_path);*/ }
+ virtual void set_local_path(const String &p_local_path) { /*scene->set_filename(p_local_path);*/
+ }
virtual Ref<Resource> get_resource() { return resource; }
virtual Error poll() { return ERR_FILE_EOF; }
virtual int get_stage() const { return 1; }
@@ -110,94 +105,87 @@ public:
ResourceInteractiveLoaderDefault() {}
};
-
-
Ref<ResourceInteractiveLoader> ResourceFormatLoader::load_interactive(const String &p_path, Error *r_error) {
//either this
- Ref<Resource> res = load(p_path,p_path,r_error);
+ Ref<Resource> res = load(p_path, p_path, r_error);
if (res.is_null())
return Ref<ResourceInteractiveLoader>();
- Ref<ResourceInteractiveLoaderDefault> ril = Ref<ResourceInteractiveLoaderDefault>( memnew( ResourceInteractiveLoaderDefault ));
- ril->resource=res;
+ Ref<ResourceInteractiveLoaderDefault> ril = Ref<ResourceInteractiveLoaderDefault>(memnew(ResourceInteractiveLoaderDefault));
+ ril->resource = res;
return ril;
}
-RES ResourceFormatLoader::load(const String &p_path, const String& p_original_path, Error *r_error) {
+RES ResourceFormatLoader::load(const String &p_path, const String &p_original_path, Error *r_error) {
-
- String path=p_path;
+ String path = p_path;
//or this must be implemented
- Ref<ResourceInteractiveLoader> ril = load_interactive(p_path,r_error);
+ Ref<ResourceInteractiveLoader> ril = load_interactive(p_path, r_error);
if (!ril.is_valid())
return RES();
ril->set_local_path(p_original_path);
- while(true) {
+ while (true) {
Error err = ril->poll();
- if (err==ERR_FILE_EOF) {
+ if (err == ERR_FILE_EOF) {
if (r_error)
- *r_error=OK;
+ *r_error = OK;
return ril->get_resource();
}
if (r_error)
- *r_error=err;
+ *r_error = err;
- ERR_FAIL_COND_V(err!=OK,RES());
+ ERR_FAIL_COND_V(err != OK, RES());
}
return RES();
-
}
-void ResourceFormatLoader::get_dependencies(const String& p_path, List<String> *p_dependencies, bool p_add_types) {
+void ResourceFormatLoader::get_dependencies(const String &p_path, List<String> *p_dependencies, bool p_add_types) {
//do nothing by default
}
-
///////////////////////////////////
-
-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, bool p_no_cache, Error *r_error) {
if (r_error)
- *r_error=ERR_CANT_OPEN;
+ *r_error = ERR_CANT_OPEN;
String local_path;
if (p_path.is_rel_path())
- local_path="res://"+p_path;
+ local_path = "res://" + p_path;
else
local_path = GlobalConfig::get_singleton()->localize_path(p_path);
-
- ERR_FAIL_COND_V(local_path=="",RES());
+ ERR_FAIL_COND_V(local_path == "", RES());
if (!p_no_cache && ResourceCache::has(local_path)) {
if (OS::get_singleton()->is_stdout_verbose())
- print_line("load resource: "+local_path+" (cached)");
+ print_line("load resource: " + local_path + " (cached)");
- return RES( ResourceCache::get(local_path ) );
+ return RES(ResourceCache::get(local_path));
}
if (OS::get_singleton()->is_stdout_verbose())
- print_line("load resource: "+local_path);
- bool found=false;
+ print_line("load resource: " + local_path);
+ bool found = false;
- for (int i=0;i<loader_count;i++) {
+ for (int i = 0; i < loader_count; i++) {
- if (!loader[i]->recognize_path(local_path,p_type_hint)) {
+ if (!loader[i]->recognize_path(local_path, p_type_hint)) {
print_line("path not recognized");
continue;
}
- found=true;
- RES res = loader[i]->load(local_path,local_path,r_error);
+ found = true;
+ RES res = loader[i]->load(local_path, local_path, r_error);
if (res.is_null()) {
continue;
}
@@ -217,37 +205,31 @@ RES ResourceLoader::load(const String &p_path, const String& p_type_hint, bool p
}
if (found) {
- ERR_EXPLAIN("Failed loading resource: "+p_path);
+ ERR_EXPLAIN("Failed loading resource: " + p_path);
} else {
- ERR_EXPLAIN("No loader found for resource: "+p_path);
+ ERR_EXPLAIN("No loader found for resource: " + p_path);
}
ERR_FAIL_V(RES());
return RES();
}
-
-
-Ref<ResourceInteractiveLoader> ResourceLoader::load_interactive(const String &p_path,const String& p_type_hint,bool p_no_cache,Error *r_error) {
-
+Ref<ResourceInteractiveLoader> ResourceLoader::load_interactive(const String &p_path, const String &p_type_hint, bool p_no_cache, Error *r_error) {
if (r_error)
- *r_error=ERR_CANT_OPEN;
+ *r_error = ERR_CANT_OPEN;
String local_path;
if (p_path.is_rel_path())
- local_path="res://"+p_path;
+ local_path = "res://" + p_path;
else
local_path = GlobalConfig::get_singleton()->localize_path(p_path);
-
- ERR_FAIL_COND_V(local_path=="",Ref<ResourceInteractiveLoader>());
-
-
+ ERR_FAIL_COND_V(local_path == "", Ref<ResourceInteractiveLoader>());
if (!p_no_cache && ResourceCache::has(local_path)) {
if (OS::get_singleton()->is_stdout_verbose())
- print_line("load resource: "+local_path+" (cached)");
+ print_line("load resource: " + local_path + " (cached)");
Ref<Resource> res_cached = ResourceCache::get(local_path);
Ref<ResourceInteractiveLoaderDefault> ril = Ref<ResourceInteractiveLoaderDefault>(memnew(ResourceInteractiveLoaderDefault));
@@ -259,14 +241,14 @@ Ref<ResourceInteractiveLoader> ResourceLoader::load_interactive(const String &p_
if (OS::get_singleton()->is_stdout_verbose())
print_line("load resource: ");
- bool found=false;
+ bool found = false;
- for (int i=0;i<loader_count;i++) {
+ for (int i = 0; i < loader_count; i++) {
- if (!loader[i]->recognize_path(local_path,p_type_hint))
+ if (!loader[i]->recognize_path(local_path, p_type_hint))
continue;
- found=true;
- Ref<ResourceInteractiveLoader> ril = loader[i]->load_interactive(local_path,r_error);
+ found = true;
+ Ref<ResourceInteractiveLoader> ril = loader[i]->load_interactive(local_path, r_error);
if (ril.is_null())
continue;
if (!p_no_cache)
@@ -276,39 +258,37 @@ Ref<ResourceInteractiveLoader> ResourceLoader::load_interactive(const String &p_
}
if (found) {
- ERR_EXPLAIN("Failed loading resource: "+p_path);
+ ERR_EXPLAIN("Failed loading resource: " + p_path);
} else {
- ERR_EXPLAIN("No loader found for resource: "+p_path);
+ ERR_EXPLAIN("No loader found for resource: " + p_path);
}
ERR_FAIL_V(Ref<ResourceInteractiveLoader>());
return Ref<ResourceInteractiveLoader>();
-
}
void ResourceLoader::add_resource_format_loader(ResourceFormatLoader *p_format_loader, bool p_at_front) {
- ERR_FAIL_COND( loader_count >= MAX_LOADERS );
+ ERR_FAIL_COND(loader_count >= MAX_LOADERS);
if (p_at_front) {
- for(int i=loader_count;i>0;i--) {
- loader[i]=loader[i-1];
+ for (int i = loader_count; i > 0; i--) {
+ loader[i] = loader[i - 1];
}
- loader[0]=p_format_loader;
+ loader[0] = p_format_loader;
loader_count++;
} else {
- loader[loader_count++]=p_format_loader;
+ loader[loader_count++] = p_format_loader;
}
}
-void ResourceLoader::get_dependencies(const String& p_path, List<String> *p_dependencies, bool p_add_types) {
-
+void ResourceLoader::get_dependencies(const String &p_path, List<String> *p_dependencies, bool p_add_types) {
String local_path;
if (p_path.is_rel_path())
- local_path="res://"+p_path;
+ local_path = "res://" + p_path;
else
local_path = GlobalConfig::get_singleton()->localize_path(p_path);
- for (int i=0;i<loader_count;i++) {
+ for (int i = 0; i < loader_count; i++) {
if (!loader[i]->recognize_path(local_path))
continue;
@@ -317,22 +297,19 @@ void ResourceLoader::get_dependencies(const String& p_path, List<String> *p_depe
continue;
*/
- loader[i]->get_dependencies(local_path,p_dependencies,p_add_types);
-
+ loader[i]->get_dependencies(local_path, p_dependencies, p_add_types);
}
}
-Error ResourceLoader::rename_dependencies(const String &p_path,const Map<String,String>& p_map) {
-
+Error ResourceLoader::rename_dependencies(const String &p_path, const Map<String, String> &p_map) {
String local_path;
if (p_path.is_rel_path())
- local_path="res://"+p_path;
+ local_path = "res://" + p_path;
else
local_path = GlobalConfig::get_singleton()->localize_path(p_path);
-
- for (int i=0;i<loader_count;i++) {
+ for (int i = 0; i < loader_count; i++) {
if (!loader[i]->recognize_path(local_path))
continue;
@@ -341,41 +318,34 @@ Error ResourceLoader::rename_dependencies(const String &p_path,const Map<String,
continue;
*/
- return loader[i]->rename_dependencies(local_path,p_map);
-
+ return loader[i]->rename_dependencies(local_path, p_map);
}
return OK; // ??
-
}
-
-
String ResourceLoader::get_resource_type(const String &p_path) {
String local_path;
if (p_path.is_rel_path())
- local_path="res://"+p_path;
+ local_path = "res://" + p_path;
else
local_path = GlobalConfig::get_singleton()->localize_path(p_path);
-
- for (int i=0;i<loader_count;i++) {
+ for (int i = 0; i < loader_count; i++) {
String result = loader[i]->get_resource_type(local_path);
- if (result!="")
+ if (result != "")
return result;
}
return "";
-
}
-ResourceLoadErrorNotify ResourceLoader::err_notify=NULL;
-void *ResourceLoader::err_notify_ud=NULL;
-
-DependencyErrorNotify ResourceLoader::dep_err_notify=NULL;
-void *ResourceLoader::dep_err_notify_ud=NULL;
+ResourceLoadErrorNotify ResourceLoader::err_notify = NULL;
+void *ResourceLoader::err_notify_ud = NULL;
-bool ResourceLoader::abort_on_missing_resource=true;
-bool ResourceLoader::timestamp_on_load=false;
+DependencyErrorNotify ResourceLoader::dep_err_notify = NULL;
+void *ResourceLoader::dep_err_notify_ud = NULL;
+bool ResourceLoader::abort_on_missing_resource = true;
+bool ResourceLoader::timestamp_on_load = false;