#ifndef __DNAMP2_HPP__ #define __DNAMP2_HPP__ #include "DataSpec/DNACommon/DNACommon.hpp" #include "PAK.hpp" namespace DataSpec::DNAMP2 { extern logvisor::Module Log; /* MP2-specific, one-shot PAK traversal/extraction class */ class PAKBridge { const nod::Node& m_node; DNAMP2::PAK m_pak; public: bool m_doExtract; using Level = DataSpec::Level; std::unordered_map m_levelDeps; hecl::SystemString m_levelString; PAKBridge(const nod::Node& node, bool doExtract=true); void build(); static ResExtractor LookupExtractor(const nod::Node& pakNode, const DNAMP2::PAK& pak, const DNAMP2::PAK::Entry& entry); std::string_view getName() const {return m_node.getName();} hecl::SystemStringView getLevelString() const {return m_levelString;} using PAKType = DNAMP2::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; void addMAPATransforms(PAKRouter& pakRouter, std::unordered_map& addTo, std::unordered_map& pathOverrides) const; }; } #endif // __DNAMP2_HPP__