metaforce/DataSpec/DNAMP1/PAK.hpp

58 lines
1.6 KiB
C++
Raw Permalink Normal View History

2018-10-07 03:42:33 +00:00
#pragma once
2015-07-06 01:33:06 +00:00
#include <unordered_map>
2016-03-04 23:04:53 +00:00
#include <nod/DiscBase.hpp>
2018-06-29 20:21:36 +00:00
#include "DataSpec/DNACommon/PAK.hpp"
2015-07-06 01:33:06 +00:00
2018-12-08 05:30:43 +00:00
namespace DataSpec::DNAMP1 {
struct PAK : BigDNA {
bool m_useLzo;
bool m_noShare;
PAK(bool useLzo, bool noShare) : m_useLzo(useLzo), m_noShare(noShare) {}
AT_DECL_EXPLICIT_DNA
struct NameEntry : BigDNA {
AT_DECL_DNA
DNAFourCC type;
UniqueID32 id;
Value<atUint32> nameLen;
String<AT_DNA_COUNT(nameLen)> name;
};
struct Entry : BigDNA {
AT_DECL_DNA
Value<atUint32> compressed;
DNAFourCC type;
UniqueID32 id;
Value<atUint32> size;
Value<atUint32> offset;
UniqueResult unique;
std::string name; /* backreferencing name for RE purposes */
std::unique_ptr<atUint8[]> getBuffer(const nod::Node& pak, atUint64& szOut) const;
inline PAKEntryReadStream beginReadStream(const nod::Node& pak, atUint64 off = 0) const {
atUint64 sz;
std::unique_ptr<atUint8[]> buf = getBuffer(pak, sz);
return PAKEntryReadStream(std::move(buf), sz, off);
}
};
std::vector<NameEntry> m_nameEntries;
std::unordered_map<UniqueID32, Entry> m_entries;
std::vector<UniqueID32> m_firstEntries;
std::unordered_map<std::string, UniqueID32> m_nameMap;
std::unordered_set<UniqueID32> m_dupeMREAs;
const Entry* lookupEntry(const UniqueID32& id) const;
const Entry* lookupEntry(std::string_view name) const;
2019-10-01 07:38:03 +00:00
std::string bestEntryName(const nod::Node& pakNode, const Entry& entry, std::string& catalogueName) const;
2018-12-08 05:30:43 +00:00
bool mreaHasDupeResources(const UniqueID32& id) const { return m_dupeMREAs.find(id) != m_dupeMREAs.cend(); }
using IDType = UniqueID32;
2015-07-06 01:33:06 +00:00
};
2018-12-08 05:30:43 +00:00
} // namespace DataSpec::DNAMP1