mirror of
https://github.com/AxioDL/metaforce.git
synced 2025-12-08 19:44:55 +00:00
Add OIDS resource for translating against original IDs
This commit is contained in:
@@ -23,6 +23,8 @@
|
||||
#include "Audio/CSfxManager.hpp"
|
||||
#include "Runtime/CDependencyGroup.hpp"
|
||||
#include "DataSpec/DNACommon/TXTR.hpp"
|
||||
#include "CSimplePool.hpp"
|
||||
#include "GameGlobalObjects.hpp"
|
||||
|
||||
namespace DataSpec
|
||||
{
|
||||
@@ -33,6 +35,57 @@ extern hecl::Database::DataSpecEntry SpecEntMP1PC;
|
||||
namespace urde
|
||||
{
|
||||
|
||||
class MP1OriginalIDs
|
||||
{
|
||||
std::vector<std::pair<ResId, ResId>> m_origToNew;
|
||||
std::vector<std::pair<ResId, ResId>> m_newToOrig;
|
||||
|
||||
public:
|
||||
MP1OriginalIDs(CInputStream& in)
|
||||
{
|
||||
u32 count = in.readUint32Big();
|
||||
m_origToNew.reserve(count);
|
||||
for (u32 i=0 ; i<count ; ++i)
|
||||
{
|
||||
ResId a = in.readUint32Big();
|
||||
ResId b = in.readUint32Big();
|
||||
m_origToNew.push_back(std::make_pair(a, b));
|
||||
}
|
||||
m_newToOrig.reserve(count);
|
||||
for (u32 i=0 ; i<count ; ++i)
|
||||
{
|
||||
ResId a = in.readUint32Big();
|
||||
ResId b = in.readUint32Big();
|
||||
m_newToOrig.push_back(std::make_pair(a, b));
|
||||
}
|
||||
}
|
||||
|
||||
ResId TranslateOriginalToNew(ResId id) const
|
||||
{
|
||||
auto search = std::lower_bound(m_origToNew.cbegin(), m_origToNew.cend(),
|
||||
std::make_pair(id, ResId(0)));
|
||||
if (search == m_origToNew.cend() || search->first != id)
|
||||
return -1;
|
||||
return search->second;
|
||||
}
|
||||
|
||||
ResId TranslateNewToOriginal(ResId id) const
|
||||
{
|
||||
auto search = std::lower_bound(m_newToOrig.cbegin(), m_newToOrig.cend(),
|
||||
std::make_pair(id, ResId(0)));
|
||||
if (search == m_newToOrig.cend() || search->first != id)
|
||||
return -1;
|
||||
return search->second;
|
||||
}
|
||||
};
|
||||
|
||||
CFactoryFnReturn FMP1OriginalIDsFactory(const SObjectTag& tag, CInputStream& in,
|
||||
const CVParamTransfer& param,
|
||||
CObjectReference* selfRef)
|
||||
{
|
||||
return TToken<MP1OriginalIDs>::GetIObjObjectFor(std::make_unique<MP1OriginalIDs>(in));
|
||||
}
|
||||
|
||||
ProjectResourceFactoryMP1::ProjectResourceFactoryMP1(hecl::ClientProcess& clientProc)
|
||||
: ProjectResourceFactoryBase(clientProc)
|
||||
{
|
||||
@@ -54,11 +107,29 @@ ProjectResourceFactoryMP1::ProjectResourceFactoryMP1(hecl::ClientProcess& client
|
||||
m_factoryMgr.AddFactory(FOURCC('HINT'), FFactoryFunc(FHintFactory));
|
||||
m_factoryMgr.AddFactory(FOURCC('SAVW'), FFactoryFunc(FSaveWorldFactory));
|
||||
m_factoryMgr.AddFactory(FOURCC('MAPW'), FFactoryFunc(FMapWorldFactory));
|
||||
m_factoryMgr.AddFactory(FOURCC('OIDS'), FFactoryFunc(FMP1OriginalIDsFactory));
|
||||
}
|
||||
|
||||
void ProjectResourceFactoryMP1::IndexMP1Resources(hecl::Database::Project& proj)
|
||||
void ProjectResourceFactoryMP1::IndexMP1Resources(hecl::Database::Project& proj, CSimplePool& sp)
|
||||
{
|
||||
BeginBackgroundIndex(proj, DataSpec::SpecEntMP1, DataSpec::SpecEntMP1PC);
|
||||
m_origIds = sp.GetObj("MP1OriginalIDs");
|
||||
}
|
||||
|
||||
void ProjectResourceFactoryMP1::Shutdown()
|
||||
{
|
||||
m_origIds = TLockedToken<MP1OriginalIDs>();
|
||||
ProjectResourceFactoryBase::Shutdown();
|
||||
}
|
||||
|
||||
ResId ProjectResourceFactoryMP1::TranslateOriginalToNew(ResId id) const
|
||||
{
|
||||
return m_origIds->TranslateOriginalToNew(id);
|
||||
}
|
||||
|
||||
ResId ProjectResourceFactoryMP1::TranslateNewToOriginal(ResId id) const
|
||||
{
|
||||
return m_origIds->TranslateNewToOriginal(id);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user