metaforce/DataSpec/DNAMP3/DNAMP3.hpp

57 lines
1.5 KiB
C++
Raw Normal View History

2015-07-16 01:57:34 +00:00
#ifndef __DNAMP3_HPP__
#define __DNAMP3_HPP__
#include "../DNACommon/DNACommon.hpp"
2015-07-17 00:01:05 +00:00
#include "PAK.hpp"
2015-07-16 01:57:34 +00:00
namespace Retro
{
namespace DNAMP3
{
extern LogVisor::LogModule Log;
2015-07-17 00:01:05 +00:00
/* MP3-specific, one-shot PAK traversal/extraction class */
class PAKBridge
{
HECL::Database::Project& m_project;
const NOD::DiscBase::IPartition::Node& m_node;
PAK m_pak;
public:
struct Level
2015-09-23 06:35:07 +00:00
{
HECL::SystemString name;
struct Area
2015-09-23 06:35:07 +00:00
{
HECL::SystemString name;
struct Layer
{
HECL::SystemString name;
std::unordered_set<UniqueID64> resources;
};
std::vector<Layer> layers;
2015-09-23 06:35:07 +00:00
std::unordered_set<UniqueID64> resources;
};
std::unordered_map<UniqueID64, Area> areas;
2015-09-23 06:35:07 +00:00
};
std::unordered_map<UniqueID64, Level> m_levelDeps;
2015-09-23 06:35:07 +00:00
HECL::SystemString m_levelString;
2015-07-17 00:01:05 +00:00
PAKBridge(HECL::Database::Project& project, const NOD::DiscBase::IPartition::Node& node);
void build();
static ResExtractor<PAKBridge> LookupExtractor(const PAK::Entry& entry);
inline const std::string& getName() const {return m_node.getName();}
inline HECL::SystemString getLevelString() const {return m_levelString;}
2015-07-28 23:53:57 +00:00
2015-09-19 01:38:40 +00:00
using PAKType = PAK;
inline const PAKType& getPAK() const {return m_pak;}
inline const NOD::DiscBase::IPartition::Node& getNode() const {return m_node;}
void addCMDLRigPairs(std::unordered_map<UniqueID64, std::pair<UniqueID64, UniqueID64>>& addTo) const;
2015-07-17 00:01:05 +00:00
};
2015-07-16 01:57:34 +00:00
}
}
#endif // __DNAMP3_HPP__