mirror of
				https://github.com/Laupetin/OpenAssetTools.git
				synced 2025-10-31 02:26:59 +00:00 
			
		
		
		
	Merge branch 'Laupetin:main' into main
This commit is contained in:
		| @@ -22,50 +22,50 @@ namespace T6 | ||||
|             switch (static_cast<weapFieldType_t>(field.iFieldType)) | ||||
|             { | ||||
|             case WFT_WEAPONTYPE: | ||||
|                 FillFromEnumInt(std::string(field.szName), field.iOffset, szWeapTypeNames, std::extent<decltype(szWeapTypeNames)>::value); | ||||
|                 FillFromEnumInt(std::string(field.szName), field.iOffset, szWeapTypeNames, std::extent_v<decltype(szWeapTypeNames)>); | ||||
|                 break; | ||||
|  | ||||
|             case WFT_WEAPONCLASS: | ||||
|                 FillFromEnumInt(std::string(field.szName), field.iOffset, szWeapClassNames, std::extent<decltype(szWeapClassNames)>::value); | ||||
|                 FillFromEnumInt(std::string(field.szName), field.iOffset, szWeapClassNames, std::extent_v<decltype(szWeapClassNames)>); | ||||
|                 break; | ||||
|             case WFT_OVERLAYRETICLE: | ||||
|                 FillFromEnumInt(std::string(field.szName), field.iOffset, szWeapOverlayReticleNames, std::extent<decltype(szWeapOverlayReticleNames)>::value); | ||||
|                 FillFromEnumInt(std::string(field.szName), field.iOffset, szWeapOverlayReticleNames, std::extent_v<decltype(szWeapOverlayReticleNames)>); | ||||
|                 break; | ||||
|  | ||||
|             case WFT_PENETRATE_TYPE: | ||||
|                 FillFromEnumInt(std::string(field.szName), field.iOffset, penetrateTypeNames, std::extent<decltype(penetrateTypeNames)>::value); | ||||
|                 FillFromEnumInt(std::string(field.szName), field.iOffset, penetrateTypeNames, std::extent_v<decltype(penetrateTypeNames)>); | ||||
|                 break; | ||||
|  | ||||
|             case WFT_IMPACT_TYPE: | ||||
|                 FillFromEnumInt(std::string(field.szName), field.iOffset, impactTypeNames, std::extent<decltype(impactTypeNames)>::value); | ||||
|                 FillFromEnumInt(std::string(field.szName), field.iOffset, impactTypeNames, std::extent_v<decltype(impactTypeNames)>); | ||||
|                 break; | ||||
|  | ||||
|             case WFT_STANCE: | ||||
|                 FillFromEnumInt(std::string(field.szName), field.iOffset, szWeapStanceNames, std::extent<decltype(szWeapStanceNames)>::value); | ||||
|                 FillFromEnumInt(std::string(field.szName), field.iOffset, szWeapStanceNames, std::extent_v<decltype(szWeapStanceNames)>); | ||||
|                 break; | ||||
|  | ||||
|             case WFT_PROJ_EXPLOSION: | ||||
|                 FillFromEnumInt(std::string(field.szName), field.iOffset, szProjectileExplosionNames, std::extent<decltype(szProjectileExplosionNames)>::value); | ||||
|                 FillFromEnumInt(std::string(field.szName), field.iOffset, szProjectileExplosionNames, std::extent_v<decltype(szProjectileExplosionNames)>); | ||||
|                 break; | ||||
|  | ||||
|             case WFT_OFFHAND_CLASS: | ||||
|                 FillFromEnumInt(std::string(field.szName), field.iOffset, offhandClassNames, std::extent<decltype(offhandClassNames)>::value); | ||||
|                 FillFromEnumInt(std::string(field.szName), field.iOffset, offhandClassNames, std::extent_v<decltype(offhandClassNames)>); | ||||
|                 break; | ||||
|  | ||||
|             case WFT_OFFHAND_SLOT: | ||||
|                 FillFromEnumInt(std::string(field.szName), field.iOffset, offhandSlotNames, std::extent<decltype(offhandSlotNames)>::value); | ||||
|                 FillFromEnumInt(std::string(field.szName), field.iOffset, offhandSlotNames, std::extent_v<decltype(offhandSlotNames)>); | ||||
|                 break; | ||||
|  | ||||
|             case WFT_ANIMTYPE: | ||||
|                 FillFromEnumInt(std::string(field.szName), field.iOffset, playerAnimTypeNames, std::extent<decltype(playerAnimTypeNames)>::value); | ||||
|                 FillFromEnumInt(std::string(field.szName), field.iOffset, playerAnimTypeNames, std::extent_v<decltype(playerAnimTypeNames)>); | ||||
|                 break; | ||||
|  | ||||
|             case WFT_ACTIVE_RETICLE_TYPE: | ||||
|                 FillFromEnumInt(std::string(field.szName), field.iOffset, activeReticleNames, std::extent<decltype(activeReticleNames)>::value); | ||||
|                 FillFromEnumInt(std::string(field.szName), field.iOffset, activeReticleNames, std::extent_v<decltype(activeReticleNames)>); | ||||
|                 break; | ||||
|  | ||||
|             case WFT_GUIDED_MISSILE_TYPE: | ||||
|                 FillFromEnumInt(std::string(field.szName), field.iOffset, guidedMissileNames, std::extent<decltype(guidedMissileNames)>::value); | ||||
|                 FillFromEnumInt(std::string(field.szName), field.iOffset, guidedMissileNames, std::extent_v<decltype(guidedMissileNames)>); | ||||
|                 break; | ||||
|  | ||||
|             case WFT_BOUNCE_SOUND: | ||||
| @@ -92,31 +92,31 @@ namespace T6 | ||||
|             } | ||||
|  | ||||
|             case WFT_STICKINESS: | ||||
|                 FillFromEnumInt(std::string(field.szName), field.iOffset, stickinessNames, std::extent<decltype(stickinessNames)>::value); | ||||
|                 FillFromEnumInt(std::string(field.szName), field.iOffset, stickinessNames, std::extent_v<decltype(stickinessNames)>); | ||||
|                 break; | ||||
|  | ||||
|             case WFT_ROTATETYPE: | ||||
|                 FillFromEnumInt(std::string(field.szName), field.iOffset, rotateTypeNames, std::extent<decltype(rotateTypeNames)>::value); | ||||
|                 FillFromEnumInt(std::string(field.szName), field.iOffset, rotateTypeNames, std::extent_v<decltype(rotateTypeNames)>); | ||||
|                 break; | ||||
|  | ||||
|             case WFT_OVERLAYINTERFACE: | ||||
|                 FillFromEnumInt(std::string(field.szName), field.iOffset, overlayInterfaceNames, std::extent<decltype(overlayInterfaceNames)>::value); | ||||
|                 FillFromEnumInt(std::string(field.szName), field.iOffset, overlayInterfaceNames, std::extent_v<decltype(overlayInterfaceNames)>); | ||||
|                 break; | ||||
|  | ||||
|             case WFT_INVENTORYTYPE: | ||||
|                 FillFromEnumInt(std::string(field.szName), field.iOffset, szWeapInventoryTypeNames, std::extent<decltype(szWeapInventoryTypeNames)>::value); | ||||
|                 FillFromEnumInt(std::string(field.szName), field.iOffset, szWeapInventoryTypeNames, std::extent_v<decltype(szWeapInventoryTypeNames)>); | ||||
|                 break; | ||||
|  | ||||
|             case WFT_FIRETYPE: | ||||
|                 FillFromEnumInt(std::string(field.szName), field.iOffset, szWeapFireTypeNames, std::extent<decltype(szWeapFireTypeNames)>::value); | ||||
|                 FillFromEnumInt(std::string(field.szName), field.iOffset, szWeapFireTypeNames, std::extent_v<decltype(szWeapFireTypeNames)>); | ||||
|                 break; | ||||
|  | ||||
|             case WFT_CLIPTYPE: | ||||
|                 FillFromEnumInt(std::string(field.szName), field.iOffset, szWeapClipTypeNames, std::extent<decltype(szWeapClipTypeNames)>::value); | ||||
|                 FillFromEnumInt(std::string(field.szName), field.iOffset, szWeapClipTypeNames, std::extent_v<decltype(szWeapClipTypeNames)>); | ||||
|                 break; | ||||
|  | ||||
|             case WFT_AMMOCOUNTER_CLIPTYPE: | ||||
|                 FillFromEnumInt(std::string(field.szName), field.iOffset, ammoCounterClipNames, std::extent<decltype(ammoCounterClipNames)>::value); | ||||
|                 FillFromEnumInt(std::string(field.szName), field.iOffset, ammoCounterClipNames, std::extent_v<decltype(ammoCounterClipNames)>); | ||||
|                 break; | ||||
|  | ||||
|             case WFT_ICONRATIO_HUD: | ||||
| @@ -124,11 +124,11 @@ namespace T6 | ||||
|             case WFT_ICONRATIO_KILL: | ||||
|             case WFT_ICONRATIO_DPAD: | ||||
|             case WFT_ICONRATIO_INDICATOR: | ||||
|                 FillFromEnumInt(std::string(field.szName), field.iOffset, weapIconRatioNames, std::extent<decltype(weapIconRatioNames)>::value); | ||||
|                 FillFromEnumInt(std::string(field.szName), field.iOffset, weapIconRatioNames, std::extent_v<decltype(weapIconRatioNames)>); | ||||
|                 break; | ||||
|  | ||||
|             case WFT_BARRELTYPE: | ||||
|                 FillFromEnumInt(std::string(field.szName), field.iOffset, barrelTypeNames, std::extent<decltype(barrelTypeNames)>::value); | ||||
|                 FillFromEnumInt(std::string(field.szName), field.iOffset, barrelTypeNames, std::extent_v<decltype(barrelTypeNames)>); | ||||
|                 break; | ||||
|  | ||||
|             case WFT_HIDETAGS: | ||||
| @@ -137,7 +137,7 @@ namespace T6 | ||||
|                 std::stringstream ss; | ||||
|                 bool first = true; | ||||
|  | ||||
|                 for (auto i = 0u; i < std::extent<decltype(WeaponFullDef::hideTags)>::value; i++) | ||||
|                 for (auto i = 0u; i < std::extent_v<decltype(WeaponFullDef::hideTags)>; i++) | ||||
|                 { | ||||
|                     const auto& str = m_get_scr_string(hideTags[i]); | ||||
|                     if (!str.empty()) | ||||
| @@ -162,11 +162,11 @@ namespace T6 | ||||
|             case WFT_NOTETRACKSOUNDMAP: | ||||
|             { | ||||
|                 const auto* keys = reinterpret_cast<scr_string_t*>(reinterpret_cast<uintptr_t>(m_structure) + field.iOffset); | ||||
|                 const auto* values = &keys[std::extent<decltype(WeaponFullDef::notetrackSoundMapKeys)>::value]; | ||||
|                 const auto* values = &keys[std::extent_v<decltype(WeaponFullDef::notetrackSoundMapKeys)>]; | ||||
|                 std::stringstream ss; | ||||
|                 bool first = true; | ||||
|  | ||||
|                 for (auto i = 0u; i < std::extent<decltype(WeaponFullDef::notetrackSoundMapKeys)>::value; i++) | ||||
|                 for (auto i = 0u; i < std::extent_v<decltype(WeaponFullDef::notetrackSoundMapKeys)>; i++) | ||||
|                 { | ||||
|                     const auto& key = m_get_scr_string(keys[i]); | ||||
|                     const auto& value = m_get_scr_string(values[i]); | ||||
| @@ -205,7 +205,7 @@ namespace T6 | ||||
|                 std::stringstream ss; | ||||
|                 auto first = true; | ||||
|  | ||||
|                 for (auto i = 0u; i < std::extent<decltype(WeaponFullDef::attachments)>::value; i++) | ||||
|                 for (auto i = 0u; i < std::extent_v<decltype(WeaponFullDef::attachments)>; i++) | ||||
|                 { | ||||
|                     if (attachments[i]) | ||||
|                     { | ||||
| @@ -227,7 +227,7 @@ namespace T6 | ||||
|                 std::stringstream ss; | ||||
|                 auto first = true; | ||||
|  | ||||
|                 for (auto i = 0u; i < std::extent<decltype(WeaponFullDef::attachmentUniques)>::value; i++) | ||||
|                 for (auto i = 0u; i < std::extent_v<decltype(WeaponFullDef::attachmentUniques)>; i++) | ||||
|                 { | ||||
|                     if (attachmentUniques[i]) | ||||
|                     { | ||||
| @@ -243,6 +243,10 @@ namespace T6 | ||||
|                 break; | ||||
|             } | ||||
|  | ||||
|             case WFT_ANIM_NAME: | ||||
|                 FillFromString(std::string(field.szName), field.iOffset); | ||||
|                 break; | ||||
|  | ||||
|             case WFT_NUM_FIELD_TYPES: | ||||
|             default: | ||||
|                 assert(false); | ||||
| @@ -274,21 +278,21 @@ void AssetDumperWeapon::CopyToFullDef(const WeaponVariantDef* weapon, WeaponFull | ||||
|     if (weapon->attachments) | ||||
|     { | ||||
|         assert(sizeof(WeaponFullDef::attachments) >= sizeof(void*) * std::extent<decltype(WeaponFullDef::attachments)>::value); | ||||
|         memcpy(fullDef->attachments, weapon->attachments, sizeof(void*) * std::extent<decltype(WeaponFullDef::attachments)>::value); | ||||
|         memcpy(fullDef->attachments, weapon->attachments, sizeof(void*) * std::extent_v<decltype(WeaponFullDef::attachments)>); | ||||
|         fullDef->weapVariantDef.attachments = fullDef->attachments; | ||||
|     } | ||||
|  | ||||
|     if (weapon->attachmentUniques) | ||||
|     { | ||||
|         assert(sizeof(WeaponFullDef::attachmentUniques) >= sizeof(void*) * std::extent<decltype(WeaponFullDef::attachmentUniques)>::value); | ||||
|         memcpy(fullDef->attachmentUniques, weapon->attachmentUniques, sizeof(void*) * std::extent<decltype(WeaponFullDef::attachmentUniques)>::value); | ||||
|         memcpy(fullDef->attachmentUniques, weapon->attachmentUniques, sizeof(void*) * std::extent_v<decltype(WeaponFullDef::attachmentUniques)>); | ||||
|         fullDef->weapVariantDef.attachmentUniques = fullDef->attachmentUniques; | ||||
|     } | ||||
|  | ||||
|     if (fullDef->weapDef.gunXModel) | ||||
|     { | ||||
|         assert(sizeof(WeaponFullDef::gunXModel) >= sizeof(void*) * std::extent<decltype(WeaponFullDef::gunXModel)>::value); | ||||
|         memcpy(fullDef->gunXModel, fullDef->weapDef.gunXModel, sizeof(void*) * std::extent<decltype(WeaponFullDef::gunXModel)>::value); | ||||
|         memcpy(fullDef->gunXModel, fullDef->weapDef.gunXModel, sizeof(void*) * std::extent_v<decltype(WeaponFullDef::gunXModel)>); | ||||
|         fullDef->weapDef.gunXModel = fullDef->gunXModel; | ||||
|     } | ||||
|  | ||||
| @@ -302,7 +306,7 @@ void AssetDumperWeapon::CopyToFullDef(const WeaponVariantDef* weapon, WeaponFull | ||||
|     if (weapon->hideTags) | ||||
|     { | ||||
|         assert(sizeof(WeaponFullDef::hideTags) >= sizeof(scr_string_t) * std::extent<decltype(WeaponFullDef::hideTags)>::value); | ||||
|         memcpy(fullDef->hideTags, weapon->hideTags, sizeof(scr_string_t) * std::extent<decltype(WeaponFullDef::hideTags)>::value); | ||||
|         memcpy(fullDef->hideTags, weapon->hideTags, sizeof(scr_string_t) * std::extent_v<decltype(WeaponFullDef::hideTags)>); | ||||
|         fullDef->weapVariantDef.hideTags = fullDef->hideTags; | ||||
|     } | ||||
|  | ||||
| @@ -311,7 +315,7 @@ void AssetDumperWeapon::CopyToFullDef(const WeaponVariantDef* weapon, WeaponFull | ||||
|         assert(sizeof(WeaponFullDef::notetrackSoundMapKeys) >= sizeof(scr_string_t) * std::extent<decltype(WeaponFullDef::notetrackSoundMapKeys)>::value); | ||||
|         memcpy(fullDef->notetrackSoundMapKeys, | ||||
|                fullDef->weapDef.notetrackSoundMapKeys, | ||||
|                sizeof(scr_string_t) * std::extent<decltype(WeaponFullDef::notetrackSoundMapKeys)>::value); | ||||
|                sizeof(scr_string_t) * std::extent_v<decltype(WeaponFullDef::notetrackSoundMapKeys)>); | ||||
|         fullDef->weapDef.notetrackSoundMapKeys = fullDef->notetrackSoundMapKeys; | ||||
|     } | ||||
|  | ||||
| @@ -320,42 +324,42 @@ void AssetDumperWeapon::CopyToFullDef(const WeaponVariantDef* weapon, WeaponFull | ||||
|         assert(sizeof(WeaponFullDef::notetrackSoundMapValues) >= sizeof(scr_string_t) * std::extent<decltype(WeaponFullDef::notetrackSoundMapValues)>::value); | ||||
|         memcpy(fullDef->notetrackSoundMapValues, | ||||
|                fullDef->weapDef.notetrackSoundMapValues, | ||||
|                sizeof(scr_string_t) * std::extent<decltype(WeaponFullDef::notetrackSoundMapValues)>::value); | ||||
|                sizeof(scr_string_t) * std::extent_v<decltype(WeaponFullDef::notetrackSoundMapValues)>); | ||||
|         fullDef->weapDef.notetrackSoundMapValues = fullDef->notetrackSoundMapValues; | ||||
|     } | ||||
|  | ||||
|     if (fullDef->weapDef.worldModel) | ||||
|     { | ||||
|         assert(sizeof(WeaponFullDef::worldModel) >= sizeof(void*) * std::extent<decltype(WeaponFullDef::worldModel)>::value); | ||||
|         memcpy(fullDef->worldModel, fullDef->weapDef.worldModel, sizeof(void*) * std::extent<decltype(WeaponFullDef::worldModel)>::value); | ||||
|         memcpy(fullDef->worldModel, fullDef->weapDef.worldModel, sizeof(void*) * std::extent_v<decltype(WeaponFullDef::worldModel)>); | ||||
|         fullDef->weapDef.worldModel = fullDef->worldModel; | ||||
|     } | ||||
|  | ||||
|     if (weapon->attachViewModel) | ||||
|     { | ||||
|         assert(sizeof(WeaponFullDef::attachViewModel) >= sizeof(void*) * std::extent<decltype(WeaponFullDef::attachViewModel)>::value); | ||||
|         memcpy(fullDef->attachViewModel, weapon->attachViewModel, sizeof(void*) * std::extent<decltype(WeaponFullDef::attachViewModel)>::value); | ||||
|         memcpy(fullDef->attachViewModel, weapon->attachViewModel, sizeof(void*) * std::extent_v<decltype(WeaponFullDef::attachViewModel)>); | ||||
|         fullDef->weapVariantDef.attachViewModel = fullDef->attachViewModel; | ||||
|     } | ||||
|  | ||||
|     if (weapon->attachWorldModel) | ||||
|     { | ||||
|         assert(sizeof(WeaponFullDef::attachWorldModel) >= sizeof(void*) * std::extent<decltype(WeaponFullDef::attachWorldModel)>::value); | ||||
|         memcpy(fullDef->attachWorldModel, weapon->attachWorldModel, sizeof(void*) * std::extent<decltype(WeaponFullDef::attachWorldModel)>::value); | ||||
|         memcpy(fullDef->attachWorldModel, weapon->attachWorldModel, sizeof(void*) * std::extent_v<decltype(WeaponFullDef::attachWorldModel)>); | ||||
|         fullDef->weapVariantDef.attachWorldModel = fullDef->attachWorldModel; | ||||
|     } | ||||
|  | ||||
|     if (weapon->attachViewModelTag) | ||||
|     { | ||||
|         assert(sizeof(WeaponFullDef::attachViewModelTag) >= sizeof(void*) * std::extent<decltype(WeaponFullDef::attachViewModelTag)>::value); | ||||
|         memcpy(fullDef->attachViewModelTag, weapon->attachViewModelTag, sizeof(void*) * std::extent<decltype(WeaponFullDef::attachViewModelTag)>::value); | ||||
|         memcpy(fullDef->attachViewModelTag, weapon->attachViewModelTag, sizeof(void*) * std::extent_v<decltype(WeaponFullDef::attachViewModelTag)>); | ||||
|         fullDef->weapVariantDef.attachViewModelTag = fullDef->attachViewModelTag; | ||||
|     } | ||||
|  | ||||
|     if (weapon->attachWorldModelTag) | ||||
|     { | ||||
|         assert(sizeof(WeaponFullDef::attachWorldModelTag) >= sizeof(void*) * std::extent<decltype(WeaponFullDef::attachWorldModelTag)>::value); | ||||
|         memcpy(fullDef->attachWorldModelTag, weapon->attachWorldModelTag, sizeof(void*) * std::extent<decltype(WeaponFullDef::attachWorldModelTag)>::value); | ||||
|         memcpy(fullDef->attachWorldModelTag, weapon->attachWorldModelTag, sizeof(void*) * std::extent_v<decltype(WeaponFullDef::attachWorldModelTag)>); | ||||
|         fullDef->weapVariantDef.attachWorldModelTag = fullDef->attachWorldModelTag; | ||||
|     } | ||||
|  | ||||
| @@ -382,7 +386,7 @@ void AssetDumperWeapon::CopyToFullDef(const WeaponVariantDef* weapon, WeaponFull | ||||
|  | ||||
|     if (fullDef->weapDef.weaponCamo && fullDef->weapDef.weaponCamo->name) | ||||
|     { | ||||
|         strncpy(fullDef->weaponCamo, fullDef->weapDef.weaponCamo->name, std::extent<decltype(WeaponFullDef::weaponCamo)>::value); | ||||
|         strncpy(fullDef->weaponCamo, fullDef->weapDef.weaponCamo->name, std::extent_v<decltype(WeaponFullDef::weaponCamo)>); | ||||
|     } | ||||
| } | ||||
|  | ||||
| @@ -394,7 +398,7 @@ InfoString AssetDumperWeapon::CreateInfoString(XAssetInfo<WeaponVariantDef>* ass | ||||
|  | ||||
|     InfoStringFromWeaponConverter converter(fullDef.get(), | ||||
|                                             weapon_fields, | ||||
|                                             std::extent<decltype(weapon_fields)>::value, | ||||
|                                             std::extent_v<decltype(weapon_fields)>, | ||||
|                                             [asset](const scr_string_t scrStr) -> std::string | ||||
|                                             { | ||||
|                                                 assert(scrStr < asset->m_zone->m_script_strings.Count()); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user