mirror of
				https://github.com/Laupetin/OpenAssetTools.git
				synced 2025-10-26 00:05:52 +00:00 
			
		
		
		
	ZoneLoading: Properly link assets as dependencies instead of only saving the name of the dependency
This commit is contained in:
		| @@ -123,7 +123,7 @@ void GameAssetPoolT6::InitPoolStatic(const asset_type_t type, const size_t capac | ||||
|     { \ | ||||
|         if((poolName) == nullptr && capacity > 0)  \ | ||||
|         { \ | ||||
|             (poolName) = new AssetPoolStatic<poolType>(capacity, m_priority); \ | ||||
|             (poolName) = new AssetPoolStatic<poolType>(capacity, m_priority, (assetType)); \ | ||||
|         } \ | ||||
|         break; \ | ||||
|     } | ||||
| @@ -195,7 +195,7 @@ void GameAssetPoolT6::InitPoolDynamic(const asset_type_t type) | ||||
|     { \ | ||||
|         if((poolName) == nullptr) \ | ||||
|         { \ | ||||
|             (poolName) = new AssetPoolDynamic<poolType>(m_priority); \ | ||||
|             (poolName) = new AssetPoolDynamic<poolType>(m_priority, (assetType)); \ | ||||
|         } \ | ||||
|         break; \ | ||||
|     } | ||||
| @@ -260,7 +260,7 @@ void GameAssetPoolT6::InitPoolDynamic(const asset_type_t type) | ||||
| #undef CASE_INIT_POOL_STATIC | ||||
| } | ||||
|  | ||||
| void* GameAssetPoolT6::AddAsset(asset_type_t type, std::string name, void* asset, std::vector<std::string>& scriptStrings, std::vector<XAssetDependency>& dependencies) | ||||
| XAssetInfoGeneric* GameAssetPoolT6::AddAsset(asset_type_t type, std::string name, void* asset, std::vector<std::string>& scriptStrings, std::vector<XAssetInfoGeneric*>& dependencies) | ||||
| { | ||||
|     XAsset xAsset{}; | ||||
|  | ||||
| @@ -271,7 +271,7 @@ void* GameAssetPoolT6::AddAsset(asset_type_t type, std::string name, void* asset | ||||
|     case assetType: \ | ||||
|     { \ | ||||
|         assert((poolName) != nullptr); \ | ||||
|         return (poolName)->AddAsset(std::move(name), xAsset.header.headerName, scriptStrings, dependencies)->m_asset; \ | ||||
|         return (poolName)->AddAsset(std::move(name), xAsset.header.headerName, scriptStrings, dependencies); \ | ||||
|     } | ||||
|  | ||||
|     switch(xAsset.type) | ||||
| @@ -336,6 +336,78 @@ void* GameAssetPoolT6::AddAsset(asset_type_t type, std::string name, void* asset | ||||
| #undef CASE_ADD_TO_POOL | ||||
| } | ||||
|  | ||||
| XAssetInfoGeneric* GameAssetPoolT6::GetAsset(const asset_type_t type, std::string name) | ||||
| { | ||||
| #define CASE_GET_ASSET(assetType, poolName) \ | ||||
|     case assetType: \ | ||||
|     { \ | ||||
|         if((poolName) != nullptr) \ | ||||
|             return (poolName)->GetAsset(std::move(name)); \ | ||||
|         break; \ | ||||
|     } | ||||
|  | ||||
|     switch (type) | ||||
|     { | ||||
|         CASE_GET_ASSET(ASSET_TYPE_PHYSPRESET, m_phys_preset); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_PHYSCONSTRAINTS, m_phys_constraints); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_DESTRUCTIBLEDEF, m_destructible_def); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_XANIMPARTS, m_xanim_parts); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_XMODEL, m_xmodel); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_MATERIAL, m_material); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_TECHNIQUE_SET, m_technique_set); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_IMAGE, m_image); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_SOUND, m_sound_bank); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_SOUND_PATCH, m_sound_patch); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_CLIPMAP, m_clip_map); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_CLIPMAP_PVS, m_clip_map); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_COMWORLD, m_com_world); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_GAMEWORLD_SP, m_game_world_sp); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_GAMEWORLD_MP, m_game_world_mp); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_MAP_ENTS, m_map_ents); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_GFXWORLD, m_gfx_world); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_LIGHT_DEF, m_gfx_light_def); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_FONT, m_font); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_FONTICON, m_font_icon); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_MENULIST, m_menu_list); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_MENU, m_menu_def); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_LOCALIZE_ENTRY, m_localize); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_WEAPON, m_weapon); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_ATTACHMENT, m_attachment); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_ATTACHMENT_UNIQUE, m_attachment_unique); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_WEAPON_CAMO, m_camo); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_SNDDRIVER_GLOBALS, m_snd_driver_globals); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_FX, m_fx); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_IMPACT_FX, m_fx_impact_table); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_RAWFILE, m_raw_file); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_STRINGTABLE, m_string_table); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_LEADERBOARD, m_leaderboard); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_XGLOBALS, m_xglobals); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_DDL, m_ddl); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_GLASSES, m_glasses); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_EMBLEMSET, m_emblem_set); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_SCRIPTPARSETREE, m_script); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_KEYVALUEPAIRS, m_key_value_pairs); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_VEHICLEDEF, m_vehicle); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_MEMORYBLOCK, m_memory_block); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_ADDON_MAP_ENTS, m_addon_map_ents); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_TRACER, m_tracer); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_SKINNEDVERTS, m_skinned_verts); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_QDB, m_qdb); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_SLUG, m_slug); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_FOOTSTEP_TABLE, m_footstep_table); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_FOOTSTEPFX_TABLE, m_footstep_fx_table); | ||||
|         CASE_GET_ASSET(ASSET_TYPE_ZBARRIER, m_zbarrier); | ||||
|  | ||||
|     default: | ||||
|         assert(false); | ||||
|         break; | ||||
|     } | ||||
|  | ||||
|     return nullptr; | ||||
|  | ||||
| #undef CASE_GET_ASSET | ||||
| } | ||||
|  | ||||
| ZoneContent GameAssetPoolT6::GetContent() const | ||||
| { | ||||
|     ZoneContent content{}; | ||||
| @@ -403,4 +475,4 @@ ZoneContent GameAssetPoolT6::GetContent() const | ||||
|     return content; | ||||
|  | ||||
| #undef POOL_ADD_TO_CONTENT | ||||
| } | ||||
| } | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| #pragma once | ||||
|  | ||||
| #include "Pool/AssetPool.h" | ||||
| #include "Pool/IZoneAssetPools.h" | ||||
| #include "Pool/AssetPool.h" | ||||
| #include "T6.h" | ||||
|  | ||||
| class GameAssetPoolT6 final : public IZoneAssetPools | ||||
| @@ -64,7 +64,8 @@ public: | ||||
|     void InitPoolStatic(asset_type_t type, size_t capacity) override; | ||||
|     void InitPoolDynamic(asset_type_t type) override; | ||||
|  | ||||
|     void* AddAsset(asset_type_t type, std::string name, void* asset, std::vector<std::string>& scriptStrings, std::vector<XAssetDependency>& dependencies) override; | ||||
|     XAssetInfoGeneric* AddAsset(asset_type_t type, std::string name, void* asset, std::vector<std::string>& scriptStrings, std::vector<XAssetInfoGeneric*>& dependencies) override; | ||||
|     XAssetInfoGeneric* GetAsset(asset_type_t type, std::string name) override; | ||||
|  | ||||
|     ZoneContent GetContent() const override; | ||||
| }; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user