2015-07-16 01:57:34 +00:00
|
|
|
#ifndef __DNAMP1_HPP__
|
|
|
|
#define __DNAMP1_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 DNAMP1
|
|
|
|
{
|
|
|
|
|
|
|
|
extern LogVisor::LogModule Log;
|
|
|
|
|
2015-07-17 00:01:05 +00:00
|
|
|
/* MP1-specific, one-shot PAK traversal/extraction class */
|
|
|
|
class PAKBridge
|
|
|
|
{
|
|
|
|
HECL::Database::Project& m_project;
|
|
|
|
const NOD::DiscBase::IPartition::Node& m_node;
|
|
|
|
PAK m_pak;
|
2015-08-04 02:14:47 +00:00
|
|
|
struct Area
|
|
|
|
{
|
|
|
|
HECL::SystemString name;
|
|
|
|
struct Layer
|
|
|
|
{
|
|
|
|
HECL::SystemString name;
|
|
|
|
std::unordered_set<UniqueID32> resources;
|
|
|
|
};
|
|
|
|
std::vector<Layer> layers;
|
|
|
|
std::unordered_set<UniqueID32> resources;
|
|
|
|
};
|
|
|
|
std::unordered_map<UniqueID32, Area> m_areaDeps;
|
|
|
|
HECL::SystemString m_levelString;
|
|
|
|
UniqueResult uniqueCheck(const PAK::Entry& entry);
|
2015-07-17 00:01:05 +00:00
|
|
|
public:
|
|
|
|
PAKBridge(HECL::Database::Project& project, const NOD::DiscBase::IPartition::Node& node);
|
2015-08-04 02:14:47 +00:00
|
|
|
void build();
|
|
|
|
static ResExtractor<PAKBridge> LookupExtractor(const PAK::Entry& entry);
|
2015-09-06 05:34:30 +00:00
|
|
|
const std::string& getName() const {return m_node.getName();}
|
|
|
|
const HECL::SystemString& getLevelString() const {return m_levelString;}
|
2015-07-28 23:53:57 +00:00
|
|
|
|
2015-09-06 05:34:30 +00:00
|
|
|
using PAKType = PAK;
|
|
|
|
const PAKType& getPAK() const {return m_pak;}
|
|
|
|
const NOD::DiscBase::IPartition::Node& getNode() const {return m_node;}
|
|
|
|
|
|
|
|
void addCMDLRigPairs(std::unordered_map<UniqueID32, std::pair<UniqueID32, UniqueID32>>& addTo) const;
|
2015-07-17 00:01:05 +00:00
|
|
|
};
|
|
|
|
|
2015-07-16 01:57:34 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif // __DNAMP1_HPP__
|