#ifndef __DNAMP2_HPP__ #define __DNAMP2_HPP__ #include "../DNACommon/DNACommon.hpp" #include "../DNAMP1/PAK.hpp" namespace DataSpec { namespace DNAMP2 { extern logvisor::Module Log; /* MP2-specific, one-shot PAK traversal/extraction class */ class PAKBridge { hecl::Database::Project& m_project; const nod::Node& m_node; DNAMP1::PAK m_pak; public: bool m_doExtract; using Level = DataSpec::Level; std::unordered_map m_levelDeps; hecl::SystemString m_levelString; PAKBridge(hecl::Database::Project& project, const nod::Node& node, bool doExtract=true); void build(); static ResExtractor LookupExtractor(const DNAMP1::PAK& pak, const DNAMP1::PAK::Entry& entry); const std::string& getName() const {return m_node.getName();} const hecl::SystemString& getLevelString() const {return m_levelString;} using PAKType = DNAMP1::PAK; const PAKType& getPAK() const {return m_pak;} const nod::Node& getNode() const {return m_node;} void addCMDLRigPairs(PAKRouter& pakRouter, std::unordered_map>& addTo, std::unordered_map>& cskrCinfToAncs) const; }; } } #endif // __DNAMP2_HPP__