| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | /**************************************************************************/ | 
					
						
							|  |  |  | /*  resource_format_binary.h                                              */ | 
					
						
							|  |  |  | /**************************************************************************/ | 
					
						
							|  |  |  | /*                         This file is part of:                          */ | 
					
						
							|  |  |  | /*                             GODOT ENGINE                               */ | 
					
						
							|  |  |  | /*                        https://godotengine.org                         */ | 
					
						
							|  |  |  | /**************************************************************************/ | 
					
						
							|  |  |  | /* Copyright (c) 2014-present Godot Engine contributors (see AUTHORS.md). */ | 
					
						
							|  |  |  | /* Copyright (c) 2007-2014 Juan Linietsky, Ariel Manzur.                  */ | 
					
						
							|  |  |  | /*                                                                        */ | 
					
						
							|  |  |  | /* Permission is hereby granted, free of charge, to any person obtaining  */ | 
					
						
							|  |  |  | /* a copy of this software and associated documentation files (the        */ | 
					
						
							|  |  |  | /* "Software"), to deal in the Software without restriction, including    */ | 
					
						
							|  |  |  | /* without limitation the rights to use, copy, modify, merge, publish,    */ | 
					
						
							|  |  |  | /* distribute, sublicense, and/or sell copies of the Software, and to     */ | 
					
						
							|  |  |  | /* permit persons to whom the Software is furnished to do so, subject to  */ | 
					
						
							|  |  |  | /* the following conditions:                                              */ | 
					
						
							|  |  |  | /*                                                                        */ | 
					
						
							|  |  |  | /* The above copyright notice and this permission notice shall be         */ | 
					
						
							|  |  |  | /* included in all copies or substantial portions of the Software.        */ | 
					
						
							|  |  |  | /*                                                                        */ | 
					
						
							|  |  |  | /* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,        */ | 
					
						
							|  |  |  | /* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF     */ | 
					
						
							|  |  |  | /* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. */ | 
					
						
							|  |  |  | /* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY   */ | 
					
						
							|  |  |  | /* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,   */ | 
					
						
							|  |  |  | /* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE      */ | 
					
						
							|  |  |  | /* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.                 */ | 
					
						
							|  |  |  | /**************************************************************************/ | 
					
						
							| 
									
										
										
										
											2018-01-05 00:50:27 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-11 14:51:48 +02:00
										 |  |  | #include "core/io/file_access.h"
 | 
					
						
							| 
									
										
										
										
											2018-09-11 18:13:45 +02:00
										 |  |  | #include "core/io/resource_loader.h"
 | 
					
						
							|  |  |  | #include "core/io/resource_saver.h"
 | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-28 08:27:04 -03:00
										 |  |  | class ResourceLoaderBinary { | 
					
						
							| 
									
										
										
										
											2020-05-12 17:01:17 +02:00
										 |  |  | 	bool translation_remapped = false; | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 	String local_path; | 
					
						
							|  |  |  | 	String res_path; | 
					
						
							|  |  |  | 	String type; | 
					
						
							|  |  |  | 	Ref<Resource> resource; | 
					
						
							| 
									
										
										
										
											2020-05-12 17:01:17 +02:00
										 |  |  | 	uint32_t ver_format = 0; | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-23 11:08:58 +02:00
										 |  |  | 	Ref<FileAccess> f; | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-12 17:01:17 +02:00
										 |  |  | 	uint64_t importmd_ofs = 0; | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-07-23 16:01:18 -03:00
										 |  |  | 	ResourceUID::ID uid = ResourceUID::INVALID_ID; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 	Vector<char> str_buf; | 
					
						
							| 
									
										
										
										
											2022-05-03 01:43:50 +02:00
										 |  |  | 	List<Ref<Resource>> resource_cache; | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	Vector<StringName> string_map; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-15 08:29:46 -03:00
										 |  |  | 	StringName _get_string(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-08 12:02:49 +07:00
										 |  |  | 	struct ExtResource { | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 		String path; | 
					
						
							|  |  |  | 		String type; | 
					
						
							| 
									
										
										
										
											2021-07-23 16:01:18 -03:00
										 |  |  | 		ResourceUID::ID uid = ResourceUID::INVALID_ID; | 
					
						
							| 
									
										
										
										
											2023-03-05 01:09:18 +01:00
										 |  |  | 		Ref<ResourceLoader::LoadToken> load_token; | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 	}; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-07-20 21:36:56 -03:00
										 |  |  | 	bool using_named_scene_ids = false; | 
					
						
							| 
									
										
										
										
											2021-07-23 16:01:18 -03:00
										 |  |  | 	bool using_uids = false; | 
					
						
							| 
									
										
										
										
											2023-01-19 19:12:25 +01:00
										 |  |  | 	String script_class; | 
					
						
							| 
									
										
										
										
											2020-05-12 17:01:17 +02:00
										 |  |  | 	bool use_sub_threads = false; | 
					
						
							|  |  |  | 	float *progress = nullptr; | 
					
						
							| 
									
										
										
										
											2017-08-08 12:02:49 +07:00
										 |  |  | 	Vector<ExtResource> external_resources; | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-08 12:02:49 +07:00
										 |  |  | 	struct IntResource { | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 		String path; | 
					
						
							|  |  |  | 		uint64_t offset; | 
					
						
							|  |  |  | 	}; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-08 12:02:49 +07:00
										 |  |  | 	Vector<IntResource> internal_resources; | 
					
						
							| 
									
										
										
										
											2022-05-13 15:04:37 +02:00
										 |  |  | 	HashMap<String, Ref<Resource>> internal_index_cache; | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	String get_unicode_string(); | 
					
						
							|  |  |  | 	void _advance_padding(uint32_t p_len); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-05-13 15:04:37 +02:00
										 |  |  | 	HashMap<String, String> remaps; | 
					
						
							| 
									
										
										
										
											2020-05-12 17:01:17 +02:00
										 |  |  | 	Error error = OK; | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-11 14:18:45 -03:00
										 |  |  | 	ResourceFormatLoader::CacheMode cache_mode = ResourceFormatLoader::CACHE_MODE_REUSE; | 
					
						
							| 
									
										
										
										
											2024-02-22 12:53:19 +01:00
										 |  |  | 	ResourceFormatLoader::CacheMode cache_mode_for_external = ResourceFormatLoader::CACHE_MODE_REUSE; | 
					
						
							| 
									
										
										
										
											2020-04-19 23:19:21 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 	friend class ResourceFormatLoaderBinary; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	Error parse_variant(Variant &r_v); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-05-13 15:04:37 +02:00
										 |  |  | 	HashMap<String, Ref<Resource>> dependency_cache; | 
					
						
							| 
									
										
										
										
											2020-02-28 08:27:04 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | public: | 
					
						
							| 
									
										
										
										
											2020-02-28 08:27:04 -03:00
										 |  |  | 	Ref<Resource> get_resource(); | 
					
						
							|  |  |  | 	Error load(); | 
					
						
							|  |  |  | 	void set_translation_remapped(bool p_remapped); | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-05-13 15:04:37 +02:00
										 |  |  | 	void set_remaps(const HashMap<String, String> &p_remaps) { remaps = p_remaps; } | 
					
						
							| 
									
										
										
										
											2022-03-23 11:08:58 +02:00
										 |  |  | 	void open(Ref<FileAccess> p_f, bool p_no_resources = false, bool p_keep_uuid_paths = false); | 
					
						
							|  |  |  | 	String recognize(Ref<FileAccess> p_f); | 
					
						
							| 
									
										
										
										
											2023-01-19 19:12:25 +01:00
										 |  |  | 	String recognize_script_class(Ref<FileAccess> p_f); | 
					
						
							| 
									
										
										
										
											2022-03-23 11:08:58 +02:00
										 |  |  | 	void get_dependencies(Ref<FileAccess> p_f, List<String> *p_dependencies, bool p_add_types); | 
					
						
							| 
									
										
										
										
											2022-07-14 14:18:18 +02:00
										 |  |  | 	void get_classes_used(Ref<FileAccess> p_f, HashSet<StringName> *p_classes); | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-12 17:01:17 +02:00
										 |  |  | 	ResourceLoaderBinary() {} | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class ResourceFormatLoaderBinary : public ResourceFormatLoader { | 
					
						
							|  |  |  | public: | 
					
						
							| 
									
										
										
										
											2024-03-25 04:06:34 +08:00
										 |  |  | 	virtual Ref<Resource> 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; | 
					
						
							|  |  |  | 	virtual void get_recognized_extensions_for_type(const String &p_type, List<String> *p_extensions) const override; | 
					
						
							|  |  |  | 	virtual void get_recognized_extensions(List<String> *p_extensions) const override; | 
					
						
							|  |  |  | 	virtual bool handles_type(const String &p_type) const override; | 
					
						
							|  |  |  | 	virtual String get_resource_type(const String &p_path) const override; | 
					
						
							|  |  |  | 	virtual String get_resource_script_class(const String &p_path) const override; | 
					
						
							|  |  |  | 	virtual void get_classes_used(const String &p_path, HashSet<StringName> *r_classes) override; | 
					
						
							|  |  |  | 	virtual ResourceUID::ID get_resource_uid(const String &p_path) const override; | 
					
						
							| 
									
										
										
										
											2024-09-23 10:42:18 +02:00
										 |  |  | 	virtual bool has_custom_uid_support() const override; | 
					
						
							| 
									
										
										
										
											2024-03-25 04:06:34 +08:00
										 |  |  | 	virtual void get_dependencies(const String &p_path, List<String> *p_dependencies, bool p_add_types = false) override; | 
					
						
							|  |  |  | 	virtual Error rename_dependencies(const String &p_path, const HashMap<String, String> &p_map) override; | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class ResourceFormatSaverBinaryInstance { | 
					
						
							|  |  |  | 	String local_path; | 
					
						
							| 
									
										
										
										
											2019-02-24 10:45:08 -03:00
										 |  |  | 	String path; | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	bool relative_paths; | 
					
						
							|  |  |  | 	bool bundle_resources; | 
					
						
							|  |  |  | 	bool skip_editor; | 
					
						
							|  |  |  | 	bool big_endian; | 
					
						
							| 
									
										
										
										
											2014-06-27 23:21:45 -03:00
										 |  |  | 	bool takeover_paths; | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 	String magic; | 
					
						
							| 
									
										
										
										
											2022-05-19 17:00:06 +02:00
										 |  |  | 	HashSet<Ref<Resource>> resource_set; | 
					
						
							| 
									
										
										
										
											2019-02-21 20:49:42 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	struct NonPersistentKey { //for resource properties generated on the fly
 | 
					
						
							| 
									
										
										
										
											2022-05-03 01:43:50 +02:00
										 |  |  | 		Ref<Resource> base; | 
					
						
							| 
									
										
										
										
											2019-02-21 20:49:42 -03:00
										 |  |  | 		StringName property; | 
					
						
							|  |  |  | 		bool operator<(const NonPersistentKey &p_key) const { return base == p_key.base ? property < p_key.property : base < p_key.base; } | 
					
						
							|  |  |  | 	}; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-12-17 22:20:27 +01:00
										 |  |  | 	RBMap<NonPersistentKey, Variant> non_persistent_map; | 
					
						
							| 
									
										
										
										
											2022-05-13 15:04:37 +02:00
										 |  |  | 	HashMap<StringName, int> string_map; | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 	Vector<StringName> strings; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-05-13 15:04:37 +02:00
										 |  |  | 	HashMap<Ref<Resource>, int> external_resources; | 
					
						
							| 
									
										
										
										
											2022-05-03 01:43:50 +02:00
										 |  |  | 	List<Ref<Resource>> saved_resources; | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	struct Property { | 
					
						
							|  |  |  | 		int name_idx; | 
					
						
							|  |  |  | 		Variant value; | 
					
						
							|  |  |  | 		PropertyInfo pi; | 
					
						
							|  |  |  | 	}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	struct ResourceData { | 
					
						
							|  |  |  | 		String type; | 
					
						
							|  |  |  | 		List<Property> properties; | 
					
						
							|  |  |  | 	}; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-23 11:08:58 +02:00
										 |  |  | 	static void _pad_buffer(Ref<FileAccess> f, int p_bytes); | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 	void _find_resources(const Variant &p_variant, bool p_main = false); | 
					
						
							| 
									
										
										
										
											2022-03-23 11:08:58 +02:00
										 |  |  | 	static void save_unicode_string(Ref<FileAccess> f, const String &p_string, bool p_bit_on_len = false); | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 	int get_string_index(const String &p_string); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | public: | 
					
						
							| 
									
										
										
										
											2021-07-20 21:36:56 -03:00
										 |  |  | 	enum { | 
					
						
							| 
									
										
										
										
											2021-07-23 16:01:18 -03:00
										 |  |  | 		FORMAT_FLAG_NAMED_SCENE_IDS = 1, | 
					
						
							|  |  |  | 		FORMAT_FLAG_UIDS = 2, | 
					
						
							| 
									
										
										
										
											2022-02-16 00:55:13 +00:00
										 |  |  | 		FORMAT_FLAG_REAL_T_IS_DOUBLE = 4, | 
					
						
							| 
									
										
										
										
											2023-01-19 19:12:25 +01:00
										 |  |  | 		FORMAT_FLAG_HAS_SCRIPT_CLASS = 8, | 
					
						
							| 
									
										
										
										
											2022-02-16 00:55:13 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-07-29 22:24:29 -07:00
										 |  |  | 		// Amount of reserved 32-bit fields in resource header
 | 
					
						
							|  |  |  | 		RESERVED_FIELDS = 11 | 
					
						
							| 
									
										
										
										
											2021-07-20 21:36:56 -03:00
										 |  |  | 	}; | 
					
						
							| 
									
										
										
										
											2022-05-03 01:43:50 +02:00
										 |  |  | 	Error save(const String &p_path, const Ref<Resource> &p_resource, uint32_t p_flags = 0); | 
					
						
							| 
									
										
										
										
											2022-12-05 19:01:59 +01:00
										 |  |  | 	Error set_uid(const String &p_path, ResourceUID::ID p_uid); | 
					
						
							| 
									
										
										
										
											2022-05-13 15:04:37 +02:00
										 |  |  | 	static void write_variant(Ref<FileAccess> f, const Variant &p_property, HashMap<Ref<Resource>, int> &resource_map, HashMap<Ref<Resource>, int> &external_resources, HashMap<StringName, int> &string_map, const PropertyInfo &p_hint = PropertyInfo()); | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class ResourceFormatSaverBinary : public ResourceFormatSaver { | 
					
						
							|  |  |  | public: | 
					
						
							| 
									
										
										
										
											2025-04-28 20:27:50 +02:00
										 |  |  | 	static inline ResourceFormatSaverBinary *singleton = nullptr; | 
					
						
							| 
									
										
										
										
											2024-03-25 04:06:34 +08:00
										 |  |  | 	virtual Error save(const Ref<Resource> &p_resource, const String &p_path, uint32_t p_flags = 0) override; | 
					
						
							|  |  |  | 	virtual Error set_uid(const String &p_path, ResourceUID::ID p_uid) override; | 
					
						
							|  |  |  | 	virtual bool recognize(const Ref<Resource> &p_resource) const override; | 
					
						
							|  |  |  | 	virtual void get_recognized_extensions(const Ref<Resource> &p_resource, List<String> *p_extensions) const override; | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-23 20:15:56 -03:00
										 |  |  | 	ResourceFormatSaverBinary(); | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | }; |