2
0
mirror of https://github.com/Laupetin/OpenAssetTools.git synced 2025-10-25 07:45:52 +00:00

chore: normalize asset names before adding to asset pools

This commit is contained in:
Jan
2024-05-11 12:23:49 +02:00
parent b59bd01280
commit a9488b8152
8 changed files with 40 additions and 35 deletions

View File

@@ -52,7 +52,8 @@ public:
XAssetInfo<T>* GetAsset(const std::string& name)
{
auto foundAsset = m_asset_lookup.find(name);
const auto normalizedName = XAssetInfo<T>::NormalizeAssetName(name);
auto foundAsset = m_asset_lookup.find(normalizedName);
if (foundAsset == m_asset_lookup.end())
return nullptr;

View File

@@ -40,15 +40,17 @@ public:
XAssetInfo<T>* AddAsset(std::unique_ptr<XAssetInfo<T>> xAssetInfo) override
{
const auto normalizedName = XAssetInfo<T>::NormalizeAssetName(xAssetInfo->m_name);
T* newAsset = new T();
memcpy(newAsset, xAssetInfo->Asset(), sizeof(T));
xAssetInfo->m_ptr = newAsset;
auto* pAssetInfo = xAssetInfo.get();
m_asset_lookup[xAssetInfo->m_name] = pAssetInfo;
m_asset_lookup[normalizedName] = pAssetInfo;
m_assets.emplace_back(std::move(xAssetInfo));
GlobalAssetPool<T>::LinkAsset(this, pAssetInfo);
GlobalAssetPool<T>::LinkAsset(this, normalizedName, pAssetInfo);
return pAssetInfo;
}

View File

@@ -84,6 +84,8 @@ public:
if (m_free == nullptr)
throw std::runtime_error("Could not add asset to static asset pool: capacity exhausted.");
const auto normalizedName = XAssetInfo<T>::NormalizeAssetName(xAssetInfo->m_name);
AssetPoolEntry* poolSlot = m_free;
m_free = m_free->m_next;
@@ -93,9 +95,9 @@ public:
*poolSlot->m_info = std::move(*xAssetInfo);
m_asset_lookup[poolSlot->m_info->m_name] = poolSlot->m_info;
m_asset_lookup[normalizedName] = poolSlot->m_info;
GlobalAssetPool<T>::LinkAsset(this, poolSlot->m_info);
GlobalAssetPool<T>::LinkAsset(this, normalizedName, poolSlot->m_info);
return poolSlot->m_info;
}

View File

@@ -64,11 +64,9 @@ template<typename T> class GlobalAssetPool
return occurrences > 0;
}
static void LinkAsset(LinkedAssetPool* link, XAssetInfo<T>* asset)
static void LinkAsset(LinkedAssetPool* link, const std::string& normalizedAssetName, XAssetInfo<T>* asset)
{
std::string assetName = std::string(asset->m_name);
auto existingAsset = m_assets.find(assetName);
auto existingAsset = m_assets.find(normalizedAssetName);
if (existingAsset == m_assets.end())
{
@@ -77,7 +75,7 @@ template<typename T> class GlobalAssetPool
entry.m_asset_pool = link;
entry.m_duplicate = false;
m_assets[assetName] = entry;
m_assets[normalizedAssetName] = entry;
}
else
{
@@ -106,11 +104,12 @@ public:
for (auto asset : *assetPool)
{
LinkAsset(newLinkPtr, asset);
const auto normalizedAssetName = XAssetInfo<T>::NormalizeAssetName(asset->m_name);
LinkAsset(newLinkPtr, normalizedAssetName, asset);
}
}
static void LinkAsset(AssetPool<T>* assetPool, XAssetInfo<T>* asset)
static void LinkAsset(AssetPool<T>* assetPool, const std::string& normalizedAssetName, XAssetInfo<T>* asset)
{
LinkedAssetPool* link = nullptr;
@@ -127,7 +126,7 @@ public:
if (link == nullptr)
return;
LinkAsset(link, asset);
LinkAsset(link, normalizedAssetName, asset);
}
static void UnlinkAssetPool(AssetPool<T>* assetPool)

View File

@@ -2,6 +2,8 @@
#include "Utils/StringUtils.h"
#include <algorithm>
IndirectAssetReference::IndirectAssetReference()
: m_type(-1)
{
@@ -90,3 +92,12 @@ XAssetInfoGeneric::XAssetInfoGeneric(const asset_type_t type,
m_zone(zone)
{
}
std::string XAssetInfoGeneric::NormalizeAssetName(std::string input)
{
utils::MakeStringLowerCase(input);
std::ranges::replace(input, '\\', '/');
return input;
}

View File

@@ -30,14 +30,6 @@ template<> struct std::hash<IndirectAssetReference>
class XAssetInfoGeneric
{
public:
asset_type_t m_type;
std::string m_name;
void* m_ptr;
std::vector<XAssetInfoGeneric*> m_dependencies;
std::vector<scr_string_t> m_used_script_strings;
std::vector<IndirectAssetReference> m_indirect_asset_references;
Zone* m_zone;
XAssetInfoGeneric();
XAssetInfoGeneric(asset_type_t type, std::string name, void* ptr);
XAssetInfoGeneric(
@@ -61,6 +53,16 @@ public:
XAssetInfoGeneric(XAssetInfoGeneric&& other) noexcept = default;
XAssetInfoGeneric& operator=(const XAssetInfoGeneric& other) = default;
XAssetInfoGeneric& operator=(XAssetInfoGeneric&& other) noexcept = default;
static std::string NormalizeAssetName(std::string input);
asset_type_t m_type;
std::string m_name;
void* m_ptr;
std::vector<XAssetInfoGeneric*> m_dependencies;
std::vector<scr_string_t> m_used_script_strings;
std::vector<IndirectAssetReference> m_indirect_asset_references;
Zone* m_zone;
};
template<typename T> class XAssetInfo : public XAssetInfoGeneric