mirror of https://github.com/AxioDL/metaforce.git
99 lines
3.2 KiB
C++
99 lines
3.2 KiB
C++
#include "ProjectResourceFactory.hpp"
|
|
#include "Runtime/IOStreams.hpp"
|
|
|
|
#include "Runtime/Particle/CParticleDataFactory.hpp"
|
|
#include "Runtime/Particle/CGenDescription.hpp"
|
|
#include "Runtime/Particle/CElectricDescription.hpp"
|
|
#include "Runtime/Particle/CSwooshDescription.hpp"
|
|
#include "Runtime/CModel.hpp"
|
|
#include "Runtime/CTexture.hpp"
|
|
|
|
namespace URDE
|
|
{
|
|
|
|
ProjectResourceFactory::ProjectResourceFactory()
|
|
{
|
|
m_factoryMgr.AddFactory(HECL::FOURCC('TXTR'), pshag::FTextureFactory);
|
|
m_factoryMgr.AddFactory(HECL::FOURCC('PART'), pshag::FParticleFactory);
|
|
}
|
|
|
|
void ProjectResourceFactory::BuildObjectMap(const HECL::Database::Project::ProjectDataSpec &spec)
|
|
{
|
|
m_tagToPath.clear();
|
|
m_catalogNameToTag.clear();
|
|
HECL::SystemString catalogPath = HECL::ProjectPath(spec.cookedPath, HECL::SystemString(spec.spec.m_name) + _S("/catalog.yaml")).getAbsolutePath();
|
|
FILE* catalogFile = HECL::Fopen(catalogPath.c_str(), _S("r"));
|
|
Athena::io::YAMLDocReader reader;
|
|
yaml_parser_set_input_file(reader.getParser(), catalogFile);
|
|
reader.parse();
|
|
const Athena::io::YAMLNode* catalogRoot = reader.getRootNode();
|
|
if (catalogRoot)
|
|
{
|
|
m_catalogNameToPath.reserve(catalogRoot->m_mapChildren.size());
|
|
for (const std::pair<std::string, std::unique_ptr<Athena::io::YAMLNode>>& ch : catalogRoot->m_mapChildren)
|
|
{
|
|
if (ch.second->m_type == YAML_SCALAR_NODE)
|
|
m_catalogNameToPath[ch.first] = HECL::ProjectPath(spec.cookedPath, HECL::SystemString(ch.second->m_scalarString));
|
|
}
|
|
}
|
|
|
|
if (!HECL::StrCmp(spec.spec.m_name, _S("MP3")))
|
|
{
|
|
RecursiveAddDirObjects(spec.cookedPath);
|
|
}
|
|
else
|
|
{
|
|
RecursiveAddDirObjects(spec.cookedPath);
|
|
}
|
|
}
|
|
|
|
std::unique_ptr<pshag::IObj> ProjectResourceFactory::Build(const pshag::SObjectTag& tag,
|
|
const pshag::CVParamTransfer& paramXfer)
|
|
{
|
|
auto search = m_tagToPath.find(tag);
|
|
if (search == m_tagToPath.end())
|
|
return {};
|
|
|
|
fprintf(stderr, "Loading resource %s\n", search->second.getRelativePath().c_str());
|
|
Athena::io::FileReader fr(search->second.getAbsolutePath(), 32 * 1024, false);
|
|
if (fr.hasError())
|
|
return {};
|
|
|
|
return m_factoryMgr.MakeObject(tag, fr, paramXfer);
|
|
}
|
|
|
|
void ProjectResourceFactory::BuildAsync(const pshag::SObjectTag& tag,
|
|
const pshag::CVParamTransfer& paramXfer,
|
|
pshag::IObj** objOut)
|
|
{
|
|
std::unique_ptr<pshag::IObj> obj = Build(tag, paramXfer);
|
|
*objOut = obj.release();
|
|
}
|
|
|
|
void ProjectResourceFactory::CancelBuild(const pshag::SObjectTag&)
|
|
{
|
|
}
|
|
|
|
bool ProjectResourceFactory::CanBuild(const pshag::SObjectTag& tag)
|
|
{
|
|
auto search = m_tagToPath.find(tag);
|
|
if (search == m_tagToPath.end())
|
|
return false;
|
|
|
|
Athena::io::FileReader fr(search->second.getAbsolutePath(), 32 * 1024, false);
|
|
if (fr.hasError())
|
|
return false;
|
|
|
|
return true;
|
|
}
|
|
|
|
const pshag::SObjectTag* ProjectResourceFactory::GetResourceIdByName(const char* name) const
|
|
{
|
|
if (m_catalogNameToTag.find(name) == m_catalogNameToTag.end())
|
|
return nullptr;
|
|
const pshag::SObjectTag& tag = m_catalogNameToTag.at(name);
|
|
return &tag;
|
|
}
|
|
|
|
}
|