mirror of https://github.com/AxioDL/metaforce.git
Merge branch 'master' of https://github.com/AxioDL/urde into drone
This commit is contained in:
commit
dc4b39aa9d
|
@ -1,15 +1,19 @@
|
|||
#include "AROTBuilder.hpp"
|
||||
|
||||
#include <algorithm>
|
||||
#include <array>
|
||||
|
||||
#include "hecl/Blender/Connection.hpp"
|
||||
#include "../DNAMP1/PATH.hpp"
|
||||
|
||||
namespace DataSpec {
|
||||
logvisor::Module Log("AROTBuilder");
|
||||
|
||||
#define AROT_MAX_LEVEL 10
|
||||
#define AROT_MIN_SUBDIV 10.f
|
||||
#define AROT_MIN_MODELS 8
|
||||
#define COLLISION_MIN_NODE_TRIANGLES 8
|
||||
#define PATH_MIN_NODE_REGIONS 16
|
||||
constexpr s32 AROT_MAX_LEVEL = 10;
|
||||
constexpr s32 AROT_MIN_MODELS = 8;
|
||||
constexpr s32 COLLISION_MIN_NODE_TRIANGLES = 8;
|
||||
constexpr s32 PATH_MIN_NODE_REGIONS = 16;
|
||||
constexpr float AROT_MIN_SUBDIV = 10.f;
|
||||
|
||||
static zeus::CAABox SplitAABB(const zeus::CAABox& aabb, int i) {
|
||||
zeus::CAABox pos, neg;
|
||||
|
@ -128,7 +132,9 @@ size_t AROTBuilder::BitmapPool::addIndices(const std::set<int>& indices) {
|
|||
return m_pool.size() - 1;
|
||||
}
|
||||
|
||||
static const uint32_t AROTChildCounts[] = {0, 2, 2, 4, 2, 4, 4, 8};
|
||||
constexpr std::array<uint32_t, 8> AROTChildCounts{
|
||||
0, 2, 2, 4, 2, 4, 4, 8,
|
||||
};
|
||||
|
||||
void AROTBuilder::Node::nodeCount(size_t& sz, size_t& idxRefs, BitmapPool& bmpPool, size_t& curOff) {
|
||||
sz += 1;
|
||||
|
@ -176,7 +182,7 @@ void AROTBuilder::Node::writeNodes(athena::io::MemoryWriter& w, int nodeIdx) {
|
|||
if (curIdx > 65535)
|
||||
Log.report(logvisor::Fatal, fmt("AROT node exceeds 16-bit node addressing; area too complex"));
|
||||
|
||||
int childIndices[8];
|
||||
std::array<int, 8> childIndices;
|
||||
|
||||
for (int k = 0; k < 1 + ((compSubdivs & 0x4) != 0); ++k) {
|
||||
for (int j = 0; j < 1 + ((compSubdivs & 0x2) != 0); ++j) {
|
||||
|
@ -280,17 +286,16 @@ void AROTBuilder::Node::pathWrite(DNAMP1::PATH& path, const zeus::CAABox& curAAB
|
|||
n.aabb[0] = curAABB.min;
|
||||
n.aabb[1] = curAABB.max;
|
||||
n.centroid = curAABB.center();
|
||||
for (int i = 0; i < 8; ++i)
|
||||
n.children[i] = 0xffffffff;
|
||||
std::fill(std::begin(n.children), std::end(n.children), 0xFFFFFFFF);
|
||||
n.regionCount = childIndices.size();
|
||||
n.regionStart = path.octreeRegionLookup.size();
|
||||
for (int r : childIndices)
|
||||
path.octreeRegionLookup.push_back(r);
|
||||
} else {
|
||||
atUint32 children[8];
|
||||
for (int i = 0; i < 8; ++i) {
|
||||
std::array<atUint32, 8> children;
|
||||
for (size_t i = 0; i < children.size(); ++i) {
|
||||
/* Head recursion (first node will be a leaf) */
|
||||
childNodes[i].pathWrite(path, SplitAABB(curAABB, i));
|
||||
childNodes[i].pathWrite(path, SplitAABB(curAABB, static_cast<int>(i)));
|
||||
children[i] = path.octree.size() - 1;
|
||||
}
|
||||
|
||||
|
@ -300,8 +305,7 @@ void AROTBuilder::Node::pathWrite(DNAMP1::PATH& path, const zeus::CAABox& curAAB
|
|||
n.aabb[0] = curAABB.min;
|
||||
n.aabb[1] = curAABB.max;
|
||||
n.centroid = curAABB.center();
|
||||
for (int i = 0; i < 8; ++i)
|
||||
n.children[i] = children[i];
|
||||
std::copy(children.cbegin(), children.cend(), std::begin(n.children));
|
||||
n.regionCount = 0;
|
||||
n.regionStart = 0;
|
||||
}
|
||||
|
@ -343,18 +347,20 @@ void AROTBuilder::build(std::vector<std::vector<uint8_t>>& secs, const zeus::CAA
|
|||
auto bmpIt = bmp.cbegin();
|
||||
if (bmpIt != bmp.cend()) {
|
||||
int curIdx = 0;
|
||||
for (size_t w = 0; w < bmpWordCount; ++w) {
|
||||
for (int b = 0; b < 32; ++b) {
|
||||
for (size_t word = 0; word < bmpWordCount; ++word) {
|
||||
for (u32 b = 0; b < 32; ++b) {
|
||||
if (*bmpIt == curIdx) {
|
||||
bmpWords[w] |= 1 << b;
|
||||
bmpWords[word] |= 1U << b;
|
||||
++bmpIt;
|
||||
if (bmpIt == bmp.cend())
|
||||
if (bmpIt == bmp.cend()) {
|
||||
break;
|
||||
}
|
||||
}
|
||||
++curIdx;
|
||||
}
|
||||
if (bmpIt == bmp.cend())
|
||||
if (bmpIt == bmp.cend()) {
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -377,12 +383,11 @@ std::pair<std::unique_ptr<uint8_t[]>, uint32_t> AROTBuilder::buildCol(const ColM
|
|||
std::vector<zeus::CAABox> triBoxes;
|
||||
triBoxes.reserve(mesh.trianges.size());
|
||||
for (const ColMesh::Triangle& tri : mesh.trianges) {
|
||||
triBoxes.emplace_back();
|
||||
zeus::CAABox& aabb = triBoxes.back();
|
||||
for (int e = 0; e < 3; ++e) {
|
||||
const ColMesh::Edge& edge = mesh.edges[tri.edges[e]];
|
||||
for (int v = 0; v < 2; ++v) {
|
||||
const auto& vert = mesh.verts[edge.verts[v]];
|
||||
zeus::CAABox& aabb = triBoxes.emplace_back();
|
||||
for (const u32 edgeIdx : tri.edges) {
|
||||
const ColMesh::Edge& edge = mesh.edges[edgeIdx];
|
||||
for (const u32 vertIdx : edge.verts) {
|
||||
const auto& vert = mesh.verts[vertIdx];
|
||||
aabb.accumulateBounds(zeus::CVector3f(vert));
|
||||
}
|
||||
}
|
||||
|
|
|
@ -48,9 +48,7 @@ bool ATBL::Cook(const hecl::ProjectPath& inPath, const hecl::ProjectPath& outPat
|
|||
maxI = std::max(maxI, i);
|
||||
}
|
||||
|
||||
std::vector<uint16_t> vecOut;
|
||||
vecOut.resize(maxI + 1, 0xffff);
|
||||
|
||||
std::vector<uint16_t> vecOut(maxI + 1, 0xffff);
|
||||
for (const auto& pair : dr.getRootNode()->m_mapChildren) {
|
||||
unsigned long i = strtoul(pair.first.c_str(), nullptr, 0);
|
||||
vecOut[i] = hecl::SBig(uint16_t(strtoul(pair.second->m_scalarString.c_str(), nullptr, 0)));
|
||||
|
|
|
@ -1,248 +1,24 @@
|
|||
#include "DataSpec/DNACommon/CRSC.hpp"
|
||||
|
||||
#include <algorithm>
|
||||
|
||||
#include "DataSpec/DNACommon/PAK.hpp"
|
||||
|
||||
#include <logvisor/logvisor.hpp>
|
||||
|
||||
namespace DataSpec::DNAParticle {
|
||||
static const std::vector<FourCC> GeneratorTypes = {
|
||||
SBIG('NODP'), SBIG('DEFS'), SBIG('CRTS'), SBIG('MTLS'), SBIG('GRAS'), SBIG('ICEE'), SBIG('GOOO'), SBIG('WODS'),
|
||||
SBIG('WATR'), SBIG('1MUD'), SBIG('1LAV'), SBIG('1SAN'), SBIG('1PRJ'), SBIG('DCHR'), SBIG('DCHS'), SBIG('DCSH'),
|
||||
SBIG('DENM'), SBIG('DESP'), SBIG('DESH'), SBIG('BTLE'), SBIG('WASP'), SBIG('TALP'), SBIG('PTGM'), SBIG('SPIR'),
|
||||
SBIG('FPIR'), SBIG('FFLE'), SBIG('PARA'), SBIG('BMON'), SBIG('BFLR'), SBIG('PBOS'), SBIG('IBOS'), SBIG('1SVA'),
|
||||
SBIG('1RPR'), SBIG('1MTR'), SBIG('1PDS'), SBIG('1FLB'), SBIG('1DRN'), SBIG('1MRE'), SBIG('CHOZ'), SBIG('JZAP'),
|
||||
SBIG('1ISE'), SBIG('1BSE'), SBIG('1ATB'), SBIG('1ATA'), SBIG('BTSP'), SBIG('WWSP'), SBIG('TASP'), SBIG('TGSP'),
|
||||
SBIG('SPSP'), SBIG('FPSP'), SBIG('FFSP'), SBIG('PSSP'), SBIG('BMSP'), SBIG('BFSP'), SBIG('PBSP'), SBIG('IBSP'),
|
||||
SBIG('2SVA'), SBIG('2RPR'), SBIG('2MTR'), SBIG('2PDS'), SBIG('2FLB'), SBIG('2DRN'), SBIG('2MRE'), SBIG('CHSP'),
|
||||
SBIG('JZSP'), SBIG('3ISE'), SBIG('3BSE'), SBIG('3ATB'), SBIG('3ATA'), SBIG('BTSH'), SBIG('WWSH'), SBIG('TASH'),
|
||||
SBIG('TGSH'), SBIG('SPSH'), SBIG('FPSH'), SBIG('FFSH'), SBIG('PSSH'), SBIG('BMSH'), SBIG('BFSH'), SBIG('PBSH'),
|
||||
SBIG('IBSH'), SBIG('3SVA'), SBIG('3RPR'), SBIG('3MTR'), SBIG('3PDS'), SBIG('3FLB'), SBIG('3DRN'), SBIG('3MRE'),
|
||||
SBIG('CHSH'), SBIG('JZSH'), SBIG('5ISE'), SBIG('5BSE'), SBIG('5ATB'), SBIG('5ATA')};
|
||||
|
||||
static const std::vector<FourCC> SFXTypes = {
|
||||
SBIG('DSFX'), SBIG('CSFX'), SBIG('MSFX'), SBIG('GRFX'), SBIG('NSFX'), SBIG('DSFX'), SBIG('CSFX'), SBIG('MSFX'),
|
||||
SBIG('GRFX'), SBIG('ICFX'), SBIG('GOFX'), SBIG('WSFX'), SBIG('WTFX'), SBIG('2MUD'), SBIG('2LAV'), SBIG('2SAN'),
|
||||
SBIG('2PRJ'), SBIG('DCFX'), SBIG('DSFX'), SBIG('DSHX'), SBIG('DEFX'), SBIG('ESFX'), SBIG('SHFX'), SBIG('BEFX'),
|
||||
SBIG('WWFX'), SBIG('TAFX'), SBIG('GTFX'), SBIG('SPFX'), SBIG('FPFX'), SBIG('FFFX'), SBIG('PAFX'), SBIG('BMFX'),
|
||||
SBIG('BFFX'), SBIG('PBFX'), SBIG('IBFX'), SBIG('4SVA'), SBIG('4RPR'), SBIG('4MTR'), SBIG('4PDS'), SBIG('4FLB'),
|
||||
SBIG('4DRN'), SBIG('4MRE'), SBIG('CZFX'), SBIG('JZAS'), SBIG('2ISE'), SBIG('2BSE'), SBIG('2ATB'), SBIG('2ATA'),
|
||||
SBIG('BSFX'), SBIG('WSFX'), SBIG('TSFX'), SBIG('GSFX'), SBIG('SSFX'), SBIG('FSFX'), SBIG('SFFX'), SBIG('PSFX'),
|
||||
SBIG('MSFX'), SBIG('SBFX'), SBIG('PBSX'), SBIG('IBSX'), SBIG('5SVA'), SBIG('5RPR'), SBIG('5MTR'), SBIG('5PDS'),
|
||||
SBIG('5FLB'), SBIG('5DRN'), SBIG('5MRE'), SBIG('CSFX'), SBIG('JZPS'), SBIG('4ISE'), SBIG('4BSE'), SBIG('4ATB'),
|
||||
SBIG('4ATA'), SBIG('BHFX'), SBIG('WHFX'), SBIG('THFX'), SBIG('GHFX'), SBIG('SHFX'), SBIG('FHFX'), SBIG('HFFX'),
|
||||
SBIG('PHFX'), SBIG('MHFX'), SBIG('HBFX'), SBIG('PBHX'), SBIG('IBHX'), SBIG('6SVA'), SBIG('6RPR'), SBIG('6MTR'),
|
||||
SBIG('6PDS'), SBIG('6FLB'), SBIG('6DRN'), SBIG('6MRE'), SBIG('CHFX'), SBIG('JZHS'), SBIG('6ISE'), SBIG('6BSE'),
|
||||
SBIG('6ATB'), SBIG('6ATA'),
|
||||
};
|
||||
template struct PPImpl<_CRSM<UniqueID32>>;
|
||||
template struct PPImpl<_CRSM<UniqueID64>>;
|
||||
|
||||
static const std::vector<FourCC> DecalTypes = {SBIG('NCDL'), SBIG('DDCL'), SBIG('CODL'), SBIG('MEDL'), SBIG('GRDL'),
|
||||
SBIG('ICDL'), SBIG('GODL'), SBIG('WODL'), SBIG('WTDL'), SBIG('3MUD'),
|
||||
SBIG('3LAV'), SBIG('3SAN'), SBIG('CHDL'), SBIG('ENDL')};
|
||||
AT_SUBSPECIALIZE_DNA_YAML(PPImpl<_CRSM<UniqueID32>>)
|
||||
AT_SUBSPECIALIZE_DNA_YAML(PPImpl<_CRSM<UniqueID64>>)
|
||||
|
||||
template <>
|
||||
std::string_view CRSM<UniqueID32>::DNAType() {
|
||||
return "CRSM<UniqueID32>"sv;
|
||||
std::string_view PPImpl<_CRSM<UniqueID32>>::DNAType() {
|
||||
return "urde::CRSM<UniqueID32>"sv;
|
||||
}
|
||||
|
||||
template <>
|
||||
std::string_view CRSM<UniqueID64>::DNAType() {
|
||||
return "CRSM<UniqueID64>"sv;
|
||||
std::string_view PPImpl<_CRSM<UniqueID64>>::DNAType() {
|
||||
return "urde::CRSM<UniqueID64>"sv;
|
||||
}
|
||||
|
||||
template <class IDType>
|
||||
void CRSM<IDType>::_read(athena::io::YAMLDocReader& r) {
|
||||
for (const auto& elem : r.getCurNode()->m_mapChildren) {
|
||||
if (elem.first.size() < 4) {
|
||||
LogModule.report(logvisor::Warning, fmt("short FourCC in element '{}'"), elem.first);
|
||||
continue;
|
||||
}
|
||||
|
||||
if (auto rec = r.enterSubRecord(elem.first.c_str())) {
|
||||
FourCC clsId(elem.first.c_str());
|
||||
auto gen = std::find_if(GeneratorTypes.begin(), GeneratorTypes.end(),
|
||||
[&clsId](const FourCC& other) { return clsId == other; });
|
||||
if (gen != GeneratorTypes.end()) {
|
||||
x0_generators[clsId].read(r);
|
||||
continue;
|
||||
}
|
||||
|
||||
auto sfx = std::find_if(SFXTypes.begin(), SFXTypes.end(),
|
||||
[&clsId](const FourCC& other) { return clsId == other; });
|
||||
if (sfx != SFXTypes.end()) {
|
||||
x10_sfx[clsId] = r.readInt32(clsId.toString());
|
||||
continue;
|
||||
}
|
||||
|
||||
auto decal = std::find_if(DecalTypes.begin(), DecalTypes.end(),
|
||||
[&clsId](const FourCC& other) { return clsId == other; });
|
||||
if (decal != DecalTypes.end()) {
|
||||
x20_decals[clsId].read(r);
|
||||
continue;
|
||||
}
|
||||
if (clsId == SBIG('RNGE'))
|
||||
x30_RNGE = r.readFloat();
|
||||
else if (clsId == SBIG('FOFF'))
|
||||
x34_FOFF = r.readFloat();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
template <class IDType>
|
||||
void CRSM<IDType>::_write(athena::io::YAMLDocWriter& w) const {
|
||||
for (const auto& pair : x0_generators)
|
||||
if (pair.second)
|
||||
if (auto rec = w.enterSubRecord(pair.first.toString()))
|
||||
pair.second.write(w);
|
||||
|
||||
for (const auto& pair : x10_sfx)
|
||||
if (pair.second != UINT32_MAX)
|
||||
w.writeUint32(pair.first.toString(), pair.second);
|
||||
|
||||
for (const auto& pair : x20_decals)
|
||||
if (pair.second)
|
||||
if (auto rec = w.enterSubRecord(pair.first.toString()))
|
||||
pair.second.write(w);
|
||||
|
||||
if (x30_RNGE != 50.f)
|
||||
w.writeFloat("RNGE", x30_RNGE);
|
||||
if (x34_FOFF != 0.2f)
|
||||
w.writeFloat("FOFF", x34_FOFF);
|
||||
}
|
||||
|
||||
template <class IDType>
|
||||
void CRSM<IDType>::_binarySize(size_t& __isz) const {
|
||||
__isz += 4;
|
||||
for (const auto& pair : x0_generators) {
|
||||
if (pair.second) {
|
||||
__isz += 4;
|
||||
pair.second.binarySize(__isz);
|
||||
}
|
||||
}
|
||||
for (const auto& pair : x10_sfx) {
|
||||
if (pair.second != UINT32_MAX)
|
||||
__isz += 12;
|
||||
}
|
||||
|
||||
for (const auto& pair : x20_decals) {
|
||||
if (pair.second) {
|
||||
__isz += 4;
|
||||
pair.second.binarySize(__isz);
|
||||
}
|
||||
}
|
||||
|
||||
if (x30_RNGE != 50.f)
|
||||
__isz += 12;
|
||||
if (x34_FOFF != 0.2f)
|
||||
__isz += 12;
|
||||
}
|
||||
|
||||
template <class IDType>
|
||||
void CRSM<IDType>::_read(athena::io::IStreamReader& r) {
|
||||
DNAFourCC clsId;
|
||||
clsId.read(r);
|
||||
if (clsId != SBIG('CRSM')) {
|
||||
LogModule.report(logvisor::Warning, fmt("non CRSM provided to CRSM parser"));
|
||||
return;
|
||||
}
|
||||
|
||||
while (clsId != SBIG('_END')) {
|
||||
clsId.read(r);
|
||||
auto gen = std::find_if(GeneratorTypes.begin(), GeneratorTypes.end(),
|
||||
[&clsId](const FourCC& other) { return clsId == other; });
|
||||
if (gen != GeneratorTypes.end()) {
|
||||
x0_generators[clsId].read(r);
|
||||
continue;
|
||||
}
|
||||
|
||||
auto sfx = std::find_if(SFXTypes.begin(), SFXTypes.end(),
|
||||
[&clsId](const FourCC& other) { return clsId == other; });
|
||||
if (sfx != SFXTypes.end()) {
|
||||
DNAFourCC fcc;
|
||||
fcc.read(r);
|
||||
if (fcc != SBIG('NONE'))
|
||||
x10_sfx[clsId] = r.readInt32Big();
|
||||
else
|
||||
x10_sfx[clsId] = ~0;
|
||||
continue;
|
||||
}
|
||||
|
||||
auto decal = std::find_if(DecalTypes.begin(), DecalTypes.end(),
|
||||
[&clsId](const FourCC& other) { return clsId == other; });
|
||||
if (decal != DecalTypes.end()) {
|
||||
x20_decals[clsId].read(r);
|
||||
continue;
|
||||
}
|
||||
if (clsId == SBIG('RNGE')) {
|
||||
r.readUint32();
|
||||
x30_RNGE = r.readFloatBig();
|
||||
continue;
|
||||
}
|
||||
if (clsId == SBIG('FOFF')) {
|
||||
r.readUint32();
|
||||
x34_FOFF = r.readFloatBig();
|
||||
continue;
|
||||
}
|
||||
if (clsId != SBIG('_END'))
|
||||
LogModule.report(logvisor::Fatal, fmt("Unknown CRSM class {} @{}"), clsId, r.position());
|
||||
}
|
||||
}
|
||||
|
||||
template <class IDType>
|
||||
void CRSM<IDType>::_write(athena::io::IStreamWriter& w) const {
|
||||
w.writeBytes("CRSM", 4);
|
||||
for (const auto& pair : x0_generators) {
|
||||
w.writeBytes(pair.first.getChars(), 4);
|
||||
pair.second.write(w);
|
||||
}
|
||||
|
||||
for (const auto& pair : x10_sfx) {
|
||||
w.writeBytes(pair.first.getChars(), 4);
|
||||
if (pair.second != UINT32_MAX) {
|
||||
w.writeBytes("CNST", 4);
|
||||
w.writeUint32Big(pair.second);
|
||||
} else {
|
||||
w.writeBytes("NONE", 4);
|
||||
}
|
||||
}
|
||||
|
||||
for (const auto& pair : x20_decals) {
|
||||
w.writeBytes(pair.first.getChars(), 4);
|
||||
pair.second.write(w);
|
||||
}
|
||||
|
||||
if (x30_RNGE != 50.f) {
|
||||
w.writeBytes("RNGECNST", 8);
|
||||
w.writeFloatBig(x30_RNGE);
|
||||
}
|
||||
if (x34_FOFF != 0.2f) {
|
||||
w.writeBytes("FOFFCNST", 8);
|
||||
w.writeFloatBig(x34_FOFF);
|
||||
}
|
||||
w.writeBytes("_END", 4);
|
||||
}
|
||||
|
||||
AT_SUBSPECIALIZE_DNA_YAML(CRSM<UniqueID32>)
|
||||
AT_SUBSPECIALIZE_DNA_YAML(CRSM<UniqueID64>)
|
||||
|
||||
template <class IDType>
|
||||
void CRSM<IDType>::gatherDependencies(std::vector<hecl::ProjectPath>& pathsOut) const {
|
||||
for (const auto& p : x0_generators)
|
||||
g_curSpec->flattenDependencies(p.second.id, pathsOut);
|
||||
for (const auto& p : x20_decals)
|
||||
g_curSpec->flattenDependencies(p.second.id, pathsOut);
|
||||
}
|
||||
|
||||
template <class IDType>
|
||||
CRSM<IDType>::CRSM() : x30_RNGE(50.f), x34_FOFF(0.2f) {
|
||||
for (const auto& sfx : SFXTypes)
|
||||
x10_sfx[sfx] = ~0;
|
||||
}
|
||||
|
||||
template struct CRSM<UniqueID32>;
|
||||
template struct CRSM<UniqueID64>;
|
||||
|
||||
template <class IDType>
|
||||
bool ExtractCRSM(PAKEntryReadStream& rs, const hecl::ProjectPath& outPath) {
|
||||
athena::io::FileWriter writer(outPath.getAbsolutePath());
|
||||
|
|
|
@ -0,0 +1,222 @@
|
|||
#ifndef ENTRY
|
||||
#define ENTRY(name, identifier)
|
||||
#endif
|
||||
|
||||
#ifndef RES_ENTRY
|
||||
#define RES_ENTRY(name, identifier) ENTRY(name, identifier)
|
||||
#endif
|
||||
|
||||
#ifndef U32_ENTRY
|
||||
#define U32_ENTRY(name, identifier) ENTRY(name, identifier)
|
||||
#endif
|
||||
|
||||
#ifndef FLOAT_ENTRY
|
||||
#define FLOAT_ENTRY(name, identifier) ENTRY(name, identifier)
|
||||
#endif
|
||||
|
||||
RES_ENTRY('NODP', NODP)
|
||||
RES_ENTRY('DEFS', DEFS)
|
||||
RES_ENTRY('CRTS', CRTS)
|
||||
RES_ENTRY('MTLS', MTLS)
|
||||
RES_ENTRY('GRAS', GRAS)
|
||||
RES_ENTRY('ICEE', ICEE)
|
||||
RES_ENTRY('GOOO', GOOO)
|
||||
RES_ENTRY('WODS', WODS)
|
||||
RES_ENTRY('WATR', WATR)
|
||||
RES_ENTRY('1MUD', _1MUD)
|
||||
RES_ENTRY('1LAV', _1LAV)
|
||||
RES_ENTRY('1SAN', _1SAN)
|
||||
RES_ENTRY('1PRJ', _1PRJ)
|
||||
RES_ENTRY('DCHR', DCHR)
|
||||
RES_ENTRY('DCHS', DCHS)
|
||||
RES_ENTRY('DCSH', DCSH)
|
||||
RES_ENTRY('DENM', DENM)
|
||||
RES_ENTRY('DESP', DESP)
|
||||
RES_ENTRY('DESH', DESH)
|
||||
RES_ENTRY('BTLE', BTLE)
|
||||
RES_ENTRY('WASP', WASP)
|
||||
RES_ENTRY('TALP', TALP)
|
||||
RES_ENTRY('PTGM', PTGM)
|
||||
RES_ENTRY('SPIR', SPIR)
|
||||
RES_ENTRY('FPIR', FPIR)
|
||||
RES_ENTRY('FFLE', FFLE)
|
||||
RES_ENTRY('PARA', PARA)
|
||||
RES_ENTRY('BMON', BMON)
|
||||
RES_ENTRY('BFLR', BFLR)
|
||||
RES_ENTRY('PBOS', PBOS)
|
||||
RES_ENTRY('IBOS', IBOS)
|
||||
RES_ENTRY('1SVA', _1SVA)
|
||||
RES_ENTRY('1RPR', _1RPR)
|
||||
RES_ENTRY('1MTR', _1MTR)
|
||||
RES_ENTRY('1PDS', _1PDS)
|
||||
RES_ENTRY('1FLB', _1FLB)
|
||||
RES_ENTRY('1DRN', _1DRN)
|
||||
RES_ENTRY('1MRE', _1MRE)
|
||||
RES_ENTRY('CHOZ', CHOZ)
|
||||
RES_ENTRY('JZAP', JZAP)
|
||||
RES_ENTRY('1ISE', _1ISE)
|
||||
RES_ENTRY('1BSE', _1BSE)
|
||||
RES_ENTRY('1ATB', _1ATB)
|
||||
RES_ENTRY('1ATA', _1ATA)
|
||||
RES_ENTRY('BTSP', BTSP)
|
||||
RES_ENTRY('WWSP', WWSP)
|
||||
RES_ENTRY('TASP', TASP)
|
||||
RES_ENTRY('TGSP', TGSP)
|
||||
RES_ENTRY('SPSP', SPSP)
|
||||
RES_ENTRY('FPSP', FPSP)
|
||||
RES_ENTRY('FFSP', FFSP)
|
||||
RES_ENTRY('PSSP', PSSP)
|
||||
RES_ENTRY('BMSP', BMSP)
|
||||
RES_ENTRY('BFSP', BFSP)
|
||||
RES_ENTRY('PBSP', PBSP)
|
||||
RES_ENTRY('IBSP', IBSP)
|
||||
RES_ENTRY('2SVA', _2SVA)
|
||||
RES_ENTRY('2RPR', _2RPR)
|
||||
RES_ENTRY('2MTR', _2MTR)
|
||||
RES_ENTRY('2PDS', _2PDS)
|
||||
RES_ENTRY('2FLB', _2FLB)
|
||||
RES_ENTRY('2DRN', _2DRN)
|
||||
RES_ENTRY('2MRE', _2MRE)
|
||||
RES_ENTRY('CHSP', CHSP)
|
||||
RES_ENTRY('JZSP', JZSP)
|
||||
RES_ENTRY('3ISE', _3ISE)
|
||||
RES_ENTRY('3BSE', _3BSE)
|
||||
RES_ENTRY('3ATB', _3ATB)
|
||||
RES_ENTRY('3ATA', _3ATA)
|
||||
RES_ENTRY('BTSH', BTSH)
|
||||
RES_ENTRY('WWSH', WWSH)
|
||||
RES_ENTRY('TASH', TASH)
|
||||
RES_ENTRY('TGSH', TGSH)
|
||||
RES_ENTRY('SPSH', SPSH)
|
||||
RES_ENTRY('FPSH', FPSH)
|
||||
RES_ENTRY('FFSH', FFSH)
|
||||
RES_ENTRY('PSSH', PSSH)
|
||||
RES_ENTRY('BMSH', BMSH)
|
||||
RES_ENTRY('BFSH', BFSH)
|
||||
RES_ENTRY('PBSH', PBSH)
|
||||
RES_ENTRY('IBSH', IBSH)
|
||||
RES_ENTRY('3SVA', _3SVA)
|
||||
RES_ENTRY('3RPR', _3RPR)
|
||||
RES_ENTRY('3MTR', _3MTR)
|
||||
RES_ENTRY('3PDS', _3PDS)
|
||||
RES_ENTRY('3FLB', _3FLB)
|
||||
RES_ENTRY('3DRN', _3DRN)
|
||||
RES_ENTRY('3MRE', _3MRE)
|
||||
RES_ENTRY('CHSH', CHSH)
|
||||
RES_ENTRY('JZSH', JZSH)
|
||||
RES_ENTRY('5ISE', _5ISE)
|
||||
RES_ENTRY('5BSE', _5BSE)
|
||||
RES_ENTRY('5ATB', _5ATB)
|
||||
RES_ENTRY('5ATA', _5ATA)
|
||||
RES_ENTRY('NCDL', NCDL)
|
||||
RES_ENTRY('DDCL', DDCL)
|
||||
RES_ENTRY('CODL', CODL)
|
||||
RES_ENTRY('MEDL', MEDL)
|
||||
RES_ENTRY('GRDL', GRDL)
|
||||
RES_ENTRY('ICDL', ICDL)
|
||||
RES_ENTRY('GODL', GODL)
|
||||
RES_ENTRY('WODL', WODL)
|
||||
RES_ENTRY('WTDL', WTDL)
|
||||
RES_ENTRY('3MUD', _3MUD)
|
||||
RES_ENTRY('3LAV', _3LAV)
|
||||
RES_ENTRY('3SAN', _3SAN)
|
||||
RES_ENTRY('CHDL', CHDL)
|
||||
RES_ENTRY('ENDL', ENDL)
|
||||
|
||||
U32_ENTRY('NSFX', NSFX)
|
||||
U32_ENTRY('DSFX', DSFX)
|
||||
U32_ENTRY('CSFX', CSFX)
|
||||
U32_ENTRY('MSFX', MSFX)
|
||||
U32_ENTRY('GRFX', GRFX)
|
||||
U32_ENTRY('ICFX', ICFX)
|
||||
U32_ENTRY('GOFX', GOFX)
|
||||
U32_ENTRY('WSFX', WSFX)
|
||||
U32_ENTRY('WTFX', WTFX)
|
||||
U32_ENTRY('2MUD', _2MUD)
|
||||
U32_ENTRY('2LAV', _2LAV)
|
||||
U32_ENTRY('2SAN', _2SAN)
|
||||
U32_ENTRY('2PRJ', _2PRJ)
|
||||
U32_ENTRY('DCFX', DCFX)
|
||||
U32_ENTRY('DSHX', DSHX)
|
||||
U32_ENTRY('DEFX', DEFX)
|
||||
U32_ENTRY('ESFX', ESFX)
|
||||
U32_ENTRY('SHFX', SHFX)
|
||||
U32_ENTRY('BEFX', BEFX)
|
||||
U32_ENTRY('WWFX', WWFX)
|
||||
U32_ENTRY('TAFX', TAFX)
|
||||
U32_ENTRY('GTFX', GTFX)
|
||||
U32_ENTRY('SPFX', SPFX)
|
||||
U32_ENTRY('FPFX', FPFX)
|
||||
U32_ENTRY('FFFX', FFFX)
|
||||
U32_ENTRY('PAFX', PAFX)
|
||||
U32_ENTRY('BMFX', BMFX)
|
||||
U32_ENTRY('BFFX', BFFX)
|
||||
U32_ENTRY('PBFX', PBFX)
|
||||
U32_ENTRY('IBFX', IBFX)
|
||||
U32_ENTRY('4SVA', _4SVA)
|
||||
U32_ENTRY('4RPR', _4RPR)
|
||||
U32_ENTRY('4MTR', _4MTR)
|
||||
U32_ENTRY('4PDS', _4PDS)
|
||||
U32_ENTRY('4FLB', _4FLB)
|
||||
U32_ENTRY('4DRN', _4DRN)
|
||||
U32_ENTRY('4MRE', _4MRE)
|
||||
U32_ENTRY('CZFX', CZFX)
|
||||
U32_ENTRY('JZAS', JZAS)
|
||||
U32_ENTRY('2ISE', _2ISE)
|
||||
U32_ENTRY('2BSE', _2BSE)
|
||||
U32_ENTRY('2ATB', _2ATB)
|
||||
U32_ENTRY('2ATA', _2ATA)
|
||||
U32_ENTRY('BSFX', BSFX)
|
||||
U32_ENTRY('TSFX', TSFX)
|
||||
U32_ENTRY('GSFX', GSFX)
|
||||
U32_ENTRY('SSFX', SSFX)
|
||||
U32_ENTRY('FSFX', FSFX)
|
||||
U32_ENTRY('SFFX', SFFX)
|
||||
U32_ENTRY('PSFX', PSFX)
|
||||
U32_ENTRY('SBFX', SBFX)
|
||||
U32_ENTRY('PBSX', PBSX)
|
||||
U32_ENTRY('IBSX', IBSX)
|
||||
U32_ENTRY('5SVA', _5SVA)
|
||||
U32_ENTRY('5RPR', _5RPR)
|
||||
U32_ENTRY('5MTR', _5MTR)
|
||||
U32_ENTRY('5PDS', _5PDS)
|
||||
U32_ENTRY('5FLB', _5FLB)
|
||||
U32_ENTRY('5DRN', _5DRN)
|
||||
U32_ENTRY('5MRE', _5MRE)
|
||||
U32_ENTRY('JZPS', JZPS)
|
||||
U32_ENTRY('4ISE', _4ISE)
|
||||
U32_ENTRY('4BSE', _4BSE)
|
||||
U32_ENTRY('4ATB', _4ATB)
|
||||
U32_ENTRY('4ATA', _4ATA)
|
||||
U32_ENTRY('BHFX', BHFX)
|
||||
U32_ENTRY('WHFX', WHFX)
|
||||
U32_ENTRY('THFX', THFX)
|
||||
U32_ENTRY('GHFX', GHFX)
|
||||
U32_ENTRY('FHFX', FHFX)
|
||||
U32_ENTRY('HFFX', HFFX)
|
||||
U32_ENTRY('PHFX', PHFX)
|
||||
U32_ENTRY('MHFX', MHFX)
|
||||
U32_ENTRY('HBFX', HBFX)
|
||||
U32_ENTRY('PBHX', PBHX)
|
||||
U32_ENTRY('IBHX', IBHX)
|
||||
U32_ENTRY('6SVA', _6SVA)
|
||||
U32_ENTRY('6RPR', _6RPR)
|
||||
U32_ENTRY('6MTR', _6MTR)
|
||||
U32_ENTRY('6PDS', _6PDS)
|
||||
U32_ENTRY('6FLB', _6FLB)
|
||||
U32_ENTRY('6DRN', _6DRN)
|
||||
U32_ENTRY('6MRE', _6MRE)
|
||||
U32_ENTRY('CHFX', CHFX)
|
||||
U32_ENTRY('JZHS', JZHS)
|
||||
U32_ENTRY('6ISE', _6ISE)
|
||||
U32_ENTRY('6BSE', _6BSE)
|
||||
U32_ENTRY('6ATB', _6ATB)
|
||||
U32_ENTRY('6ATA', _6ATA)
|
||||
|
||||
FLOAT_ENTRY('RNGE', x30_RNGE)
|
||||
FLOAT_ENTRY('FOFF', x34_FOFF)
|
||||
|
||||
#undef ENTRY
|
||||
#undef RES_ENTRY
|
||||
#undef U32_ENTRY
|
||||
#undef FLOAT_ENTRY
|
|
@ -18,20 +18,33 @@ class ProjectPath;
|
|||
}
|
||||
|
||||
namespace DataSpec::DNAParticle {
|
||||
|
||||
template <class IDType>
|
||||
struct CRSM : BigDNA {
|
||||
AT_DECL_EXPLICIT_DNA_YAML
|
||||
AT_SUBDECL_DNA
|
||||
std::unordered_map<FourCC, ChildResourceFactory<IDType>> x0_generators;
|
||||
std::unordered_map<FourCC, uint32_t> x10_sfx;
|
||||
std::unordered_map<FourCC, ChildResourceFactory<IDType>> x20_decals;
|
||||
float x30_RNGE;
|
||||
float x34_FOFF;
|
||||
struct _CRSM {
|
||||
static constexpr ParticleType Type = ParticleType::CRSM;
|
||||
#define RES_ENTRY(name, identifier) ChildResourceFactory<IDType> identifier;
|
||||
#define U32_ENTRY(name, identifier) uint32_t identifier = ~0;
|
||||
#define FLOAT_ENTRY(name, identifier) float identifier = 0.f;
|
||||
#include "CRSC.def"
|
||||
|
||||
CRSM();
|
||||
template<typename _Func>
|
||||
void constexpr Enumerate(_Func f) {
|
||||
#define ENTRY(name, identifier) f(FOURCC(name), identifier);
|
||||
#include "CRSC.def"
|
||||
}
|
||||
|
||||
void gatherDependencies(std::vector<hecl::ProjectPath>&) const;
|
||||
template<typename _Func>
|
||||
bool constexpr Lookup(FourCC fcc, _Func f) {
|
||||
switch (fcc.toUint32()) {
|
||||
#define ENTRY(name, identifier) case SBIG(name): f(identifier); return true;
|
||||
#include "CRSC.def"
|
||||
default: return false;
|
||||
}
|
||||
}
|
||||
};
|
||||
template <class IDType>
|
||||
using CRSM = PPImpl<_CRSM<IDType>>;
|
||||
|
||||
template <class IDType>
|
||||
bool ExtractCRSM(PAKEntryReadStream& rs, const hecl::ProjectPath& outPath);
|
||||
|
||||
|
|
|
@ -1,391 +1,24 @@
|
|||
#include "DataSpec/DNACommon/DPSC.hpp"
|
||||
|
||||
#include "DataSpec/DNACommon/PAK.hpp"
|
||||
|
||||
#include <athena/DNAYaml.hpp>
|
||||
#include <logvisor/logvisor.hpp>
|
||||
|
||||
namespace DataSpec::DNAParticle {
|
||||
|
||||
template struct PPImpl<_DPSM<UniqueID32>>;
|
||||
template struct PPImpl<_DPSM<UniqueID64>>;
|
||||
|
||||
AT_SUBSPECIALIZE_DNA_YAML(PPImpl<_DPSM<UniqueID32>>)
|
||||
AT_SUBSPECIALIZE_DNA_YAML(PPImpl<_DPSM<UniqueID64>>)
|
||||
|
||||
template <>
|
||||
std::string_view DPSM<UniqueID32>::DNAType() {
|
||||
std::string_view PPImpl<_DPSM<UniqueID32>>::DNAType() {
|
||||
return "DPSM<UniqueID32>"sv;
|
||||
}
|
||||
|
||||
template <>
|
||||
std::string_view DPSM<UniqueID64>::DNAType() {
|
||||
std::string_view PPImpl<_DPSM<UniqueID64>>::DNAType() {
|
||||
return "DPSM<UniqueID64>"sv;
|
||||
}
|
||||
|
||||
template <class IDType>
|
||||
void DPSM<IDType>::_read(athena::io::YAMLDocReader& r) {
|
||||
for (const auto& elem : r.getCurNode()->m_mapChildren) {
|
||||
if (elem.first.size() < 4) {
|
||||
LogModule.report(logvisor::Warning, fmt("short FourCC in element '{}'"), elem.first);
|
||||
continue;
|
||||
}
|
||||
|
||||
if (auto rec = r.enterSubRecord(elem.first.c_str())) {
|
||||
bool loadFirstDesc = false;
|
||||
uint32_t clsId = *reinterpret_cast<const uint32_t*>(elem.first.c_str());
|
||||
switch (clsId) {
|
||||
case SBIG('1SZE'):
|
||||
case SBIG('1LFT'):
|
||||
case SBIG('1ROT'):
|
||||
case SBIG('1OFF'):
|
||||
case SBIG('1CLR'):
|
||||
case SBIG('1TEX'):
|
||||
case SBIG('1ADD'):
|
||||
loadFirstDesc = true;
|
||||
[[fallthrough]];
|
||||
case SBIG('2SZE'):
|
||||
case SBIG('2LFT'):
|
||||
case SBIG('2ROT'):
|
||||
case SBIG('2OFF'):
|
||||
case SBIG('2CLR'):
|
||||
case SBIG('2TEX'):
|
||||
case SBIG('2ADD'):
|
||||
if (loadFirstDesc)
|
||||
readQuadDecalInfo(r, clsId, x0_quad);
|
||||
else
|
||||
readQuadDecalInfo(r, clsId, x1c_quad);
|
||||
break;
|
||||
case SBIG('DMDL'):
|
||||
x38_DMDL.read(r);
|
||||
break;
|
||||
case SBIG('DLFT'):
|
||||
x48_DLFT.read(r);
|
||||
break;
|
||||
case SBIG('DMOP'):
|
||||
x4c_DMOP.read(r);
|
||||
break;
|
||||
case SBIG('DMRT'):
|
||||
x50_DMRT.read(r);
|
||||
break;
|
||||
case SBIG('DMSC'):
|
||||
x54_DMSC.read(r);
|
||||
break;
|
||||
case SBIG('DMCL'):
|
||||
x58_DMCL.read(r);
|
||||
break;
|
||||
case SBIG('DMAB'):
|
||||
x5c_24_DMAB = r.readBool();
|
||||
break;
|
||||
case SBIG('DMOO'):
|
||||
x5c_25_DMOO = r.readBool();
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
template <class IDType>
|
||||
void DPSM<IDType>::_write(athena::io::YAMLDocWriter& w) const {
|
||||
writeQuadDecalInfo(w, x0_quad, true);
|
||||
writeQuadDecalInfo(w, x1c_quad, false);
|
||||
|
||||
if (x38_DMDL)
|
||||
if (auto rec = w.enterSubRecord("DMDL"))
|
||||
x38_DMDL.write(w);
|
||||
if (x48_DLFT)
|
||||
if (auto rec = w.enterSubRecord("DLFT"))
|
||||
x48_DLFT.write(w);
|
||||
if (x4c_DMOP)
|
||||
if (auto rec = w.enterSubRecord("DMOP"))
|
||||
x4c_DMOP.write(w);
|
||||
if (x50_DMRT)
|
||||
if (auto rec = w.enterSubRecord("DMRT"))
|
||||
x50_DMRT.write(w);
|
||||
if (x54_DMSC)
|
||||
if (auto rec = w.enterSubRecord("DMSC"))
|
||||
x54_DMSC.write(w);
|
||||
if (x58_DMCL)
|
||||
if (auto rec = w.enterSubRecord("DMCL"))
|
||||
x54_DMSC.write(w);
|
||||
|
||||
if (x5c_24_DMAB)
|
||||
w.writeBool("DMAB", x5c_24_DMAB);
|
||||
if (x5c_25_DMOO)
|
||||
w.writeBool("DMOO", x5c_25_DMOO);
|
||||
}
|
||||
|
||||
template <class IDType>
|
||||
template <class Reader>
|
||||
void DPSM<IDType>::readQuadDecalInfo(Reader& r, FourCC clsId, typename DPSM<IDType>::SQuadDescr& quad) {
|
||||
switch (clsId.toUint32()) {
|
||||
case SBIG('1LFT'):
|
||||
case SBIG('2LFT'):
|
||||
quad.x0_LFT.read(r);
|
||||
break;
|
||||
case SBIG('1SZE'):
|
||||
case SBIG('2SZE'):
|
||||
quad.x4_SZE.read(r);
|
||||
break;
|
||||
case SBIG('1ROT'):
|
||||
case SBIG('2ROT'):
|
||||
quad.x8_ROT.read(r);
|
||||
break;
|
||||
case SBIG('1OFF'):
|
||||
case SBIG('2OFF'):
|
||||
quad.xc_OFF.read(r);
|
||||
break;
|
||||
case SBIG('1CLR'):
|
||||
case SBIG('2CLR'):
|
||||
quad.x10_CLR.read(r);
|
||||
break;
|
||||
case SBIG('1TEX'):
|
||||
case SBIG('2TEX'):
|
||||
quad.x14_TEX.read(r);
|
||||
break;
|
||||
case SBIG('1ADD'):
|
||||
case SBIG('2ADD'):
|
||||
quad.x18_ADD.read(r);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
template <class IDType>
|
||||
void DPSM<IDType>::writeQuadDecalInfo(athena::io::YAMLDocWriter& w, const typename DPSM<IDType>::SQuadDescr& quad,
|
||||
bool first) const {
|
||||
if (quad.x0_LFT)
|
||||
if (auto rec = w.enterSubRecord((first ? "1LFT" : "2LFT")))
|
||||
quad.x0_LFT.write(w);
|
||||
if (quad.x4_SZE)
|
||||
if (auto rec = w.enterSubRecord((first ? "1SZE" : "2SZE")))
|
||||
quad.x4_SZE.write(w);
|
||||
if (quad.x8_ROT)
|
||||
if (auto rec = w.enterSubRecord((first ? "1ROT" : "2ROT")))
|
||||
quad.x8_ROT.write(w);
|
||||
if (quad.xc_OFF)
|
||||
if (auto rec = w.enterSubRecord((first ? "1OFF" : "2OFF")))
|
||||
quad.xc_OFF.write(w);
|
||||
if (quad.x10_CLR)
|
||||
if (auto rec = w.enterSubRecord((first ? "1CLR" : "2CLR")))
|
||||
quad.x10_CLR.write(w);
|
||||
if (quad.x14_TEX)
|
||||
if (auto rec = w.enterSubRecord((first ? "1TEX" : "2TEX")))
|
||||
quad.x14_TEX.write(w);
|
||||
if (quad.x18_ADD)
|
||||
if (auto rec = w.enterSubRecord((first ? "1ADD" : "2ADD")))
|
||||
quad.x18_ADD.write(w);
|
||||
}
|
||||
|
||||
template <class IDType>
|
||||
void DPSM<IDType>::_binarySize(size_t& s) const {
|
||||
s += 4;
|
||||
getQuadDecalBinarySize(s, x0_quad);
|
||||
getQuadDecalBinarySize(s, x1c_quad);
|
||||
if (x38_DMDL) {
|
||||
s += 4;
|
||||
x38_DMDL.binarySize(s);
|
||||
}
|
||||
if (x48_DLFT) {
|
||||
s += 4;
|
||||
x48_DLFT.binarySize(s);
|
||||
}
|
||||
if (x4c_DMOP) {
|
||||
s += 4;
|
||||
x4c_DMOP.binarySize(s);
|
||||
}
|
||||
if (x50_DMRT) {
|
||||
s += 4;
|
||||
x50_DMRT.binarySize(s);
|
||||
}
|
||||
if (x54_DMSC) {
|
||||
s += 4;
|
||||
x54_DMSC.binarySize(s);
|
||||
}
|
||||
if (x58_DMCL) {
|
||||
x58_DMCL.binarySize(s);
|
||||
}
|
||||
if (x5c_24_DMAB)
|
||||
s += 9;
|
||||
if (x5c_25_DMOO)
|
||||
s += 9;
|
||||
}
|
||||
|
||||
template <class IDType>
|
||||
void DPSM<IDType>::getQuadDecalBinarySize(size_t& s, const typename DPSM<IDType>::SQuadDescr& quad) const {
|
||||
if (quad.x0_LFT) {
|
||||
s += 4;
|
||||
quad.x0_LFT.binarySize(s);
|
||||
}
|
||||
if (quad.x4_SZE) {
|
||||
s += 4;
|
||||
quad.x4_SZE.binarySize(s);
|
||||
}
|
||||
if (quad.x8_ROT) {
|
||||
s += 4;
|
||||
quad.x8_ROT.binarySize(s);
|
||||
}
|
||||
if (quad.xc_OFF) {
|
||||
s += 4;
|
||||
quad.xc_OFF.binarySize(s);
|
||||
}
|
||||
if (quad.x10_CLR) {
|
||||
s += 4;
|
||||
quad.x10_CLR.binarySize(s);
|
||||
}
|
||||
if (quad.x14_TEX) {
|
||||
s += 4;
|
||||
quad.x14_TEX.binarySize(s);
|
||||
}
|
||||
if (quad.x18_ADD) {
|
||||
s += 4;
|
||||
quad.x18_ADD.binarySize(s);
|
||||
}
|
||||
}
|
||||
|
||||
template <class IDType>
|
||||
void DPSM<IDType>::_read(athena::io::IStreamReader& r) {
|
||||
DNAFourCC clsId;
|
||||
clsId.read(r);
|
||||
if (clsId != SBIG('DPSM')) {
|
||||
LogModule.report(logvisor::Warning, fmt("non DPSM provided to DPSM parser"));
|
||||
return;
|
||||
}
|
||||
bool loadFirstDesc = false;
|
||||
clsId.read(r);
|
||||
while (clsId != SBIG('_END')) {
|
||||
switch (clsId.toUint32()) {
|
||||
case SBIG('1SZE'):
|
||||
case SBIG('1LFT'):
|
||||
case SBIG('1ROT'):
|
||||
case SBIG('1OFF'):
|
||||
case SBIG('1CLR'):
|
||||
case SBIG('1TEX'):
|
||||
case SBIG('1ADD'):
|
||||
loadFirstDesc = true;
|
||||
[[fallthrough]];
|
||||
case SBIG('2SZE'):
|
||||
case SBIG('2LFT'):
|
||||
case SBIG('2ROT'):
|
||||
case SBIG('2OFF'):
|
||||
case SBIG('2CLR'):
|
||||
case SBIG('2TEX'):
|
||||
case SBIG('2ADD'):
|
||||
if (loadFirstDesc)
|
||||
readQuadDecalInfo(r, clsId, x0_quad);
|
||||
else
|
||||
readQuadDecalInfo(r, clsId, x1c_quad);
|
||||
break;
|
||||
case SBIG('DMDL'):
|
||||
x38_DMDL.read(r);
|
||||
break;
|
||||
case SBIG('DLFT'):
|
||||
x48_DLFT.read(r);
|
||||
break;
|
||||
case SBIG('DMOP'):
|
||||
x4c_DMOP.read(r);
|
||||
break;
|
||||
case SBIG('DMRT'):
|
||||
x50_DMRT.read(r);
|
||||
break;
|
||||
case SBIG('DMSC'):
|
||||
x54_DMSC.read(r);
|
||||
break;
|
||||
case SBIG('DMCL'):
|
||||
x58_DMCL.read(r);
|
||||
break;
|
||||
case SBIG('DMAB'):
|
||||
r.readUint32();
|
||||
x5c_24_DMAB = r.readBool();
|
||||
break;
|
||||
case SBIG('DMOO'):
|
||||
r.readUint32();
|
||||
x5c_25_DMOO = r.readBool();
|
||||
break;
|
||||
default:
|
||||
LogModule.report(logvisor::Fatal, fmt("Unknown DPSM class {} @{}"), clsId, r.position());
|
||||
break;
|
||||
}
|
||||
clsId.read(r);
|
||||
}
|
||||
}
|
||||
|
||||
template <class IDType>
|
||||
void DPSM<IDType>::_write(athena::io::IStreamWriter& w) const {
|
||||
w.writeBytes("DPSM", 4);
|
||||
writeQuadDecalInfo(w, x0_quad, true);
|
||||
writeQuadDecalInfo(w, x1c_quad, false);
|
||||
if (x38_DMDL) {
|
||||
w.writeBytes("DMDL", 4);
|
||||
x38_DMDL.write(w);
|
||||
}
|
||||
if (x48_DLFT) {
|
||||
w.writeBytes("DLFT", 4);
|
||||
x48_DLFT.write(w);
|
||||
}
|
||||
if (x4c_DMOP) {
|
||||
w.writeBytes("DMOP", 4);
|
||||
x4c_DMOP.write(w);
|
||||
}
|
||||
if (x50_DMRT) {
|
||||
w.writeBytes("DMRT", 4);
|
||||
x50_DMRT.write(w);
|
||||
}
|
||||
if (x54_DMSC) {
|
||||
w.writeBytes("DMSC", 4);
|
||||
x54_DMSC.write(w);
|
||||
}
|
||||
if (x58_DMCL) {
|
||||
w.writeBytes("DMCL", 4);
|
||||
x58_DMCL.write(w);
|
||||
}
|
||||
if (x5c_24_DMAB)
|
||||
w.writeBytes("DMABCNST\x01", 9);
|
||||
if (x5c_25_DMOO)
|
||||
w.writeBytes("DMOOCNST\x01", 9);
|
||||
w.writeBytes("_END", 4);
|
||||
}
|
||||
|
||||
template <class IDType>
|
||||
void DPSM<IDType>::writeQuadDecalInfo(athena::io::IStreamWriter& w, const typename DPSM<IDType>::SQuadDescr& quad,
|
||||
bool first) const {
|
||||
if (quad.x0_LFT) {
|
||||
w.writeBytes((first ? "1LFT" : "2LFT"), 4);
|
||||
quad.x0_LFT.write(w);
|
||||
}
|
||||
if (quad.x4_SZE) {
|
||||
w.writeBytes((first ? "1SZE" : "2SZE"), 4);
|
||||
quad.x4_SZE.write(w);
|
||||
}
|
||||
if (quad.x8_ROT) {
|
||||
w.writeBytes((first ? "1ROT" : "2ROT"), 4);
|
||||
quad.x8_ROT.write(w);
|
||||
}
|
||||
if (quad.xc_OFF) {
|
||||
w.writeBytes((first ? "1OFF" : "2OFF"), 4);
|
||||
quad.xc_OFF.write(w);
|
||||
}
|
||||
if (quad.x10_CLR) {
|
||||
w.writeBytes((first ? "1CLR" : "2CLR"), 4);
|
||||
quad.x10_CLR.write(w);
|
||||
}
|
||||
if (quad.x14_TEX) {
|
||||
w.writeBytes((first ? "1TEX" : "2TEX"), 4);
|
||||
quad.x14_TEX.write(w);
|
||||
}
|
||||
if (quad.x18_ADD) {
|
||||
w.writeBytes((first ? "1ADD" : "2ADD"), 4);
|
||||
quad.x18_ADD.write(w);
|
||||
}
|
||||
}
|
||||
|
||||
template <class IDType>
|
||||
void DPSM<IDType>::gatherDependencies(std::vector<hecl::ProjectPath>& pathsOut) const {
|
||||
if (x0_quad.x14_TEX.m_elem)
|
||||
x0_quad.x14_TEX.m_elem->gatherDependencies(pathsOut);
|
||||
if (x1c_quad.x14_TEX.m_elem)
|
||||
x1c_quad.x14_TEX.m_elem->gatherDependencies(pathsOut);
|
||||
g_curSpec->flattenDependencies(x38_DMDL.id, pathsOut);
|
||||
}
|
||||
|
||||
AT_SUBSPECIALIZE_DNA_YAML(DPSM<UniqueID32>)
|
||||
AT_SUBSPECIALIZE_DNA_YAML(DPSM<UniqueID64>)
|
||||
template struct DPSM<UniqueID32>;
|
||||
template struct DPSM<UniqueID64>;
|
||||
|
||||
template <class IDType>
|
||||
bool ExtractDPSM(PAKEntryReadStream& rs, const hecl::ProjectPath& outPath) {
|
||||
athena::io::FileWriter writer(outPath.getAbsolutePath());
|
||||
|
|
|
@ -0,0 +1,28 @@
|
|||
#ifndef ENTRY
|
||||
#define ENTRY(name, identifier)
|
||||
#endif
|
||||
|
||||
ENTRY('1LFT', x0_quad.x0_LFT)
|
||||
ENTRY('1SZE', x0_quad.x4_SZE)
|
||||
ENTRY('1ROT', x0_quad.x8_ROT)
|
||||
ENTRY('1OFF', x0_quad.xc_OFF)
|
||||
ENTRY('1CLR', x0_quad.x10_CLR)
|
||||
ENTRY('1TEX', x0_quad.x14_TEX)
|
||||
ENTRY('1ADD', x0_quad.x18_ADD)
|
||||
ENTRY('2LFT', x1c_quad.x0_LFT)
|
||||
ENTRY('2SZE', x1c_quad.x4_SZE)
|
||||
ENTRY('2ROT', x1c_quad.x8_ROT)
|
||||
ENTRY('2OFF', x1c_quad.xc_OFF)
|
||||
ENTRY('2CLR', x1c_quad.x10_CLR)
|
||||
ENTRY('2TEX', x1c_quad.x14_TEX)
|
||||
ENTRY('2ADD', x1c_quad.x18_ADD)
|
||||
ENTRY('DMDL', x38_DMDL)
|
||||
ENTRY('DLFT', x48_DLFT)
|
||||
ENTRY('DMOP', x4c_DMOP)
|
||||
ENTRY('DMRT', x50_DMRT)
|
||||
ENTRY('DMSC', x54_DMSC)
|
||||
ENTRY('DMCL', x58_DMCL)
|
||||
ENTRY('DMAB', x5c_24_DMAB)
|
||||
ENTRY('DMOO', x5c_25_DMOO)
|
||||
|
||||
#undef ENTRY
|
|
@ -20,9 +20,8 @@ class ProjectPath;
|
|||
namespace DataSpec::DNAParticle {
|
||||
|
||||
template <class IDType>
|
||||
struct DPSM : BigDNA {
|
||||
AT_DECL_EXPLICIT_DNA_YAML
|
||||
AT_SUBDECL_DNA
|
||||
struct _DPSM {
|
||||
static constexpr ParticleType Type = ParticleType::DPSM;
|
||||
|
||||
struct SQuadDescr {
|
||||
IntElementFactory x0_LFT;
|
||||
|
@ -31,7 +30,7 @@ struct DPSM : BigDNA {
|
|||
VectorElementFactory xc_OFF;
|
||||
ColorElementFactory x10_CLR;
|
||||
UVElementFactory<IDType> x14_TEX;
|
||||
BoolHelper x18_ADD;
|
||||
bool x18_ADD = false;
|
||||
};
|
||||
|
||||
SQuadDescr x0_quad;
|
||||
|
@ -42,21 +41,27 @@ struct DPSM : BigDNA {
|
|||
VectorElementFactory x50_DMRT;
|
||||
VectorElementFactory x54_DMSC;
|
||||
ColorElementFactory x58_DMCL;
|
||||
union {
|
||||
struct {
|
||||
bool x5c_24_DMAB : 1;
|
||||
bool x5c_25_DMOO : 1;
|
||||
};
|
||||
uint8_t dummy;
|
||||
};
|
||||
template <class Reader>
|
||||
void readQuadDecalInfo(Reader& r, FourCC clsId, SQuadDescr& quad);
|
||||
void writeQuadDecalInfo(athena::io::YAMLDocWriter& w, const SQuadDescr& quad, bool first) const;
|
||||
void getQuadDecalBinarySize(size_t& s, const SQuadDescr& desc) const;
|
||||
void writeQuadDecalInfo(athena::io::IStreamWriter& w, const SQuadDescr& quad, bool first) const;
|
||||
|
||||
void gatherDependencies(std::vector<hecl::ProjectPath>&) const;
|
||||
bool x5c_24_DMAB = false;
|
||||
bool x5c_25_DMOO = false;
|
||||
|
||||
template<typename _Func>
|
||||
void constexpr Enumerate(_Func f) {
|
||||
#define ENTRY(name, identifier) f(FOURCC(name), identifier);
|
||||
#include "DPSC.def"
|
||||
}
|
||||
|
||||
template<typename _Func>
|
||||
bool constexpr Lookup(FourCC fcc, _Func f) {
|
||||
switch (fcc.toUint32()) {
|
||||
#define ENTRY(name, identifier) case SBIG(name): f(identifier); return true;
|
||||
#include "DPSC.def"
|
||||
default: return false;
|
||||
}
|
||||
}
|
||||
};
|
||||
template <class IDType>
|
||||
using DPSM = PPImpl<_DPSM<IDType>>;
|
||||
|
||||
template <class IDType>
|
||||
bool ExtractDPSM(PAKEntryReadStream& rs, const hecl::ProjectPath& outPath);
|
||||
|
|
|
@ -1,403 +1,13 @@
|
|||
#include "DataSpec/DNACommon/ELSC.hpp"
|
||||
|
||||
#include <logvisor/logvisor.hpp>
|
||||
#include "DataSpec/DNACommon/PAK.hpp"
|
||||
|
||||
namespace DataSpec::DNAParticle {
|
||||
|
||||
template <class IDType>
|
||||
void ELSM<IDType>::_read(athena::io::IStreamReader& r) {
|
||||
DNAFourCC clsId;
|
||||
clsId.read(r);
|
||||
if (clsId != SBIG('ELSM')) {
|
||||
LogModule.report(logvisor::Warning, fmt("non ELSM provided to ELSM parser"));
|
||||
return;
|
||||
}
|
||||
template struct PPImpl<_ELSM<UniqueID32>>;
|
||||
template struct PPImpl<_ELSM<UniqueID64>>;
|
||||
|
||||
clsId.read(r);
|
||||
while (clsId != SBIG('_END')) {
|
||||
switch (clsId.toUint32()) {
|
||||
case SBIG('LIFE'):
|
||||
x0_LIFE.read(r);
|
||||
break;
|
||||
case SBIG('SLIF'):
|
||||
x4_SLIF.read(r);
|
||||
break;
|
||||
case SBIG('GRAT'):
|
||||
x8_GRAT.read(r);
|
||||
break;
|
||||
case SBIG('SCNT'):
|
||||
xc_SCNT.read(r);
|
||||
break;
|
||||
case SBIG('SSEG'):
|
||||
x10_SSEG.read(r);
|
||||
break;
|
||||
case SBIG('COLR'):
|
||||
x14_COLR.read(r);
|
||||
break;
|
||||
case SBIG('IEMT'):
|
||||
x18_IEMT.read(r);
|
||||
break;
|
||||
case SBIG('FEMT'):
|
||||
x1c_FEMT.read(r);
|
||||
break;
|
||||
case SBIG('AMPL'):
|
||||
x20_AMPL.read(r);
|
||||
break;
|
||||
case SBIG('AMPD'):
|
||||
x24_AMPD.read(r);
|
||||
break;
|
||||
case SBIG('LWD1'):
|
||||
x28_LWD1.read(r);
|
||||
break;
|
||||
case SBIG('LWD2'):
|
||||
x2c_LWD2.read(r);
|
||||
break;
|
||||
case SBIG('LWD3'):
|
||||
x30_LWD3.read(r);
|
||||
break;
|
||||
case SBIG('LCL1'):
|
||||
x34_LCL1.read(r);
|
||||
break;
|
||||
case SBIG('LCL2'):
|
||||
x38_LCL2.read(r);
|
||||
break;
|
||||
case SBIG('LCL3'):
|
||||
x3c_LCL3.read(r);
|
||||
break;
|
||||
case SBIG('SSWH'):
|
||||
x40_SSWH.read(r);
|
||||
break;
|
||||
case SBIG('GPSM'):
|
||||
x50_GPSM.read(r);
|
||||
break;
|
||||
case SBIG('EPSM'):
|
||||
x60_EPSM.read(r);
|
||||
break;
|
||||
case SBIG('ZERY'):
|
||||
x70_ZERY.read(r);
|
||||
break;
|
||||
default:
|
||||
LogModule.report(logvisor::Fatal, fmt("Unknown ELSM class {} @{}"), clsId, r.position());
|
||||
break;
|
||||
}
|
||||
clsId.read(r);
|
||||
}
|
||||
}
|
||||
|
||||
template <class IDType>
|
||||
void ELSM<IDType>::_write(athena::io::IStreamWriter& w) const {
|
||||
w.writeBytes((atInt8*)"ELSM", 4);
|
||||
if (x0_LIFE) {
|
||||
w.writeBytes((atInt8*)"LIFE", 4);
|
||||
x0_LIFE.write(w);
|
||||
}
|
||||
if (x4_SLIF) {
|
||||
w.writeBytes((atInt8*)"SLIF", 4);
|
||||
x4_SLIF.write(w);
|
||||
}
|
||||
if (x8_GRAT) {
|
||||
w.writeBytes((atInt8*)"GRAT", 4);
|
||||
x8_GRAT.write(w);
|
||||
}
|
||||
if (xc_SCNT) {
|
||||
w.writeBytes((atInt8*)"SCNT", 4);
|
||||
xc_SCNT.write(w);
|
||||
}
|
||||
if (x10_SSEG) {
|
||||
w.writeBytes((atInt8*)"SSEG", 4);
|
||||
x10_SSEG.write(w);
|
||||
}
|
||||
if (x14_COLR) {
|
||||
w.writeBytes((atInt8*)"COLR", 4);
|
||||
x14_COLR.write(w);
|
||||
}
|
||||
if (x18_IEMT) {
|
||||
w.writeBytes((atInt8*)"IEMT", 4);
|
||||
x18_IEMT.write(w);
|
||||
}
|
||||
if (x1c_FEMT) {
|
||||
w.writeBytes((atInt8*)"FEMT", 4);
|
||||
x1c_FEMT.write(w);
|
||||
}
|
||||
if (x20_AMPL) {
|
||||
w.writeBytes((atInt8*)"AMPL", 4);
|
||||
x20_AMPL.write(w);
|
||||
}
|
||||
if (x24_AMPD) {
|
||||
w.writeBytes((atInt8*)"AMPD", 4);
|
||||
x24_AMPD.write(w);
|
||||
}
|
||||
if (x28_LWD1) {
|
||||
w.writeBytes((atInt8*)"LWD1", 4);
|
||||
x28_LWD1.write(w);
|
||||
}
|
||||
if (x2c_LWD2) {
|
||||
w.writeBytes((atInt8*)"LWD2", 4);
|
||||
x2c_LWD2.write(w);
|
||||
}
|
||||
if (x30_LWD3) {
|
||||
w.writeBytes((atInt8*)"LWD3", 4);
|
||||
x30_LWD3.write(w);
|
||||
}
|
||||
if (x34_LCL1) {
|
||||
w.writeBytes((atInt8*)"LCL1", 4);
|
||||
x34_LCL1.write(w);
|
||||
}
|
||||
if (x38_LCL2) {
|
||||
w.writeBytes((atInt8*)"LCL2", 4);
|
||||
x38_LCL2.write(w);
|
||||
}
|
||||
if (x3c_LCL3) {
|
||||
w.writeBytes((atInt8*)"LCL3", 4);
|
||||
x3c_LCL3.write(w);
|
||||
}
|
||||
if (x40_SSWH) {
|
||||
w.writeBytes((atInt8*)"SSWH", 4);
|
||||
x40_SSWH.write(w);
|
||||
}
|
||||
if (x50_GPSM) {
|
||||
w.writeBytes((atInt8*)"GPSM", 4);
|
||||
x50_GPSM.write(w);
|
||||
}
|
||||
if (x60_EPSM) {
|
||||
w.writeBytes((atInt8*)"EPSM", 4);
|
||||
x60_EPSM.write(w);
|
||||
}
|
||||
if (x70_ZERY) {
|
||||
w.writeBytes((atInt8*)"ZERY", 4);
|
||||
x70_ZERY.write(w);
|
||||
}
|
||||
w.writeBytes("_END", 4);
|
||||
}
|
||||
|
||||
template <class IDType>
|
||||
void ELSM<IDType>::_binarySize(size_t& s) const {
|
||||
s += 4;
|
||||
if (x0_LIFE) {
|
||||
s += 4;
|
||||
x0_LIFE.binarySize(s);
|
||||
}
|
||||
if (x4_SLIF) {
|
||||
s += 4;
|
||||
x4_SLIF.binarySize(s);
|
||||
}
|
||||
if (x8_GRAT) {
|
||||
s += 4;
|
||||
x8_GRAT.binarySize(s);
|
||||
}
|
||||
if (xc_SCNT) {
|
||||
s += 4;
|
||||
xc_SCNT.binarySize(s);
|
||||
}
|
||||
if (x10_SSEG) {
|
||||
s += 4;
|
||||
x10_SSEG.binarySize(s);
|
||||
}
|
||||
if (x14_COLR) {
|
||||
s += 4;
|
||||
x14_COLR.binarySize(s);
|
||||
}
|
||||
if (x18_IEMT) {
|
||||
s += 4;
|
||||
x18_IEMT.binarySize(s);
|
||||
}
|
||||
if (x1c_FEMT) {
|
||||
s += 4;
|
||||
x1c_FEMT.binarySize(s);
|
||||
}
|
||||
if (x20_AMPL) {
|
||||
s += 4;
|
||||
x20_AMPL.binarySize(s);
|
||||
}
|
||||
if (x24_AMPD) {
|
||||
s += 4;
|
||||
x24_AMPD.binarySize(s);
|
||||
}
|
||||
if (x28_LWD1) {
|
||||
s += 4;
|
||||
x28_LWD1.binarySize(s);
|
||||
}
|
||||
if (x2c_LWD2) {
|
||||
s += 4;
|
||||
x2c_LWD2.binarySize(s);
|
||||
}
|
||||
if (x30_LWD3) {
|
||||
s += 4;
|
||||
x30_LWD3.binarySize(s);
|
||||
}
|
||||
if (x34_LCL1) {
|
||||
s += 4;
|
||||
x34_LCL1.binarySize(s);
|
||||
}
|
||||
if (x38_LCL2) {
|
||||
s += 4;
|
||||
x38_LCL2.binarySize(s);
|
||||
}
|
||||
if (x3c_LCL3) {
|
||||
s += 4;
|
||||
x3c_LCL3.binarySize(s);
|
||||
}
|
||||
if (x40_SSWH) {
|
||||
s += 4;
|
||||
x40_SSWH.binarySize(s);
|
||||
}
|
||||
if (x50_GPSM) {
|
||||
s += 4;
|
||||
x50_GPSM.binarySize(s);
|
||||
}
|
||||
if (x60_EPSM) {
|
||||
s += 4;
|
||||
x60_EPSM.binarySize(s);
|
||||
}
|
||||
if (x70_ZERY) {
|
||||
s += 4;
|
||||
x70_ZERY.binarySize(s);
|
||||
}
|
||||
}
|
||||
|
||||
template <class IDType>
|
||||
void ELSM<IDType>::_read(athena::io::YAMLDocReader& r) {
|
||||
for (const auto& elem : r.getCurNode()->m_mapChildren) {
|
||||
if (elem.first.size() < 4) {
|
||||
LogModule.report(logvisor::Warning, fmt("short FourCC in element '{}'"), elem.first);
|
||||
continue;
|
||||
}
|
||||
|
||||
if (auto rec = r.enterSubRecord(elem.first.c_str())) {
|
||||
switch (*reinterpret_cast<const uint32_t*>(elem.first.data())) {
|
||||
case SBIG('LIFE'):
|
||||
x0_LIFE.read(r);
|
||||
break;
|
||||
case SBIG('SLIF'):
|
||||
x4_SLIF.read(r);
|
||||
break;
|
||||
case SBIG('GRAT'):
|
||||
x8_GRAT.read(r);
|
||||
break;
|
||||
case SBIG('SCNT'):
|
||||
xc_SCNT.read(r);
|
||||
break;
|
||||
case SBIG('SSEG'):
|
||||
x10_SSEG.read(r);
|
||||
break;
|
||||
case SBIG('COLR'):
|
||||
x14_COLR.read(r);
|
||||
break;
|
||||
case SBIG('IEMT'):
|
||||
x18_IEMT.read(r);
|
||||
break;
|
||||
case SBIG('FEMT'):
|
||||
x1c_FEMT.read(r);
|
||||
break;
|
||||
case SBIG('AMPL'):
|
||||
x20_AMPL.read(r);
|
||||
break;
|
||||
case SBIG('AMPD'):
|
||||
x24_AMPD.read(r);
|
||||
break;
|
||||
case SBIG('LWD1'):
|
||||
x28_LWD1.read(r);
|
||||
break;
|
||||
case SBIG('LWD2'):
|
||||
x2c_LWD2.read(r);
|
||||
break;
|
||||
case SBIG('LWD3'):
|
||||
x30_LWD3.read(r);
|
||||
break;
|
||||
case SBIG('LCL1'):
|
||||
x34_LCL1.read(r);
|
||||
break;
|
||||
case SBIG('LCL2'):
|
||||
x38_LCL2.read(r);
|
||||
break;
|
||||
case SBIG('LCL3'):
|
||||
x3c_LCL3.read(r);
|
||||
break;
|
||||
case SBIG('SSWH'):
|
||||
x40_SSWH.read(r);
|
||||
break;
|
||||
case SBIG('GPSM'):
|
||||
x50_GPSM.read(r);
|
||||
break;
|
||||
case SBIG('EPSM'):
|
||||
x60_EPSM.read(r);
|
||||
break;
|
||||
case SBIG('ZERY'):
|
||||
x70_ZERY.read(r);
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
template <class IDType>
|
||||
void ELSM<IDType>::_write(athena::io::YAMLDocWriter& w) const {
|
||||
if (x0_LIFE)
|
||||
if (auto rec = w.enterSubRecord("LIFE"))
|
||||
x0_LIFE.write(w);
|
||||
if (x4_SLIF)
|
||||
if (auto rec = w.enterSubRecord("SLIF"))
|
||||
x4_SLIF.write(w);
|
||||
if (x8_GRAT)
|
||||
if (auto rec = w.enterSubRecord("GRAT"))
|
||||
x8_GRAT.write(w);
|
||||
if (xc_SCNT)
|
||||
if (auto rec = w.enterSubRecord("SCNT"))
|
||||
xc_SCNT.write(w);
|
||||
if (x10_SSEG)
|
||||
if (auto rec = w.enterSubRecord("SSEG"))
|
||||
x10_SSEG.write(w);
|
||||
if (x14_COLR)
|
||||
if (auto rec = w.enterSubRecord("COLR"))
|
||||
x14_COLR.write(w);
|
||||
if (x18_IEMT)
|
||||
if (auto rec = w.enterSubRecord("IEMT"))
|
||||
x18_IEMT.write(w);
|
||||
if (x1c_FEMT)
|
||||
if (auto rec = w.enterSubRecord("FEMT"))
|
||||
x1c_FEMT.write(w);
|
||||
if (x20_AMPL)
|
||||
if (auto rec = w.enterSubRecord("AMPL"))
|
||||
x20_AMPL.write(w);
|
||||
if (x24_AMPD)
|
||||
if (auto rec = w.enterSubRecord("AMPD"))
|
||||
x24_AMPD.write(w);
|
||||
if (x28_LWD1)
|
||||
if (auto rec = w.enterSubRecord("LWD1"))
|
||||
x28_LWD1.write(w);
|
||||
if (x2c_LWD2)
|
||||
if (auto rec = w.enterSubRecord("LWD2"))
|
||||
x2c_LWD2.write(w);
|
||||
if (x30_LWD3)
|
||||
if (auto rec = w.enterSubRecord("LWD3"))
|
||||
x30_LWD3.write(w);
|
||||
if (x34_LCL1)
|
||||
if (auto rec = w.enterSubRecord("LCL1"))
|
||||
x34_LCL1.write(w);
|
||||
if (x38_LCL2)
|
||||
if (auto rec = w.enterSubRecord("LCL2"))
|
||||
x38_LCL2.write(w);
|
||||
if (x3c_LCL3)
|
||||
if (auto rec = w.enterSubRecord("LCL3"))
|
||||
x3c_LCL3.write(w);
|
||||
if (x40_SSWH)
|
||||
if (auto rec = w.enterSubRecord("SSWH"))
|
||||
x40_SSWH.write(w);
|
||||
if (x50_GPSM)
|
||||
if (auto rec = w.enterSubRecord("GPSM"))
|
||||
x50_GPSM.write(w);
|
||||
if (x60_EPSM)
|
||||
if (auto rec = w.enterSubRecord("EPSM"))
|
||||
x60_EPSM.write(w);
|
||||
if (x70_ZERY)
|
||||
if (auto rec = w.enterSubRecord("ZERY"))
|
||||
x70_ZERY.write(w);
|
||||
}
|
||||
|
||||
AT_SUBSPECIALIZE_DNA_YAML(ELSM<UniqueID32>)
|
||||
AT_SUBSPECIALIZE_DNA_YAML(ELSM<UniqueID64>)
|
||||
AT_SUBSPECIALIZE_DNA_YAML(PPImpl<_ELSM<UniqueID32>>)
|
||||
AT_SUBSPECIALIZE_DNA_YAML(PPImpl<_ELSM<UniqueID64>>)
|
||||
|
||||
template <>
|
||||
std::string_view ELSM<UniqueID32>::DNAType() {
|
||||
|
@ -409,16 +19,6 @@ std::string_view ELSM<UniqueID64>::DNAType() {
|
|||
return "urde::ELSM<UniqueID64>"sv;
|
||||
}
|
||||
|
||||
template <class IDType>
|
||||
void ELSM<IDType>::gatherDependencies(std::vector<hecl::ProjectPath>& pathsOut) const {
|
||||
g_curSpec->flattenDependencies(x40_SSWH.id, pathsOut);
|
||||
g_curSpec->flattenDependencies(x50_GPSM.id, pathsOut);
|
||||
g_curSpec->flattenDependencies(x60_EPSM.id, pathsOut);
|
||||
}
|
||||
|
||||
template struct ELSM<UniqueID32>;
|
||||
template struct ELSM<UniqueID64>;
|
||||
|
||||
template <class IDType>
|
||||
bool ExtractELSM(PAKEntryReadStream& rs, const hecl::ProjectPath& outPath) {
|
||||
athena::io::FileWriter writer(outPath.getAbsolutePath());
|
||||
|
|
|
@ -0,0 +1,56 @@
|
|||
#ifndef ENTRY
|
||||
#define ENTRY(name, identifier)
|
||||
#endif
|
||||
|
||||
#ifndef INT_ENTRY
|
||||
#define INT_ENTRY(name, identifier) ENTRY(name, identifier)
|
||||
#endif
|
||||
|
||||
#ifndef REAL_ENTRY
|
||||
#define REAL_ENTRY(name, identifier) ENTRY(name, identifier)
|
||||
#endif
|
||||
|
||||
#ifndef COLOR_ENTRY
|
||||
#define COLOR_ENTRY(name, identifier) ENTRY(name, identifier)
|
||||
#endif
|
||||
|
||||
#ifndef EMITTER_ENTRY
|
||||
#define EMITTER_ENTRY(name, identifier) ENTRY(name, identifier)
|
||||
#endif
|
||||
|
||||
#ifndef RES_ENTRY
|
||||
#define RES_ENTRY(name, identifier) ENTRY(name, identifier)
|
||||
#endif
|
||||
|
||||
#ifndef BOOL_ENTRY
|
||||
#define BOOL_ENTRY(name, identifier) ENTRY(name, identifier)
|
||||
#endif
|
||||
|
||||
INT_ENTRY('LIFE', x0_LIFE)
|
||||
INT_ENTRY('SLIF', x4_SLIF)
|
||||
REAL_ENTRY('GRAT', x8_GRAT)
|
||||
INT_ENTRY('SCNT', xc_SCNT)
|
||||
INT_ENTRY('SSEG', x10_SSEG)
|
||||
COLOR_ENTRY('COLR', x14_COLR)
|
||||
EMITTER_ENTRY('IEMT', x18_IEMT)
|
||||
EMITTER_ENTRY('FEMT', x1c_FEMT)
|
||||
REAL_ENTRY('AMPL', x20_AMPL)
|
||||
REAL_ENTRY('AMPD', x24_AMPD)
|
||||
REAL_ENTRY('LWD1', x28_LWD1)
|
||||
REAL_ENTRY('LWD2', x2c_LWD2)
|
||||
REAL_ENTRY('LWD3', x30_LWD3)
|
||||
COLOR_ENTRY('LCL1', x34_LCL1)
|
||||
COLOR_ENTRY('LCL2', x38_LCL2)
|
||||
COLOR_ENTRY('LCL3', x3c_LCL3)
|
||||
RES_ENTRY('SSWH', x40_SSWH)
|
||||
RES_ENTRY('GPSM', x50_GPSM)
|
||||
RES_ENTRY('EPSM', x60_EPSM)
|
||||
BOOL_ENTRY('ZERY', x70_ZERY)
|
||||
|
||||
#undef ENTRY
|
||||
#undef INT_ENTRY
|
||||
#undef REAL_ENTRY
|
||||
#undef COLOR_ENTRY
|
||||
#undef EMITTER_ENTRY
|
||||
#undef RES_ENTRY
|
||||
#undef BOOL_ENTRY
|
|
@ -12,33 +12,36 @@ class ProjectPath;
|
|||
}
|
||||
|
||||
namespace DataSpec::DNAParticle {
|
||||
template <class IDType>
|
||||
struct ELSM : BigDNA {
|
||||
AT_DECL_EXPLICIT_DNA_YAML
|
||||
AT_SUBDECL_DNA
|
||||
IntElementFactory x0_LIFE;
|
||||
IntElementFactory x4_SLIF;
|
||||
RealElementFactory x8_GRAT;
|
||||
IntElementFactory xc_SCNT;
|
||||
IntElementFactory x10_SSEG;
|
||||
ColorElementFactory x14_COLR;
|
||||
EmitterElementFactory x18_IEMT;
|
||||
EmitterElementFactory x1c_FEMT;
|
||||
RealElementFactory x20_AMPL;
|
||||
RealElementFactory x24_AMPD;
|
||||
RealElementFactory x28_LWD1;
|
||||
RealElementFactory x2c_LWD2;
|
||||
RealElementFactory x30_LWD3;
|
||||
ColorElementFactory x34_LCL1;
|
||||
ColorElementFactory x38_LCL2;
|
||||
ColorElementFactory x3c_LCL3;
|
||||
ChildResourceFactory<IDType> x40_SSWH;
|
||||
ChildResourceFactory<IDType> x50_GPSM;
|
||||
ChildResourceFactory<IDType> x60_EPSM;
|
||||
BoolHelper x70_ZERY;
|
||||
|
||||
void gatherDependencies(std::vector<hecl::ProjectPath>&) const;
|
||||
template <class IDType>
|
||||
struct _ELSM {
|
||||
static constexpr ParticleType Type = ParticleType::ELSM;
|
||||
|
||||
#define INT_ENTRY(name, identifier) IntElementFactory identifier;
|
||||
#define REAL_ENTRY(name, identifier) RealElementFactory identifier;
|
||||
#define COLOR_ENTRY(name, identifier) ColorElementFactory identifier;
|
||||
#define EMITTER_ENTRY(name, identifier) EmitterElementFactory identifier;
|
||||
#define RES_ENTRY(name, identifier) ChildResourceFactory<IDType> identifier;
|
||||
#define BOOL_ENTRY(name, identifier) bool identifier = false;
|
||||
#include "ELSC.def"
|
||||
|
||||
template<typename _Func>
|
||||
void constexpr Enumerate(_Func f) {
|
||||
#define ENTRY(name, identifier) f(FOURCC(name), identifier);
|
||||
#include "ELSC.def"
|
||||
}
|
||||
|
||||
template<typename _Func>
|
||||
bool constexpr Lookup(FourCC fcc, _Func f) {
|
||||
switch (fcc.toUint32()) {
|
||||
#define ENTRY(name, identifier) case SBIG(name): f(identifier); return true;
|
||||
#include "ELSC.def"
|
||||
default: return false;
|
||||
}
|
||||
}
|
||||
};
|
||||
template <class IDType>
|
||||
using ELSM = PPImpl<_ELSM<IDType>>;
|
||||
|
||||
template <class IDType>
|
||||
bool ExtractELSM(PAKEntryReadStream& rs, const hecl::ProjectPath& outPath);
|
||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -0,0 +1,141 @@
|
|||
#ifndef ENTRY
|
||||
#define ENTRY(name, identifier)
|
||||
#endif
|
||||
|
||||
#ifndef INT_ENTRY
|
||||
#define INT_ENTRY(name, identifier) ENTRY(name, identifier)
|
||||
#endif
|
||||
|
||||
#ifndef REAL_ENTRY
|
||||
#define REAL_ENTRY(name, identifier) ENTRY(name, identifier)
|
||||
#endif
|
||||
|
||||
#ifndef VECTOR_ENTRY
|
||||
#define VECTOR_ENTRY(name, identifier) ENTRY(name, identifier)
|
||||
#endif
|
||||
|
||||
#ifndef MOD_VECTOR_ENTRY
|
||||
#define MOD_VECTOR_ENTRY(name, identifier) ENTRY(name, identifier)
|
||||
#endif
|
||||
|
||||
#ifndef COLOR_ENTRY
|
||||
#define COLOR_ENTRY(name, identifier) ENTRY(name, identifier)
|
||||
#endif
|
||||
|
||||
#ifndef EMITTER_ENTRY
|
||||
#define EMITTER_ENTRY(name, identifier) ENTRY(name, identifier)
|
||||
#endif
|
||||
|
||||
#ifndef UV_ENTRY
|
||||
#define UV_ENTRY(name, identifier) ENTRY(name, identifier)
|
||||
#endif
|
||||
|
||||
#ifndef RES_ENTRY
|
||||
#define RES_ENTRY(name, identifier) ENTRY(name, identifier)
|
||||
#endif
|
||||
|
||||
#ifndef KSSM_ENTRY
|
||||
#define KSSM_ENTRY(name, identifier) ENTRY(name, identifier)
|
||||
#endif
|
||||
|
||||
#ifndef BOOL_ENTRY
|
||||
#define BOOL_ENTRY(name, identifier, def) ENTRY(name, identifier)
|
||||
#endif
|
||||
|
||||
VECTOR_ENTRY('PSIV', x0_PSIV)
|
||||
MOD_VECTOR_ENTRY('PSVM', x4_PSVM)
|
||||
VECTOR_ENTRY('PSOV', x8_PSOV)
|
||||
INT_ENTRY('PSLT', xc_PSLT)
|
||||
INT_ENTRY('PSWT', x10_PSWT)
|
||||
REAL_ENTRY('PSTS', x14_PSTS)
|
||||
VECTOR_ENTRY('POFS', x18_POFS)
|
||||
INT_ENTRY('SEED', x1c_SEED)
|
||||
REAL_ENTRY('LENG', x20_LENG)
|
||||
REAL_ENTRY('WIDT', x24_WIDT)
|
||||
INT_ENTRY('MAXP', x28_MAXP)
|
||||
REAL_ENTRY('GRTE', x2c_GRTE)
|
||||
COLOR_ENTRY('COLR', x30_COLR)
|
||||
INT_ENTRY('LTME', x34_LTME)
|
||||
VECTOR_ENTRY('ILOC', x38_ILOC)
|
||||
VECTOR_ENTRY('IVEC', x3c_IVEC)
|
||||
EMITTER_ENTRY('EMTR', x40_EMTR)
|
||||
INT_ENTRY('MBSP', x48_MBSP)
|
||||
REAL_ENTRY('SIZE', x4c_SIZE)
|
||||
REAL_ENTRY('ROTA', x50_ROTA)
|
||||
UV_ENTRY('TEXR', x54_TEXR)
|
||||
UV_ENTRY('TIND', x58_TIND)
|
||||
RES_ENTRY('PMDL', x5c_PMDL)
|
||||
VECTOR_ENTRY('PMOP', x6c_PMOP)
|
||||
VECTOR_ENTRY('PMRT', x70_PMRT)
|
||||
VECTOR_ENTRY('PMSC', x74_PMSC)
|
||||
COLOR_ENTRY('PMCL', x78_PMCL)
|
||||
MOD_VECTOR_ENTRY('VEL1', x7c_VEL1)
|
||||
MOD_VECTOR_ENTRY('VEL2', x80_VEL2)
|
||||
MOD_VECTOR_ENTRY('VEL3', x84_VEL3)
|
||||
MOD_VECTOR_ENTRY('VEL4', x88_VEL4)
|
||||
RES_ENTRY('ICTS', x8c_ICTS)
|
||||
INT_ENTRY('NCSY', x9c_NCSY)
|
||||
INT_ENTRY('CSSD', xa0_CSSD)
|
||||
RES_ENTRY('IDTS', xa4_IDTS)
|
||||
INT_ENTRY('NDSY', xb4_NDSY)
|
||||
RES_ENTRY('IITS', xb8_IITS)
|
||||
INT_ENTRY('PISY', xc8_PISY)
|
||||
INT_ENTRY('SISY', xcc_SISY)
|
||||
KSSM_ENTRY('KSSM', xd0_KSSM)
|
||||
RES_ENTRY('SSWH', xd4_SSWH)
|
||||
INT_ENTRY('SSSD', xe4_SSSD)
|
||||
VECTOR_ENTRY('SSPO', xe8_SSPO)
|
||||
INT_ENTRY('SESD', xf8_SESD)
|
||||
VECTOR_ENTRY('SEPO', xfc_SEPO)
|
||||
RES_ENTRY('PMLC', xec_PMLC)
|
||||
INT_ENTRY('LTYP', x100_LTYP)
|
||||
COLOR_ENTRY('LCLR', x104_LCLR)
|
||||
REAL_ENTRY('LINT', x108_LINT)
|
||||
VECTOR_ENTRY('LOFF', x10c_LOFF)
|
||||
VECTOR_ENTRY('LDIR', x110_LDIR)
|
||||
INT_ENTRY('LFOT', x114_LFOT)
|
||||
REAL_ENTRY('LFOR', x118_LFOR)
|
||||
REAL_ENTRY('LSLA', x11c_LSLA)
|
||||
|
||||
/* 0-00 additions */
|
||||
RES_ENTRY('SELC', xd8_SELC)
|
||||
REAL_ENTRY('ADV1', x10c_ADV1)
|
||||
REAL_ENTRY('ADV2', x110_ADV2)
|
||||
REAL_ENTRY('ADV3', x114_ADV3)
|
||||
REAL_ENTRY('ADV4', x118_ADV4)
|
||||
REAL_ENTRY('ADV5', x11c_ADV5)
|
||||
REAL_ENTRY('ADV6', x120_ADV6)
|
||||
REAL_ENTRY('ADV7', x124_ADV7)
|
||||
REAL_ENTRY('ADV8', x128_ADV8)
|
||||
|
||||
BOOL_ENTRY('SORT', x44_28_SORT, false)
|
||||
BOOL_ENTRY('MBLR', x44_30_MBLR, false)
|
||||
BOOL_ENTRY('LINE', x44_24_LINE, false)
|
||||
BOOL_ENTRY('LIT_', x44_29_LIT_, false)
|
||||
BOOL_ENTRY('AAPH', x44_26_AAPH, false)
|
||||
BOOL_ENTRY('ZBUF', x44_27_ZBUF, false)
|
||||
BOOL_ENTRY('FXLL', x44_25_FXLL, false)
|
||||
BOOL_ENTRY('PMAB', x44_31_PMAB, false)
|
||||
BOOL_ENTRY('VMD4', x45_29_VMD4, false)
|
||||
BOOL_ENTRY('VMD3', x45_28_VMD3, false)
|
||||
BOOL_ENTRY('VMD2', x45_27_VMD2, false)
|
||||
BOOL_ENTRY('VMD1', x45_26_VMD1, false)
|
||||
BOOL_ENTRY('OPTS', x45_31_OPTS, false)
|
||||
BOOL_ENTRY('PMUS', x45_24_PMUS, false)
|
||||
BOOL_ENTRY('PMOO', x45_25_PMOO, true)
|
||||
BOOL_ENTRY('CIND', x45_30_CIND, false)
|
||||
|
||||
BOOL_ENTRY('ORNT', x30_30_ORNT, false)
|
||||
BOOL_ENTRY('RSOP', x30_31_RSOP, false)
|
||||
|
||||
#undef ENTRY
|
||||
#undef INT_ENTRY
|
||||
#undef REAL_ENTRY
|
||||
#undef VECTOR_ENTRY
|
||||
#undef MOD_VECTOR_ENTRY
|
||||
#undef COLOR_ENTRY
|
||||
#undef EMITTER_ENTRY
|
||||
#undef UV_ENTRY
|
||||
#undef RES_ENTRY
|
||||
#undef KSSM_ENTRY
|
||||
#undef BOOL_ENTRY
|
|
@ -17,107 +17,39 @@ class ProjectPath;
|
|||
namespace DataSpec::DNAParticle {
|
||||
|
||||
template <class IDType>
|
||||
struct GPSM : BigDNA {
|
||||
AT_DECL_EXPLICIT_DNA_YAML
|
||||
AT_SUBDECL_DNA
|
||||
VectorElementFactory x0_PSIV;
|
||||
ModVectorElementFactory x4_PSVM;
|
||||
VectorElementFactory x8_PSOV;
|
||||
IntElementFactory xc_PSLT;
|
||||
IntElementFactory x10_PSWT;
|
||||
RealElementFactory x14_PSTS;
|
||||
VectorElementFactory x18_POFS;
|
||||
IntElementFactory x1c_SEED;
|
||||
RealElementFactory x20_LENG;
|
||||
RealElementFactory x24_WIDT;
|
||||
IntElementFactory x28_MAXP;
|
||||
RealElementFactory x2c_GRTE;
|
||||
ColorElementFactory x30_COLR;
|
||||
IntElementFactory x34_LTME;
|
||||
VectorElementFactory x38_ILOC;
|
||||
VectorElementFactory x3c_IVEC;
|
||||
EmitterElementFactory x40_EMTR;
|
||||
union {
|
||||
struct {
|
||||
bool x44_28_SORT : 1;
|
||||
bool x44_30_MBLR : 1;
|
||||
bool x44_24_LINE : 1;
|
||||
bool x44_29_LIT_ : 1;
|
||||
bool x44_26_AAPH : 1;
|
||||
bool x44_27_ZBUF : 1;
|
||||
bool x44_25_FXLL : 1;
|
||||
bool x44_31_PMAB : 1;
|
||||
bool x45_29_VMD4 : 1;
|
||||
bool x45_28_VMD3 : 1;
|
||||
bool x45_27_VMD2 : 1;
|
||||
bool x45_26_VMD1 : 1;
|
||||
bool x45_31_OPTS : 1;
|
||||
bool x45_24_PMUS : 1;
|
||||
bool x45_25_PMOO : 1;
|
||||
bool x45_30_CIND : 1;
|
||||
};
|
||||
uint16_t dummy1 = 0;
|
||||
};
|
||||
IntElementFactory x48_MBSP;
|
||||
RealElementFactory x4c_SIZE;
|
||||
RealElementFactory x50_ROTA;
|
||||
UVElementFactory<IDType> x54_TEXR;
|
||||
UVElementFactory<IDType> x58_TIND;
|
||||
ChildResourceFactory<IDType> x5c_PMDL;
|
||||
VectorElementFactory x6c_PMOP;
|
||||
VectorElementFactory x70_PMRT;
|
||||
VectorElementFactory x74_PMSC;
|
||||
ColorElementFactory x78_PMCL;
|
||||
ModVectorElementFactory x7c_VEL1;
|
||||
ModVectorElementFactory x80_VEL2;
|
||||
ModVectorElementFactory x84_VEL3;
|
||||
ModVectorElementFactory x88_VEL4;
|
||||
ChildResourceFactory<IDType> x8c_ICTS;
|
||||
IntElementFactory x9c_NCSY;
|
||||
IntElementFactory xa0_CSSD;
|
||||
ChildResourceFactory<IDType> xa4_IDTS;
|
||||
IntElementFactory xb4_NDSY;
|
||||
ChildResourceFactory<IDType> xb8_IITS;
|
||||
IntElementFactory xc8_PISY;
|
||||
IntElementFactory xcc_SISY;
|
||||
SpawnSystemKeyframeData<IDType> xd0_KSSM;
|
||||
ChildResourceFactory<IDType> xd4_SSWH;
|
||||
IntElementFactory xe4_SSSD;
|
||||
VectorElementFactory xe8_SSPO;
|
||||
IntElementFactory xf8_SESD;
|
||||
VectorElementFactory xfc_SEPO;
|
||||
ChildResourceFactory<IDType> xec_PMLC;
|
||||
IntElementFactory x100_LTYP;
|
||||
ColorElementFactory x104_LCLR;
|
||||
RealElementFactory x108_LINT;
|
||||
VectorElementFactory x10c_LOFF;
|
||||
VectorElementFactory x110_LDIR;
|
||||
IntElementFactory x114_LFOT;
|
||||
RealElementFactory x118_LFOR;
|
||||
RealElementFactory x11c_LSLA;
|
||||
struct _GPSM {
|
||||
static constexpr ParticleType Type = ParticleType::GPSM;
|
||||
|
||||
/* 0-00 additions */
|
||||
ChildResourceFactory<IDType> xd8_SELC;
|
||||
union {
|
||||
struct {
|
||||
bool x30_30_ORNT : 1;
|
||||
bool x30_31_RSOP : 1;
|
||||
};
|
||||
uint16_t dummy2 = 0;
|
||||
};
|
||||
RealElementFactory x10c_ADV1;
|
||||
RealElementFactory x110_ADV2;
|
||||
RealElementFactory x114_ADV3;
|
||||
RealElementFactory x118_ADV4;
|
||||
RealElementFactory x11c_ADV5;
|
||||
RealElementFactory x120_ADV6;
|
||||
RealElementFactory x124_ADV7;
|
||||
RealElementFactory x128_ADV8;
|
||||
#define INT_ENTRY(name, identifier) IntElementFactory identifier;
|
||||
#define REAL_ENTRY(name, identifier) RealElementFactory identifier;
|
||||
#define VECTOR_ENTRY(name, identifier) VectorElementFactory identifier;
|
||||
#define MOD_VECTOR_ENTRY(name, identifier) ModVectorElementFactory identifier;
|
||||
#define COLOR_ENTRY(name, identifier) ColorElementFactory identifier;
|
||||
#define EMITTER_ENTRY(name, identifier) EmitterElementFactory identifier;
|
||||
#define UV_ENTRY(name, identifier) UVElementFactory<IDType> identifier;
|
||||
#define RES_ENTRY(name, identifier) ChildResourceFactory<IDType> identifier;
|
||||
#define KSSM_ENTRY(name, identifier) SpawnSystemKeyframeData<IDType> identifier;
|
||||
#define BOOL_ENTRY(name, identifier, def) bool identifier = def;
|
||||
#include "PART.def"
|
||||
|
||||
GPSM() { x45_25_PMOO = true; }
|
||||
template<typename _Func>
|
||||
void constexpr Enumerate(_Func f) {
|
||||
#define ENTRY(name, identifier) f(FOURCC(name), identifier);
|
||||
#define BOOL_ENTRY(name, identifier, def) f(FOURCC(name), identifier, def);
|
||||
#include "PART.def"
|
||||
}
|
||||
|
||||
void gatherDependencies(std::vector<hecl::ProjectPath>&) const;
|
||||
template<typename _Func>
|
||||
bool constexpr Lookup(FourCC fcc, _Func f) {
|
||||
switch (fcc.toUint32()) {
|
||||
#define ENTRY(name, identifier) case SBIG(name): f(identifier); return true;
|
||||
#include "PART.def"
|
||||
default: return false;
|
||||
}
|
||||
}
|
||||
};
|
||||
template <class IDType>
|
||||
using GPSM = PPImpl<_GPSM<IDType>>;
|
||||
|
||||
template <class IDType>
|
||||
bool ExtractGPSM(PAKEntryReadStream& rs, const hecl::ProjectPath& outPath);
|
||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -10,6 +10,257 @@
|
|||
namespace DataSpec::DNAParticle {
|
||||
extern logvisor::Module LogModule;
|
||||
|
||||
enum class ParticleType {
|
||||
GPSM = SBIG('GPSM'),
|
||||
SWSH = SBIG('SWSH'),
|
||||
ELSM = SBIG('ELSM'),
|
||||
DPSM = SBIG('DPSM'),
|
||||
CRSM = SBIG('CRSM'),
|
||||
WPSM = SBIG('WPSM')
|
||||
};
|
||||
|
||||
/*
|
||||
* The particle property (PP) metaclass system provides common compile-time utilities
|
||||
* for storing, enumerating, and streaming particle scripts.
|
||||
*/
|
||||
|
||||
template <class _Basis>
|
||||
struct PPImpl : BigDNA, _Basis {
|
||||
AT_DECL_EXPLICIT_DNA_YAML
|
||||
|
||||
template<typename T>
|
||||
static constexpr bool _shouldStore(T& p, bool defaultBool) {
|
||||
if constexpr (std::is_same_v<T, bool>) {
|
||||
return p != defaultBool;
|
||||
} else if constexpr (std::is_same_v<T, uint32_t>) {
|
||||
return p != 0xffffffff;
|
||||
} else if constexpr (std::is_same_v<T, float>) {
|
||||
return true;
|
||||
} else {
|
||||
return p.operator bool();
|
||||
}
|
||||
}
|
||||
|
||||
constexpr void _read(athena::io::IStreamReader& r) {
|
||||
constexpr FourCC RefType = uint32_t(_Basis::Type);
|
||||
DNAFourCC clsId(r);
|
||||
if (clsId != RefType) {
|
||||
LogModule.report(logvisor::Warning, fmt("non {} provided to {} parser"), RefType, RefType);
|
||||
return;
|
||||
}
|
||||
clsId.read(r);
|
||||
while (clsId != SBIG('_END')) {
|
||||
if (!_Basis::Lookup(clsId, [&](auto& p) {
|
||||
using Tp = std::decay_t<decltype(p)>;
|
||||
if constexpr (std::is_same_v<Tp, bool>) {
|
||||
DNAFourCC tp(r);
|
||||
if (tp == SBIG('CNST'))
|
||||
p = r.readBool();
|
||||
} else if constexpr (std::is_same_v<Tp, uint32_t>) {
|
||||
DNAFourCC tp(r);
|
||||
if (tp == SBIG('CNST'))
|
||||
p = r.readUint32Big();
|
||||
} else if constexpr (std::is_same_v<Tp, float>) {
|
||||
DNAFourCC tp(r);
|
||||
if (tp == SBIG('CNST'))
|
||||
p = r.readFloatBig();
|
||||
} else {
|
||||
p.read(r);
|
||||
}
|
||||
})) {
|
||||
LogModule.report(logvisor::Fatal, fmt("Unknown {} class {} @{}"), RefType, clsId, r.position());
|
||||
}
|
||||
clsId.read(r);
|
||||
}
|
||||
}
|
||||
|
||||
constexpr void _write(athena::io::IStreamWriter& w) {
|
||||
constexpr DNAFourCC RefType = uint32_t(_Basis::Type);
|
||||
RefType.write(w);
|
||||
_Basis::Enumerate([&](FourCC fcc, auto& p, bool defaultBool = false) {
|
||||
if (_shouldStore(p, defaultBool)) {
|
||||
using Tp = std::decay_t<decltype(p)>;
|
||||
DNAFourCC(fcc).write(w);
|
||||
if constexpr (std::is_same_v<Tp, bool>) {
|
||||
w.writeBytes("CNST", 4);
|
||||
w.writeBool(p);
|
||||
} else if constexpr (std::is_same_v<Tp, uint32_t>) {
|
||||
w.writeBytes("CNST", 4);
|
||||
w.writeUint32Big(p);
|
||||
} else if constexpr (std::is_same_v<Tp, float>) {
|
||||
w.writeBytes("CNST", 4);
|
||||
w.writeFloatBig(p);
|
||||
} else {
|
||||
p.write(w);
|
||||
}
|
||||
}
|
||||
});
|
||||
w.writeBytes("_END", 4);
|
||||
}
|
||||
|
||||
constexpr void _binarySize(std::size_t& s) {
|
||||
constexpr DNAFourCC RefType = uint32_t(_Basis::Type);
|
||||
RefType.binarySize(s);
|
||||
_Basis::Enumerate([&](FourCC fcc, auto& p, bool defaultBool = false) {
|
||||
if (_shouldStore(p, defaultBool)) {
|
||||
using Tp = std::decay_t<decltype(p)>;
|
||||
DNAFourCC(fcc).binarySize(s);
|
||||
if constexpr (std::is_same_v<Tp, bool>) {
|
||||
s += 5;
|
||||
} else if constexpr (std::is_same_v<Tp, uint32_t> || std::is_same_v<Tp, float>) {
|
||||
s += 8;
|
||||
} else {
|
||||
p.binarySize(s);
|
||||
}
|
||||
}
|
||||
});
|
||||
s += 4;
|
||||
}
|
||||
|
||||
void _read(athena::io::YAMLDocReader& r) {
|
||||
constexpr DNAFourCC RefType = uint32_t(_Basis::Type);
|
||||
|
||||
for (const auto& [key, value] : r.getCurNode()->m_mapChildren) {
|
||||
if (key == "DNAType"sv)
|
||||
continue;
|
||||
if (key.size() < 4) {
|
||||
LogModule.report(logvisor::Warning, fmt("short FourCC in element '{}'"), key);
|
||||
continue;
|
||||
}
|
||||
|
||||
if (auto rec = r.enterSubRecord(key)) {
|
||||
const DNAFourCC clsId = key.c_str();
|
||||
if (!_Basis::Lookup(clsId, [&](auto& p) {
|
||||
using Tp = std::decay_t<decltype(p)>;
|
||||
if constexpr (std::is_same_v<Tp, bool>) {
|
||||
p = r.readBool();
|
||||
} else if constexpr (std::is_same_v<Tp, uint32_t>) {
|
||||
p = r.readUint32();
|
||||
} else if constexpr (std::is_same_v<Tp, float>) {
|
||||
p = r.readFloat();
|
||||
} else {
|
||||
p.read(r);
|
||||
}
|
||||
})) {
|
||||
LogModule.report(logvisor::Fatal, fmt("Unknown {} class {}"), RefType, clsId);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
constexpr void _write(athena::io::YAMLDocWriter& w) {
|
||||
_Basis::Enumerate([&](FourCC fcc, auto& p, bool defaultBool = false) {
|
||||
if (_shouldStore(p, defaultBool)) {
|
||||
using Tp = std::decay_t<decltype(p)>;
|
||||
if (auto rec = w.enterSubRecord(fcc.toStringView())) {
|
||||
if constexpr (std::is_same_v<Tp, bool>) {
|
||||
w.writeBool(p);
|
||||
} else if constexpr (std::is_same_v<Tp, uint32_t>) {
|
||||
w.writeUint32(p);
|
||||
} else if constexpr (std::is_same_v<Tp, float>) {
|
||||
w.writeFloat(p);
|
||||
} else {
|
||||
p.write(w);
|
||||
}
|
||||
}
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
constexpr void gatherDependencies(std::vector<hecl::ProjectPath>& deps) {
|
||||
_Basis::Enumerate([&](FourCC fcc, auto& p, bool defaultBool = false) {
|
||||
using Tp = std::decay_t<decltype(p)>;
|
||||
if constexpr (!std::is_same_v<Tp, bool> && !std::is_same_v<Tp, uint32_t> && !std::is_same_v<Tp, float>)
|
||||
p.gatherDependencies(deps);
|
||||
});
|
||||
}
|
||||
|
||||
constexpr void gatherDependencies(std::vector<hecl::ProjectPath>& deps) const {
|
||||
const_cast<PPImpl&>(*this).gatherDependencies(deps);
|
||||
}
|
||||
};
|
||||
|
||||
template <typename _Type>
|
||||
struct PEType {
|
||||
using Type = _Type;
|
||||
};
|
||||
|
||||
template <class _Basis>
|
||||
struct PEImpl : BigDNA {
|
||||
AT_DECL_EXPLICIT_DNA_YAML
|
||||
using _PtrType = typename _Basis::PtrType;
|
||||
|
||||
void _read(athena::io::IStreamReader& r) {
|
||||
DNAFourCC clsId(r);
|
||||
if (clsId == FOURCC('NONE')) {
|
||||
m_elem.reset();
|
||||
return;
|
||||
}
|
||||
if (!_Basis::Lookup(clsId, [&](auto&& p) {
|
||||
using Tp = std::decay_t<decltype(p)>;
|
||||
m_elem = std::make_unique<typename Tp::Type>();
|
||||
m_elem->read(r);
|
||||
})) {
|
||||
LogModule.report(logvisor::Fatal, fmt("Unknown {} class {} @{}"), _PtrType::TypeName, clsId, r.position());
|
||||
}
|
||||
}
|
||||
|
||||
void _write(athena::io::IStreamWriter& w) {
|
||||
if (m_elem) {
|
||||
w.writeBytes(m_elem->ClassID().data(), 4);
|
||||
m_elem->write(w);
|
||||
} else {
|
||||
w.writeBytes("NONE", 4);
|
||||
}
|
||||
}
|
||||
|
||||
void _binarySize(std::size_t& s) {
|
||||
if (m_elem)
|
||||
m_elem->binarySize(s);
|
||||
s += 4;
|
||||
}
|
||||
|
||||
void _read(athena::io::YAMLDocReader& r) {
|
||||
const auto& mapChildren = r.getCurNode()->m_mapChildren;
|
||||
if (mapChildren.empty()) {
|
||||
m_elem.reset();
|
||||
return;
|
||||
}
|
||||
|
||||
const auto& [key, value] = mapChildren[0];
|
||||
if (key.size() < 4)
|
||||
LogModule.report(logvisor::Fatal, fmt("short FourCC in element '{}'"), key);
|
||||
|
||||
if (auto rec = r.enterSubRecord(key)) {
|
||||
const DNAFourCC clsId = key.c_str();
|
||||
if (!_Basis::Lookup(clsId, [&](auto&& p) {
|
||||
using Tp = std::decay_t<decltype(p)>;
|
||||
m_elem = std::make_unique<typename Tp::Type>();
|
||||
m_elem->read(r);
|
||||
})) {
|
||||
LogModule.report(logvisor::Fatal, fmt("Unknown {} class {}"), _PtrType::TypeName, clsId);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void _write(athena::io::YAMLDocWriter& w) {
|
||||
if (m_elem)
|
||||
if (auto rec = w.enterSubRecord(m_elem->ClassID()))
|
||||
m_elem->write(w);
|
||||
}
|
||||
|
||||
void gatherDependencies(std::vector<hecl::ProjectPath>& deps) const {
|
||||
_Basis::gatherDependencies(deps, m_elem);
|
||||
}
|
||||
|
||||
operator bool() const { return m_elem.operator bool(); }
|
||||
auto* get() const { return m_elem.get(); }
|
||||
auto* operator->() const { return get(); }
|
||||
void reset() { m_elem.reset(); }
|
||||
private:
|
||||
std::unique_ptr<_PtrType> m_elem;
|
||||
};
|
||||
|
||||
struct IElement : BigDNAVYaml {
|
||||
Delete _d;
|
||||
~IElement() override = default;
|
||||
|
@ -19,61 +270,296 @@ struct IElement : BigDNAVYaml {
|
|||
|
||||
struct IRealElement : IElement {
|
||||
Delete _d2;
|
||||
static constexpr std::string_view TypeName = "RealElement"sv;
|
||||
};
|
||||
struct RealElementFactory : BigDNA {
|
||||
AT_DECL_EXPLICIT_DNA_YAML
|
||||
std::unique_ptr<IRealElement> m_elem;
|
||||
operator bool() const { return m_elem.operator bool(); }
|
||||
struct RELifetimeTween;
|
||||
struct REConstant;
|
||||
struct RETimeChain;
|
||||
struct REAdd;
|
||||
struct REClamp;
|
||||
struct REKeyframeEmitter;
|
||||
struct REKeyframeEmitter;
|
||||
struct REInitialRandom;
|
||||
struct RERandom;
|
||||
struct REMultiply;
|
||||
struct REPulse;
|
||||
struct RETimeScale;
|
||||
struct RELifetimePercent;
|
||||
struct RESineWave;
|
||||
struct REInitialSwitch;
|
||||
struct RECompareLessThan;
|
||||
struct RECompareEquals;
|
||||
struct REParticleAdvanceParam1;
|
||||
struct REParticleAdvanceParam2;
|
||||
struct REParticleAdvanceParam3;
|
||||
struct REParticleAdvanceParam4;
|
||||
struct REParticleAdvanceParam5;
|
||||
struct REParticleAdvanceParam6;
|
||||
struct REParticleAdvanceParam7;
|
||||
struct REParticleAdvanceParam8;
|
||||
struct REParticleSizeOrLineLength;
|
||||
struct REParticleRotationOrLineWidth;
|
||||
struct RESubtract;
|
||||
struct REVectorMagnitude;
|
||||
struct REVectorXToReal;
|
||||
struct REVectorYToReal;
|
||||
struct REVectorZToReal;
|
||||
struct RECEXT;
|
||||
struct REIntTimesReal;
|
||||
struct _RealElementFactory {
|
||||
using PtrType = IRealElement;
|
||||
template<typename _Func>
|
||||
static bool constexpr Lookup(FourCC fcc, _Func f) {
|
||||
switch (fcc.toUint32()) {
|
||||
case SBIG('LFTW'): f(PEType<RELifetimeTween>{}); return true;
|
||||
case SBIG('CNST'): f(PEType<REConstant>{}); return true;
|
||||
case SBIG('CHAN'): f(PEType<RETimeChain>{}); return true;
|
||||
case SBIG('ADD_'): f(PEType<REAdd>{}); return true;
|
||||
case SBIG('CLMP'): f(PEType<REClamp>{}); return true;
|
||||
case SBIG('KEYE'): f(PEType<REKeyframeEmitter>{}); return true;
|
||||
case SBIG('KEYP'): f(PEType<REKeyframeEmitter>{}); return true;
|
||||
case SBIG('IRND'): f(PEType<REInitialRandom>{}); return true;
|
||||
case SBIG('RAND'): f(PEType<RERandom>{}); return true;
|
||||
case SBIG('MULT'): f(PEType<REMultiply>{}); return true;
|
||||
case SBIG('PULS'): f(PEType<REPulse>{}); return true;
|
||||
case SBIG('SCAL'): f(PEType<RETimeScale>{}); return true;
|
||||
case SBIG('RLPT'): f(PEType<RELifetimePercent>{}); return true;
|
||||
case SBIG('SINE'): f(PEType<RESineWave>{}); return true;
|
||||
case SBIG('ISWT'): f(PEType<REInitialSwitch>{}); return true;
|
||||
case SBIG('CLTN'): f(PEType<RECompareLessThan>{}); return true;
|
||||
case SBIG('CEQL'): f(PEType<RECompareEquals>{}); return true;
|
||||
case SBIG('PAP1'): f(PEType<REParticleAdvanceParam1>{}); return true;
|
||||
case SBIG('PAP2'): f(PEType<REParticleAdvanceParam2>{}); return true;
|
||||
case SBIG('PAP3'): f(PEType<REParticleAdvanceParam3>{}); return true;
|
||||
case SBIG('PAP4'): f(PEType<REParticleAdvanceParam4>{}); return true;
|
||||
case SBIG('PAP5'): f(PEType<REParticleAdvanceParam5>{}); return true;
|
||||
case SBIG('PAP6'): f(PEType<REParticleAdvanceParam6>{}); return true;
|
||||
case SBIG('PAP7'): f(PEType<REParticleAdvanceParam7>{}); return true;
|
||||
case SBIG('PAP8'): f(PEType<REParticleAdvanceParam8>{}); return true;
|
||||
case SBIG('PSLL'): f(PEType<REParticleSizeOrLineLength>{}); return true;
|
||||
case SBIG('PRLW'): f(PEType<REParticleRotationOrLineWidth>{}); return true;
|
||||
case SBIG('SUB_'): f(PEType<RESubtract>{}); return true;
|
||||
case SBIG('VMAG'): f(PEType<REVectorMagnitude>{}); return true;
|
||||
case SBIG('VXTR'): f(PEType<REVectorXToReal>{}); return true;
|
||||
case SBIG('VYTR'): f(PEType<REVectorYToReal>{}); return true;
|
||||
case SBIG('VZTR'): f(PEType<REVectorZToReal>{}); return true;
|
||||
case SBIG('CEXT'): f(PEType<RECEXT>{}); return true;
|
||||
case SBIG('ITRL'): f(PEType<REIntTimesReal>{}); return true;
|
||||
default: return false;
|
||||
}
|
||||
}
|
||||
static constexpr void gatherDependencies(std::vector<hecl::ProjectPath>& pathsOut,
|
||||
const std::unique_ptr<IRealElement>& elemPtr) {}
|
||||
};
|
||||
using RealElementFactory = PEImpl<_RealElementFactory>;
|
||||
|
||||
struct IIntElement : IElement {
|
||||
Delete _d2;
|
||||
static constexpr std::string_view TypeName = "IntElement"sv;
|
||||
};
|
||||
struct IntElementFactory : BigDNA {
|
||||
AT_DECL_EXPLICIT_DNA_YAML
|
||||
std::unique_ptr<IIntElement> m_elem;
|
||||
operator bool() const { return m_elem.operator bool(); }
|
||||
struct IEKeyframeEmitter;
|
||||
struct IEKeyframeEmitter;
|
||||
struct IEDeath;
|
||||
struct IEClamp;
|
||||
struct IETimeChain;
|
||||
struct IEAdd;
|
||||
struct IEConstant;
|
||||
struct IEImpulse;
|
||||
struct IELifetimePercent;
|
||||
struct IEInitialRandom;
|
||||
struct IEPulse;
|
||||
struct IEMultiply;
|
||||
struct IESampleAndHold;
|
||||
struct IERandom;
|
||||
struct IETimeScale;
|
||||
struct IEGTCP;
|
||||
struct IEModulo;
|
||||
struct IESubtract;
|
||||
struct _IntElementFactory {
|
||||
using PtrType = IIntElement;
|
||||
template<typename _Func>
|
||||
static bool constexpr Lookup(FourCC fcc, _Func f) {
|
||||
switch (fcc.toUint32()) {
|
||||
case SBIG('KEYE'): f(PEType<IEKeyframeEmitter>{}); return true;
|
||||
case SBIG('KEYP'): f(PEType<IEKeyframeEmitter>{}); return true;
|
||||
case SBIG('DETH'): f(PEType<IEDeath>{}); return true;
|
||||
case SBIG('CLMP'): f(PEType<IEClamp>{}); return true;
|
||||
case SBIG('CHAN'): f(PEType<IETimeChain>{}); return true;
|
||||
case SBIG('ADD_'): f(PEType<IEAdd>{}); return true;
|
||||
case SBIG('CNST'): f(PEType<IEConstant>{}); return true;
|
||||
case SBIG('IMPL'): f(PEType<IEImpulse>{}); return true;
|
||||
case SBIG('ILPT'): f(PEType<IELifetimePercent>{}); return true;
|
||||
case SBIG('IRND'): f(PEType<IEInitialRandom>{}); return true;
|
||||
case SBIG('PULS'): f(PEType<IEPulse>{}); return true;
|
||||
case SBIG('MULT'): f(PEType<IEMultiply>{}); return true;
|
||||
case SBIG('SPAH'): f(PEType<IESampleAndHold>{}); return true;
|
||||
case SBIG('RAND'): f(PEType<IERandom>{}); return true;
|
||||
case SBIG('TSCL'): f(PEType<IETimeScale>{}); return true;
|
||||
case SBIG('GTCP'): f(PEType<IEGTCP>{}); return true;
|
||||
case SBIG('MODU'): f(PEType<IEModulo>{}); return true;
|
||||
case SBIG('SUB_'): f(PEType<IESubtract>{}); return true;
|
||||
default: return false;
|
||||
}
|
||||
}
|
||||
static constexpr void gatherDependencies(std::vector<hecl::ProjectPath>& pathsOut,
|
||||
const std::unique_ptr<IIntElement>& elemPtr) {}
|
||||
};
|
||||
using IntElementFactory = PEImpl<_IntElementFactory>;
|
||||
|
||||
struct IVectorElement : IElement {
|
||||
Delete _d2;
|
||||
static constexpr std::string_view TypeName = "VectorElement"sv;
|
||||
};
|
||||
struct VectorElementFactory : BigDNA {
|
||||
AT_DECL_EXPLICIT_DNA_YAML
|
||||
std::unique_ptr<IVectorElement> m_elem;
|
||||
operator bool() const { return m_elem.operator bool(); }
|
||||
struct VECone;
|
||||
struct VETimeChain;
|
||||
struct VEAngleCone;
|
||||
struct VEAdd;
|
||||
struct VECircleCluster;
|
||||
struct VEConstant;
|
||||
struct VECircle;
|
||||
struct VEKeyframeEmitter;
|
||||
struct VEKeyframeEmitter;
|
||||
struct VEMultiply;
|
||||
struct VERealToVector;
|
||||
struct VEPulse;
|
||||
struct VEParticleVelocity;
|
||||
struct VESPOS;
|
||||
struct VEPLCO;
|
||||
struct VEPLOC;
|
||||
struct VEPSOR;
|
||||
struct VEPSOF;
|
||||
struct _VectorElementFactory {
|
||||
using PtrType = IVectorElement;
|
||||
template<typename _Func>
|
||||
static bool constexpr Lookup(FourCC fcc, _Func f) {
|
||||
switch (fcc.toUint32()) {
|
||||
case SBIG('CONE'): f(PEType<VECone>{}); return true;
|
||||
case SBIG('CHAN'): f(PEType<VETimeChain>{}); return true;
|
||||
case SBIG('ANGC'): f(PEType<VEAngleCone>{}); return true;
|
||||
case SBIG('ADD_'): f(PEType<VEAdd>{}); return true;
|
||||
case SBIG('CCLU'): f(PEType<VECircleCluster>{}); return true;
|
||||
case SBIG('CNST'): f(PEType<VEConstant>{}); return true;
|
||||
case SBIG('CIRC'): f(PEType<VECircle>{}); return true;
|
||||
case SBIG('KEYE'): f(PEType<VEKeyframeEmitter>{}); return true;
|
||||
case SBIG('KEYP'): f(PEType<VEKeyframeEmitter>{}); return true;
|
||||
case SBIG('MULT'): f(PEType<VEMultiply>{}); return true;
|
||||
case SBIG('RTOV'): f(PEType<VERealToVector>{}); return true;
|
||||
case SBIG('PULS'): f(PEType<VEPulse>{}); return true;
|
||||
case SBIG('PVEL'): f(PEType<VEParticleVelocity>{}); return true;
|
||||
case SBIG('SPOS'): f(PEType<VESPOS>{}); return true;
|
||||
case SBIG('PLCO'): f(PEType<VEPLCO>{}); return true;
|
||||
case SBIG('PLOC'): f(PEType<VEPLOC>{}); return true;
|
||||
case SBIG('PSOR'): f(PEType<VEPSOR>{}); return true;
|
||||
case SBIG('PSOF'): f(PEType<VEPSOF>{}); return true;
|
||||
default: return false;
|
||||
}
|
||||
}
|
||||
static constexpr void gatherDependencies(std::vector<hecl::ProjectPath>& pathsOut,
|
||||
const std::unique_ptr<IVectorElement>& elemPtr) {}
|
||||
};
|
||||
using VectorElementFactory = PEImpl<_VectorElementFactory>;
|
||||
|
||||
struct IColorElement : IElement {
|
||||
Delete _d2;
|
||||
static constexpr std::string_view TypeName = "ColorElement"sv;
|
||||
};
|
||||
struct ColorElementFactory : BigDNA {
|
||||
AT_DECL_EXPLICIT_DNA_YAML
|
||||
std::unique_ptr<IColorElement> m_elem;
|
||||
operator bool() const { return m_elem.operator bool(); }
|
||||
struct CEKeyframeEmitter;
|
||||
struct CEKeyframeEmitter;
|
||||
struct CEConstant;
|
||||
struct CETimeChain;
|
||||
struct CEFadeEnd;
|
||||
struct CEFade;
|
||||
struct CEPulse;
|
||||
struct _ColorElementFactory {
|
||||
using PtrType = IColorElement;
|
||||
template<typename _Func>
|
||||
static bool constexpr Lookup(FourCC fcc, _Func f) {
|
||||
switch (fcc.toUint32()) {
|
||||
case SBIG('KEYE'): f(PEType<CEKeyframeEmitter>{}); return true;
|
||||
case SBIG('KEYP'): f(PEType<CEKeyframeEmitter>{}); return true;
|
||||
case SBIG('CNST'): f(PEType<CEConstant>{}); return true;
|
||||
case SBIG('CHAN'): f(PEType<CETimeChain>{}); return true;
|
||||
case SBIG('CFDE'): f(PEType<CEFadeEnd>{}); return true;
|
||||
case SBIG('FADE'): f(PEType<CEFade>{}); return true;
|
||||
case SBIG('PULS'): f(PEType<CEPulse>{}); return true;
|
||||
default: return false;
|
||||
}
|
||||
}
|
||||
static constexpr void gatherDependencies(std::vector<hecl::ProjectPath>& pathsOut,
|
||||
const std::unique_ptr<IColorElement>& elemPtr) {}
|
||||
};
|
||||
using ColorElementFactory = PEImpl<_ColorElementFactory>;
|
||||
|
||||
struct IModVectorElement : IElement {
|
||||
Delete _d2;
|
||||
static constexpr std::string_view TypeName = "ModVectorElement"sv;
|
||||
};
|
||||
struct ModVectorElementFactory : BigDNA {
|
||||
AT_DECL_EXPLICIT_DNA_YAML
|
||||
std::unique_ptr<IModVectorElement> m_elem;
|
||||
operator bool() const { return m_elem.operator bool(); }
|
||||
struct MVEImplosion;
|
||||
struct MVEExponentialImplosion;
|
||||
struct MVETimeChain;
|
||||
struct MVEBounce;
|
||||
struct MVEConstant;
|
||||
struct MVEGravity;
|
||||
struct MVEExplode;
|
||||
struct MVESetPosition;
|
||||
struct MVELinearImplosion;
|
||||
struct MVEPulse;
|
||||
struct MVEWind;
|
||||
struct MVESwirl;
|
||||
struct _ModVectorElementFactory {
|
||||
using PtrType = IModVectorElement;
|
||||
template<typename _Func>
|
||||
static bool constexpr Lookup(FourCC fcc, _Func f) {
|
||||
switch (fcc.toUint32()) {
|
||||
case SBIG('IMPL'): f(PEType<MVEImplosion>{}); return true;
|
||||
case SBIG('EMPL'): f(PEType<MVEExponentialImplosion>{}); return true;
|
||||
case SBIG('CHAN'): f(PEType<MVETimeChain>{}); return true;
|
||||
case SBIG('BNCE'): f(PEType<MVEBounce>{}); return true;
|
||||
case SBIG('CNST'): f(PEType<MVEConstant>{}); return true;
|
||||
case SBIG('GRAV'): f(PEType<MVEGravity>{}); return true;
|
||||
case SBIG('EXPL'): f(PEType<MVEExplode>{}); return true;
|
||||
case SBIG('SPOS'): f(PEType<MVESetPosition>{}); return true;
|
||||
case SBIG('LMPL'): f(PEType<MVELinearImplosion>{}); return true;
|
||||
case SBIG('PULS'): f(PEType<MVEPulse>{}); return true;
|
||||
case SBIG('WIND'): f(PEType<MVEWind>{}); return true;
|
||||
case SBIG('SWRL'): f(PEType<MVESwirl>{}); return true;
|
||||
default: return false;
|
||||
}
|
||||
}
|
||||
static constexpr void gatherDependencies(std::vector<hecl::ProjectPath>& pathsOut,
|
||||
const std::unique_ptr<IModVectorElement>& elemPtr) {}
|
||||
};
|
||||
using ModVectorElementFactory = PEImpl<_ModVectorElementFactory>;
|
||||
|
||||
struct IEmitterElement : IElement {
|
||||
Delete _d2;
|
||||
static constexpr std::string_view TypeName = "EmitterElement"sv;
|
||||
};
|
||||
struct EmitterElementFactory : BigDNA {
|
||||
AT_DECL_EXPLICIT_DNA_YAML
|
||||
std::unique_ptr<IEmitterElement> m_elem;
|
||||
operator bool() const { return m_elem.operator bool(); }
|
||||
struct EESimpleEmitterTR;
|
||||
struct EESimpleEmitter;
|
||||
struct VESphere;
|
||||
struct VEAngleSphere;
|
||||
struct _EmitterElementFactory {
|
||||
using PtrType = IEmitterElement;
|
||||
template<typename _Func>
|
||||
static bool constexpr Lookup(FourCC fcc, _Func f) {
|
||||
switch (fcc.toUint32()) {
|
||||
case SBIG('SETR'): f(PEType<EESimpleEmitterTR>{}); return true;
|
||||
case SBIG('SEMR'): f(PEType<EESimpleEmitter>{}); return true;
|
||||
case SBIG('SPHE'): f(PEType<VESphere>{}); return true;
|
||||
case SBIG('ASPH'): f(PEType<VEAngleSphere>{}); return true;
|
||||
default: return false;
|
||||
}
|
||||
}
|
||||
static constexpr void gatherDependencies(std::vector<hecl::ProjectPath>& pathsOut,
|
||||
const std::unique_ptr<IEmitterElement>& elemPtr) {}
|
||||
};
|
||||
using EmitterElementFactory = PEImpl<_EmitterElementFactory>;
|
||||
|
||||
struct IUVElement : IElement {
|
||||
Delete _d2;
|
||||
virtual void gatherDependencies(std::vector<hecl::ProjectPath>& pathsOut) const = 0;
|
||||
static constexpr std::string_view TypeName = "UVElement"sv;
|
||||
};
|
||||
|
||||
struct BoolHelper : IElement {
|
||||
|
@ -87,6 +573,46 @@ struct BoolHelper : IElement {
|
|||
std::string_view ClassID() const override { return "BoolHelper"sv; }
|
||||
};
|
||||
|
||||
template <typename Tp>
|
||||
struct ValueHelper : BigDNA {
|
||||
AT_DECL_EXPLICIT_DNA_YAML
|
||||
|
||||
void _read(athena::io::IStreamReader& r) {
|
||||
hecl::DNAFourCC ValueType;
|
||||
ValueType.read(r);
|
||||
if (ValueType == FOURCC('CNST'))
|
||||
athena::io::Read<athena::io::PropType::None>::Do<Tp, athena::Endian::Big>({}, value.emplace(), r);
|
||||
else
|
||||
value = std::nullopt;
|
||||
}
|
||||
void _write(athena::io::IStreamWriter& w) {
|
||||
if (value) {
|
||||
w.writeBytes("CNST", 4);
|
||||
athena::io::Write<athena::io::PropType::None>::Do<Tp, athena::Endian::Big>({}, *value, w);
|
||||
} else {
|
||||
w.writeBytes("NONE", 4);
|
||||
}
|
||||
}
|
||||
void _binarySize(std::size_t& s) {
|
||||
s += 4;
|
||||
if (value)
|
||||
athena::io::BinarySize<athena::io::PropType::None>::Do<Tp, athena::Endian::Big>({}, *value, s);
|
||||
}
|
||||
void _read(athena::io::YAMLDocReader& r) {
|
||||
athena::io::ReadYaml<athena::io::PropType::None>::Do<Tp, athena::Endian::Big>({}, value.emplace(), r);
|
||||
}
|
||||
void _write(athena::io::YAMLDocWriter& w) {
|
||||
athena::io::WriteYaml<athena::io::PropType::None>::Do<Tp, athena::Endian::Big>({}, *value, w);
|
||||
}
|
||||
|
||||
static constexpr void gatherDependencies(std::vector<hecl::ProjectPath>& pathsOut) {}
|
||||
|
||||
std::optional<Tp> value = {};
|
||||
void emplace(Tp val) { value.emplace(val); }
|
||||
Tp operator*() const { return *value; }
|
||||
operator bool() const { return value.operator bool(); }
|
||||
};
|
||||
|
||||
struct RELifetimeTween : IRealElement {
|
||||
AT_DECL_DNA_YAMLV_NO_TYPE
|
||||
RealElementFactory a;
|
||||
|
@ -743,7 +1269,8 @@ struct UVEConstant : IUVElement {
|
|||
std::string_view ClassID() const override { return "CNST"sv; }
|
||||
|
||||
void gatherDependencies(std::vector<hecl::ProjectPath>& pathsOut) const override {
|
||||
g_curSpec->flattenDependencies(tex, pathsOut);
|
||||
if (tex.isValid())
|
||||
g_curSpec->flattenDependencies(tex, pathsOut);
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -761,18 +1288,30 @@ struct UVEAnimTexture : IUVElement {
|
|||
std::string_view ClassID() const override { return "ATEX"sv; }
|
||||
|
||||
void gatherDependencies(std::vector<hecl::ProjectPath>& pathsOut) const override {
|
||||
g_curSpec->flattenDependencies(tex, pathsOut);
|
||||
if (tex.isValid())
|
||||
g_curSpec->flattenDependencies(tex, pathsOut);
|
||||
}
|
||||
};
|
||||
|
||||
template <class IDType>
|
||||
struct UVElementFactory : BigDNA {
|
||||
AT_DECL_EXPLICIT_DNA_YAML
|
||||
AT_SUBDECL_DNA
|
||||
DNAFourCC m_type;
|
||||
std::unique_ptr<IUVElement> m_elem;
|
||||
operator bool() const { return m_elem.operator bool(); }
|
||||
struct _UVElementFactory {
|
||||
using PtrType = IUVElement;
|
||||
template<typename _Func>
|
||||
static bool constexpr Lookup(FourCC fcc, _Func f) {
|
||||
switch (fcc.toUint32()) {
|
||||
case SBIG('CNST'): f(PEType<UVEConstant<IDType>>{}); return true;
|
||||
case SBIG('ATEX'): f(PEType<UVEAnimTexture<IDType>>{}); return true;
|
||||
default: return false;
|
||||
}
|
||||
}
|
||||
static constexpr void gatherDependencies(std::vector<hecl::ProjectPath>& pathsOut,
|
||||
const std::unique_ptr<IUVElement>& elemPtr) {
|
||||
if (elemPtr)
|
||||
elemPtr->gatherDependencies(pathsOut);
|
||||
}
|
||||
};
|
||||
template <class IDType>
|
||||
using UVElementFactory = PEImpl<_UVElementFactory<IDType>>;
|
||||
|
||||
template <class IDType>
|
||||
struct SpawnSystemKeyframeData : BigDNA {
|
||||
|
@ -809,6 +1348,10 @@ struct ChildResourceFactory : BigDNA {
|
|||
AT_DECL_EXPLICIT_DNA_YAML
|
||||
AT_SUBDECL_DNA
|
||||
operator bool() const { return id.isValid(); }
|
||||
void gatherDependencies(std::vector<hecl::ProjectPath>& pathsOut) const {
|
||||
if (id.isValid())
|
||||
g_curSpec->flattenDependencies(id, pathsOut);
|
||||
}
|
||||
};
|
||||
|
||||
} // namespace DataSpec::DNAParticle
|
||||
|
|
|
@ -1,11 +1,14 @@
|
|||
#include "DataSpec/DNACommon/SWHC.hpp"
|
||||
|
||||
#include "DataSpec/DNACommon/PAK.hpp"
|
||||
|
||||
#include <logvisor/logvisor.hpp>
|
||||
|
||||
namespace DataSpec::DNAParticle {
|
||||
|
||||
template struct PPImpl<_SWSH<UniqueID32>>;
|
||||
template struct PPImpl<_SWSH<UniqueID64>>;
|
||||
|
||||
AT_SUBSPECIALIZE_DNA_YAML(PPImpl<_SWSH<UniqueID32>>)
|
||||
AT_SUBSPECIALIZE_DNA_YAML(PPImpl<_SWSH<UniqueID64>>)
|
||||
|
||||
template <>
|
||||
std::string_view SWSH<UniqueID32>::DNAType() {
|
||||
return "SWSH<UniqueID32>"sv;
|
||||
|
@ -16,504 +19,6 @@ std::string_view SWSH<UniqueID64>::DNAType() {
|
|||
return "SWSH<UniqueID64>"sv;
|
||||
}
|
||||
|
||||
template <class IDType>
|
||||
void SWSH<IDType>::_read(typename BigDNA::ReadYaml::StreamT& r) {
|
||||
for (const auto& elem : r.getCurNode()->m_mapChildren) {
|
||||
if (elem.first.size() < 4) {
|
||||
LogModule.report(logvisor::Warning, fmt("short FourCC in element '{}'"), elem.first);
|
||||
continue;
|
||||
}
|
||||
|
||||
if (auto rec = r.enterSubRecord(elem.first.c_str())) {
|
||||
switch (*reinterpret_cast<const uint32_t*>(elem.first.data())) {
|
||||
case SBIG('PSLT'):
|
||||
x0_PSLT.read(r);
|
||||
break;
|
||||
case SBIG('TIME'):
|
||||
x4_TIME.read(r);
|
||||
break;
|
||||
case SBIG('LRAD'):
|
||||
x8_LRAD.read(r);
|
||||
break;
|
||||
case SBIG('RRAD'):
|
||||
xc_RRAD.read(r);
|
||||
break;
|
||||
case SBIG('LENG'):
|
||||
x10_LENG.read(r);
|
||||
break;
|
||||
case SBIG('COLR'):
|
||||
x14_COLR.read(r);
|
||||
break;
|
||||
case SBIG('SIDE'):
|
||||
x18_SIDE.read(r);
|
||||
break;
|
||||
case SBIG('IROT'):
|
||||
x1c_IROT.read(r);
|
||||
break;
|
||||
case SBIG('ROTM'):
|
||||
x20_ROTM.read(r);
|
||||
break;
|
||||
case SBIG('POFS'):
|
||||
x24_POFS.read(r);
|
||||
break;
|
||||
case SBIG('IVEL'):
|
||||
x28_IVEL.read(r);
|
||||
break;
|
||||
case SBIG('NPOS'):
|
||||
x2c_NPOS.read(r);
|
||||
break;
|
||||
case SBIG('VELM'):
|
||||
x30_VELM.read(r);
|
||||
break;
|
||||
case SBIG('VLM2'):
|
||||
x34_VLM2.read(r);
|
||||
break;
|
||||
case SBIG('SPLN'):
|
||||
x38_SPLN.read(r);
|
||||
break;
|
||||
case SBIG('TEXR'):
|
||||
x3c_TEXR.read(r);
|
||||
break;
|
||||
case SBIG('TSPN'):
|
||||
x40_TSPN.read(r);
|
||||
break;
|
||||
case SBIG('LLRD'):
|
||||
x44_24_LLRD = r.readBool();
|
||||
break;
|
||||
case SBIG('CROS'):
|
||||
x44_25_CROS = r.readBool();
|
||||
break;
|
||||
case SBIG('VLS1'):
|
||||
x44_26_VLS1 = r.readBool();
|
||||
break;
|
||||
case SBIG('VLS2'):
|
||||
x44_27_VLS2 = r.readBool();
|
||||
break;
|
||||
case SBIG('SROT'):
|
||||
x44_28_SROT = r.readBool();
|
||||
break;
|
||||
case SBIG('WIRE'):
|
||||
x44_29_WIRE = r.readBool();
|
||||
break;
|
||||
case SBIG('TEXW'):
|
||||
x44_30_TEXW = r.readBool();
|
||||
break;
|
||||
case SBIG('AALP'):
|
||||
x44_31_AALP = r.readBool();
|
||||
break;
|
||||
case SBIG('ZBUF'):
|
||||
x45_24_ZBUF = r.readBool();
|
||||
break;
|
||||
case SBIG('ORNT'):
|
||||
x45_25_ORNT = r.readBool();
|
||||
break;
|
||||
case SBIG('CRND'):
|
||||
x45_26_CRND = r.readBool();
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
template <class IDType>
|
||||
void SWSH<IDType>::_write(typename BigDNA::WriteYaml::StreamT& w) const {
|
||||
if (x0_PSLT)
|
||||
if (auto rec = w.enterSubRecord("PSLT"))
|
||||
x0_PSLT.write(w);
|
||||
if (x4_TIME)
|
||||
if (auto rec = w.enterSubRecord("TIME"))
|
||||
x4_TIME.write(w);
|
||||
if (x8_LRAD)
|
||||
if (auto rec = w.enterSubRecord("LRAD"))
|
||||
x8_LRAD.write(w);
|
||||
if (xc_RRAD)
|
||||
if (auto rec = w.enterSubRecord("RRAD"))
|
||||
xc_RRAD.write(w);
|
||||
if (x10_LENG)
|
||||
if (auto rec = w.enterSubRecord("LENG"))
|
||||
x10_LENG.write(w);
|
||||
if (x14_COLR)
|
||||
if (auto rec = w.enterSubRecord("COLR"))
|
||||
x14_COLR.write(w);
|
||||
if (x18_SIDE)
|
||||
if (auto rec = w.enterSubRecord("SIDE"))
|
||||
x18_SIDE.write(w);
|
||||
if (x1c_IROT)
|
||||
if (auto rec = w.enterSubRecord("IROT"))
|
||||
x1c_IROT.write(w);
|
||||
if (x20_ROTM)
|
||||
if (auto rec = w.enterSubRecord("ROTM"))
|
||||
x20_ROTM.write(w);
|
||||
if (x24_POFS)
|
||||
if (auto rec = w.enterSubRecord("POFS"))
|
||||
x24_POFS.write(w);
|
||||
if (x28_IVEL)
|
||||
if (auto rec = w.enterSubRecord("IVEL"))
|
||||
x28_IVEL.write(w);
|
||||
if (x2c_NPOS)
|
||||
if (auto rec = w.enterSubRecord("NPOS"))
|
||||
x2c_NPOS.write(w);
|
||||
if (x30_VELM)
|
||||
if (auto rec = w.enterSubRecord("VELM"))
|
||||
x30_VELM.write(w);
|
||||
if (x34_VLM2)
|
||||
if (auto rec = w.enterSubRecord("VLM2"))
|
||||
x34_VLM2.write(w);
|
||||
if (x38_SPLN)
|
||||
if (auto rec = w.enterSubRecord("SPLN"))
|
||||
x38_SPLN.write(w);
|
||||
if (x3c_TEXR)
|
||||
if (auto rec = w.enterSubRecord("TEXR"))
|
||||
x3c_TEXR.write(w);
|
||||
if (x40_TSPN)
|
||||
if (auto rec = w.enterSubRecord("TSPN"))
|
||||
x40_TSPN.write(w);
|
||||
|
||||
if (x44_24_LLRD)
|
||||
w.writeBool("LLRD", true);
|
||||
if (!x44_25_CROS)
|
||||
w.writeBool("CROS", false);
|
||||
if (x44_26_VLS1)
|
||||
w.writeBool("VLS1", true);
|
||||
if (x44_27_VLS2)
|
||||
w.writeBool("VLS2", true);
|
||||
if (x44_28_SROT)
|
||||
w.writeBool("SROT", true);
|
||||
if (x44_29_WIRE)
|
||||
w.writeBool("WIRE", true);
|
||||
if (x44_30_TEXW)
|
||||
w.writeBool("TEXW", true);
|
||||
if (x44_31_AALP)
|
||||
w.writeBool("AALP", true);
|
||||
if (x45_24_ZBUF)
|
||||
w.writeBool("ZBUF", true);
|
||||
if (x45_25_ORNT)
|
||||
w.writeBool("ORNT", true);
|
||||
if (x45_26_CRND)
|
||||
w.writeBool("CRND", true);
|
||||
}
|
||||
|
||||
template <class IDType>
|
||||
void SWSH<IDType>::_binarySize(typename BigDNA::BinarySize::StreamT& s) const {
|
||||
s += 4;
|
||||
if (x0_PSLT) {
|
||||
s += 4;
|
||||
x0_PSLT.binarySize(s);
|
||||
}
|
||||
if (x4_TIME) {
|
||||
s += 4;
|
||||
x4_TIME.binarySize(s);
|
||||
}
|
||||
if (x8_LRAD) {
|
||||
s += 4;
|
||||
x8_LRAD.binarySize(s);
|
||||
}
|
||||
if (xc_RRAD) {
|
||||
s += 4;
|
||||
xc_RRAD.binarySize(s);
|
||||
}
|
||||
if (x10_LENG) {
|
||||
s += 4;
|
||||
x10_LENG.binarySize(s);
|
||||
}
|
||||
if (x14_COLR) {
|
||||
s += 4;
|
||||
x14_COLR.binarySize(s);
|
||||
}
|
||||
if (x18_SIDE) {
|
||||
s += 4;
|
||||
x18_SIDE.binarySize(s);
|
||||
}
|
||||
if (x1c_IROT) {
|
||||
s += 4;
|
||||
x1c_IROT.binarySize(s);
|
||||
}
|
||||
if (x20_ROTM) {
|
||||
s += 4;
|
||||
x20_ROTM.binarySize(s);
|
||||
}
|
||||
if (x24_POFS) {
|
||||
s += 4;
|
||||
x24_POFS.binarySize(s);
|
||||
}
|
||||
if (x28_IVEL) {
|
||||
s += 4;
|
||||
x28_IVEL.binarySize(s);
|
||||
}
|
||||
if (x2c_NPOS) {
|
||||
s += 4;
|
||||
x2c_NPOS.binarySize(s);
|
||||
}
|
||||
if (x30_VELM) {
|
||||
s += 4;
|
||||
x30_VELM.binarySize(s);
|
||||
}
|
||||
if (x34_VLM2) {
|
||||
s += 4;
|
||||
x34_VLM2.binarySize(s);
|
||||
}
|
||||
if (x38_SPLN) {
|
||||
s += 4;
|
||||
x38_SPLN.binarySize(s);
|
||||
}
|
||||
if (x3c_TEXR) {
|
||||
s += 4;
|
||||
x3c_TEXR.binarySize(s);
|
||||
}
|
||||
if (x40_TSPN) {
|
||||
s += 4;
|
||||
x40_TSPN.binarySize(s);
|
||||
}
|
||||
if (x44_24_LLRD)
|
||||
s += 9;
|
||||
if (!x44_25_CROS)
|
||||
s += 9;
|
||||
if (x44_26_VLS1)
|
||||
s += 9;
|
||||
if (x44_27_VLS2)
|
||||
s += 9;
|
||||
if (x44_28_SROT)
|
||||
s += 9;
|
||||
if (x44_29_WIRE)
|
||||
s += 9;
|
||||
if (x44_30_TEXW)
|
||||
s += 9;
|
||||
if (x44_31_AALP)
|
||||
s += 9;
|
||||
if (x45_24_ZBUF)
|
||||
s += 9;
|
||||
if (x45_25_ORNT)
|
||||
s += 9;
|
||||
if (x45_26_CRND)
|
||||
s += 9;
|
||||
}
|
||||
|
||||
template <class IDType>
|
||||
void SWSH<IDType>::_read(typename BigDNA::Read::StreamT& r) {
|
||||
DNAFourCC clsId;
|
||||
clsId.read(r);
|
||||
if (clsId != SBIG('SWSH')) {
|
||||
LogModule.report(logvisor::Warning, fmt("non SWSH provided to SWSH parser"));
|
||||
return;
|
||||
}
|
||||
|
||||
clsId.read(r);
|
||||
while (clsId != SBIG('_END')) {
|
||||
switch (clsId.toUint32()) {
|
||||
case SBIG('PSLT'):
|
||||
x0_PSLT.read(r);
|
||||
break;
|
||||
case SBIG('TIME'):
|
||||
x4_TIME.read(r);
|
||||
break;
|
||||
case SBIG('LRAD'):
|
||||
x8_LRAD.read(r);
|
||||
break;
|
||||
case SBIG('RRAD'):
|
||||
xc_RRAD.read(r);
|
||||
break;
|
||||
case SBIG('LENG'):
|
||||
x10_LENG.read(r);
|
||||
break;
|
||||
case SBIG('COLR'):
|
||||
x14_COLR.read(r);
|
||||
break;
|
||||
case SBIG('SIDE'):
|
||||
x18_SIDE.read(r);
|
||||
break;
|
||||
case SBIG('IROT'):
|
||||
x1c_IROT.read(r);
|
||||
break;
|
||||
case SBIG('ROTM'):
|
||||
x20_ROTM.read(r);
|
||||
break;
|
||||
case SBIG('POFS'):
|
||||
x24_POFS.read(r);
|
||||
break;
|
||||
case SBIG('IVEL'):
|
||||
x28_IVEL.read(r);
|
||||
break;
|
||||
case SBIG('NPOS'):
|
||||
x2c_NPOS.read(r);
|
||||
break;
|
||||
case SBIG('VELM'):
|
||||
x30_VELM.read(r);
|
||||
break;
|
||||
case SBIG('VLM2'):
|
||||
x34_VLM2.read(r);
|
||||
break;
|
||||
case SBIG('SPLN'):
|
||||
x38_SPLN.read(r);
|
||||
break;
|
||||
case SBIG('TEXR'):
|
||||
x3c_TEXR.read(r);
|
||||
break;
|
||||
case SBIG('TSPN'):
|
||||
x40_TSPN.read(r);
|
||||
break;
|
||||
case SBIG('LLRD'):
|
||||
r.readUint32Big();
|
||||
x44_24_LLRD = r.readBool();
|
||||
break;
|
||||
case SBIG('CROS'):
|
||||
r.readUint32Big();
|
||||
x44_25_CROS = r.readBool();
|
||||
break;
|
||||
case SBIG('VLS1'):
|
||||
r.readUint32Big();
|
||||
x44_26_VLS1 = r.readBool();
|
||||
break;
|
||||
case SBIG('VLS2'):
|
||||
r.readUint32Big();
|
||||
x44_27_VLS2 = r.readBool();
|
||||
break;
|
||||
case SBIG('SROT'):
|
||||
r.readUint32Big();
|
||||
x44_28_SROT = r.readBool();
|
||||
break;
|
||||
case SBIG('WIRE'):
|
||||
r.readUint32Big();
|
||||
x44_29_WIRE = r.readBool();
|
||||
break;
|
||||
case SBIG('TEXW'):
|
||||
r.readUint32Big();
|
||||
x44_30_TEXW = r.readBool();
|
||||
break;
|
||||
case SBIG('AALP'):
|
||||
r.readUint32Big();
|
||||
x44_31_AALP = r.readBool();
|
||||
break;
|
||||
case SBIG('ZBUF'):
|
||||
r.readUint32Big();
|
||||
x45_24_ZBUF = r.readBool();
|
||||
break;
|
||||
case SBIG('ORNT'):
|
||||
r.readUint32Big();
|
||||
x45_25_ORNT = r.readBool();
|
||||
break;
|
||||
case SBIG('CRND'):
|
||||
r.readUint32Big();
|
||||
x45_26_CRND = r.readBool();
|
||||
break;
|
||||
default:
|
||||
LogModule.report(logvisor::Fatal, fmt("Unknown SWSH class {} @{}"), clsId, r.position());
|
||||
break;
|
||||
}
|
||||
clsId.read(r);
|
||||
}
|
||||
}
|
||||
|
||||
template <class IDType>
|
||||
void SWSH<IDType>::_write(typename BigDNA::Write::StreamT& w) const {
|
||||
w.writeBytes((atInt8*)"SWSH", 4);
|
||||
if (x0_PSLT) {
|
||||
w.writeBytes((atInt8*)"PSLT", 4);
|
||||
x0_PSLT.write(w);
|
||||
}
|
||||
if (x4_TIME) {
|
||||
w.writeBytes((atInt8*)"TIME", 4);
|
||||
x4_TIME.write(w);
|
||||
}
|
||||
if (x8_LRAD) {
|
||||
w.writeBytes((atInt8*)"LRAD", 4);
|
||||
x8_LRAD.write(w);
|
||||
}
|
||||
if (xc_RRAD) {
|
||||
w.writeBytes((atInt8*)"RRAD", 4);
|
||||
xc_RRAD.write(w);
|
||||
}
|
||||
if (x10_LENG) {
|
||||
w.writeBytes((atInt8*)"LENG", 4);
|
||||
x10_LENG.write(w);
|
||||
}
|
||||
if (x14_COLR) {
|
||||
w.writeBytes((atInt8*)"COLR", 4);
|
||||
x14_COLR.write(w);
|
||||
}
|
||||
if (x18_SIDE) {
|
||||
w.writeBytes((atInt8*)"SIDE", 4);
|
||||
x18_SIDE.write(w);
|
||||
}
|
||||
if (x1c_IROT) {
|
||||
w.writeBytes((atInt8*)"IROT", 4);
|
||||
x1c_IROT.write(w);
|
||||
}
|
||||
if (x20_ROTM) {
|
||||
w.writeBytes((atInt8*)"ROTM", 4);
|
||||
x20_ROTM.write(w);
|
||||
}
|
||||
if (x24_POFS) {
|
||||
w.writeBytes((atInt8*)"POFS", 4);
|
||||
x24_POFS.write(w);
|
||||
}
|
||||
if (x28_IVEL) {
|
||||
w.writeBytes((atInt8*)"IVEL", 4);
|
||||
x28_IVEL.write(w);
|
||||
}
|
||||
if (x2c_NPOS) {
|
||||
w.writeBytes((atInt8*)"NPOS", 4);
|
||||
x2c_NPOS.write(w);
|
||||
}
|
||||
if (x30_VELM) {
|
||||
w.writeBytes((atInt8*)"VELM", 4);
|
||||
x30_VELM.write(w);
|
||||
}
|
||||
if (x34_VLM2) {
|
||||
w.writeBytes((atInt8*)"VLM2", 4);
|
||||
x34_VLM2.write(w);
|
||||
}
|
||||
if (x38_SPLN) {
|
||||
w.writeBytes((atInt8*)"SPLN", 4);
|
||||
x38_SPLN.write(w);
|
||||
}
|
||||
if (x3c_TEXR) {
|
||||
w.writeBytes((atInt8*)"TEXR", 4);
|
||||
x3c_TEXR.write(w);
|
||||
}
|
||||
if (x40_TSPN) {
|
||||
w.writeBytes((atInt8*)"TSPN", 4);
|
||||
x40_TSPN.write(w);
|
||||
}
|
||||
|
||||
if (x44_24_LLRD)
|
||||
w.writeBytes("LLRDCNST\x01", 9);
|
||||
if (!x44_25_CROS)
|
||||
w.writeBytes("CROSCNST\x00", 9);
|
||||
if (x44_26_VLS1)
|
||||
w.writeBytes("VLS1CNST\x01", 9);
|
||||
if (x44_27_VLS2)
|
||||
w.writeBytes("VLS2CNST\x01", 9);
|
||||
if (x44_28_SROT)
|
||||
w.writeBytes("SROTCNST\x01", 9);
|
||||
if (x44_29_WIRE)
|
||||
w.writeBytes("WIRECNST\x01", 9);
|
||||
if (x44_30_TEXW)
|
||||
w.writeBytes("TEXWCNST\x01", 9);
|
||||
if (x44_31_AALP)
|
||||
w.writeBytes("AALPCNST\x01", 9);
|
||||
if (x45_24_ZBUF)
|
||||
w.writeBytes("ZBUFCNST\x01", 9);
|
||||
if (x45_25_ORNT)
|
||||
w.writeBytes("ORNTCNST\x01", 9);
|
||||
if (x45_26_CRND)
|
||||
w.writeBytes("CRNDCNST\x01", 9);
|
||||
w.writeBytes("_END", 4);
|
||||
}
|
||||
|
||||
AT_SUBSPECIALIZE_DNA_YAML(SWSH<UniqueID32>)
|
||||
AT_SUBSPECIALIZE_DNA_YAML(SWSH<UniqueID64>)
|
||||
|
||||
template <class IDType>
|
||||
void SWSH<IDType>::gatherDependencies(std::vector<hecl::ProjectPath>& pathsOut) const {
|
||||
if (x3c_TEXR.m_elem)
|
||||
x3c_TEXR.m_elem->gatherDependencies(pathsOut);
|
||||
}
|
||||
|
||||
template struct SWSH<UniqueID32>;
|
||||
template struct SWSH<UniqueID64>;
|
||||
|
||||
template <class IDType>
|
||||
bool ExtractSWSH(PAKEntryReadStream& rs, const hecl::ProjectPath& outPath) {
|
||||
athena::io::FileWriter writer(outPath.getAbsolutePath());
|
||||
|
|
|
@ -0,0 +1,69 @@
|
|||
#ifndef ENTRY
|
||||
#define ENTRY(name, identifier)
|
||||
#endif
|
||||
|
||||
#ifndef INT_ENTRY
|
||||
#define INT_ENTRY(name, identifier) ENTRY(name, identifier)
|
||||
#endif
|
||||
|
||||
#ifndef REAL_ENTRY
|
||||
#define REAL_ENTRY(name, identifier) ENTRY(name, identifier)
|
||||
#endif
|
||||
|
||||
#ifndef VECTOR_ENTRY
|
||||
#define VECTOR_ENTRY(name, identifier) ENTRY(name, identifier)
|
||||
#endif
|
||||
|
||||
#ifndef MOD_VECTOR_ENTRY
|
||||
#define MOD_VECTOR_ENTRY(name, identifier) ENTRY(name, identifier)
|
||||
#endif
|
||||
|
||||
#ifndef COLOR_ENTRY
|
||||
#define COLOR_ENTRY(name, identifier) ENTRY(name, identifier)
|
||||
#endif
|
||||
|
||||
#ifndef UV_ENTRY
|
||||
#define UV_ENTRY(name, identifier) ENTRY(name, identifier)
|
||||
#endif
|
||||
|
||||
#ifndef BOOL_ENTRY
|
||||
#define BOOL_ENTRY(name, identifier, def) ENTRY(name, identifier)
|
||||
#endif
|
||||
|
||||
INT_ENTRY('PSLT', x0_PSLT)
|
||||
REAL_ENTRY('TIME', x4_TIME)
|
||||
REAL_ENTRY('LRAD', x8_LRAD)
|
||||
REAL_ENTRY('RRAD', xc_RRAD)
|
||||
INT_ENTRY('LENG', x10_LENG)
|
||||
COLOR_ENTRY('COLR', x14_COLR)
|
||||
INT_ENTRY('SIDE', x18_SIDE)
|
||||
REAL_ENTRY('IROT', x1c_IROT)
|
||||
REAL_ENTRY('ROTM', x20_ROTM)
|
||||
VECTOR_ENTRY('POFS', x24_POFS)
|
||||
VECTOR_ENTRY('IVEL', x28_IVEL)
|
||||
VECTOR_ENTRY('NPOS', x2c_NPOS)
|
||||
MOD_VECTOR_ENTRY('VELM', x30_VELM)
|
||||
MOD_VECTOR_ENTRY('VLM2', x34_VLM2)
|
||||
INT_ENTRY('SPLN', x38_SPLN)
|
||||
UV_ENTRY('TEXR', x3c_TEXR)
|
||||
INT_ENTRY('TSPN', x40_TSPN)
|
||||
BOOL_ENTRY('LLRD', x44_24_LLRD, false)
|
||||
BOOL_ENTRY('CROS', x44_25_CROS, true)
|
||||
BOOL_ENTRY('VLS1', x44_26_VLS1, false)
|
||||
BOOL_ENTRY('VLS2', x44_27_VLS2, false)
|
||||
BOOL_ENTRY('SROT', x44_28_SROT, false)
|
||||
BOOL_ENTRY('WIRE', x44_29_WIRE, false)
|
||||
BOOL_ENTRY('TEXW', x44_30_TEXW, false)
|
||||
BOOL_ENTRY('AALP', x44_31_AALP, false)
|
||||
BOOL_ENTRY('ZBUF', x45_24_ZBUF, false)
|
||||
BOOL_ENTRY('ORNT', x45_25_ORNT, false)
|
||||
BOOL_ENTRY('CRND', x45_26_CRND, false)
|
||||
|
||||
#undef ENTRY
|
||||
#undef INT_ENTRY
|
||||
#undef REAL_ENTRY
|
||||
#undef VECTOR_ENTRY
|
||||
#undef MOD_VECTOR_ENTRY
|
||||
#undef COLOR_ENTRY
|
||||
#undef UV_ENTRY
|
||||
#undef BOOL_ENTRY
|
|
@ -16,48 +16,36 @@ class ProjectPath;
|
|||
namespace DataSpec::DNAParticle {
|
||||
|
||||
template <class IDType>
|
||||
struct SWSH : public BigDNA {
|
||||
AT_DECL_EXPLICIT_DNA_YAML
|
||||
AT_SUBDECL_DNA
|
||||
struct _SWSH {
|
||||
static constexpr ParticleType Type = ParticleType::SWSH;
|
||||
|
||||
IntElementFactory x0_PSLT;
|
||||
RealElementFactory x4_TIME;
|
||||
RealElementFactory x8_LRAD;
|
||||
RealElementFactory xc_RRAD;
|
||||
IntElementFactory x10_LENG;
|
||||
ColorElementFactory x14_COLR;
|
||||
IntElementFactory x18_SIDE;
|
||||
RealElementFactory x1c_IROT;
|
||||
RealElementFactory x20_ROTM;
|
||||
VectorElementFactory x24_POFS;
|
||||
VectorElementFactory x28_IVEL;
|
||||
VectorElementFactory x2c_NPOS;
|
||||
ModVectorElementFactory x30_VELM;
|
||||
ModVectorElementFactory x34_VLM2;
|
||||
IntElementFactory x38_SPLN;
|
||||
UVElementFactory<IDType> x3c_TEXR;
|
||||
IntElementFactory x40_TSPN;
|
||||
union {
|
||||
struct {
|
||||
bool x44_24_LLRD : 1;
|
||||
bool x44_25_CROS : 1;
|
||||
bool x44_26_VLS1 : 1;
|
||||
bool x44_27_VLS2 : 1;
|
||||
bool x44_28_SROT : 1;
|
||||
bool x44_29_WIRE : 1;
|
||||
bool x44_30_TEXW : 1;
|
||||
bool x44_31_AALP : 1;
|
||||
bool x45_24_ZBUF : 1;
|
||||
bool x45_25_ORNT : 1;
|
||||
bool x45_26_CRND : 1;
|
||||
};
|
||||
uint16_t dummy = 0;
|
||||
};
|
||||
#define INT_ENTRY(name, identifier) IntElementFactory identifier;
|
||||
#define REAL_ENTRY(name, identifier) RealElementFactory identifier;
|
||||
#define VECTOR_ENTRY(name, identifier) VectorElementFactory identifier;
|
||||
#define MOD_VECTOR_ENTRY(name, identifier) ModVectorElementFactory identifier;
|
||||
#define COLOR_ENTRY(name, identifier) ColorElementFactory identifier;
|
||||
#define UV_ENTRY(name, identifier) UVElementFactory<IDType> identifier;
|
||||
#define BOOL_ENTRY(name, identifier, def) bool identifier = def;
|
||||
#include "SWHC.def"
|
||||
|
||||
SWSH() { x44_25_CROS = true; }
|
||||
template<typename _Func>
|
||||
void constexpr Enumerate(_Func f) {
|
||||
#define ENTRY(name, identifier) f(FOURCC(name), identifier);
|
||||
#define BOOL_ENTRY(name, identifier, def) f(FOURCC(name), identifier, def);
|
||||
#include "SWHC.def"
|
||||
}
|
||||
|
||||
void gatherDependencies(std::vector<hecl::ProjectPath>&) const;
|
||||
template<typename _Func>
|
||||
bool constexpr Lookup(FourCC fcc, _Func f) {
|
||||
switch (fcc.toUint32()) {
|
||||
#define ENTRY(name, identifier) case SBIG(name): f(identifier); return true;
|
||||
#include "SWHC.def"
|
||||
default: return false;
|
||||
}
|
||||
}
|
||||
};
|
||||
template <class IDType>
|
||||
using SWSH = PPImpl<_SWSH<IDType>>;
|
||||
|
||||
template <class IDType>
|
||||
bool ExtractSWSH(PAKEntryReadStream& rs, const hecl::ProjectPath& outPath);
|
||||
|
|
|
@ -1,645 +1,13 @@
|
|||
#include "DataSpec/DNACommon/WPSC.hpp"
|
||||
|
||||
#include "DataSpec/DNACommon/PAK.hpp"
|
||||
|
||||
#include <logvisor/logvisor.hpp>
|
||||
|
||||
namespace DataSpec::DNAParticle {
|
||||
|
||||
template <class IDType>
|
||||
void WPSM<IDType>::_read(athena::io::YAMLDocReader& r) {
|
||||
for (const auto& elem : r.getCurNode()->m_mapChildren) {
|
||||
if (elem.first.size() < 4) {
|
||||
LogModule.report(logvisor::Warning, fmt("short FourCC in element '{}'"), elem.first);
|
||||
continue;
|
||||
}
|
||||
template struct PPImpl<_WPSM<UniqueID32>>;
|
||||
template struct PPImpl<_WPSM<UniqueID64>>;
|
||||
|
||||
if (auto rec = r.enterSubRecord(elem.first.c_str())) {
|
||||
switch (*reinterpret_cast<const uint32_t*>(elem.first.data())) {
|
||||
case SBIG('IORN'):
|
||||
x0_IORN.read(r);
|
||||
break;
|
||||
case SBIG('IVEC'):
|
||||
x4_IVEC.read(r);
|
||||
break;
|
||||
case SBIG('PSOV'):
|
||||
x8_PSOV.read(r);
|
||||
break;
|
||||
case SBIG('PSVM'):
|
||||
xc_PSVM.read(r);
|
||||
break;
|
||||
case SBIG('VMD2'):
|
||||
x10_VMD2.read(r);
|
||||
break;
|
||||
case SBIG('PSLT'):
|
||||
x14_PSLT.read(r);
|
||||
break;
|
||||
case SBIG('PSCL'):
|
||||
x18_PSCL.read(r);
|
||||
break;
|
||||
case SBIG('PCOL'):
|
||||
x1c_PCOL.read(r);
|
||||
break;
|
||||
case SBIG('POFS'):
|
||||
x20_POFS.read(r);
|
||||
break;
|
||||
case SBIG('OFST'):
|
||||
x24_OFST.read(r);
|
||||
break;
|
||||
case SBIG('APSO'):
|
||||
x28_APSO.read(r);
|
||||
break;
|
||||
case SBIG('HOMG'):
|
||||
x29_HOMG.read(r);
|
||||
break;
|
||||
case SBIG('AP11'):
|
||||
x2a_AP11.read(r);
|
||||
break;
|
||||
case SBIG('AP21'):
|
||||
x2b_AP21.read(r);
|
||||
break;
|
||||
case SBIG('AS11'):
|
||||
x2c_AS11.read(r);
|
||||
break;
|
||||
case SBIG('AS12'):
|
||||
x2d_AS12.read(r);
|
||||
break;
|
||||
case SBIG('AS13'):
|
||||
x2e_AS13.read(r);
|
||||
break;
|
||||
case SBIG('TRAT'):
|
||||
x30_TRAT.read(r);
|
||||
break;
|
||||
case SBIG('APSM'):
|
||||
x34_APSM.read(r);
|
||||
break;
|
||||
case SBIG('APS2'):
|
||||
x44_APS2.read(r);
|
||||
break;
|
||||
case SBIG('ASW1'):
|
||||
x54_ASW1.read(r);
|
||||
break;
|
||||
case SBIG('ASW2'):
|
||||
x64_ASW2.read(r);
|
||||
break;
|
||||
case SBIG('ASW3'):
|
||||
x74_ASW3.read(r);
|
||||
break;
|
||||
case SBIG('OHEF'):
|
||||
x84_OHEF.read(r);
|
||||
break;
|
||||
case SBIG('COLR'):
|
||||
x94_COLR.read(r);
|
||||
break;
|
||||
case SBIG('EWTR'):
|
||||
xa4_EWTR.read(r);
|
||||
break;
|
||||
case SBIG('LWTR'):
|
||||
xa5_LWTR.read(r);
|
||||
break;
|
||||
case SBIG('SWTR'):
|
||||
xa6_SWTR.read(r);
|
||||
break;
|
||||
case SBIG('PJFX'):
|
||||
xa8_PJFX = r.readUint32();
|
||||
break;
|
||||
case SBIG('RNGE'):
|
||||
xac_RNGE.read(r);
|
||||
break;
|
||||
case SBIG('FOFF'):
|
||||
xb0_FOFF.read(r);
|
||||
break;
|
||||
case SBIG('FC60'):
|
||||
xunk_FC60.read(r);
|
||||
break;
|
||||
case SBIG('SPS1'):
|
||||
xunk_SPS1.read(r);
|
||||
break;
|
||||
case SBIG('SPS2'):
|
||||
xunk_SPS2.read(r);
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
template <class IDType>
|
||||
void WPSM<IDType>::_write(athena::io::YAMLDocWriter& w) const {
|
||||
if (x0_IORN)
|
||||
if (auto rec = w.enterSubRecord("IORN"))
|
||||
x0_IORN.write(w);
|
||||
if (x4_IVEC)
|
||||
if (auto rec = w.enterSubRecord("IVEC"))
|
||||
x4_IVEC.write(w);
|
||||
if (x8_PSOV)
|
||||
if (auto rec = w.enterSubRecord("PSOV"))
|
||||
x8_PSOV.write(w);
|
||||
if (xc_PSVM)
|
||||
if (auto rec = w.enterSubRecord("PSVM"))
|
||||
xc_PSVM.write(w);
|
||||
if (x10_VMD2)
|
||||
if (auto rec = w.enterSubRecord("VMD2"))
|
||||
x10_VMD2.write(w);
|
||||
if (x14_PSLT)
|
||||
if (auto rec = w.enterSubRecord("PSLT"))
|
||||
x14_PSLT.write(w);
|
||||
if (x18_PSCL)
|
||||
if (auto rec = w.enterSubRecord("PSCL"))
|
||||
x18_PSCL.write(w);
|
||||
if (x1c_PCOL)
|
||||
if (auto rec = w.enterSubRecord("PCOL"))
|
||||
x1c_PCOL.write(w);
|
||||
if (x20_POFS)
|
||||
if (auto rec = w.enterSubRecord("POFS"))
|
||||
x20_POFS.write(w);
|
||||
if (x24_OFST)
|
||||
if (auto rec = w.enterSubRecord("OFST"))
|
||||
x24_OFST.write(w);
|
||||
if (x28_APSO)
|
||||
if (auto rec = w.enterSubRecord("APSO"))
|
||||
x28_APSO.write(w);
|
||||
if (x29_HOMG)
|
||||
if (auto rec = w.enterSubRecord("HOMG"))
|
||||
x29_HOMG.write(w);
|
||||
if (x2a_AP11)
|
||||
if (auto rec = w.enterSubRecord("AP11"))
|
||||
x2a_AP11.write(w);
|
||||
if (x2b_AP21)
|
||||
if (auto rec = w.enterSubRecord("AP21"))
|
||||
x2b_AP21.write(w);
|
||||
if (x2c_AS11)
|
||||
if (auto rec = w.enterSubRecord("AS11"))
|
||||
x2c_AS11.write(w);
|
||||
if (x2d_AS12)
|
||||
if (auto rec = w.enterSubRecord("AS12"))
|
||||
x2d_AS12.write(w);
|
||||
if (x2e_AS13)
|
||||
if (auto rec = w.enterSubRecord("AS13"))
|
||||
x2e_AS13.write(w);
|
||||
if (x30_TRAT)
|
||||
if (auto rec = w.enterSubRecord("TRAT"))
|
||||
x30_TRAT.write(w);
|
||||
if (x34_APSM)
|
||||
if (auto rec = w.enterSubRecord("APSM"))
|
||||
x34_APSM.write(w);
|
||||
if (x44_APS2)
|
||||
if (auto rec = w.enterSubRecord("APS2"))
|
||||
x44_APS2.write(w);
|
||||
if (x54_ASW1)
|
||||
if (auto rec = w.enterSubRecord("ASW1"))
|
||||
x54_ASW1.write(w);
|
||||
if (x64_ASW2)
|
||||
if (auto rec = w.enterSubRecord("ASW2"))
|
||||
x64_ASW2.write(w);
|
||||
if (x74_ASW3)
|
||||
if (auto rec = w.enterSubRecord("ASW3"))
|
||||
x74_ASW3.write(w);
|
||||
if (x84_OHEF)
|
||||
if (auto rec = w.enterSubRecord("OHEF"))
|
||||
x84_OHEF.write(w);
|
||||
if (x94_COLR)
|
||||
if (auto rec = w.enterSubRecord("COLR"))
|
||||
x94_COLR.write(w);
|
||||
if (!xa4_EWTR)
|
||||
if (auto rec = w.enterSubRecord("EWTR"))
|
||||
xa4_EWTR.write(w);
|
||||
if (!xa5_LWTR)
|
||||
if (auto rec = w.enterSubRecord("LWTR"))
|
||||
xa5_LWTR.write(w);
|
||||
if (!xa6_SWTR)
|
||||
if (auto rec = w.enterSubRecord("SWTR"))
|
||||
xa6_SWTR.write(w);
|
||||
if (xa8_PJFX != UINT32_MAX)
|
||||
w.writeUint32("PJFX", xa8_PJFX);
|
||||
if (xac_RNGE)
|
||||
if (auto rec = w.enterSubRecord("RNGE"))
|
||||
xac_RNGE.write(w);
|
||||
if (xb0_FOFF)
|
||||
if (auto rec = w.enterSubRecord("FOFF"))
|
||||
xb0_FOFF.write(w);
|
||||
if (xunk_FC60)
|
||||
if (auto rec = w.enterSubRecord("FC60"))
|
||||
xunk_FC60.write(w);
|
||||
if (xunk_SPS1)
|
||||
if (auto rec = w.enterSubRecord("SPS1"))
|
||||
xunk_SPS1.write(w);
|
||||
if (xunk_SPS1)
|
||||
if (auto rec = w.enterSubRecord("SPS2"))
|
||||
xunk_SPS2.write(w);
|
||||
}
|
||||
|
||||
template <class IDType>
|
||||
void WPSM<IDType>::_binarySize(size_t& __isz) const {
|
||||
__isz += 4;
|
||||
if (x0_IORN) {
|
||||
__isz += 4;
|
||||
x0_IORN.binarySize(__isz);
|
||||
}
|
||||
if (x4_IVEC) {
|
||||
__isz += 4;
|
||||
x4_IVEC.binarySize(__isz);
|
||||
}
|
||||
if (x8_PSOV) {
|
||||
__isz += 4;
|
||||
x8_PSOV.binarySize(__isz);
|
||||
}
|
||||
if (xc_PSVM) {
|
||||
__isz += 4;
|
||||
xc_PSVM.binarySize(__isz);
|
||||
}
|
||||
if (x10_VMD2) {
|
||||
__isz += 4;
|
||||
x10_VMD2.binarySize(__isz);
|
||||
}
|
||||
if (x14_PSLT) {
|
||||
__isz += 4;
|
||||
x14_PSLT.binarySize(__isz);
|
||||
}
|
||||
if (x18_PSCL) {
|
||||
__isz += 4;
|
||||
x18_PSCL.binarySize(__isz);
|
||||
}
|
||||
if (x1c_PCOL) {
|
||||
__isz += 4;
|
||||
x1c_PCOL.binarySize(__isz);
|
||||
}
|
||||
if (x20_POFS) {
|
||||
__isz += 4;
|
||||
x20_POFS.binarySize(__isz);
|
||||
}
|
||||
if (x24_OFST) {
|
||||
__isz += 4;
|
||||
x24_OFST.binarySize(__isz);
|
||||
}
|
||||
if (x28_APSO) {
|
||||
__isz += 4;
|
||||
x28_APSO.binarySize(__isz);
|
||||
}
|
||||
if (x29_HOMG) {
|
||||
__isz += 4;
|
||||
x29_HOMG.binarySize(__isz);
|
||||
}
|
||||
if (x2a_AP11) {
|
||||
__isz += 4;
|
||||
x2a_AP11.binarySize(__isz);
|
||||
}
|
||||
if (x2b_AP21) {
|
||||
__isz += 4;
|
||||
x2b_AP21.binarySize(__isz);
|
||||
}
|
||||
if (x2c_AS11) {
|
||||
__isz += 4;
|
||||
x2c_AS11.binarySize(__isz);
|
||||
}
|
||||
if (x2d_AS12) {
|
||||
__isz += 4;
|
||||
x2d_AS12.binarySize(__isz);
|
||||
}
|
||||
if (x2e_AS13) {
|
||||
__isz += 4;
|
||||
x2e_AS13.binarySize(__isz);
|
||||
}
|
||||
if (x30_TRAT) {
|
||||
__isz += 4;
|
||||
x30_TRAT.binarySize(__isz);
|
||||
}
|
||||
if (x34_APSM) {
|
||||
__isz += 4;
|
||||
x34_APSM.binarySize(__isz);
|
||||
}
|
||||
if (x44_APS2) {
|
||||
__isz += 4;
|
||||
x44_APS2.binarySize(__isz);
|
||||
}
|
||||
if (x54_ASW1) {
|
||||
__isz += 4;
|
||||
x54_ASW1.binarySize(__isz);
|
||||
}
|
||||
if (x64_ASW2) {
|
||||
__isz += 4;
|
||||
x64_ASW2.binarySize(__isz);
|
||||
}
|
||||
if (x74_ASW3) {
|
||||
__isz += 4;
|
||||
x74_ASW3.binarySize(__isz);
|
||||
}
|
||||
if (x84_OHEF) {
|
||||
__isz += 4;
|
||||
x84_OHEF.binarySize(__isz);
|
||||
}
|
||||
if (x94_COLR) {
|
||||
__isz += 4;
|
||||
x94_COLR.binarySize(__isz);
|
||||
}
|
||||
if (!xa4_EWTR) {
|
||||
__isz += 4;
|
||||
xa4_EWTR.binarySize(__isz);
|
||||
}
|
||||
if (!xa5_LWTR) {
|
||||
__isz += 4;
|
||||
xa5_LWTR.binarySize(__isz);
|
||||
}
|
||||
if (!xa6_SWTR) {
|
||||
__isz += 4;
|
||||
xa6_SWTR.binarySize(__isz);
|
||||
}
|
||||
if (xa8_PJFX != UINT32_MAX)
|
||||
__isz += 12;
|
||||
if (xac_RNGE) {
|
||||
__isz += 4;
|
||||
xac_RNGE.binarySize(__isz);
|
||||
}
|
||||
if (xb0_FOFF) {
|
||||
__isz += 4;
|
||||
xb0_FOFF.binarySize(__isz);
|
||||
}
|
||||
if (xunk_FC60) {
|
||||
__isz += 4;
|
||||
xunk_FC60.binarySize(__isz);
|
||||
}
|
||||
if (xunk_SPS1) {
|
||||
__isz += 4;
|
||||
xunk_SPS1.binarySize(__isz);
|
||||
}
|
||||
if (xunk_SPS2) {
|
||||
__isz += 4;
|
||||
xunk_SPS2.binarySize(__isz);
|
||||
}
|
||||
}
|
||||
|
||||
template <class IDType>
|
||||
void WPSM<IDType>::_read(athena::io::IStreamReader& r) {
|
||||
DNAFourCC clsId;
|
||||
clsId.read(r);
|
||||
if (clsId != SBIG('WPSM')) {
|
||||
LogModule.report(logvisor::Warning, fmt("non WPSM provided to WPSM parser"));
|
||||
return;
|
||||
}
|
||||
clsId.read(r);
|
||||
while (clsId != SBIG('_END')) {
|
||||
switch (clsId.toUint32()) {
|
||||
case SBIG('IORN'):
|
||||
x0_IORN.read(r);
|
||||
break;
|
||||
case SBIG('IVEC'):
|
||||
x4_IVEC.read(r);
|
||||
break;
|
||||
case SBIG('PSOV'):
|
||||
x8_PSOV.read(r);
|
||||
break;
|
||||
case SBIG('PSVM'):
|
||||
xc_PSVM.read(r);
|
||||
break;
|
||||
case SBIG('VMD2'):
|
||||
x10_VMD2.read(r);
|
||||
break;
|
||||
case SBIG('PSLT'):
|
||||
x14_PSLT.read(r);
|
||||
break;
|
||||
case SBIG('PSCL'):
|
||||
x18_PSCL.read(r);
|
||||
break;
|
||||
case SBIG('PCOL'):
|
||||
x1c_PCOL.read(r);
|
||||
break;
|
||||
case SBIG('POFS'):
|
||||
x20_POFS.read(r);
|
||||
break;
|
||||
case SBIG('OFST'):
|
||||
x24_OFST.read(r);
|
||||
break;
|
||||
case SBIG('APSO'):
|
||||
r.readUint32();
|
||||
x28_APSO = r.readBool();
|
||||
break;
|
||||
case SBIG('HOMG'):
|
||||
x29_HOMG.read(r);
|
||||
break;
|
||||
case SBIG('AP11'):
|
||||
x2a_AP11.read(r);
|
||||
break;
|
||||
case SBIG('AP21'):
|
||||
x2b_AP21.read(r);
|
||||
break;
|
||||
case SBIG('AS11'):
|
||||
x2c_AS11.read(r);
|
||||
break;
|
||||
case SBIG('AS12'):
|
||||
x2d_AS12.read(r);
|
||||
break;
|
||||
case SBIG('AS13'):
|
||||
x2e_AS13.read(r);
|
||||
break;
|
||||
case SBIG('TRAT'):
|
||||
x30_TRAT.read(r);
|
||||
break;
|
||||
case SBIG('APSM'):
|
||||
x34_APSM.read(r);
|
||||
break;
|
||||
case SBIG('APS2'):
|
||||
x44_APS2.read(r);
|
||||
break;
|
||||
case SBIG('ASW1'):
|
||||
x54_ASW1.read(r);
|
||||
break;
|
||||
case SBIG('ASW2'):
|
||||
x64_ASW2.read(r);
|
||||
break;
|
||||
case SBIG('ASW3'):
|
||||
x74_ASW3.read(r);
|
||||
break;
|
||||
case SBIG('OHEF'):
|
||||
x84_OHEF.read(r);
|
||||
break;
|
||||
case SBIG('COLR'):
|
||||
x94_COLR.read(r);
|
||||
break;
|
||||
case SBIG('EWTR'):
|
||||
r.readUint32();
|
||||
xa4_EWTR = r.readBool();
|
||||
break;
|
||||
case SBIG('LWTR'):
|
||||
r.readUint32();
|
||||
xa5_LWTR = r.readBool();
|
||||
break;
|
||||
case SBIG('SWTR'):
|
||||
r.readUint32();
|
||||
xa6_SWTR = r.readBool();
|
||||
break;
|
||||
case SBIG('PJFX'): {
|
||||
uint32_t fcc;
|
||||
r.readBytesToBuf(&fcc, 4);
|
||||
if (fcc != SBIG('NONE'))
|
||||
xa8_PJFX = r.readUint32Big();
|
||||
} break;
|
||||
case SBIG('RNGE'):
|
||||
xac_RNGE.read(r);
|
||||
break;
|
||||
case SBIG('FOFF'):
|
||||
xb0_FOFF.read(r);
|
||||
break;
|
||||
case SBIG('FC60'):
|
||||
xunk_FC60.read(r);
|
||||
break;
|
||||
case SBIG('SPS1'):
|
||||
xunk_SPS1.read(r);
|
||||
break;
|
||||
case SBIG('SPS2'):
|
||||
xunk_SPS2.read(r);
|
||||
break;
|
||||
default:
|
||||
LogModule.report(logvisor::Fatal, fmt("Unknown WPSM class {} @{}"), clsId, r.position());
|
||||
break;
|
||||
}
|
||||
clsId.read(r);
|
||||
}
|
||||
}
|
||||
|
||||
template <class IDType>
|
||||
void WPSM<IDType>::_write(athena::io::IStreamWriter& w) const {
|
||||
w.writeBytes("WPSM", 4);
|
||||
if (x0_IORN) {
|
||||
w.writeBytes("IORN", 4);
|
||||
x0_IORN.write(w);
|
||||
}
|
||||
if (x4_IVEC) {
|
||||
w.writeBytes("IVEC", 4);
|
||||
x4_IVEC.write(w);
|
||||
}
|
||||
if (x8_PSOV) {
|
||||
w.writeBytes("PSOV", 4);
|
||||
x8_PSOV.write(w);
|
||||
}
|
||||
if (xc_PSVM) {
|
||||
w.writeBytes("PSVM", 4);
|
||||
xc_PSVM.write(w);
|
||||
}
|
||||
if (x10_VMD2) {
|
||||
w.writeBytes("VMD2", 4);
|
||||
x10_VMD2.write(w);
|
||||
}
|
||||
if (x14_PSLT) {
|
||||
w.writeBytes("PSLT", 4);
|
||||
x14_PSLT.write(w);
|
||||
}
|
||||
if (x18_PSCL) {
|
||||
w.writeBytes("PSCL", 4);
|
||||
x18_PSCL.write(w);
|
||||
}
|
||||
if (x1c_PCOL) {
|
||||
w.writeBytes("PCOL", 4);
|
||||
x1c_PCOL.write(w);
|
||||
}
|
||||
if (x20_POFS) {
|
||||
w.writeBytes("POFS", 4);
|
||||
x20_POFS.write(w);
|
||||
}
|
||||
if (x24_OFST) {
|
||||
w.writeBytes("OFST", 4);
|
||||
x24_OFST.write(w);
|
||||
}
|
||||
if (x28_APSO) {
|
||||
w.writeBytes("APSO", 4);
|
||||
x28_APSO.write(w);
|
||||
}
|
||||
if (x29_HOMG) {
|
||||
w.writeBytes("HOMG", 4);
|
||||
x29_HOMG.write(w);
|
||||
}
|
||||
if (x2a_AP11) {
|
||||
w.writeBytes("AP11", 4);
|
||||
x2a_AP11.write(w);
|
||||
}
|
||||
if (x2b_AP21) {
|
||||
w.writeBytes("AP21", 4);
|
||||
x2b_AP21.write(w);
|
||||
}
|
||||
if (x2c_AS11) {
|
||||
w.writeBytes("AS11", 4);
|
||||
x2c_AS11.write(w);
|
||||
}
|
||||
if (x2d_AS12) {
|
||||
w.writeBytes("AS12", 4);
|
||||
x2d_AS12.write(w);
|
||||
}
|
||||
if (x2e_AS13) {
|
||||
w.writeBytes("AS13", 4);
|
||||
x2e_AS13.write(w);
|
||||
}
|
||||
if (x30_TRAT) {
|
||||
w.writeBytes("TRAT", 4);
|
||||
x30_TRAT.write(w);
|
||||
}
|
||||
if (x34_APSM) {
|
||||
w.writeBytes("APSM", 4);
|
||||
x34_APSM.write(w);
|
||||
}
|
||||
if (x44_APS2) {
|
||||
w.writeBytes("APS2", 4);
|
||||
x44_APS2.write(w);
|
||||
}
|
||||
if (x54_ASW1) {
|
||||
w.writeBytes("ASW1", 4);
|
||||
x54_ASW1.write(w);
|
||||
}
|
||||
if (x64_ASW2) {
|
||||
w.writeBytes("ASW2", 4);
|
||||
x64_ASW2.write(w);
|
||||
}
|
||||
if (x74_ASW3) {
|
||||
w.writeBytes("ASW3", 4);
|
||||
x74_ASW3.write(w);
|
||||
}
|
||||
if (x84_OHEF) {
|
||||
w.writeBytes("OHEF", 4);
|
||||
x84_OHEF.write(w);
|
||||
}
|
||||
if (x94_COLR) {
|
||||
w.writeBytes("COLR", 4);
|
||||
x94_COLR.write(w);
|
||||
}
|
||||
if (!xa4_EWTR) {
|
||||
w.writeBytes("EWTR", 4);
|
||||
xa4_EWTR.write(w);
|
||||
}
|
||||
if (!xa5_LWTR) {
|
||||
w.writeBytes("LWTR", 4);
|
||||
xa5_LWTR.write(w);
|
||||
}
|
||||
if (!xa6_SWTR) {
|
||||
w.writeBytes("SWTR", 4);
|
||||
xa6_SWTR.write(w);
|
||||
}
|
||||
if (xa8_PJFX != UINT32_MAX) {
|
||||
w.writeBytes("PJFXCNST", 8);
|
||||
w.writeUint32(xa8_PJFX);
|
||||
}
|
||||
if (xac_RNGE) {
|
||||
w.writeBytes("RNGE", 4);
|
||||
xac_RNGE.write(w);
|
||||
}
|
||||
if (xb0_FOFF) {
|
||||
w.writeBytes("FOFF", 4);
|
||||
xb0_FOFF.write(w);
|
||||
}
|
||||
if (xunk_FC60) {
|
||||
w.writeBytes("FC60", 4);
|
||||
xunk_FC60.write(w);
|
||||
}
|
||||
if (xunk_SPS1) {
|
||||
w.writeBytes("SPS1", 4);
|
||||
xunk_SPS1.write(w);
|
||||
}
|
||||
if (xunk_SPS2) {
|
||||
w.writeBytes("SPS2", 4);
|
||||
xunk_SPS2.write(w);
|
||||
}
|
||||
|
||||
w.writeBytes("_END", 4);
|
||||
}
|
||||
|
||||
AT_SUBSPECIALIZE_DNA_YAML(WPSM<UniqueID32>)
|
||||
AT_SUBSPECIALIZE_DNA_YAML(WPSM<UniqueID64>)
|
||||
AT_SUBSPECIALIZE_DNA_YAML(PPImpl<_WPSM<UniqueID32>>)
|
||||
AT_SUBSPECIALIZE_DNA_YAML(PPImpl<_WPSM<UniqueID64>>)
|
||||
|
||||
template <>
|
||||
std::string_view WPSM<UniqueID32>::DNAType() {
|
||||
|
@ -651,20 +19,6 @@ std::string_view WPSM<UniqueID64>::DNAType() {
|
|||
return "WPSM<UniqueID64>"sv;
|
||||
}
|
||||
|
||||
template <class IDType>
|
||||
void WPSM<IDType>::gatherDependencies(std::vector<hecl::ProjectPath>& pathsOut) const {
|
||||
g_curSpec->flattenDependencies(x34_APSM.id, pathsOut);
|
||||
g_curSpec->flattenDependencies(x44_APS2.id, pathsOut);
|
||||
g_curSpec->flattenDependencies(x54_ASW1.id, pathsOut);
|
||||
g_curSpec->flattenDependencies(x64_ASW2.id, pathsOut);
|
||||
g_curSpec->flattenDependencies(x74_ASW3.id, pathsOut);
|
||||
g_curSpec->flattenDependencies(x84_OHEF.id, pathsOut);
|
||||
g_curSpec->flattenDependencies(x94_COLR.id, pathsOut);
|
||||
}
|
||||
|
||||
template struct WPSM<UniqueID32>;
|
||||
template struct WPSM<UniqueID64>;
|
||||
|
||||
template <class IDType>
|
||||
bool ExtractWPSM(PAKEntryReadStream& rs, const hecl::ProjectPath& outPath) {
|
||||
athena::io::FileWriter writer(outPath.getAbsolutePath());
|
||||
|
|
|
@ -0,0 +1,87 @@
|
|||
#ifndef ENTRY
|
||||
#define ENTRY(name, identifier)
|
||||
#endif
|
||||
|
||||
#ifndef INT_ENTRY
|
||||
#define INT_ENTRY(name, identifier) ENTRY(name, identifier)
|
||||
#endif
|
||||
|
||||
#ifndef U32_ENTRY
|
||||
#define U32_ENTRY(name, identifier) ENTRY(name, identifier)
|
||||
#endif
|
||||
|
||||
#ifndef REAL_ENTRY
|
||||
#define REAL_ENTRY(name, identifier) ENTRY(name, identifier)
|
||||
#endif
|
||||
|
||||
#ifndef VECTOR_ENTRY
|
||||
#define VECTOR_ENTRY(name, identifier) ENTRY(name, identifier)
|
||||
#endif
|
||||
|
||||
#ifndef MOD_VECTOR_ENTRY
|
||||
#define MOD_VECTOR_ENTRY(name, identifier) ENTRY(name, identifier)
|
||||
#endif
|
||||
|
||||
#ifndef COLOR_ENTRY
|
||||
#define COLOR_ENTRY(name, identifier) ENTRY(name, identifier)
|
||||
#endif
|
||||
|
||||
#ifndef UV_ENTRY
|
||||
#define UV_ENTRY(name, identifier) ENTRY(name, identifier)
|
||||
#endif
|
||||
|
||||
#ifndef RES_ENTRY
|
||||
#define RES_ENTRY(name, identifier) ENTRY(name, identifier)
|
||||
#endif
|
||||
|
||||
#ifndef BOOL_ENTRY
|
||||
#define BOOL_ENTRY(name, identifier, def) ENTRY(name, identifier)
|
||||
#endif
|
||||
|
||||
VECTOR_ENTRY('IORN', x0_IORN)
|
||||
VECTOR_ENTRY('IVEC', x4_IVEC)
|
||||
VECTOR_ENTRY('PSOV', x8_PSOV)
|
||||
MOD_VECTOR_ENTRY('PSVM', xc_PSVM)
|
||||
INT_ENTRY('PSLT', x14_PSLT)
|
||||
VECTOR_ENTRY('PSCL', x18_PSCL)
|
||||
COLOR_ENTRY('PCOL', x1c_PCOL)
|
||||
VECTOR_ENTRY('POFS', x20_POFS)
|
||||
VECTOR_ENTRY('OFST', x24_OFST)
|
||||
|
||||
REAL_ENTRY('TRAT', x30_TRAT)
|
||||
RES_ENTRY('APSM', x34_APSM)
|
||||
RES_ENTRY('APS2', x44_APS2)
|
||||
RES_ENTRY('ASW1', x54_ASW1)
|
||||
RES_ENTRY('ASW2', x64_ASW2)
|
||||
RES_ENTRY('ASW3', x74_ASW3)
|
||||
RES_ENTRY('OHEF', x84_OHEF)
|
||||
RES_ENTRY('COLR', x94_COLR)
|
||||
U32_ENTRY('PJFX', xa8_PJFX)
|
||||
REAL_ENTRY('RNGE', xac_RNGE)
|
||||
REAL_ENTRY('FOFF', xb0_FOFF)
|
||||
|
||||
BOOL_ENTRY('VMD2', x10_VMD2, false)
|
||||
BOOL_ENTRY('APSO', x28_APSO, false)
|
||||
BOOL_ENTRY('HOMG', x29_HOMG, false)
|
||||
BOOL_ENTRY('AP11', x2a_AP11, false)
|
||||
BOOL_ENTRY('AP21', x2b_AP21, false)
|
||||
BOOL_ENTRY('AS11', x2c_AS11, false)
|
||||
BOOL_ENTRY('AS12', x2d_AS12, false)
|
||||
BOOL_ENTRY('AS13', x2e_AS13, false)
|
||||
BOOL_ENTRY('EWTR', xa4_EWTR, true)
|
||||
BOOL_ENTRY('LWTR', xa5_LWTR, true)
|
||||
BOOL_ENTRY('SWTR', xa6_SWTR, true)
|
||||
BOOL_ENTRY('FC60', xunk_FC60, false)
|
||||
BOOL_ENTRY('SPS1', xunk_SPS1, false)
|
||||
BOOL_ENTRY('SPS2', xunk_SPS2, false)
|
||||
|
||||
#undef ENTRY
|
||||
#undef INT_ENTRY
|
||||
#undef U32_ENTRY
|
||||
#undef REAL_ENTRY
|
||||
#undef VECTOR_ENTRY
|
||||
#undef MOD_VECTOR_ENTRY
|
||||
#undef COLOR_ENTRY
|
||||
#undef UV_ENTRY
|
||||
#undef RES_ENTRY
|
||||
#undef BOOL_ENTRY
|
|
@ -12,53 +12,40 @@ class ProjectPath;
|
|||
}
|
||||
|
||||
namespace DataSpec::DNAParticle {
|
||||
template <class IDType>
|
||||
struct WPSM : BigDNA {
|
||||
AT_DECL_EXPLICIT_DNA_YAML
|
||||
AT_SUBDECL_DNA
|
||||
VectorElementFactory x0_IORN;
|
||||
VectorElementFactory x4_IVEC;
|
||||
VectorElementFactory x8_PSOV;
|
||||
ModVectorElementFactory xc_PSVM;
|
||||
BoolHelper x10_VMD2;
|
||||
IntElementFactory x14_PSLT;
|
||||
VectorElementFactory x18_PSCL;
|
||||
ColorElementFactory x1c_PCOL;
|
||||
VectorElementFactory x20_POFS;
|
||||
VectorElementFactory x24_OFST;
|
||||
BoolHelper x28_APSO;
|
||||
BoolHelper x29_HOMG;
|
||||
BoolHelper x2a_AP11;
|
||||
BoolHelper x2b_AP21;
|
||||
BoolHelper x2c_AS11;
|
||||
BoolHelper x2d_AS12;
|
||||
BoolHelper x2e_AS13;
|
||||
RealElementFactory x30_TRAT;
|
||||
ChildResourceFactory<IDType> x34_APSM;
|
||||
ChildResourceFactory<IDType> x44_APS2;
|
||||
ChildResourceFactory<IDType> x54_ASW1;
|
||||
ChildResourceFactory<IDType> x64_ASW2;
|
||||
ChildResourceFactory<IDType> x74_ASW3;
|
||||
ChildResourceFactory<IDType> x84_OHEF;
|
||||
ChildResourceFactory<IDType> x94_COLR;
|
||||
BoolHelper xa4_EWTR;
|
||||
BoolHelper xa5_LWTR;
|
||||
BoolHelper xa6_SWTR;
|
||||
uint32_t xa8_PJFX = ~0;
|
||||
RealElementFactory xac_RNGE;
|
||||
RealElementFactory xb0_FOFF;
|
||||
BoolHelper xunk_FC60;
|
||||
BoolHelper xunk_SPS1;
|
||||
BoolHelper xunk_SPS2;
|
||||
|
||||
WPSM() {
|
||||
xa4_EWTR = true;
|
||||
xa5_LWTR = true;
|
||||
xa6_SWTR = true;
|
||||
template <class IDType>
|
||||
struct _WPSM {
|
||||
static constexpr ParticleType Type = ParticleType::WPSM;
|
||||
|
||||
#define INT_ENTRY(name, identifier) IntElementFactory identifier;
|
||||
#define U32_ENTRY(name, identifier) uint32_t identifier = ~0;
|
||||
#define REAL_ENTRY(name, identifier) RealElementFactory identifier;
|
||||
#define VECTOR_ENTRY(name, identifier) VectorElementFactory identifier;
|
||||
#define MOD_VECTOR_ENTRY(name, identifier) ModVectorElementFactory identifier;
|
||||
#define COLOR_ENTRY(name, identifier) ColorElementFactory identifier;
|
||||
#define UV_ENTRY(name, identifier) UVElementFactory<IDType> identifier;
|
||||
#define RES_ENTRY(name, identifier) ChildResourceFactory<IDType> identifier;
|
||||
#define BOOL_ENTRY(name, identifier, def) bool identifier = def;
|
||||
#include "WPSC.def"
|
||||
|
||||
template<typename _Func>
|
||||
void constexpr Enumerate(_Func f) {
|
||||
#define ENTRY(name, identifier) f(FOURCC(name), identifier);
|
||||
#define BOOL_ENTRY(name, identifier, def) f(FOURCC(name), identifier, def);
|
||||
#include "WPSC.def"
|
||||
}
|
||||
|
||||
void gatherDependencies(std::vector<hecl::ProjectPath>&) const;
|
||||
template<typename _Func>
|
||||
bool constexpr Lookup(FourCC fcc, _Func f) {
|
||||
switch (fcc.toUint32()) {
|
||||
#define ENTRY(name, identifier) case SBIG(name): f(identifier); return true;
|
||||
#include "WPSC.def"
|
||||
default: return false;
|
||||
}
|
||||
}
|
||||
};
|
||||
template <class IDType>
|
||||
using WPSM = PPImpl<_WPSM<IDType>>;
|
||||
|
||||
template <class IDType>
|
||||
bool ExtractWPSM(PAKEntryReadStream& rs, const hecl::ProjectPath& outPath);
|
||||
|
|
|
@ -21,7 +21,7 @@ class CAudioGroupSet {
|
|||
amuse::AudioGroupData LoadData();
|
||||
|
||||
public:
|
||||
CAudioGroupSet(std::unique_ptr<u8[]>&& in);
|
||||
explicit CAudioGroupSet(std::unique_ptr<u8[]>&& in);
|
||||
const amuse::AudioGroupData& GetAudioGroupData() const { return m_data; }
|
||||
std::string_view GetName() const { return x20_name; }
|
||||
};
|
||||
|
|
|
@ -19,7 +19,7 @@ public:
|
|||
u16 GetGroupId() const { return x2_groupId; }
|
||||
CAssetId GetAGSCAssetId() const { return x4_agscId; }
|
||||
const u8* GetArrData() const { return x8_arrData.get(); }
|
||||
CMidiData(CInputStream& in);
|
||||
explicit CMidiData(CInputStream& in);
|
||||
};
|
||||
|
||||
class CMidiWrapper {
|
||||
|
|
|
@ -53,7 +53,7 @@ class CStaticAudioPlayer {
|
|||
memset(data, 0, 4 * frames);
|
||||
return frames;
|
||||
}
|
||||
AudioVoiceCallback(CStaticAudioPlayer& p) : m_parent(p) {}
|
||||
explicit AudioVoiceCallback(CStaticAudioPlayer& p) : m_parent(p) {}
|
||||
} m_voiceCallback;
|
||||
boo::ObjToken<boo::IAudioVoice> m_voice;
|
||||
|
||||
|
|
|
@ -50,7 +50,7 @@ struct SDSPStreamInfo {
|
|||
s16 x1c_coef[8][2];
|
||||
|
||||
SDSPStreamInfo() = default;
|
||||
SDSPStreamInfo(const CDSPStreamManager& stream);
|
||||
explicit SDSPStreamInfo(const CDSPStreamManager& stream);
|
||||
};
|
||||
|
||||
struct SDSPStream : boo::IAudioVoiceCallback {
|
||||
|
|
|
@ -224,7 +224,7 @@ private:
|
|||
CAssetId GetAreaHintDescriptionString(CAssetId mreaId);
|
||||
|
||||
public:
|
||||
CAutoMapper(CStateManager& stateMgr);
|
||||
explicit CAutoMapper(CStateManager& stateMgr);
|
||||
bool CheckLoadComplete();
|
||||
bool CanLeaveMapScreen(const CStateManager& mgr) const;
|
||||
float GetMapRotationX() const { return xa8_renderStates[0].x1c_camAngle; }
|
||||
|
|
|
@ -38,7 +38,7 @@ public:
|
|||
std::vector<Instance> m_instances;
|
||||
|
||||
public:
|
||||
CMapAreaSurface(const void* surfBuf);
|
||||
explicit CMapAreaSurface(const void* surfBuf);
|
||||
CMapAreaSurface(CMapAreaSurface&&) = default;
|
||||
void PostConstruct(const u8* buf, std::vector<u32>& index);
|
||||
void Draw(const zeus::CVector3f* verts, const zeus::CColor& surfColor, const zeus::CColor& lineColor,
|
||||
|
@ -69,7 +69,7 @@ private:
|
|||
boo::ObjToken<boo::IGraphicsBufferS> m_ibo;
|
||||
|
||||
public:
|
||||
CMapArea(CInputStream& in, u32 size);
|
||||
explicit CMapArea(CInputStream& in, u32 size);
|
||||
void PostConstruct();
|
||||
bool GetIsVisibleToAutoMapper(bool worldVis, bool areaVis) const;
|
||||
zeus::CVector3f GetAreaCenterPoint() const { return x10_box.center(); }
|
||||
|
|
|
@ -84,7 +84,7 @@ public:
|
|||
zeus::CVector3f x64_centerPoint = zeus::skZero3f;
|
||||
|
||||
public:
|
||||
CMapWorldData(CInputStream& in, u32 version);
|
||||
explicit CMapWorldData(CInputStream& in, u32 version);
|
||||
CAssetId GetWorldAssetId() const { return x10_worldAssetId; }
|
||||
const zeus::CVector3f& GetWorldCenterPoint() const { return x64_centerPoint; }
|
||||
std::string_view GetWorldLabel() const { return x0_label; }
|
||||
|
@ -105,7 +105,7 @@ private:
|
|||
float x2c_universeRadius = 1600.f;
|
||||
|
||||
public:
|
||||
CMapUniverse(CInputStream&, u32);
|
||||
explicit CMapUniverse(CInputStream&, u32);
|
||||
const CMapWorldData& GetMapWorldData(s32 idx) const { return x10_worldDatas[idx]; }
|
||||
const CMapWorldData& GetMapWorldDataByWorldId(CAssetId id) const {
|
||||
for (const CMapWorldData& data : x10_worldDatas)
|
||||
|
|
|
@ -1,6 +1,7 @@
|
|||
#include "Runtime/AutoMapper/CMapWorld.hpp"
|
||||
|
||||
#include <algorithm>
|
||||
#include <array>
|
||||
|
||||
#include "Runtime/CSimplePool.hpp"
|
||||
#include "Runtime/CStateManager.hpp"
|
||||
|
@ -9,6 +10,254 @@
|
|||
#include "Runtime/World/CWorld.hpp"
|
||||
|
||||
namespace urde {
|
||||
namespace {
|
||||
struct Support {
|
||||
int x0_;
|
||||
std::array<int, 3> x4_;
|
||||
};
|
||||
|
||||
struct Circle2 {
|
||||
zeus::CVector2f x0_point;
|
||||
float x8_radiusSq;
|
||||
};
|
||||
|
||||
struct Circle {
|
||||
zeus::CVector2f x0_point;
|
||||
float x8_radius;
|
||||
Circle(const Circle2& circ2) : x0_point(circ2.x0_point), x8_radius(std::sqrt(circ2.x8_radiusSq)) {}
|
||||
};
|
||||
|
||||
Circle2 ExactCircle1(const zeus::CVector2f* a) { return {*a, 0.f}; }
|
||||
|
||||
Circle2 ExactCircle2(const zeus::CVector2f* a, const zeus::CVector2f* b) {
|
||||
Circle2 ret = {};
|
||||
ret.x0_point = 0.5f * (*a + *b);
|
||||
ret.x8_radiusSq = (*b - *a).magSquared() * 0.25f;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Circle2 ExactCircle3(const zeus::CVector2f* a, const zeus::CVector2f* b, const zeus::CVector2f* c) {
|
||||
Circle2 ret = {};
|
||||
zeus::CVector2f d1 = *b - *a;
|
||||
zeus::CVector2f d2 = *c - *a;
|
||||
float cross = d1.cross(d2);
|
||||
zeus::CVector2f magVec(d1.magSquared() * 0.5f, d2.magSquared() * 0.5f);
|
||||
if (std::fabs(cross) > 0.01f) {
|
||||
zeus::CVector2f tmp((d2.y() * magVec.x() - d1.y() * magVec.y()) / cross,
|
||||
(d1.x() * magVec.y() - d2.x() * magVec.x()) / cross);
|
||||
ret.x0_point = *a + tmp;
|
||||
ret.x8_radiusSq = tmp.magSquared();
|
||||
} else {
|
||||
ret.x8_radiusSq = FLT_MAX;
|
||||
}
|
||||
return ret;
|
||||
}
|
||||
|
||||
bool PointInsideCircle(const zeus::CVector2f& point, const Circle2& circ, float& intersect) {
|
||||
intersect = (point - circ.x0_point).magSquared() - circ.x8_radiusSq;
|
||||
return intersect <= 0.f;
|
||||
}
|
||||
|
||||
Circle2 UpdateSupport1(int idx, const zeus::CVector2f** list, Support& support) {
|
||||
Circle2 ret = ExactCircle2(list[support.x4_[0]], list[idx]);
|
||||
support.x0_ = 2;
|
||||
support.x4_[1] = idx;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Circle2 UpdateSupport2(int idx, const zeus::CVector2f** list, Support& support) {
|
||||
std::array<Circle2, 3> circs{};
|
||||
float intersect;
|
||||
int circIdx = -1;
|
||||
float minRad = FLT_MAX;
|
||||
|
||||
circs[0] = ExactCircle2(list[support.x4_[0]], list[idx]);
|
||||
if (PointInsideCircle(*list[support.x4_[1]], circs[0], intersect)) {
|
||||
minRad = circs[0].x8_radiusSq;
|
||||
circIdx = 0;
|
||||
}
|
||||
|
||||
circs[1] = ExactCircle2(list[support.x4_[1]], list[idx]);
|
||||
if (circs[1].x8_radiusSq < minRad && PointInsideCircle(*list[support.x4_[0]], circs[1], intersect)) {
|
||||
circIdx = 1;
|
||||
}
|
||||
|
||||
Circle2 ret;
|
||||
if (circIdx != -1) {
|
||||
ret = circs[circIdx];
|
||||
support.x4_[1 - circIdx] = idx;
|
||||
} else {
|
||||
ret = ExactCircle3(list[support.x4_[0]], list[support.x4_[1]], list[idx]);
|
||||
support.x0_ = 3;
|
||||
support.x4_[2] = idx;
|
||||
}
|
||||
return ret;
|
||||
}
|
||||
|
||||
Circle2 UpdateSupport3(int idx, const zeus::CVector2f** list, Support& support) {
|
||||
std::array<Circle2, 6> circs{};
|
||||
float intersect;
|
||||
int circIdxA = -1;
|
||||
int circIdxB = -1;
|
||||
float minRadA = FLT_MAX;
|
||||
float minRadB = FLT_MAX;
|
||||
|
||||
circs[0] = ExactCircle2(list[support.x4_[0]], list[idx]);
|
||||
if (PointInsideCircle(*list[support.x4_[1]], circs[0], intersect)) {
|
||||
if (PointInsideCircle(*list[support.x4_[2]], circs[0], intersect)) {
|
||||
minRadA = circs[0].x8_radiusSq;
|
||||
circIdxA = 0;
|
||||
} else {
|
||||
minRadB = intersect;
|
||||
circIdxB = 0;
|
||||
}
|
||||
} else {
|
||||
minRadB = intersect;
|
||||
circIdxB = 0;
|
||||
}
|
||||
|
||||
circs[1] = ExactCircle2(list[support.x4_[1]], list[idx]);
|
||||
if (circs[1].x8_radiusSq < minRadA) {
|
||||
if (PointInsideCircle(*list[support.x4_[0]], circs[1], intersect)) {
|
||||
if (PointInsideCircle(*list[support.x4_[2]], circs[1], intersect)) {
|
||||
minRadA = circs[1].x8_radiusSq;
|
||||
circIdxA = 1;
|
||||
} else if (intersect < minRadB) {
|
||||
minRadB = intersect;
|
||||
circIdxB = 1;
|
||||
}
|
||||
} else if (intersect < minRadB) {
|
||||
minRadB = intersect;
|
||||
circIdxB = 1;
|
||||
}
|
||||
}
|
||||
|
||||
circs[2] = ExactCircle2(list[support.x4_[2]], list[idx]);
|
||||
if (circs[2].x8_radiusSq < minRadA) {
|
||||
if (PointInsideCircle(*list[support.x4_[0]], circs[2], intersect)) {
|
||||
if (PointInsideCircle(*list[support.x4_[1]], circs[2], intersect)) {
|
||||
minRadA = circs[2].x8_radiusSq;
|
||||
circIdxA = 2;
|
||||
} else if (intersect < minRadB) {
|
||||
minRadB = intersect;
|
||||
circIdxB = 2;
|
||||
}
|
||||
} else if (intersect < minRadB) {
|
||||
minRadB = intersect;
|
||||
circIdxB = 2;
|
||||
}
|
||||
}
|
||||
|
||||
circs[3] = ExactCircle3(list[support.x4_[0]], list[support.x4_[1]], list[idx]);
|
||||
if (circs[3].x8_radiusSq < minRadA) {
|
||||
if (PointInsideCircle(*list[support.x4_[2]], circs[3], intersect)) {
|
||||
minRadA = circs[3].x8_radiusSq;
|
||||
circIdxA = 3;
|
||||
} else if (intersect < minRadB) {
|
||||
minRadB = intersect;
|
||||
circIdxB = 3;
|
||||
}
|
||||
}
|
||||
|
||||
circs[4] = ExactCircle3(list[support.x4_[0]], list[support.x4_[2]], list[idx]);
|
||||
if (circs[4].x8_radiusSq < minRadA) {
|
||||
if (PointInsideCircle(*list[support.x4_[1]], circs[4], intersect)) {
|
||||
minRadA = circs[4].x8_radiusSq;
|
||||
circIdxA = 4;
|
||||
} else if (intersect < minRadB) {
|
||||
minRadB = intersect;
|
||||
circIdxB = 4;
|
||||
}
|
||||
}
|
||||
|
||||
circs[5] = ExactCircle3(list[support.x4_[1]], list[support.x4_[2]], list[idx]);
|
||||
if (circs[5].x8_radiusSq < minRadA) {
|
||||
if (PointInsideCircle(*list[support.x4_[0]], circs[5], intersect)) {
|
||||
circIdxA = 5;
|
||||
} else if (intersect < minRadB) {
|
||||
circIdxB = 5;
|
||||
}
|
||||
}
|
||||
|
||||
if (circIdxA == -1)
|
||||
circIdxA = circIdxB;
|
||||
|
||||
switch (circIdxA) {
|
||||
case 0:
|
||||
support.x0_ = 2;
|
||||
support.x4_[1] = idx;
|
||||
break;
|
||||
case 1:
|
||||
support.x0_ = 2;
|
||||
support.x4_[0] = idx;
|
||||
break;
|
||||
case 2:
|
||||
support.x0_ = 2;
|
||||
support.x4_[0] = support.x4_[2];
|
||||
support.x4_[1] = idx;
|
||||
break;
|
||||
case 3:
|
||||
support.x4_[2] = idx;
|
||||
break;
|
||||
case 4:
|
||||
support.x4_[1] = idx;
|
||||
break;
|
||||
case 5:
|
||||
support.x4_[0] = idx;
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
|
||||
return circs[circIdxA];
|
||||
}
|
||||
|
||||
using FSupport = Circle2 (*)(int idx, const zeus::CVector2f** list, Support& support);
|
||||
constexpr std::array<FSupport, 4> SupportFuncs{
|
||||
nullptr,
|
||||
UpdateSupport1,
|
||||
UpdateSupport2,
|
||||
UpdateSupport3,
|
||||
};
|
||||
|
||||
Circle MinCircle(const std::vector<zeus::CVector2f>& coords) {
|
||||
Circle2 ret = {};
|
||||
if (coords.size() >= 1) {
|
||||
std::unique_ptr<const zeus::CVector2f*[]> randArr(new const zeus::CVector2f*[coords.size()]);
|
||||
for (size_t i = 0; i < coords.size(); ++i)
|
||||
randArr[i] = &coords[i];
|
||||
for (int i = coords.size() - 1; i >= 0; --i) {
|
||||
int shuf = rand() % (i + 1);
|
||||
if (shuf != i)
|
||||
std::swap(randArr[i], randArr[shuf]);
|
||||
}
|
||||
ret = ExactCircle1(randArr[0]);
|
||||
|
||||
Support support = {};
|
||||
support.x0_ = 1;
|
||||
for (size_t i = 1; i < coords.size();) {
|
||||
bool broke = false;
|
||||
for (int j = 0; j < support.x0_; ++j) {
|
||||
if ((*randArr[i] - *randArr[support.x4_[j]]).magSquared() < 0.01f) {
|
||||
broke = true;
|
||||
break;
|
||||
}
|
||||
}
|
||||
float intersect;
|
||||
if (!broke && !PointInsideCircle(*randArr[i], ret, intersect)) {
|
||||
Circle2 circ = SupportFuncs[support.x0_](i, randArr.get(), support);
|
||||
if (circ.x8_radiusSq > ret.x8_radiusSq) {
|
||||
i = 0;
|
||||
ret = circ;
|
||||
continue;
|
||||
}
|
||||
}
|
||||
++i;
|
||||
}
|
||||
}
|
||||
return ret;
|
||||
}
|
||||
} // Anonymous namespace
|
||||
|
||||
CMapWorld::CMapAreaData::CMapAreaData(CAssetId areaRes, EMapAreaList list, CMapAreaData* next)
|
||||
: x0_area(g_SimplePool->GetObj(SObjectTag{FOURCC('MAPA'), areaRes})), x10_list(list), x14_next(next) {}
|
||||
|
@ -378,248 +627,6 @@ void CMapWorld::DrawAreas(const CMapWorld::CMapWorldDrawParms& parms, int selAre
|
|||
}
|
||||
}
|
||||
|
||||
struct Support {
|
||||
int x0_;
|
||||
int x4_[3];
|
||||
};
|
||||
|
||||
struct Circle2 {
|
||||
zeus::CVector2f x0_point;
|
||||
float x8_radiusSq;
|
||||
};
|
||||
|
||||
struct Circle {
|
||||
zeus::CVector2f x0_point;
|
||||
float x8_radius;
|
||||
Circle(const Circle2& circ2) : x0_point(circ2.x0_point), x8_radius(std::sqrt(circ2.x8_radiusSq)) {}
|
||||
};
|
||||
|
||||
static Circle2 ExactCircle1(const zeus::CVector2f* a) { return {*a, 0.f}; }
|
||||
|
||||
static Circle2 ExactCircle2(const zeus::CVector2f* a, const zeus::CVector2f* b) {
|
||||
Circle2 ret = {};
|
||||
ret.x0_point = 0.5f * (*a + *b);
|
||||
ret.x8_radiusSq = (*b - *a).magSquared() * 0.25f;
|
||||
return ret;
|
||||
}
|
||||
|
||||
static Circle2 ExactCircle3(const zeus::CVector2f* a, const zeus::CVector2f* b, const zeus::CVector2f* c) {
|
||||
Circle2 ret = {};
|
||||
zeus::CVector2f d1 = *b - *a;
|
||||
zeus::CVector2f d2 = *c - *a;
|
||||
float cross = d1.cross(d2);
|
||||
zeus::CVector2f magVec(d1.magSquared() * 0.5f, d2.magSquared() * 0.5f);
|
||||
if (std::fabs(cross) > 0.01f) {
|
||||
zeus::CVector2f tmp((d2.y() * magVec.x() - d1.y() * magVec.y()) / cross,
|
||||
(d1.x() * magVec.y() - d2.x() * magVec.x()) / cross);
|
||||
ret.x0_point = *a + tmp;
|
||||
ret.x8_radiusSq = tmp.magSquared();
|
||||
} else {
|
||||
ret.x8_radiusSq = FLT_MAX;
|
||||
}
|
||||
return ret;
|
||||
}
|
||||
|
||||
static bool PointInsideCircle(const zeus::CVector2f& point, const Circle2& circ, float& intersect) {
|
||||
intersect = (point - circ.x0_point).magSquared() - circ.x8_radiusSq;
|
||||
return intersect <= 0.f;
|
||||
}
|
||||
|
||||
static Circle2 UpdateSupport1(int idx, const zeus::CVector2f** list, Support& support) {
|
||||
Circle2 ret = ExactCircle2(list[support.x4_[0]], list[idx]);
|
||||
support.x0_ = 2;
|
||||
support.x4_[1] = idx;
|
||||
return ret;
|
||||
}
|
||||
|
||||
static Circle2 UpdateSupport2(int idx, const zeus::CVector2f** list, Support& support) {
|
||||
Circle2 circs[3] = {};
|
||||
float intersect;
|
||||
int circIdx = -1;
|
||||
float minRad = FLT_MAX;
|
||||
|
||||
circs[0] = ExactCircle2(list[support.x4_[0]], list[idx]);
|
||||
if (PointInsideCircle(*list[support.x4_[1]], circs[0], intersect)) {
|
||||
minRad = circs[0].x8_radiusSq;
|
||||
circIdx = 0;
|
||||
}
|
||||
|
||||
circs[1] = ExactCircle2(list[support.x4_[1]], list[idx]);
|
||||
if (circs[1].x8_radiusSq < minRad && PointInsideCircle(*list[support.x4_[0]], circs[1], intersect)) {
|
||||
circIdx = 1;
|
||||
}
|
||||
|
||||
Circle2 ret;
|
||||
if (circIdx != -1) {
|
||||
ret = circs[circIdx];
|
||||
support.x4_[1 - circIdx] = idx;
|
||||
} else {
|
||||
ret = ExactCircle3(list[support.x4_[0]], list[support.x4_[1]], list[idx]);
|
||||
support.x0_ = 3;
|
||||
support.x4_[2] = idx;
|
||||
}
|
||||
return ret;
|
||||
}
|
||||
|
||||
static Circle2 UpdateSupport3(int idx, const zeus::CVector2f** list, Support& support) {
|
||||
Circle2 circs[6] = {};
|
||||
float intersect;
|
||||
int circIdxA = -1;
|
||||
int circIdxB = -1;
|
||||
float minRadA = FLT_MAX;
|
||||
float minRadB = FLT_MAX;
|
||||
|
||||
circs[0] = ExactCircle2(list[support.x4_[0]], list[idx]);
|
||||
if (PointInsideCircle(*list[support.x4_[1]], circs[0], intersect)) {
|
||||
if (PointInsideCircle(*list[support.x4_[2]], circs[0], intersect)) {
|
||||
minRadA = circs[0].x8_radiusSq;
|
||||
circIdxA = 0;
|
||||
} else {
|
||||
minRadB = intersect;
|
||||
circIdxB = 0;
|
||||
}
|
||||
} else {
|
||||
minRadB = intersect;
|
||||
circIdxB = 0;
|
||||
}
|
||||
|
||||
circs[1] = ExactCircle2(list[support.x4_[1]], list[idx]);
|
||||
if (circs[1].x8_radiusSq < minRadA) {
|
||||
if (PointInsideCircle(*list[support.x4_[0]], circs[1], intersect)) {
|
||||
if (PointInsideCircle(*list[support.x4_[2]], circs[1], intersect)) {
|
||||
minRadA = circs[1].x8_radiusSq;
|
||||
circIdxA = 1;
|
||||
} else if (intersect < minRadB) {
|
||||
minRadB = intersect;
|
||||
circIdxB = 1;
|
||||
}
|
||||
} else if (intersect < minRadB) {
|
||||
minRadB = intersect;
|
||||
circIdxB = 1;
|
||||
}
|
||||
}
|
||||
|
||||
circs[2] = ExactCircle2(list[support.x4_[2]], list[idx]);
|
||||
if (circs[2].x8_radiusSq < minRadA) {
|
||||
if (PointInsideCircle(*list[support.x4_[0]], circs[2], intersect)) {
|
||||
if (PointInsideCircle(*list[support.x4_[1]], circs[2], intersect)) {
|
||||
minRadA = circs[2].x8_radiusSq;
|
||||
circIdxA = 2;
|
||||
} else if (intersect < minRadB) {
|
||||
minRadB = intersect;
|
||||
circIdxB = 2;
|
||||
}
|
||||
} else if (intersect < minRadB) {
|
||||
minRadB = intersect;
|
||||
circIdxB = 2;
|
||||
}
|
||||
}
|
||||
|
||||
circs[3] = ExactCircle3(list[support.x4_[0]], list[support.x4_[1]], list[idx]);
|
||||
if (circs[3].x8_radiusSq < minRadA) {
|
||||
if (PointInsideCircle(*list[support.x4_[2]], circs[3], intersect)) {
|
||||
minRadA = circs[3].x8_radiusSq;
|
||||
circIdxA = 3;
|
||||
} else if (intersect < minRadB) {
|
||||
minRadB = intersect;
|
||||
circIdxB = 3;
|
||||
}
|
||||
}
|
||||
|
||||
circs[4] = ExactCircle3(list[support.x4_[0]], list[support.x4_[2]], list[idx]);
|
||||
if (circs[4].x8_radiusSq < minRadA) {
|
||||
if (PointInsideCircle(*list[support.x4_[1]], circs[4], intersect)) {
|
||||
minRadA = circs[4].x8_radiusSq;
|
||||
circIdxA = 4;
|
||||
} else if (intersect < minRadB) {
|
||||
minRadB = intersect;
|
||||
circIdxB = 4;
|
||||
}
|
||||
}
|
||||
|
||||
circs[5] = ExactCircle3(list[support.x4_[1]], list[support.x4_[2]], list[idx]);
|
||||
if (circs[5].x8_radiusSq < minRadA) {
|
||||
if (PointInsideCircle(*list[support.x4_[0]], circs[5], intersect)) {
|
||||
circIdxA = 5;
|
||||
} else if (intersect < minRadB) {
|
||||
circIdxB = 5;
|
||||
}
|
||||
}
|
||||
|
||||
if (circIdxA == -1)
|
||||
circIdxA = circIdxB;
|
||||
|
||||
switch (circIdxA) {
|
||||
case 0:
|
||||
support.x0_ = 2;
|
||||
support.x4_[1] = idx;
|
||||
break;
|
||||
case 1:
|
||||
support.x0_ = 2;
|
||||
support.x4_[0] = idx;
|
||||
break;
|
||||
case 2:
|
||||
support.x0_ = 2;
|
||||
support.x4_[0] = support.x4_[2];
|
||||
support.x4_[1] = idx;
|
||||
break;
|
||||
case 3:
|
||||
support.x4_[2] = idx;
|
||||
break;
|
||||
case 4:
|
||||
support.x4_[1] = idx;
|
||||
break;
|
||||
case 5:
|
||||
support.x4_[0] = idx;
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
|
||||
return circs[circIdxA];
|
||||
}
|
||||
|
||||
typedef Circle2 (*FSupport)(int idx, const zeus::CVector2f** list, Support& support);
|
||||
static const FSupport SupportFuncs[] = {nullptr, UpdateSupport1, UpdateSupport2, UpdateSupport3};
|
||||
|
||||
static Circle MinCircle(const std::vector<zeus::CVector2f>& coords) {
|
||||
Circle2 ret = {};
|
||||
if (coords.size() >= 1) {
|
||||
std::unique_ptr<const zeus::CVector2f*[]> randArr(new const zeus::CVector2f*[coords.size()]);
|
||||
for (size_t i = 0; i < coords.size(); ++i)
|
||||
randArr[i] = &coords[i];
|
||||
for (int i = coords.size() - 1; i >= 0; --i) {
|
||||
int shuf = rand() % (i + 1);
|
||||
if (shuf != i)
|
||||
std::swap(randArr[i], randArr[shuf]);
|
||||
}
|
||||
ret = ExactCircle1(randArr[0]);
|
||||
|
||||
Support support = {};
|
||||
support.x0_ = 1;
|
||||
for (size_t i = 1; i < coords.size();) {
|
||||
bool broke = false;
|
||||
for (int j = 0; j < support.x0_; ++j) {
|
||||
if ((*randArr[i] - *randArr[support.x4_[j]]).magSquared() < 0.01f) {
|
||||
broke = true;
|
||||
break;
|
||||
}
|
||||
}
|
||||
float intersect;
|
||||
if (!broke && !PointInsideCircle(*randArr[i], ret, intersect)) {
|
||||
Circle2 circ = SupportFuncs[support.x0_](i, randArr.get(), support);
|
||||
if (circ.x8_radiusSq > ret.x8_radiusSq) {
|
||||
i = 0;
|
||||
ret = circ;
|
||||
continue;
|
||||
}
|
||||
}
|
||||
++i;
|
||||
}
|
||||
}
|
||||
return ret;
|
||||
}
|
||||
|
||||
void CMapWorld::RecalculateWorldSphere(const CMapWorldInfo& mwInfo, const IWorld& wld) {
|
||||
std::vector<zeus::CVector2f> coords;
|
||||
coords.reserve(x0_areas.size() * 8);
|
||||
|
|
|
@ -18,7 +18,7 @@ class CMapWorldInfo {
|
|||
|
||||
public:
|
||||
CMapWorldInfo() = default;
|
||||
CMapWorldInfo(CBitStreamReader&, const CSaveWorld& saveWorld, CAssetId mlvlId);
|
||||
explicit CMapWorldInfo(CBitStreamReader&, const CSaveWorld& saveWorld, CAssetId mlvlId);
|
||||
void PutTo(CBitStreamWriter& writer, const CSaveWorld& savw, CAssetId mlvlId) const;
|
||||
bool IsMapped(TAreaId) const;
|
||||
void SetIsMapped(TAreaId, bool);
|
||||
|
|
|
@ -63,7 +63,7 @@ private:
|
|||
struct DoorSurface {
|
||||
CMapSurfaceShader m_surface;
|
||||
CLineRenderer m_outline;
|
||||
DoorSurface(boo::IGraphicsDataFactory::Context& ctx)
|
||||
explicit DoorSurface(boo::IGraphicsDataFactory::Context& ctx)
|
||||
: m_surface(ctx, g_doorVbo, g_doorIbo)
|
||||
, m_outline(ctx, CLineRenderer::EPrimitiveMode::LineLoop, 5, nullptr, false, false, true) {}
|
||||
};
|
||||
|
@ -74,7 +74,7 @@ private:
|
|||
std::pair<zeus::CColor, zeus::CColor> GetDoorColors(int idx, const CMapWorldInfo& mwInfo, float alpha) const;
|
||||
|
||||
public:
|
||||
CMappableObject(const void* buf);
|
||||
explicit CMappableObject(const void* buf);
|
||||
CMappableObject(CMappableObject&&) = default;
|
||||
void PostConstruct(const void*);
|
||||
const zeus::CTransform& GetTransform() const { return x10_transform; }
|
||||
|
|
|
@ -38,15 +38,17 @@ CWorldLayerState::CWorldLayerState(CBitStreamReader& reader, const CSaveWorld& s
|
|||
|
||||
void CWorldLayerState::PutTo(CBitStreamWriter& writer) const {
|
||||
u32 totalLayerCount = 0;
|
||||
for (int i = 0; i < x0_areaLayers.size(); ++i)
|
||||
totalLayerCount += GetAreaLayerCount(i) - 1;
|
||||
for (size_t i = 0; i < x0_areaLayers.size(); ++i) {
|
||||
totalLayerCount += GetAreaLayerCount(s32(i)) - 1;
|
||||
}
|
||||
|
||||
writer.WriteEncoded(totalLayerCount, 10);
|
||||
|
||||
for (int i = 0; i < x0_areaLayers.size(); ++i) {
|
||||
u32 count = GetAreaLayerCount(i);
|
||||
for (u32 l = 1; l < count; ++l)
|
||||
writer.WriteEncoded(IsLayerActive(i, l), 1);
|
||||
for (size_t i = 0; i < x0_areaLayers.size(); ++i) {
|
||||
const u32 count = GetAreaLayerCount(s32(i));
|
||||
for (u32 l = 1; l < count; ++l) {
|
||||
writer.WriteEncoded(IsLayerActive(s32(i), s32(l)), 1);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -95,8 +97,9 @@ CGameState::GameFileStateInfo CGameState::LoadGameFileState(const u8* data) {
|
|||
CBitStreamReader stream(data, 4096);
|
||||
GameFileStateInfo ret;
|
||||
|
||||
for (u32 i = 0; i < 128; i++)
|
||||
for (u32 i = 0; i < 128; i++) {
|
||||
stream.ReadEncoded(8);
|
||||
}
|
||||
ret.x14_timestamp = stream.ReadEncoded(32);
|
||||
|
||||
ret.x20_hardMode = stream.ReadEncoded(1);
|
||||
|
@ -143,8 +146,9 @@ CGameState::CGameState(CBitStreamReader& stream, u32 saveIdx) : x20c_saveFileIdx
|
|||
x9c_transManager = std::make_shared<CWorldTransManager>();
|
||||
x228_25_initPowerupsAtFirstSpawn = true;
|
||||
|
||||
for (u32 i = 0; i < 128; i++)
|
||||
x0_[i] = stream.ReadEncoded(8);
|
||||
for (bool& value : x0_) {
|
||||
value = stream.ReadEncoded(8) != 0;
|
||||
}
|
||||
stream.ReadEncoded(32);
|
||||
|
||||
x228_24_hardMode = stream.ReadEncoded(1);
|
||||
|
@ -205,9 +209,10 @@ void CGameState::WriteBackupBuf() {
|
|||
PutTo(w);
|
||||
}
|
||||
|
||||
void CGameState::PutTo(CBitStreamWriter& writer) const {
|
||||
for (u32 i = 0; i < 128; i++)
|
||||
writer.WriteEncoded(x0_[i], 8);
|
||||
void CGameState::PutTo(CBitStreamWriter& writer) {
|
||||
for (const bool value : x0_) {
|
||||
writer.WriteEncoded(u32(value), 8);
|
||||
}
|
||||
|
||||
writer.WriteEncoded(CBasics::ToWiiTime(std::chrono::system_clock::now()) / CBasics::TICKS_PER_SECOND, 32);
|
||||
writer.WriteEncoded(x228_24_hardMode, 1);
|
||||
|
@ -227,7 +232,7 @@ void CGameState::PutTo(CBitStreamWriter& writer) const {
|
|||
for (const auto& memWorld : memWorlds) {
|
||||
TLockedToken<CSaveWorld> saveWorld =
|
||||
g_SimplePool->GetObj(SObjectTag{FOURCC('SAVW'), memWorld.second.GetSaveWorldAssetId()});
|
||||
const CWorldState& wld = const_cast<CGameState&>(*this).StateForWorld(memWorld.first);
|
||||
const CWorldState& wld = StateForWorld(memWorld.first);
|
||||
wld.PutTo(writer, *saveWorld);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,5 +1,6 @@
|
|||
#pragma once
|
||||
|
||||
#include <array>
|
||||
#include <memory>
|
||||
#include <vector>
|
||||
|
||||
|
@ -67,7 +68,7 @@ public:
|
|||
class CGameState {
|
||||
friend class CStateManager;
|
||||
|
||||
bool x0_[128] = {};
|
||||
std::array<bool, 128> x0_{};
|
||||
u32 x80_;
|
||||
CAssetId x84_mlvlId;
|
||||
std::vector<CWorldState> x88_worldStates;
|
||||
|
@ -116,7 +117,7 @@ public:
|
|||
void SetFileIdx(u32 idx) { x20c_saveFileIdx = idx; }
|
||||
void SetCardSerial(u64 serial) { x210_cardSerial = serial; }
|
||||
u64 GetCardSerial() const { return x210_cardSerial; }
|
||||
void PutTo(CBitStreamWriter& writer) const;
|
||||
void PutTo(CBitStreamWriter& writer);
|
||||
float GetHardModeDamageMultiplier() const;
|
||||
float GetHardModeWeaponMultiplier() const;
|
||||
void InitializeMemoryWorlds();
|
||||
|
|
|
@ -21,8 +21,8 @@ public:
|
|||
virtual ~CIOWin() = default;
|
||||
virtual EMessageReturn OnMessage(const CArchitectureMessage&, CArchitectureQueue&) = 0;
|
||||
virtual bool GetIsContinueDraw() const { return true; }
|
||||
virtual void Draw() const {}
|
||||
virtual void PreDraw() const {}
|
||||
virtual void Draw() {}
|
||||
virtual void PreDraw() {}
|
||||
|
||||
std::string_view GetName() const { return x4_name; }
|
||||
size_t GetNameHash() const { return m_nameHash; }
|
||||
|
|
|
@ -11,7 +11,7 @@ class CPlayMovieBase : public CIOWin {
|
|||
public:
|
||||
CPlayMovieBase(const char* iowName, const char* path) : CIOWin(iowName), x18_moviePlayer(path, 0.0, false, false) {}
|
||||
EMessageReturn OnMessage(const CArchitectureMessage&, CArchitectureQueue&) override { return EMessageReturn::Normal; }
|
||||
void Draw() const override {}
|
||||
void Draw() override {}
|
||||
};
|
||||
|
||||
} // namespace urde
|
||||
|
|
|
@ -30,17 +30,19 @@ void CSortedListManager::Reset() {
|
|||
}
|
||||
}
|
||||
|
||||
void CSortedListManager::AddToLinkedList(s16 nodeId, s16& headId, s16& tailId) const {
|
||||
void CSortedListManager::AddToLinkedList(s16 nodeId, s16& headId, s16& tailId) {
|
||||
if (headId == -1) {
|
||||
const_cast<SNode&>(AccessElement(x0_nodes, nodeId)).x28_next = headId;
|
||||
AccessElement(x0_nodes, nodeId).x28_next = headId;
|
||||
headId = nodeId;
|
||||
tailId = nodeId;
|
||||
} else {
|
||||
if (AccessElement(x0_nodes, nodeId).x28_next != -1)
|
||||
if (AccessElement(x0_nodes, nodeId).x28_next != -1) {
|
||||
return;
|
||||
if (tailId == nodeId)
|
||||
}
|
||||
if (tailId == nodeId) {
|
||||
return;
|
||||
const_cast<SNode&>(AccessElement(x0_nodes, nodeId)).x28_next = headId;
|
||||
}
|
||||
AccessElement(x0_nodes, nodeId).x28_next = headId;
|
||||
headId = nodeId;
|
||||
}
|
||||
}
|
||||
|
@ -114,19 +116,19 @@ void CSortedListManager::InsertInList(ESortedList list, SNode& node) {
|
|||
++sl.x800_size;
|
||||
}
|
||||
|
||||
s16 CSortedListManager::FindInListUpper(ESortedList list, float val) const {
|
||||
s16 CSortedListManager::FindInListUpper(ESortedList list, float value) const {
|
||||
const auto listIndex = static_cast<size_t>(list);
|
||||
const SSortedList& sl = xb000_sortedLists[listIndex];
|
||||
int idx = 0;
|
||||
|
||||
for (int i = sl.x800_size; i > 0;) {
|
||||
/* Binary search cycle to find index */
|
||||
if (!(val < AccessElement(x0_nodes, AccessElement(sl.x0_ids, idx + i / 2)).x4_box[listIndex])) {
|
||||
/* Upper */
|
||||
// Binary search cycle to find index
|
||||
if (!(value < AccessElement(x0_nodes, AccessElement(sl.x0_ids, idx + i / 2)).x4_box[listIndex])) {
|
||||
// Upper
|
||||
idx = idx + i / 2 + 1;
|
||||
i = i - i / 2 - 1;
|
||||
} else {
|
||||
/* Lower */
|
||||
// Lower
|
||||
i /= 2;
|
||||
}
|
||||
}
|
||||
|
@ -134,19 +136,19 @@ s16 CSortedListManager::FindInListUpper(ESortedList list, float val) const {
|
|||
return idx;
|
||||
}
|
||||
|
||||
s16 CSortedListManager::FindInListLower(ESortedList list, float val) const {
|
||||
s16 CSortedListManager::FindInListLower(ESortedList list, float value) const {
|
||||
const auto listIndex = static_cast<size_t>(list);
|
||||
const SSortedList& sl = xb000_sortedLists[listIndex];
|
||||
int idx = 0;
|
||||
|
||||
for (int i = sl.x800_size; i > 0;) {
|
||||
/* Binary search cycle to find index */
|
||||
if (AccessElement(x0_nodes, AccessElement(sl.x0_ids, idx + i / 2)).x4_box[listIndex] < val) {
|
||||
/* Upper */
|
||||
// Binary search cycle to find index
|
||||
if (AccessElement(x0_nodes, AccessElement(sl.x0_ids, idx + i / 2)).x4_box[listIndex] < value) {
|
||||
// Upper
|
||||
idx = idx + i / 2 + 1;
|
||||
i = i - i / 2 - 1;
|
||||
} else {
|
||||
/* Lower */
|
||||
// Lower
|
||||
i /= 2;
|
||||
}
|
||||
}
|
||||
|
@ -233,48 +235,52 @@ s16 CSortedListManager::CalculateIntersections(ESortedList la, ESortedList lb, s
|
|||
|
||||
void CSortedListManager::BuildNearList(rstl::reserved_vector<TUniqueId, 1024>& out, const zeus::CVector3f& pos,
|
||||
const zeus::CVector3f& dir, float mag, const CMaterialFilter& filter,
|
||||
const CActor* actor) const {
|
||||
if (mag == 0.f)
|
||||
const CActor* actor) {
|
||||
if (mag == 0.f) {
|
||||
mag = 8000.f;
|
||||
}
|
||||
const zeus::CVector3f ray = dir * mag;
|
||||
const zeus::CVector3f sum = ray + pos;
|
||||
zeus::CVector3f maxs(std::max(pos.x(), sum.x()), std::max(pos.y(), sum.y()), std::max(pos.z(), sum.z()));
|
||||
zeus::CVector3f mins(std::min(sum.x(), pos.x()), std::min(sum.y(), pos.y()), std::min(sum.z(), pos.z()));
|
||||
const zeus::CVector3f maxs(std::max(pos.x(), sum.x()), std::max(pos.y(), sum.y()), std::max(pos.z(), sum.z()));
|
||||
const zeus::CVector3f mins(std::min(sum.x(), pos.x()), std::min(sum.y(), pos.y()), std::min(sum.z(), pos.z()));
|
||||
BuildNearList(out, zeus::CAABox(mins, maxs), filter, actor);
|
||||
}
|
||||
|
||||
void CSortedListManager::BuildNearList(rstl::reserved_vector<TUniqueId, 1024>& out, const CActor& actor,
|
||||
const zeus::CAABox& aabb) const {
|
||||
const zeus::CAABox& aabb) {
|
||||
const CMaterialFilter& filter = actor.GetMaterialFilter();
|
||||
s16 id = const_cast<CSortedListManager&>(*this).ConstructIntersectionArray(aabb);
|
||||
s16 id = ConstructIntersectionArray(aabb);
|
||||
while (id != -1) {
|
||||
const SNode& node = AccessElement(x0_nodes, id);
|
||||
SNode& node = AccessElement(x0_nodes, id);
|
||||
if (&actor != node.x0_actor && filter.Passes(node.x0_actor->GetMaterialList()) &&
|
||||
node.x0_actor->GetMaterialFilter().Passes(actor.GetMaterialList()))
|
||||
node.x0_actor->GetMaterialFilter().Passes(actor.GetMaterialList())) {
|
||||
out.push_back(node.x0_actor->GetUniqueId());
|
||||
}
|
||||
|
||||
id = node.x28_next;
|
||||
const_cast<SNode&>(node).x28_next = -1;
|
||||
node.x28_next = -1;
|
||||
}
|
||||
}
|
||||
|
||||
void CSortedListManager::BuildNearList(rstl::reserved_vector<TUniqueId, 1024>& out, const zeus::CAABox& aabb,
|
||||
const CMaterialFilter& filter, const CActor* actor) const {
|
||||
s16 id = const_cast<CSortedListManager&>(*this).ConstructIntersectionArray(aabb);
|
||||
const CMaterialFilter& filter, const CActor* actor) {
|
||||
s16 id = ConstructIntersectionArray(aabb);
|
||||
while (id != -1) {
|
||||
const SNode& node = AccessElement(x0_nodes, id);
|
||||
if (actor != node.x0_actor && filter.Passes(node.x0_actor->GetMaterialList()))
|
||||
SNode& node = AccessElement(x0_nodes, id);
|
||||
if (actor != node.x0_actor && filter.Passes(node.x0_actor->GetMaterialList())) {
|
||||
out.push_back(node.x0_actor->GetUniqueId());
|
||||
}
|
||||
|
||||
id = node.x28_next;
|
||||
const_cast<SNode&>(node).x28_next = -1;
|
||||
node.x28_next = -1;
|
||||
}
|
||||
}
|
||||
|
||||
void CSortedListManager::Remove(const CActor* act) {
|
||||
SNode& node = AccessElement(x0_nodes, act->GetUniqueId().Value());
|
||||
if (!node.x2a_populated)
|
||||
void CSortedListManager::Remove(const CActor* actor) {
|
||||
SNode& node = AccessElement(x0_nodes, actor->GetUniqueId().Value());
|
||||
if (!node.x2a_populated) {
|
||||
return;
|
||||
}
|
||||
|
||||
RemoveFromList(ESortedList::MinX, node.x1c_selfIdxs[0]);
|
||||
RemoveFromList(ESortedList::MaxX, node.x1c_selfIdxs[3]);
|
||||
|
@ -285,8 +291,8 @@ void CSortedListManager::Remove(const CActor* act) {
|
|||
node.x2a_populated = false;
|
||||
}
|
||||
|
||||
void CSortedListManager::Move(const CActor* act, const zeus::CAABox& aabb) {
|
||||
SNode& node = AccessElement(x0_nodes, act->GetUniqueId().Value());
|
||||
void CSortedListManager::Move(const CActor* actor, const zeus::CAABox& aabb) {
|
||||
SNode& node = AccessElement(x0_nodes, actor->GetUniqueId().Value());
|
||||
node.x4_box = aabb;
|
||||
|
||||
MoveInList(ESortedList::MinX, node.x1c_selfIdxs[0]);
|
||||
|
@ -297,14 +303,14 @@ void CSortedListManager::Move(const CActor* act, const zeus::CAABox& aabb) {
|
|||
MoveInList(ESortedList::MaxZ, node.x1c_selfIdxs[5]);
|
||||
}
|
||||
|
||||
void CSortedListManager::Insert(const CActor* act, const zeus::CAABox& aabb) {
|
||||
SNode& node = AccessElement(x0_nodes, act->GetUniqueId().Value());
|
||||
void CSortedListManager::Insert(const CActor* actor, const zeus::CAABox& aabb) {
|
||||
SNode& node = AccessElement(x0_nodes, actor->GetUniqueId().Value());
|
||||
if (node.x2a_populated) {
|
||||
Move(act, aabb);
|
||||
Move(actor, aabb);
|
||||
return;
|
||||
}
|
||||
|
||||
SNode newNode(act, aabb);
|
||||
SNode newNode(actor, aabb);
|
||||
InsertInList(ESortedList::MinX, newNode);
|
||||
InsertInList(ESortedList::MaxX, newNode);
|
||||
InsertInList(ESortedList::MinY, newNode);
|
||||
|
@ -314,10 +320,11 @@ void CSortedListManager::Insert(const CActor* act, const zeus::CAABox& aabb) {
|
|||
node = newNode;
|
||||
}
|
||||
|
||||
bool CSortedListManager::ActorInLists(const CActor* act) const {
|
||||
if (!act)
|
||||
bool CSortedListManager::ActorInLists(const CActor* actor) const {
|
||||
if (!actor) {
|
||||
return false;
|
||||
const SNode& node = AccessElement(x0_nodes, act->GetUniqueId().Value());
|
||||
}
|
||||
const SNode& node = AccessElement(x0_nodes, actor->GetUniqueId().Value());
|
||||
return node.x2a_populated;
|
||||
}
|
||||
|
||||
|
|
|
@ -31,27 +31,27 @@ class CSortedListManager {
|
|||
std::array<SNode, 1024> x0_nodes;
|
||||
std::array<SSortedList, 6> xb000_sortedLists;
|
||||
void Reset();
|
||||
void AddToLinkedList(s16 a, s16& b, s16& c) const;
|
||||
void RemoveFromList(ESortedList, s16);
|
||||
void MoveInList(ESortedList, s16);
|
||||
void InsertInList(ESortedList, SNode& node);
|
||||
s16 FindInListUpper(ESortedList, float) const;
|
||||
s16 FindInListLower(ESortedList, float) const;
|
||||
s16 ConstructIntersectionArray(const zeus::CAABox&);
|
||||
s16 CalculateIntersections(ESortedList, ESortedList, s16, s16, s16, s16, ESortedList, ESortedList, ESortedList,
|
||||
ESortedList, const zeus::CAABox&);
|
||||
void AddToLinkedList(s16 nodeId, s16& headId, s16& tailId);
|
||||
void RemoveFromList(ESortedList list, s16 idx);
|
||||
void MoveInList(ESortedList list, s16 idx);
|
||||
void InsertInList(ESortedList list, SNode& node);
|
||||
s16 FindInListUpper(ESortedList list, float value) const;
|
||||
s16 FindInListLower(ESortedList list, float value) const;
|
||||
s16 ConstructIntersectionArray(const zeus::CAABox& aabb);
|
||||
s16 CalculateIntersections(ESortedList la, ESortedList lb, s16 a, s16 b, s16 c, s16 d, ESortedList slA,
|
||||
ESortedList slB, ESortedList slC, ESortedList slD, const zeus::CAABox& aabb);
|
||||
|
||||
public:
|
||||
CSortedListManager();
|
||||
void BuildNearList(rstl::reserved_vector<TUniqueId, 1024>&, const zeus::CVector3f&, const zeus::CVector3f&, float,
|
||||
const CMaterialFilter&, const CActor*) const;
|
||||
void BuildNearList(rstl::reserved_vector<TUniqueId, 1024>&, const CActor&, const zeus::CAABox&) const;
|
||||
void BuildNearList(rstl::reserved_vector<TUniqueId, 1024>&, const zeus::CAABox&, const CMaterialFilter&,
|
||||
const CActor*) const;
|
||||
void Remove(const CActor*);
|
||||
void Move(const CActor* act, const zeus::CAABox& aabb);
|
||||
void Insert(const CActor* act, const zeus::CAABox& aabb);
|
||||
bool ActorInLists(const CActor* act) const;
|
||||
void BuildNearList(rstl::reserved_vector<TUniqueId, 1024>& out, const zeus::CVector3f& pos,
|
||||
const zeus::CVector3f& dir, float mag, const CMaterialFilter& filter, const CActor* actor);
|
||||
void BuildNearList(rstl::reserved_vector<TUniqueId, 1024>& out, const CActor& actor, const zeus::CAABox& aabb);
|
||||
void BuildNearList(rstl::reserved_vector<TUniqueId, 1024>& out, const zeus::CAABox& aabb,
|
||||
const CMaterialFilter& filter, const CActor* actor);
|
||||
void Remove(const CActor* actor);
|
||||
void Move(const CActor* actor, const zeus::CAABox& aabb);
|
||||
void Insert(const CActor* actor, const zeus::CAABox& aabb);
|
||||
bool ActorInLists(const CActor* actor) const;
|
||||
};
|
||||
|
||||
} // namespace urde
|
||||
|
|
|
@ -216,8 +216,8 @@ private:
|
|||
u32 xf94_ = 0;
|
||||
};
|
||||
|
||||
CColoredQuadFilter m_deathWhiteout = {EFilterType::Add};
|
||||
CColoredQuadFilter m_escapeWhiteout = {EFilterType::Add};
|
||||
CColoredQuadFilter m_deathWhiteout{EFilterType::Add};
|
||||
CColoredQuadFilter m_escapeWhiteout{EFilterType::Add};
|
||||
bool m_warping = false;
|
||||
|
||||
void UpdateThermalVisor();
|
||||
|
|
|
@ -80,7 +80,7 @@ class CCameraManager {
|
|||
void EnterCinematic(CStateManager& mgr);
|
||||
|
||||
public:
|
||||
CCameraManager(TUniqueId curCameraId = kInvalidUniqueId);
|
||||
explicit CCameraManager(TUniqueId curCameraId = kInvalidUniqueId);
|
||||
|
||||
static float Aspect() { return 1.42f; }
|
||||
static float FarPlane() { return 750.0f; }
|
||||
|
|
|
@ -61,7 +61,7 @@ public:
|
|||
const CCameraShakerComponent& shaker1, const CCameraShakerComponent& shaker2,
|
||||
const CCameraShakerComponent& shaker3);
|
||||
CCameraShakeData(float duration, float magnitude);
|
||||
CCameraShakeData(CInputStream&);
|
||||
explicit CCameraShakeData(CInputStream&);
|
||||
static CCameraShakeData BuildLandingCameraShakeData(float duration, float magnitude);
|
||||
static CCameraShakeData BuildProjectileCameraShake(float duration, float magnitude);
|
||||
static CCameraShakeData BuildMissileCameraShake(float duration, float magnitude, float sfxDistance,
|
||||
|
|
|
@ -296,11 +296,11 @@ void CCinematicCamera::GenerateMoveOutofIntoPoints(bool outOfEye, CStateManager&
|
|||
behindDelta = -behindDelta;
|
||||
}
|
||||
for (int i = 0; i < 2; ++i) {
|
||||
x188_viewPoints.push_back(behindPos);
|
||||
x198_viewOrientations.push_back(q);
|
||||
x1a8_viewPointArrivals.push_back(mgr.GetPlayer().GetUniqueId());
|
||||
x1b8_targets.push_back(eyePos);
|
||||
x1c8_targetArrivals.push_back(kInvalidUniqueId);
|
||||
x188_viewPoints.emplace_back(behindPos);
|
||||
x198_viewOrientations.emplace_back(q);
|
||||
x1a8_viewPointArrivals.emplace_back(mgr.GetPlayer().GetUniqueId());
|
||||
x1b8_targets.emplace_back(eyePos);
|
||||
x1c8_targetArrivals.emplace_back(kInvalidUniqueId);
|
||||
behindPos += behindDelta;
|
||||
}
|
||||
CalculateMoveOutofIntoEyePosition(outOfEye, mgr);
|
||||
|
|
|
@ -26,7 +26,7 @@ class CInterpolationCamera : public CGameCamera {
|
|||
float maxTime, float curTime);
|
||||
|
||||
public:
|
||||
CInterpolationCamera(TUniqueId uid, const zeus::CTransform& xf);
|
||||
explicit CInterpolationCamera(TUniqueId uid, const zeus::CTransform& xf);
|
||||
void Accept(IVisitor& visitor) override;
|
||||
void AcceptScriptMsg(EScriptObjectMessage, TUniqueId, CStateManager&) override;
|
||||
void ProcessInput(const CFinalInput&, CStateManager& mgr) override;
|
||||
|
|
|
@ -20,7 +20,7 @@ public:
|
|||
x4_fadeOutDur = in.readFloatBig();
|
||||
}
|
||||
CAdditiveAnimationInfo() = default;
|
||||
CAdditiveAnimationInfo(CInputStream& in) { read(in); }
|
||||
explicit CAdditiveAnimationInfo(CInputStream& in) { read(in); }
|
||||
float GetFadeInDuration() const { return x0_fadeInDur; }
|
||||
float GetFadeOutDuration() const { return x4_fadeOutDur; }
|
||||
};
|
||||
|
|
|
@ -26,7 +26,7 @@ class CAnimFormatUnion {
|
|||
static void SubConstruct(u8* storage, EAnimFormat fmt, CInputStream& in, IObjectStore& store);
|
||||
|
||||
public:
|
||||
CAnimFormatUnion(CInputStream& in, IObjectStore& store);
|
||||
explicit CAnimFormatUnion(CInputStream& in, IObjectStore& store);
|
||||
~CAnimFormatUnion();
|
||||
EAnimFormat GetFormat() const { return x0_format; }
|
||||
CAnimSource& GetAsCAnimSource() { return *reinterpret_cast<CAnimSource*>(x4_storage); }
|
||||
|
@ -40,7 +40,7 @@ class CAllFormatsAnimSource : public CAnimFormatUnion {
|
|||
SObjectTag x74_tag;
|
||||
|
||||
public:
|
||||
CAllFormatsAnimSource(CInputStream& in, IObjectStore& store, const SObjectTag& tag);
|
||||
explicit CAllFormatsAnimSource(CInputStream& in, IObjectStore& store, const SObjectTag& tag);
|
||||
static std::shared_ptr<IAnimReader> GetNewReader(const TLockedToken<CAllFormatsAnimSource>& tok,
|
||||
const CCharAnimTime& startTime);
|
||||
};
|
||||
|
|
|
@ -12,7 +12,7 @@ class CAnimCharacterSet {
|
|||
CAnimationSet x1c_animationSet;
|
||||
|
||||
public:
|
||||
CAnimCharacterSet(CInputStream& in);
|
||||
explicit CAnimCharacterSet(CInputStream& in);
|
||||
const CCharacterSet& GetCharacterSet() const { return x4_characterSet; }
|
||||
const CAnimationSet& GetAnimationSet() const { return x1c_animationSet; }
|
||||
};
|
||||
|
|
|
@ -56,7 +56,7 @@ CAnimData::CAnimData(CAssetId id, const CCharacterInfo& character, int defaultAn
|
|||
, x204_charIdx(charIdx)
|
||||
, x208_defaultAnim(defaultAnim)
|
||||
, x224_pose(layout->GetSegIdList().GetList().size())
|
||||
, x2fc_poseBuilder(layout)
|
||||
, x2fc_poseBuilder(CLayoutDescription{layout})
|
||||
, m_drawInstCount(drawInstCount) {
|
||||
x220_25_loop = loop;
|
||||
|
||||
|
@ -72,7 +72,7 @@ CAnimData::CAnimData(CAssetId id, const CCharacterInfo& character, int defaultAn
|
|||
x108_aabb = xd8_modelData->GetModel()->GetAABB();
|
||||
x120_particleDB.CacheParticleDesc(xc_charInfo.GetParticleResData());
|
||||
|
||||
CHierarchyPoseBuilder pb(xcc_layoutData);
|
||||
CHierarchyPoseBuilder pb(CLayoutDescription{xcc_layoutData});
|
||||
pb.BuildNoScale(x224_pose);
|
||||
x220_30_poseBuilt = true;
|
||||
|
||||
|
|
|
@ -251,7 +251,7 @@ public:
|
|||
|
||||
s32 GetCharacterIndex() const { return x204_charIdx; }
|
||||
u16 GetDefaultAnimation() const { return x208_defaultAnim; }
|
||||
TLockedToken<CMorphableSkinnedModel>& IceModel() { return xe4_iceModelData; }
|
||||
TLockedToken<CMorphableSkinnedModel>& GetIceModel() { return xe4_iceModelData; }
|
||||
const TLockedToken<CMorphableSkinnedModel>& GetIceModel() const { return xe4_iceModelData; }
|
||||
void SetParticleLightIdx(s32 idx) { x21c_particleLightIdx = idx; }
|
||||
|
||||
|
|
|
@ -19,7 +19,7 @@ class CAnimPOIData {
|
|||
std::vector<CSoundPOINode> x34_soundNodes;
|
||||
|
||||
public:
|
||||
CAnimPOIData(CInputStream& in);
|
||||
explicit CAnimPOIData(CInputStream& in);
|
||||
|
||||
const std::vector<CBoolPOINode>& GetBoolPOIStream() const { return x4_boolNodes; }
|
||||
const std::vector<CInt32POINode>& GetInt32POIStream() const { return x14_int32Nodes; }
|
||||
|
|
|
@ -39,7 +39,7 @@ public:
|
|||
struct CRotationAndOffsetVectors {
|
||||
std::vector<zeus::CQuaternion> x0_rotations;
|
||||
std::vector<zeus::CVector3f> x10_offsets;
|
||||
CRotationAndOffsetVectors(CInputStream& in);
|
||||
explicit CRotationAndOffsetVectors(CInputStream& in);
|
||||
};
|
||||
u32 GetFrameSizeInBytes() const;
|
||||
RotationAndOffsetStorage(const CRotationAndOffsetVectors& vectors, u32 frameCount);
|
||||
|
@ -61,7 +61,7 @@ class CAnimSource {
|
|||
void CalcAverageVelocity();
|
||||
|
||||
public:
|
||||
CAnimSource(CInputStream& in, IObjectStore& store);
|
||||
explicit CAnimSource(CInputStream& in, IObjectStore& store);
|
||||
|
||||
void GetSegStatementSet(const CSegIdList& list, CSegStatementSet& set, const CCharAnimTime& time) const;
|
||||
|
||||
|
|
|
@ -172,7 +172,7 @@ u32 CAnimSourceReaderBase::VGetSoundPOIList(const CCharAnimTime& time, CSoundPOI
|
|||
return 0;
|
||||
}
|
||||
|
||||
bool CAnimSourceReaderBase::VGetBoolPOIState(const char* name) const {
|
||||
bool CAnimSourceReaderBase::VGetBoolPOIState(std::string_view name) const {
|
||||
const auto iter = std::find_if(x24_boolStates.cbegin(), x24_boolStates.cend(),
|
||||
[name](const auto& entry) { return entry.first == name; });
|
||||
|
||||
|
@ -183,7 +183,7 @@ bool CAnimSourceReaderBase::VGetBoolPOIState(const char* name) const {
|
|||
return iter->second;
|
||||
}
|
||||
|
||||
s32 CAnimSourceReaderBase::VGetInt32POIState(const char* name) const {
|
||||
s32 CAnimSourceReaderBase::VGetInt32POIState(std::string_view name) const {
|
||||
const auto iter = std::find_if(x34_int32States.cbegin(), x34_int32States.cend(),
|
||||
[name](const auto& entry) { return entry.first == name; });
|
||||
|
||||
|
@ -194,7 +194,7 @@ s32 CAnimSourceReaderBase::VGetInt32POIState(const char* name) const {
|
|||
return iter->second;
|
||||
}
|
||||
|
||||
CParticleData::EParentedMode CAnimSourceReaderBase::VGetParticlePOIState(const char* name) const {
|
||||
CParticleData::EParentedMode CAnimSourceReaderBase::VGetParticlePOIState(std::string_view name) const {
|
||||
const auto iter = std::find_if(x44_particleStates.cbegin(), x44_particleStates.cend(),
|
||||
[name](const auto& entry) { return entry.first == name; });
|
||||
|
||||
|
|
|
@ -68,9 +68,9 @@ public:
|
|||
u32) const override;
|
||||
u32 VGetSoundPOIList(const CCharAnimTime& time, CSoundPOINode* listOut, u32 capacity, u32 iterator,
|
||||
u32) const override;
|
||||
bool VGetBoolPOIState(const char* name) const override;
|
||||
s32 VGetInt32POIState(const char* name) const override;
|
||||
CParticleData::EParentedMode VGetParticlePOIState(const char* name) const override;
|
||||
bool VGetBoolPOIState(std::string_view name) const override;
|
||||
s32 VGetInt32POIState(std::string_view name) const override;
|
||||
CParticleData::EParentedMode VGetParticlePOIState(std::string_view name) const override;
|
||||
|
||||
using IAnimReader::VGetOffset;
|
||||
virtual zeus::CVector3f VGetOffset(const CSegId& seg, const CCharAnimTime& b) const = 0;
|
||||
|
|
|
@ -58,15 +58,15 @@ u32 CAnimTreeAnimReaderContainer::VGetSoundPOIList(const CCharAnimTime& time, CS
|
|||
return x14_reader->GetSoundPOIList(time, listOut, capacity, iterator, unk);
|
||||
}
|
||||
|
||||
bool CAnimTreeAnimReaderContainer::VGetBoolPOIState(const char* name) const {
|
||||
bool CAnimTreeAnimReaderContainer::VGetBoolPOIState(std::string_view name) const {
|
||||
return x14_reader->VGetBoolPOIState(name);
|
||||
}
|
||||
|
||||
s32 CAnimTreeAnimReaderContainer::VGetInt32POIState(const char* name) const {
|
||||
return x14_reader->VGetBoolPOIState(name);
|
||||
s32 CAnimTreeAnimReaderContainer::VGetInt32POIState(std::string_view name) const {
|
||||
return x14_reader->VGetInt32POIState(name);
|
||||
}
|
||||
|
||||
CParticleData::EParentedMode CAnimTreeAnimReaderContainer::VGetParticlePOIState(const char* name) const {
|
||||
CParticleData::EParentedMode CAnimTreeAnimReaderContainer::VGetParticlePOIState(std::string_view name) const {
|
||||
return x14_reader->VGetParticlePOIState(name);
|
||||
}
|
||||
|
||||
|
|
|
@ -37,9 +37,9 @@ public:
|
|||
u32) const override;
|
||||
u32 VGetSoundPOIList(const CCharAnimTime& time, CSoundPOINode* listOut, u32 capacity, u32 iterator,
|
||||
u32) const override;
|
||||
bool VGetBoolPOIState(const char*) const override;
|
||||
s32 VGetInt32POIState(const char*) const override;
|
||||
CParticleData::EParentedMode VGetParticlePOIState(const char*) const override;
|
||||
bool VGetBoolPOIState(std::string_view name) const override;
|
||||
s32 VGetInt32POIState(std::string_view name) const override;
|
||||
CParticleData::EParentedMode VGetParticlePOIState(std::string_view name) const override;
|
||||
void VGetSegStatementSet(const CSegIdList& list, CSegStatementSet& setOut) const override;
|
||||
void VGetSegStatementSet(const CSegIdList& list, CSegStatementSet& setOut, const CCharAnimTime& time) const override;
|
||||
std::unique_ptr<IAnimReader> VClone() const override;
|
||||
|
|
|
@ -101,11 +101,11 @@ u32 CAnimTreeDoubleChild::VGetSoundPOIList(const CCharAnimTime& time, CSoundPOIN
|
|||
return newCapacity;
|
||||
}
|
||||
|
||||
bool CAnimTreeDoubleChild::VGetBoolPOIState(const char* name) const { return x18_b->VGetBoolPOIState(name); }
|
||||
bool CAnimTreeDoubleChild::VGetBoolPOIState(std::string_view name) const { return x18_b->VGetBoolPOIState(name); }
|
||||
|
||||
s32 CAnimTreeDoubleChild::VGetInt32POIState(const char* name) const { return x18_b->VGetBoolPOIState(name); }
|
||||
s32 CAnimTreeDoubleChild::VGetInt32POIState(std::string_view name) const { return x18_b->VGetInt32POIState(name); }
|
||||
|
||||
CParticleData::EParentedMode CAnimTreeDoubleChild::VGetParticlePOIState(const char* name) const {
|
||||
CParticleData::EParentedMode CAnimTreeDoubleChild::VGetParticlePOIState(std::string_view name) const {
|
||||
return x18_b->VGetParticlePOIState(name);
|
||||
}
|
||||
|
||||
|
|
|
@ -41,9 +41,9 @@ public:
|
|||
u32) const override;
|
||||
u32 VGetSoundPOIList(const CCharAnimTime& time, CSoundPOINode* listOut, u32 capacity, u32 iterator,
|
||||
u32) const override;
|
||||
bool VGetBoolPOIState(const char* name) const override;
|
||||
s32 VGetInt32POIState(const char* name) const override;
|
||||
CParticleData::EParentedMode VGetParticlePOIState(const char* name) const override;
|
||||
bool VGetBoolPOIState(std::string_view name) const override;
|
||||
s32 VGetInt32POIState(std::string_view name) const override;
|
||||
CParticleData::EParentedMode VGetParticlePOIState(std::string_view name) const override;
|
||||
void VSetPhase(float) override;
|
||||
SAdvancementResults VGetAdvancementResults(const CCharAnimTime& a, const CCharAnimTime& b) const override;
|
||||
u32 Depth() const override;
|
||||
|
|
|
@ -14,7 +14,7 @@ protected:
|
|||
std::string x4_name;
|
||||
|
||||
public:
|
||||
CAnimTreeNode(std::string_view name) : x4_name(name) {}
|
||||
explicit CAnimTreeNode(std::string_view name) : x4_name(name) {}
|
||||
bool IsCAnimTreeNode() const override { return true; }
|
||||
static std::shared_ptr<CAnimTreeNode> Cast(std::unique_ptr<IAnimReader>&& ptr) {
|
||||
if (ptr->IsCAnimTreeNode())
|
||||
|
|
|
@ -35,11 +35,11 @@ u32 CAnimTreeSingleChild::VGetSoundPOIList(const CCharAnimTime& time, CSoundPOIN
|
|||
return x14_child->GetSoundPOIList(time, listOut, capacity, iterator, unk);
|
||||
}
|
||||
|
||||
bool CAnimTreeSingleChild::VGetBoolPOIState(const char* name) const { return x14_child->VGetBoolPOIState(name); }
|
||||
bool CAnimTreeSingleChild::VGetBoolPOIState(std::string_view name) const { return x14_child->VGetBoolPOIState(name); }
|
||||
|
||||
s32 CAnimTreeSingleChild::VGetInt32POIState(const char* name) const { return x14_child->VGetInt32POIState(name); }
|
||||
s32 CAnimTreeSingleChild::VGetInt32POIState(std::string_view name) const { return x14_child->VGetInt32POIState(name); }
|
||||
|
||||
CParticleData::EParentedMode CAnimTreeSingleChild::VGetParticlePOIState(const char* name) const {
|
||||
CParticleData::EParentedMode CAnimTreeSingleChild::VGetParticlePOIState(std::string_view name) const {
|
||||
return x14_child->VGetParticlePOIState(name);
|
||||
}
|
||||
|
||||
|
|
|
@ -27,9 +27,9 @@ public:
|
|||
u32) const override;
|
||||
u32 VGetSoundPOIList(const CCharAnimTime& time, CSoundPOINode* listOut, u32 capacity, u32 iterator,
|
||||
u32) const override;
|
||||
bool VGetBoolPOIState(const char* name) const override;
|
||||
s32 VGetInt32POIState(const char* name) const override;
|
||||
CParticleData::EParentedMode VGetParticlePOIState(const char* name) const override;
|
||||
bool VGetBoolPOIState(std::string_view name) const override;
|
||||
s32 VGetInt32POIState(std::string_view name) const override;
|
||||
CParticleData::EParentedMode VGetParticlePOIState(std::string_view name) const override;
|
||||
void VGetSegStatementSet(const CSegIdList& list, CSegStatementSet& setOut) const override;
|
||||
void VGetSegStatementSet(const CSegIdList& list, CSegStatementSet& setOut, const CCharAnimTime& time) const override;
|
||||
void VSetPhase(float) override;
|
||||
|
|
|
@ -99,11 +99,11 @@ u32 CAnimTreeTimeScale::VGetSoundPOIList(const CCharAnimTime& time, CSoundPOINod
|
|||
return ret;
|
||||
}
|
||||
|
||||
bool CAnimTreeTimeScale::VGetBoolPOIState(const char* name) const { return x14_child->VGetBoolPOIState(name); }
|
||||
bool CAnimTreeTimeScale::VGetBoolPOIState(std::string_view name) const { return x14_child->VGetBoolPOIState(name); }
|
||||
|
||||
s32 CAnimTreeTimeScale::VGetInt32POIState(const char* name) const { return x14_child->VGetInt32POIState(name); }
|
||||
s32 CAnimTreeTimeScale::VGetInt32POIState(std::string_view name) const { return x14_child->VGetInt32POIState(name); }
|
||||
|
||||
CParticleData::EParentedMode CAnimTreeTimeScale::VGetParticlePOIState(const char* name) const {
|
||||
CParticleData::EParentedMode CAnimTreeTimeScale::VGetParticlePOIState(std::string_view name) const {
|
||||
return x14_child->VGetParticlePOIState(name);
|
||||
}
|
||||
|
||||
|
|
|
@ -34,9 +34,9 @@ public:
|
|||
u32) const override;
|
||||
u32 VGetSoundPOIList(const CCharAnimTime& time, CSoundPOINode* listOut, u32 capacity, u32 iterator,
|
||||
u32) const override;
|
||||
bool VGetBoolPOIState(const char* name) const override;
|
||||
s32 VGetInt32POIState(const char* name) const override;
|
||||
CParticleData::EParentedMode VGetParticlePOIState(const char* name) const override;
|
||||
bool VGetBoolPOIState(std::string_view name) const override;
|
||||
s32 VGetInt32POIState(std::string_view name) const override;
|
||||
CParticleData::EParentedMode VGetParticlePOIState(std::string_view name) const override;
|
||||
|
||||
CAnimTreeEffectiveContribution VGetContributionOfHighestInfluence() const override;
|
||||
std::shared_ptr<IAnimReader> VGetBestUnblendedChild() const override;
|
||||
|
|
|
@ -14,7 +14,7 @@ class CAnimation {
|
|||
std::shared_ptr<IMetaAnim> x10_anim;
|
||||
|
||||
public:
|
||||
CAnimation(CInputStream& in);
|
||||
explicit CAnimation(CInputStream& in);
|
||||
const std::shared_ptr<IMetaAnim>& GetMetaAnim() const { return x10_anim; }
|
||||
std::string_view GetMetaAnimName() const { return x0_name; }
|
||||
};
|
||||
|
|
|
@ -12,7 +12,7 @@ class CAnimationDatabaseGame final : public CAnimationDatabase {
|
|||
std::vector<std::shared_ptr<IMetaAnim>> x10_anims;
|
||||
|
||||
public:
|
||||
CAnimationDatabaseGame(const std::vector<CAnimation>& anims);
|
||||
explicit CAnimationDatabaseGame(const std::vector<CAnimation>& anims);
|
||||
const std::shared_ptr<IMetaAnim>& GetMetaAnim(s32 idx) const override;
|
||||
u32 GetNumMetaAnims() const override;
|
||||
const char* GetMetaAnimName(s32 idx) const override;
|
||||
|
|
|
@ -24,7 +24,7 @@ class CAnimationSet {
|
|||
std::vector<std::pair<CAssetId, CAssetId>> x50_animRes;
|
||||
|
||||
public:
|
||||
CAnimationSet(CInputStream& in);
|
||||
explicit CAnimationSet(CInputStream& in);
|
||||
|
||||
const std::vector<CAnimation>& GetAnimations() const { return x4_animations; }
|
||||
const std::vector<CTransition>& GetTransitions() const { return x14_transitions; }
|
||||
|
|
|
@ -105,7 +105,7 @@ class CBSLieOnGround : public CBodyState {
|
|||
pas::EAnimationState GetBodyStateTransition(float dt, CBodyController& bc) const;
|
||||
|
||||
public:
|
||||
CBSLieOnGround(CActor& actor);
|
||||
explicit CBSLieOnGround(CActor& actor);
|
||||
void Start(CBodyController& bc, CStateManager& mgr) override;
|
||||
pas::EAnimationState UpdateBody(float dt, CBodyController& bc, CStateManager& mgr) override;
|
||||
void Shutdown(CBodyController& bc) override;
|
||||
|
@ -371,7 +371,7 @@ protected:
|
|||
}
|
||||
|
||||
public:
|
||||
CBSBiPedLocomotion(CActor& actor);
|
||||
explicit CBSBiPedLocomotion(CActor& actor);
|
||||
bool IsMoving() const override { return x3c4_anim != pas::ELocomotionAnim::Idle; }
|
||||
void Start(CBodyController& bc, CStateManager& mgr) override;
|
||||
pas::EAnimationState UpdateBody(float dt, CBodyController& bc, CStateManager& mgr) override;
|
||||
|
@ -384,7 +384,7 @@ class CBSFlyerLocomotion : public CBSBiPedLocomotion {
|
|||
bool x3cc_pitchable;
|
||||
|
||||
public:
|
||||
CBSFlyerLocomotion(CActor& actor, bool pitchable);
|
||||
explicit CBSFlyerLocomotion(CActor& actor, bool pitchable);
|
||||
bool IsPitchable() const override { return x3cc_pitchable; }
|
||||
float ApplyLocomotionPhysics(float dt, CBodyController& bc) override;
|
||||
virtual bool IsBackPedal(CBodyController& bc) const { return false; }
|
||||
|
@ -392,13 +392,13 @@ public:
|
|||
|
||||
class CBSWallWalkerLocomotion : public CBSBiPedLocomotion {
|
||||
public:
|
||||
CBSWallWalkerLocomotion(CActor& actor);
|
||||
explicit CBSWallWalkerLocomotion(CActor& actor);
|
||||
float ApplyLocomotionPhysics(float dt, CBodyController& bc) override;
|
||||
};
|
||||
|
||||
class CBSNewFlyerLocomotion : public CBSBiPedLocomotion {
|
||||
public:
|
||||
CBSNewFlyerLocomotion(CActor& actor);
|
||||
explicit CBSNewFlyerLocomotion(CActor& actor);
|
||||
float ApplyLocomotionPhysics(float dt, CBodyController& bc) override;
|
||||
float UpdateLocomotionAnimation(float dt, float velMag, CBodyController& bc, bool init) override;
|
||||
};
|
||||
|
@ -408,7 +408,7 @@ class CBSRestrictedLocomotion : public CBSLocomotion {
|
|||
pas::ELocomotionAnim x44_anim = pas::ELocomotionAnim::Invalid;
|
||||
|
||||
public:
|
||||
CBSRestrictedLocomotion(CActor& actor);
|
||||
explicit CBSRestrictedLocomotion(CActor& actor);
|
||||
bool IsMoving() const override { return false; }
|
||||
float GetLocomotionSpeed(pas::ELocomotionType type, pas::ELocomotionAnim anim) const override { return 0.f; }
|
||||
float UpdateLocomotionAnimation(float dt, float velMag, CBodyController& bc, bool init) override;
|
||||
|
@ -416,7 +416,7 @@ public:
|
|||
|
||||
class CBSRestrictedFlyerLocomotion : public CBSRestrictedLocomotion {
|
||||
public:
|
||||
CBSRestrictedFlyerLocomotion(CActor& actor);
|
||||
explicit CBSRestrictedFlyerLocomotion(CActor& actor);
|
||||
float ApplyLocomotionPhysics(float dt, CBodyController& bc) override;
|
||||
};
|
||||
} // namespace urde
|
||||
|
|
|
@ -13,7 +13,7 @@ class CBodyStateCmd {
|
|||
|
||||
public:
|
||||
virtual ~CBodyStateCmd() = default;
|
||||
CBodyStateCmd(EBodyStateCmd cmd) : x4_cmd(cmd) {}
|
||||
explicit CBodyStateCmd(EBodyStateCmd cmd) : x4_cmd(cmd) {}
|
||||
EBodyStateCmd GetCommandId() const { return x4_cmd; }
|
||||
};
|
||||
|
||||
|
@ -23,10 +23,11 @@ class CBCMeleeAttackCmd : public CBodyStateCmd {
|
|||
bool x18_hasTargetPos = false;
|
||||
|
||||
public:
|
||||
CBCMeleeAttackCmd() : CBodyStateCmd(EBodyStateCmd::MeleeAttack) {}
|
||||
CBCMeleeAttackCmd(pas::ESeverity severity) : CBodyStateCmd(EBodyStateCmd::MeleeAttack), x8_severity(severity) {}
|
||||
CBCMeleeAttackCmd(pas::ESeverity severity, const zeus::CVector3f& target) : CBodyStateCmd(EBodyStateCmd::MeleeAttack)
|
||||
, x8_severity(severity), xc_targetPos(target), x18_hasTargetPos(true) {}
|
||||
explicit CBCMeleeAttackCmd() : CBodyStateCmd(EBodyStateCmd::MeleeAttack) {}
|
||||
explicit CBCMeleeAttackCmd(pas::ESeverity severity)
|
||||
: CBodyStateCmd(EBodyStateCmd::MeleeAttack), x8_severity(severity) {}
|
||||
explicit CBCMeleeAttackCmd(pas::ESeverity severity, const zeus::CVector3f& target)
|
||||
: CBodyStateCmd(EBodyStateCmd::MeleeAttack), x8_severity(severity), xc_targetPos(target), x18_hasTargetPos(true) {}
|
||||
pas::ESeverity GetAttackSeverity() const { return x8_severity; }
|
||||
bool HasAttackTargetPos() const { return x18_hasTargetPos; }
|
||||
const zeus::CVector3f& GetAttackTargetPos() const { return xc_targetPos; }
|
||||
|
@ -38,8 +39,8 @@ class CBCProjectileAttackCmd : public CBodyStateCmd {
|
|||
bool x18_blendAnims = false;
|
||||
|
||||
public:
|
||||
CBCProjectileAttackCmd() : CBodyStateCmd(EBodyStateCmd::ProjectileAttack) {}
|
||||
CBCProjectileAttackCmd(pas::ESeverity severity, const zeus::CVector3f& vec, bool b)
|
||||
explicit CBCProjectileAttackCmd() : CBodyStateCmd(EBodyStateCmd::ProjectileAttack) {}
|
||||
explicit CBCProjectileAttackCmd(pas::ESeverity severity, const zeus::CVector3f& vec, bool b)
|
||||
: CBodyStateCmd(EBodyStateCmd::ProjectileAttack), x8_severity(severity), xc_target(vec), x18_blendAnims(b) {}
|
||||
pas::ESeverity GetAttackSeverity() const { return x8_severity; }
|
||||
const zeus::CVector3f& GetTargetPosition() const { return xc_target; }
|
||||
|
@ -51,8 +52,8 @@ class CBCStepCmd : public CBodyStateCmd {
|
|||
pas::EStepType xc_type = pas::EStepType::Normal;
|
||||
|
||||
public:
|
||||
CBCStepCmd() : CBodyStateCmd(EBodyStateCmd::Step) {}
|
||||
CBCStepCmd(pas::EStepDirection dir, pas::EStepType type)
|
||||
explicit CBCStepCmd() : CBodyStateCmd(EBodyStateCmd::Step) {}
|
||||
explicit CBCStepCmd(pas::EStepDirection dir, pas::EStepType type)
|
||||
: CBodyStateCmd(EBodyStateCmd::Step), x8_dir(dir), xc_type(type) {}
|
||||
pas::EStepDirection GetStepDirection() const { return x8_dir; }
|
||||
pas::EStepType GetStepType() const { return xc_type; }
|
||||
|
@ -66,16 +67,16 @@ class CBCJumpCmd : public CBodyStateCmd {
|
|||
bool x24_25_startInJumpLoop : 1;
|
||||
|
||||
public:
|
||||
CBCJumpCmd() : CBodyStateCmd(EBodyStateCmd::Jump) {
|
||||
explicit CBCJumpCmd() : CBodyStateCmd(EBodyStateCmd::Jump) {
|
||||
x24_24_wallJump = false;
|
||||
x24_25_startInJumpLoop = false;
|
||||
}
|
||||
CBCJumpCmd(const zeus::CVector3f& wp1, pas::EJumpType type, bool startInLoop = false)
|
||||
explicit CBCJumpCmd(const zeus::CVector3f& wp1, pas::EJumpType type, bool startInLoop = false)
|
||||
: CBodyStateCmd(EBodyStateCmd::Jump), x8_type(type), xc_waypoint1(wp1) {
|
||||
x24_24_wallJump = false;
|
||||
x24_25_startInJumpLoop = startInLoop;
|
||||
}
|
||||
CBCJumpCmd(const zeus::CVector3f& wp1, const zeus::CVector3f& wp2, pas::EJumpType type)
|
||||
explicit CBCJumpCmd(const zeus::CVector3f& wp1, const zeus::CVector3f& wp2, pas::EJumpType type)
|
||||
: CBodyStateCmd(EBodyStateCmd::Jump), x8_type(type), xc_waypoint1(wp1), x18_waypoint2(wp2) {
|
||||
x24_24_wallJump = true;
|
||||
x24_25_startInJumpLoop = false;
|
||||
|
@ -95,22 +96,22 @@ class CBCGenerateCmd : public CBodyStateCmd {
|
|||
bool x1c_25_overrideAnim : 1;
|
||||
|
||||
public:
|
||||
CBCGenerateCmd() : CBodyStateCmd(EBodyStateCmd::Generate) {
|
||||
explicit CBCGenerateCmd() : CBodyStateCmd(EBodyStateCmd::Generate) {
|
||||
x1c_24_targetTransform = false;
|
||||
x1c_25_overrideAnim = false;
|
||||
}
|
||||
CBCGenerateCmd(pas::EGenerateType type)
|
||||
explicit CBCGenerateCmd(pas::EGenerateType type)
|
||||
: CBodyStateCmd(EBodyStateCmd::Generate), x8_type(type) {
|
||||
x1c_24_targetTransform = false;
|
||||
x1c_25_overrideAnim = false;
|
||||
}
|
||||
CBCGenerateCmd(pas::EGenerateType type, s32 animId)
|
||||
explicit CBCGenerateCmd(pas::EGenerateType type, s32 animId)
|
||||
: CBodyStateCmd(EBodyStateCmd::Generate), x8_type(type), x18_animId(animId) {
|
||||
x1c_24_targetTransform = false;
|
||||
x1c_25_overrideAnim = animId != -1;
|
||||
}
|
||||
CBCGenerateCmd(pas::EGenerateType type, const zeus::CVector3f& vec, bool targetTransform = false,
|
||||
bool overrideAnim = false)
|
||||
explicit CBCGenerateCmd(pas::EGenerateType type, const zeus::CVector3f& vec, bool targetTransform = false,
|
||||
bool overrideAnim = false)
|
||||
: CBodyStateCmd(EBodyStateCmd::Generate), x8_type(type), xc_targetPos(vec) {
|
||||
x1c_24_targetTransform = targetTransform;
|
||||
x1c_25_overrideAnim = overrideAnim;
|
||||
|
@ -127,8 +128,8 @@ class CBCKnockBackCmd : public CBodyStateCmd {
|
|||
pas::ESeverity x14_severity = pas::ESeverity::Invalid;
|
||||
|
||||
public:
|
||||
CBCKnockBackCmd() : CBodyStateCmd(EBodyStateCmd::KnockBack) {}
|
||||
CBCKnockBackCmd(const zeus::CVector3f& vec, pas::ESeverity severity)
|
||||
explicit CBCKnockBackCmd() : CBodyStateCmd(EBodyStateCmd::KnockBack) {}
|
||||
explicit CBCKnockBackCmd(const zeus::CVector3f& vec, pas::ESeverity severity)
|
||||
: CBodyStateCmd(EBodyStateCmd::KnockBack), x8_dir(vec), x14_severity(severity) {}
|
||||
const zeus::CVector3f& GetHitDirection() const { return x8_dir; }
|
||||
pas::ESeverity GetHitSeverity() const { return x14_severity; }
|
||||
|
@ -140,8 +141,8 @@ class CBCHurledCmd : public CBodyStateCmd {
|
|||
bool x20_startInKnockLoop = false;
|
||||
|
||||
public:
|
||||
CBCHurledCmd() : CBodyStateCmd(EBodyStateCmd::Hurled) {}
|
||||
CBCHurledCmd(const zeus::CVector3f& dir, const zeus::CVector3f& launchVel, bool startInLoop = false)
|
||||
explicit CBCHurledCmd() : CBodyStateCmd(EBodyStateCmd::Hurled) {}
|
||||
explicit CBCHurledCmd(const zeus::CVector3f& dir, const zeus::CVector3f& launchVel, bool startInLoop = false)
|
||||
: CBodyStateCmd(EBodyStateCmd::Hurled)
|
||||
, x8_direction(dir)
|
||||
, x14_launchVel(launchVel)
|
||||
|
@ -156,8 +157,8 @@ class CBCGetupCmd : public CBodyStateCmd {
|
|||
pas::EGetupType x8_type = pas::EGetupType::Invalid;
|
||||
|
||||
public:
|
||||
CBCGetupCmd() : CBodyStateCmd(EBodyStateCmd::Getup) {}
|
||||
CBCGetupCmd(pas::EGetupType type) : CBodyStateCmd(EBodyStateCmd::Getup), x8_type(type) {}
|
||||
explicit CBCGetupCmd() : CBodyStateCmd(EBodyStateCmd::Getup) {}
|
||||
explicit CBCGetupCmd(pas::EGetupType type) : CBodyStateCmd(EBodyStateCmd::Getup), x8_type(type) {}
|
||||
pas::EGetupType GetGetupType() const { return x8_type; }
|
||||
};
|
||||
|
||||
|
@ -165,8 +166,8 @@ class CBCLoopReactionCmd : public CBodyStateCmd {
|
|||
pas::EReactionType x8_type = pas::EReactionType::Invalid;
|
||||
|
||||
public:
|
||||
CBCLoopReactionCmd() : CBodyStateCmd(EBodyStateCmd::LoopReaction) {}
|
||||
CBCLoopReactionCmd(pas::EReactionType type) : CBodyStateCmd(EBodyStateCmd::LoopReaction), x8_type(type) {}
|
||||
explicit CBCLoopReactionCmd() : CBodyStateCmd(EBodyStateCmd::LoopReaction) {}
|
||||
explicit CBCLoopReactionCmd(pas::EReactionType type) : CBodyStateCmd(EBodyStateCmd::LoopReaction), x8_type(type) {}
|
||||
pas::EReactionType GetReactionType() const { return x8_type; }
|
||||
};
|
||||
|
||||
|
@ -174,8 +175,8 @@ class CBCLoopHitReactionCmd : public CBodyStateCmd {
|
|||
pas::EReactionType x8_type = pas::EReactionType::Invalid;
|
||||
|
||||
public:
|
||||
CBCLoopHitReactionCmd() : CBodyStateCmd(EBodyStateCmd::LoopHitReaction) {}
|
||||
CBCLoopHitReactionCmd(pas::EReactionType type) : CBodyStateCmd(EBodyStateCmd::LoopHitReaction), x8_type(type) {}
|
||||
explicit CBCLoopHitReactionCmd() : CBodyStateCmd(EBodyStateCmd::LoopHitReaction) {}
|
||||
explicit CBCLoopHitReactionCmd(pas::EReactionType type) : CBodyStateCmd(EBodyStateCmd::LoopHitReaction), x8_type(type) {}
|
||||
pas::EReactionType GetReactionType() const { return x8_type; }
|
||||
};
|
||||
|
||||
|
@ -184,8 +185,8 @@ class CBCKnockDownCmd : public CBodyStateCmd {
|
|||
pas::ESeverity x14_severity = pas::ESeverity::Invalid;
|
||||
|
||||
public:
|
||||
CBCKnockDownCmd() : CBodyStateCmd(EBodyStateCmd::KnockDown) {}
|
||||
CBCKnockDownCmd(const zeus::CVector3f& vec, pas::ESeverity severity)
|
||||
explicit CBCKnockDownCmd() : CBodyStateCmd(EBodyStateCmd::KnockDown) {}
|
||||
explicit CBCKnockDownCmd(const zeus::CVector3f& vec, pas::ESeverity severity)
|
||||
: CBodyStateCmd(EBodyStateCmd::KnockDown), x8_dir(vec), x14_severity(severity) {}
|
||||
const zeus::CVector3f& GetHitDirection() const { return x8_dir; }
|
||||
pas::ESeverity GetHitSeverity() const { return x14_severity; }
|
||||
|
@ -196,8 +197,8 @@ class CBCSlideCmd : public CBodyStateCmd {
|
|||
zeus::CVector3f xc_dir;
|
||||
|
||||
public:
|
||||
CBCSlideCmd() : CBodyStateCmd(EBodyStateCmd::Slide) {}
|
||||
CBCSlideCmd(pas::ESlideType type, const zeus::CVector3f& dir)
|
||||
explicit CBCSlideCmd() : CBodyStateCmd(EBodyStateCmd::Slide) {}
|
||||
explicit CBCSlideCmd(pas::ESlideType type, const zeus::CVector3f& dir)
|
||||
: CBodyStateCmd(EBodyStateCmd::Slide), x8_type(type), xc_dir(dir) {}
|
||||
pas::ESlideType GetSlideType() const { return x8_type; }
|
||||
const zeus::CVector3f& GetSlideDirection() const { return xc_dir; }
|
||||
|
@ -210,11 +211,11 @@ class CBCScriptedCmd : public CBodyStateCmd {
|
|||
float x10_loopDur = 0.f;
|
||||
|
||||
public:
|
||||
CBCScriptedCmd() : CBodyStateCmd(EBodyStateCmd::Scripted) {
|
||||
explicit CBCScriptedCmd() : CBodyStateCmd(EBodyStateCmd::Scripted) {
|
||||
xc_24_loopAnim = false;
|
||||
xc_25_timedLoop = false;
|
||||
}
|
||||
CBCScriptedCmd(int i, bool b1, bool b2, float f)
|
||||
explicit CBCScriptedCmd(int i, bool b1, bool b2, float f)
|
||||
: CBodyStateCmd(EBodyStateCmd::Scripted), x8_anim(i), x10_loopDur(f) {
|
||||
xc_24_loopAnim = b1;
|
||||
xc_25_timedLoop = b2;
|
||||
|
@ -231,8 +232,8 @@ class CBCCoverCmd : public CBodyStateCmd {
|
|||
zeus::CVector3f x18_alignDir;
|
||||
|
||||
public:
|
||||
CBCCoverCmd() : CBodyStateCmd(EBodyStateCmd::Cover) {}
|
||||
CBCCoverCmd(pas::ECoverDirection dir, const zeus::CVector3f& v1, const zeus::CVector3f& v2)
|
||||
explicit CBCCoverCmd() : CBodyStateCmd(EBodyStateCmd::Cover) {}
|
||||
explicit CBCCoverCmd(pas::ECoverDirection dir, const zeus::CVector3f& v1, const zeus::CVector3f& v2)
|
||||
: CBodyStateCmd(EBodyStateCmd::Cover), x8_dir(dir), xc_targetPos(v1), x18_alignDir(v2) {}
|
||||
pas::ECoverDirection GetDirection() const { return x8_dir; }
|
||||
const zeus::CVector3f& GetTarget() const { return xc_targetPos; }
|
||||
|
@ -243,22 +244,22 @@ class CBCWallHangCmd : public CBodyStateCmd {
|
|||
TUniqueId x8_wpId = kInvalidUniqueId;
|
||||
|
||||
public:
|
||||
CBCWallHangCmd() : CBodyStateCmd(EBodyStateCmd::WallHang) {}
|
||||
CBCWallHangCmd(TUniqueId uid) : CBodyStateCmd(EBodyStateCmd::WallHang), x8_wpId(uid) {}
|
||||
explicit CBCWallHangCmd() : CBodyStateCmd(EBodyStateCmd::WallHang) {}
|
||||
explicit CBCWallHangCmd(TUniqueId uid) : CBodyStateCmd(EBodyStateCmd::WallHang), x8_wpId(uid) {}
|
||||
TUniqueId GetTarget() const { return x8_wpId; }
|
||||
};
|
||||
|
||||
class CBCAdditiveAimCmd : public CBodyStateCmd {
|
||||
public:
|
||||
CBCAdditiveAimCmd() : CBodyStateCmd(EBodyStateCmd::AdditiveAim) {}
|
||||
explicit CBCAdditiveAimCmd() : CBodyStateCmd(EBodyStateCmd::AdditiveAim) {}
|
||||
};
|
||||
|
||||
class CBCAdditiveFlinchCmd : public CBodyStateCmd {
|
||||
float x8_weight = 1.f;
|
||||
|
||||
public:
|
||||
CBCAdditiveFlinchCmd() : CBodyStateCmd(EBodyStateCmd::AdditiveFlinch) {}
|
||||
CBCAdditiveFlinchCmd(float f) : CBodyStateCmd(EBodyStateCmd::AdditiveFlinch), x8_weight(f) {}
|
||||
explicit CBCAdditiveFlinchCmd() : CBodyStateCmd(EBodyStateCmd::AdditiveFlinch) {}
|
||||
explicit CBCAdditiveFlinchCmd(float f) : CBodyStateCmd(EBodyStateCmd::AdditiveFlinch), x8_weight(f) {}
|
||||
float GetWeight() const { return x8_weight; }
|
||||
};
|
||||
|
||||
|
@ -268,9 +269,9 @@ class CBCAdditiveReactionCmd : public CBodyStateCmd {
|
|||
bool x10_active = false;
|
||||
|
||||
public:
|
||||
CBCAdditiveReactionCmd() : CBodyStateCmd(EBodyStateCmd::AdditiveReaction) {}
|
||||
CBCAdditiveReactionCmd(pas::EAdditiveReactionType type, float f, bool active)
|
||||
: CBodyStateCmd(EBodyStateCmd::AdditiveReaction), x8_weight(f), xc_type(type), x10_active(active) {}
|
||||
explicit CBCAdditiveReactionCmd() : CBodyStateCmd(EBodyStateCmd::AdditiveReaction) {}
|
||||
explicit CBCAdditiveReactionCmd(pas::EAdditiveReactionType type, float weight, bool active)
|
||||
: CBodyStateCmd(EBodyStateCmd::AdditiveReaction), x8_weight(weight), xc_type(type), x10_active(active) {}
|
||||
pas::EAdditiveReactionType GetType() const { return xc_type; }
|
||||
float GetWeight() const { return x8_weight; }
|
||||
bool GetIsActive() const { return x10_active; }
|
||||
|
@ -281,8 +282,8 @@ class CBCLoopAttackCmd : public CBodyStateCmd {
|
|||
u32 xc_waitForAnimOver = 0;
|
||||
|
||||
public:
|
||||
CBCLoopAttackCmd() : CBodyStateCmd(EBodyStateCmd::LoopAttack) {}
|
||||
CBCLoopAttackCmd(pas::ELoopAttackType type) : CBodyStateCmd(EBodyStateCmd::LoopAttack), x8_type(type) {}
|
||||
explicit CBCLoopAttackCmd() : CBodyStateCmd(EBodyStateCmd::LoopAttack) {}
|
||||
explicit CBCLoopAttackCmd(pas::ELoopAttackType type) : CBodyStateCmd(EBodyStateCmd::LoopAttack), x8_type(type) {}
|
||||
pas::ELoopAttackType GetAttackType() const { return x8_type; }
|
||||
bool WaitForAnimOver() const { return xc_waitForAnimOver == 1; }
|
||||
};
|
||||
|
@ -291,8 +292,8 @@ class CBCTauntCmd : public CBodyStateCmd {
|
|||
pas::ETauntType x8_type = pas::ETauntType::Invalid;
|
||||
|
||||
public:
|
||||
CBCTauntCmd() : CBodyStateCmd(EBodyStateCmd::Taunt) {}
|
||||
CBCTauntCmd(pas::ETauntType type) : CBodyStateCmd(EBodyStateCmd::Taunt), x8_type(type) {}
|
||||
explicit CBCTauntCmd() : CBodyStateCmd(EBodyStateCmd::Taunt) {}
|
||||
explicit CBCTauntCmd(pas::ETauntType type) : CBodyStateCmd(EBodyStateCmd::Taunt), x8_type(type) {}
|
||||
pas::ETauntType GetTauntType() const { return x8_type; }
|
||||
};
|
||||
|
||||
|
@ -302,7 +303,7 @@ class CBCLocomotionCmd {
|
|||
float x18_weight;
|
||||
|
||||
public:
|
||||
CBCLocomotionCmd(const zeus::CVector3f& move, const zeus::CVector3f& face, float weight)
|
||||
explicit CBCLocomotionCmd(const zeus::CVector3f& move, const zeus::CVector3f& face, float weight)
|
||||
: x0_move(move), xc_face(face), x18_weight(weight) {}
|
||||
const zeus::CVector3f& GetMoveVector() const { return x0_move; }
|
||||
const zeus::CVector3f& GetFaceVector() const { return xc_face; }
|
||||
|
@ -324,7 +325,7 @@ class CBodyStateCmdMgr {
|
|||
u32 xb4_deliveredCmdMask = 0;
|
||||
CBCGetupCmd xb8_getup;
|
||||
CBCStepCmd xc4_step;
|
||||
CBodyStateCmd xd4_die = {EBodyStateCmd::Die};
|
||||
CBodyStateCmd xd4_die{EBodyStateCmd::Die};
|
||||
CBCKnockDownCmd xdc_knockDown;
|
||||
CBCKnockBackCmd xf4_knockBack;
|
||||
CBCMeleeAttackCmd x10c_meleeAttack;
|
||||
|
@ -332,10 +333,10 @@ class CBodyStateCmdMgr {
|
|||
CBCLoopAttackCmd x144_loopAttack;
|
||||
CBCLoopReactionCmd x154_loopReaction;
|
||||
CBCLoopHitReactionCmd x160_loopHitReaction;
|
||||
CBodyStateCmd x16c_exitState = {EBodyStateCmd::ExitState};
|
||||
CBodyStateCmd x174_leanFromCover = {EBodyStateCmd::LeanFromCover};
|
||||
CBodyStateCmd x17c_nextState = {EBodyStateCmd::NextState};
|
||||
CBodyStateCmd x184_maintainVelocity = {EBodyStateCmd::MaintainVelocity};
|
||||
CBodyStateCmd x16c_exitState{EBodyStateCmd::ExitState};
|
||||
CBodyStateCmd x174_leanFromCover{EBodyStateCmd::LeanFromCover};
|
||||
CBodyStateCmd x17c_nextState{EBodyStateCmd::NextState};
|
||||
CBodyStateCmd x184_maintainVelocity{EBodyStateCmd::MaintainVelocity};
|
||||
CBCGenerateCmd x18c_generate;
|
||||
CBCHurledCmd x1ac_hurled;
|
||||
CBCJumpCmd x1d0_jump;
|
||||
|
@ -344,12 +345,12 @@ class CBodyStateCmdMgr {
|
|||
CBCScriptedCmd x21c_scripted;
|
||||
CBCCoverCmd x230_cover;
|
||||
CBCWallHangCmd x254_wallHang;
|
||||
CBodyStateCmd x260_locomotion = {EBodyStateCmd::Locomotion};
|
||||
CBodyStateCmd x268_additiveIdle = {EBodyStateCmd::AdditiveIdle};
|
||||
CBodyStateCmd x260_locomotion{EBodyStateCmd::Locomotion};
|
||||
CBodyStateCmd x268_additiveIdle{EBodyStateCmd::AdditiveIdle};
|
||||
CBCAdditiveAimCmd x270_additiveAim;
|
||||
CBCAdditiveFlinchCmd x278_additiveFlinch;
|
||||
CBCAdditiveReactionCmd x284_additiveReaction;
|
||||
CBodyStateCmd x298_stopReaction = {EBodyStateCmd::StopReaction};
|
||||
CBodyStateCmd x298_stopReaction{EBodyStateCmd::StopReaction};
|
||||
void DeliverCmd(EBodyStateCmd cmd) { xb4_deliveredCmdMask |= (1 << int(cmd)); }
|
||||
|
||||
public:
|
||||
|
|
|
@ -42,10 +42,10 @@ CBodyStateInfo::CBodyStateInfo(CActor& actor, EBodyType type) {
|
|||
}
|
||||
|
||||
x1c_additiveStates.reserve(4);
|
||||
x1c_additiveStates.push_back({pas::EAnimationState::AdditiveIdle, std::make_unique<CABSIdle>()});
|
||||
x1c_additiveStates.push_back({pas::EAnimationState::AdditiveAim, std::make_unique<CABSAim>()});
|
||||
x1c_additiveStates.push_back({pas::EAnimationState::AdditiveFlinch, std::make_unique<CABSFlinch>()});
|
||||
x1c_additiveStates.push_back({pas::EAnimationState::AdditiveReaction, std::make_unique<CABSReaction>()});
|
||||
x1c_additiveStates.emplace_back(pas::EAnimationState::AdditiveIdle, std::make_unique<CABSIdle>());
|
||||
x1c_additiveStates.emplace_back(pas::EAnimationState::AdditiveAim, std::make_unique<CABSAim>());
|
||||
x1c_additiveStates.emplace_back(pas::EAnimationState::AdditiveFlinch, std::make_unique<CABSFlinch>());
|
||||
x1c_additiveStates.emplace_back(pas::EAnimationState::AdditiveReaction, std::make_unique<CABSReaction>());
|
||||
}
|
||||
|
||||
std::unique_ptr<CBodyState> CBodyStateInfo::SetupRestrictedFlyerBodyStates(int stateId, CActor& actor) const {
|
||||
|
|
|
@ -9,8 +9,8 @@ class CBoolPOINode : public CPOINode {
|
|||
bool x38_val = false;
|
||||
|
||||
public:
|
||||
CBoolPOINode();
|
||||
CBoolPOINode(CInputStream& in);
|
||||
explicit CBoolPOINode();
|
||||
explicit CBoolPOINode(CInputStream& in);
|
||||
bool GetValue() const { return x38_val; }
|
||||
static CBoolPOINode CopyNodeMinusStartTime(const CBoolPOINode& node, const CCharAnimTime& startTime);
|
||||
};
|
||||
|
|
|
@ -47,7 +47,7 @@ private:
|
|||
std::vector<s32> xb0_animIdxs;
|
||||
|
||||
public:
|
||||
CCharacterInfo(CInputStream& in);
|
||||
explicit CCharacterInfo(CInputStream& in);
|
||||
|
||||
std::string_view GetCharacterName() const { return x4_name; }
|
||||
CAssetId GetModelId() const { return x14_cmdl; }
|
||||
|
|
|
@ -13,7 +13,7 @@ class CCharacterSet {
|
|||
std::map<u32, CCharacterInfo> x4_characters;
|
||||
|
||||
public:
|
||||
CCharacterSet(CInputStream& in);
|
||||
explicit CCharacterSet(CInputStream& in);
|
||||
const std::map<u32, CCharacterInfo>& GetCharacterInfoMap() const { return x4_characters; }
|
||||
};
|
||||
|
||||
|
|
|
@ -18,7 +18,7 @@ class CEffectComponent {
|
|||
static SObjectTag GetSObjectTagFromStream(CInputStream& in);
|
||||
|
||||
public:
|
||||
CEffectComponent(CInputStream& in);
|
||||
explicit CEffectComponent(CInputStream& in);
|
||||
|
||||
std::string_view GetComponentName() const { return x0_name; }
|
||||
const SObjectTag& GetParticleTag() const { return x10_tag; }
|
||||
|
|
|
@ -42,7 +42,7 @@ class CFBStreamedAnimReaderTotals {
|
|||
void Allocate(u32 chanCount);
|
||||
|
||||
public:
|
||||
CFBStreamedAnimReaderTotals(const CFBStreamedCompression& source);
|
||||
explicit CFBStreamedAnimReaderTotals(const CFBStreamedCompression& source);
|
||||
void Initialize(const CFBStreamedCompression& source);
|
||||
void IncrementInto(CBitLevelLoader& loader, const CFBStreamedCompression& source, CFBStreamedAnimReaderTotals& dest);
|
||||
void CalculateDown();
|
||||
|
@ -61,7 +61,7 @@ class CFBStreamedPairOfTotals {
|
|||
float x78_t = 0.f;
|
||||
|
||||
public:
|
||||
CFBStreamedPairOfTotals(const TSubAnimTypeToken<CFBStreamedCompression>& source);
|
||||
explicit CFBStreamedPairOfTotals(const TSubAnimTypeToken<CFBStreamedCompression>& source);
|
||||
void SetTime(CBitLevelLoader& loader, const CCharAnimTime& time);
|
||||
void DoIncrement(CBitLevelLoader& loader);
|
||||
float GetT() const { return x78_t; }
|
||||
|
@ -76,7 +76,7 @@ class CBitLevelLoader {
|
|||
size_t m_bitIdx = 0;
|
||||
|
||||
public:
|
||||
CBitLevelLoader(const void* data) : m_data(reinterpret_cast<const u8*>(data)) {}
|
||||
explicit CBitLevelLoader(const void* data) : m_data(reinterpret_cast<const u8*>(data)) {}
|
||||
void Reset() { m_bitIdx = 0; }
|
||||
u32 LoadUnsigned(u8 q);
|
||||
s32 LoadSigned(u8 q);
|
||||
|
@ -88,7 +88,7 @@ class CSegIdToIndexConverter {
|
|||
std::array<s32,100> x0_indices;
|
||||
|
||||
public:
|
||||
CSegIdToIndexConverter(const CFBStreamedAnimReaderTotals& totals);
|
||||
explicit CSegIdToIndexConverter(const CFBStreamedAnimReaderTotals& totals);
|
||||
s32 SegIdToIndex(const CSegId& id) const { return x0_indices[id]; }
|
||||
};
|
||||
|
||||
|
@ -104,7 +104,7 @@ class CFBStreamedAnimReader : public CAnimSourceReaderBase {
|
|||
zeus::CQuaternion GetRotation(const CSegId& seg) const;
|
||||
|
||||
public:
|
||||
CFBStreamedAnimReader(const TSubAnimTypeToken<CFBStreamedCompression>& source, const CCharAnimTime& time);
|
||||
explicit CFBStreamedAnimReader(const TSubAnimTypeToken<CFBStreamedCompression>& source, const CCharAnimTime& time);
|
||||
|
||||
SAdvancementResults VGetAdvancementResults(const CCharAnimTime& a, const CCharAnimTime& b) const override;
|
||||
bool VSupportsReverseView() const override { return false; }
|
||||
|
|
|
@ -66,7 +66,7 @@ private:
|
|||
float CalculateAverageVelocity(const u8* chans) const;
|
||||
|
||||
public:
|
||||
CFBStreamedCompression(CInputStream& in, IObjectStore& objStore, bool pc);
|
||||
explicit CFBStreamedCompression(CInputStream& in, IObjectStore& objStore, bool pc);
|
||||
const Header& MainHeader() const { return *reinterpret_cast<const Header*>(xc_rotsAndOffs.get()); }
|
||||
const u32* GetTimes() const;
|
||||
const u8* GetPerChannelHeaders() const;
|
||||
|
|
|
@ -13,7 +13,7 @@ class CHalfTransition {
|
|||
std::shared_ptr<IMetaTrans> x4_trans;
|
||||
|
||||
public:
|
||||
CHalfTransition(CInputStream& in);
|
||||
explicit CHalfTransition(CInputStream& in);
|
||||
u32 GetId() const { return x0_id; }
|
||||
const std::shared_ptr<IMetaTrans>& GetMetaTrans() const { return x4_trans; }
|
||||
};
|
||||
|
|
|
@ -36,7 +36,7 @@ private:
|
|||
const zeus::CVector3f& offset) const;
|
||||
|
||||
public:
|
||||
CHierarchyPoseBuilder(const CLayoutDescription& layout);
|
||||
explicit CHierarchyPoseBuilder(const CLayoutDescription& layout);
|
||||
|
||||
const TLockedToken<CCharLayoutInfo>& CharLayoutInfo() const { return x0_layoutDesc.ScaledLayout(); }
|
||||
bool HasRoot() const { return x34_hasRoot; }
|
||||
|
|
|
@ -15,7 +15,7 @@ class CInt32POINode : public CPOINode {
|
|||
public:
|
||||
CInt32POINode();
|
||||
CInt32POINode(std::string_view, EPOIType, const CCharAnimTime&, s32, bool, float, s32, s32, s32, std::string_view);
|
||||
CInt32POINode(CInputStream& in);
|
||||
explicit CInt32POINode(CInputStream& in);
|
||||
s32 GetValue() const { return x38_val; }
|
||||
std::string_view GetLocatorName() const { return x3c_locatorName; }
|
||||
|
||||
|
|
|
@ -27,7 +27,7 @@ private:
|
|||
std::optional<CScaledLayoutDescription> xc_scaled;
|
||||
|
||||
public:
|
||||
CLayoutDescription(const TLockedToken<CCharLayoutInfo>& token) : x0_layoutToken(token) {}
|
||||
explicit CLayoutDescription(const TLockedToken<CCharLayoutInfo>& token) : x0_layoutToken(token) {}
|
||||
|
||||
const std::optional<CScaledLayoutDescription>& GetScaledLayoutDescription() const { return xc_scaled; }
|
||||
|
||||
|
|
|
@ -14,7 +14,7 @@ class CMetaAnimBlend : public IMetaAnim {
|
|||
bool x10_;
|
||||
|
||||
public:
|
||||
CMetaAnimBlend(CInputStream& in);
|
||||
explicit CMetaAnimBlend(CInputStream& in);
|
||||
EMetaAnimType GetType() const override { return EMetaAnimType::Blend; }
|
||||
|
||||
void GetUniquePrimitives(std::set<CPrimitive>& primsOut) const override;
|
||||
|
|
|
@ -14,7 +14,7 @@ class CMetaAnimPhaseBlend : public IMetaAnim {
|
|||
bool x10_;
|
||||
|
||||
public:
|
||||
CMetaAnimPhaseBlend(CInputStream& in);
|
||||
explicit CMetaAnimPhaseBlend(CInputStream& in);
|
||||
EMetaAnimType GetType() const override { return EMetaAnimType::PhaseBlend; }
|
||||
|
||||
void GetUniquePrimitives(std::set<CPrimitive>& primsOut) const override;
|
||||
|
|
|
@ -11,7 +11,7 @@ class CMetaAnimPlay : public IMetaAnim {
|
|||
CCharAnimTime x1c_startTime;
|
||||
|
||||
public:
|
||||
CMetaAnimPlay(CInputStream& in);
|
||||
explicit CMetaAnimPlay(CInputStream& in);
|
||||
EMetaAnimType GetType() const override { return EMetaAnimType::Play; }
|
||||
|
||||
void GetUniquePrimitives(std::set<CPrimitive>& primsOut) const override;
|
||||
|
|
|
@ -15,7 +15,7 @@ class CMetaAnimRandom : public IMetaAnim {
|
|||
static RandomData CreateRandomData(CInputStream& in);
|
||||
|
||||
public:
|
||||
CMetaAnimRandom(CInputStream& in);
|
||||
explicit CMetaAnimRandom(CInputStream& in);
|
||||
EMetaAnimType GetType() const override { return EMetaAnimType::Random; }
|
||||
|
||||
void GetUniquePrimitives(std::set<CPrimitive>& primsOut) const override;
|
||||
|
|
|
@ -13,7 +13,7 @@ class CMetaAnimSequence : public IMetaAnim {
|
|||
std::vector<std::shared_ptr<IMetaAnim>> CreateSequence(CInputStream& in);
|
||||
|
||||
public:
|
||||
CMetaAnimSequence(CInputStream& in);
|
||||
explicit CMetaAnimSequence(CInputStream& in);
|
||||
EMetaAnimType GetType() const override { return EMetaAnimType::Sequence; }
|
||||
|
||||
void GetUniquePrimitives(std::set<CPrimitive>& primsOut) const override;
|
||||
|
|
|
@ -12,7 +12,7 @@ class CMetaTransMetaAnim : public IMetaTrans {
|
|||
std::shared_ptr<IMetaAnim> x4_metaAnim;
|
||||
|
||||
public:
|
||||
CMetaTransMetaAnim(CInputStream& in);
|
||||
explicit CMetaTransMetaAnim(CInputStream& in);
|
||||
EMetaTransType GetType() const override { return EMetaTransType::MetaAnim; }
|
||||
|
||||
std::shared_ptr<CAnimTreeNode> VGetTransitionTree(const std::weak_ptr<CAnimTreeNode>& a,
|
||||
|
|
|
@ -13,7 +13,7 @@ class CMetaTransPhaseTrans : public IMetaTrans {
|
|||
u32 x10_flags;
|
||||
|
||||
public:
|
||||
CMetaTransPhaseTrans(CInputStream& in);
|
||||
explicit CMetaTransPhaseTrans(CInputStream& in);
|
||||
EMetaTransType GetType() const override { return EMetaTransType::PhaseTrans; }
|
||||
|
||||
std::shared_ptr<CAnimTreeNode> VGetTransitionTree(const std::weak_ptr<CAnimTreeNode>& a,
|
||||
|
|
|
@ -13,7 +13,7 @@ class CMetaTransTrans : public IMetaTrans {
|
|||
u32 x10_flags;
|
||||
|
||||
public:
|
||||
CMetaTransTrans(CInputStream& in);
|
||||
explicit CMetaTransTrans(CInputStream& in);
|
||||
EMetaTransType GetType() const override { return EMetaTransType::Trans; }
|
||||
|
||||
std::shared_ptr<CAnimTreeNode> VGetTransitionTree(const std::weak_ptr<CAnimTreeNode>& a,
|
||||
|
|
|
@ -20,7 +20,7 @@
|
|||
namespace urde {
|
||||
static logvisor::Module Log("urde::CModelData");
|
||||
|
||||
CModelData::~CModelData() {}
|
||||
CModelData::~CModelData() = default;
|
||||
|
||||
CModelData::CModelData() {}
|
||||
CModelData CModelData::CModelDataNull() { return CModelData(); }
|
||||
|
|
|
@ -79,7 +79,7 @@ class CModelData {
|
|||
std::unique_ptr<CBooModel> m_xrayModelInst;
|
||||
std::unique_ptr<CBooModel> m_infraModelInst;
|
||||
|
||||
int m_drawInstCount;
|
||||
int m_drawInstCount = 0;
|
||||
|
||||
public:
|
||||
enum class EWhichModel { Normal, XRay, Thermal, ThermalHot };
|
||||
|
@ -88,8 +88,8 @@ public:
|
|||
bool GetSortThermal() const { return x14_25_sortThermal; }
|
||||
|
||||
~CModelData();
|
||||
CModelData(const CStaticRes& res, int instCount = 1);
|
||||
CModelData(const CAnimRes& res, int instCount = 1);
|
||||
explicit CModelData(const CStaticRes& res, int instCount = 1);
|
||||
explicit CModelData(const CAnimRes& res, int instCount = 1);
|
||||
CModelData(CModelData&&) = default;
|
||||
CModelData& operator=(CModelData&&) = default;
|
||||
CModelData();
|
||||
|
|
|
@ -11,8 +11,8 @@ class CPASAnimInfo {
|
|||
rstl::reserved_vector<CPASAnimParm::UParmValue, 8> x4_parms;
|
||||
|
||||
public:
|
||||
CPASAnimInfo(u32 id) : x0_id(id) {}
|
||||
CPASAnimInfo(u32 id, rstl::reserved_vector<CPASAnimParm::UParmValue, 8>&& parms);
|
||||
explicit CPASAnimInfo(u32 id) : x0_id(id) {}
|
||||
explicit CPASAnimInfo(u32 id, rstl::reserved_vector<CPASAnimParm::UParmValue, 8>&& parms);
|
||||
u32 GetAnimId() const { return x0_id; }
|
||||
CPASAnimParm::UParmValue GetAnimParmValue(u32 idx) const;
|
||||
CPASAnimParm GetAnimParmData(u32, CPASAnimParm::EParmType) const;
|
||||
|
|
|
@ -12,28 +12,18 @@ class CPASAnimParmData {
|
|||
public:
|
||||
CPASAnimParmData() = default;
|
||||
|
||||
CPASAnimParmData(s32 stateId, const CPASAnimParm& parm1 = CPASAnimParm::NoParameter(),
|
||||
const CPASAnimParm& parm2 = CPASAnimParm::NoParameter(),
|
||||
const CPASAnimParm& parm3 = CPASAnimParm::NoParameter(),
|
||||
const CPASAnimParm& parm4 = CPASAnimParm::NoParameter(),
|
||||
const CPASAnimParm& parm5 = CPASAnimParm::NoParameter(),
|
||||
const CPASAnimParm& parm6 = CPASAnimParm::NoParameter(),
|
||||
const CPASAnimParm& parm7 = CPASAnimParm::NoParameter(),
|
||||
const CPASAnimParm& parm8 = CPASAnimParm::NoParameter());
|
||||
explicit CPASAnimParmData(s32 stateId, const CPASAnimParm& parm1 = CPASAnimParm::NoParameter(),
|
||||
const CPASAnimParm& parm2 = CPASAnimParm::NoParameter(),
|
||||
const CPASAnimParm& parm3 = CPASAnimParm::NoParameter(),
|
||||
const CPASAnimParm& parm4 = CPASAnimParm::NoParameter(),
|
||||
const CPASAnimParm& parm5 = CPASAnimParm::NoParameter(),
|
||||
const CPASAnimParm& parm6 = CPASAnimParm::NoParameter(),
|
||||
const CPASAnimParm& parm7 = CPASAnimParm::NoParameter(),
|
||||
const CPASAnimParm& parm8 = CPASAnimParm::NoParameter());
|
||||
|
||||
s32 GetStateId() const { return x0_stateId; }
|
||||
const rstl::reserved_vector<CPASAnimParm, 8>& GetAnimParmData() const { return x4_parms; }
|
||||
|
||||
static CPASAnimParmData NoParameters(s32 stateId) {
|
||||
return {stateId,
|
||||
CPASAnimParm::NoParameter(),
|
||||
CPASAnimParm::NoParameter(),
|
||||
CPASAnimParm::NoParameter(),
|
||||
CPASAnimParm::NoParameter(),
|
||||
CPASAnimParm::NoParameter(),
|
||||
CPASAnimParm::NoParameter(),
|
||||
CPASAnimParm::NoParameter(),
|
||||
CPASAnimParm::NoParameter()};
|
||||
}
|
||||
static auto NoParameters(s32 stateId) { return CPASAnimParmData(stateId); }
|
||||
};
|
||||
} // namespace urde
|
||||
|
|
|
@ -33,9 +33,9 @@ protected:
|
|||
s32 x34_flags;
|
||||
|
||||
public:
|
||||
CPOINode(std::string_view name, EPOIType type, const CCharAnimTime& time, s32 index, bool unique, float weight,
|
||||
s32 charIdx, s32 flags);
|
||||
CPOINode(CInputStream& in);
|
||||
explicit CPOINode(std::string_view name, EPOIType type, const CCharAnimTime& time, s32 index, bool unique,
|
||||
float weight, s32 charIdx, s32 flags);
|
||||
explicit CPOINode(CInputStream& in);
|
||||
virtual ~CPOINode() = default;
|
||||
|
||||
std::string_view GetString() const { return x8_name; }
|
||||
|
|
|
@ -22,7 +22,7 @@ private:
|
|||
|
||||
public:
|
||||
CParticleData() = default;
|
||||
CParticleData(CInputStream& in);
|
||||
explicit CParticleData(CInputStream& in);
|
||||
u32 GetDuration() const { return x0_duration; }
|
||||
const SObjectTag& GetTag() const { return x4_particle; }
|
||||
std::string_view GetSegmentName() const { return xc_boneName; }
|
||||
|
|
|
@ -10,8 +10,8 @@ class CParticlePOINode : public CPOINode {
|
|||
CParticleData x38_data;
|
||||
|
||||
public:
|
||||
CParticlePOINode();
|
||||
CParticlePOINode(CInputStream& in);
|
||||
explicit CParticlePOINode();
|
||||
explicit CParticlePOINode(CInputStream& in);
|
||||
const CParticleData& GetParticleData() const { return x38_data; }
|
||||
|
||||
static CParticlePOINode CopyNodeMinusStartTime(const CParticlePOINode& node, const CCharAnimTime& startTime);
|
||||
|
|
|
@ -13,7 +13,7 @@ class CPrimitive {
|
|||
std::string x8_animName;
|
||||
|
||||
public:
|
||||
CPrimitive(CInputStream& in);
|
||||
explicit CPrimitive(CInputStream& in);
|
||||
CAssetId GetAnimResId() const { return x0_animId; }
|
||||
u32 GetAnimDbIdx() const { return x4_animIdx; }
|
||||
std::string_view GetName() const { return x8_animName; }
|
||||
|
|
|
@ -11,7 +11,7 @@ class CSegIdList {
|
|||
std::vector<CSegId> x0_list;
|
||||
|
||||
public:
|
||||
CSegIdList(CInputStream& in);
|
||||
explicit CSegIdList(CInputStream& in);
|
||||
const std::vector<CSegId>& GetList() const { return x0_list; }
|
||||
};
|
||||
|
||||
|
|
|
@ -12,7 +12,7 @@ class CSkinBank {
|
|||
std::vector<CSegId> x0_segments;
|
||||
|
||||
public:
|
||||
CSkinBank(CInputStream& in);
|
||||
explicit CSkinBank(CInputStream& in);
|
||||
void GetBankTransforms(std::vector<const zeus::CTransform*>& out, const CPoseAsTransforms& pose) const;
|
||||
};
|
||||
|
||||
|
|
|
@ -12,10 +12,10 @@ class CSoundPOINode : public CPOINode {
|
|||
float x40_maxDist;
|
||||
|
||||
public:
|
||||
CSoundPOINode();
|
||||
CSoundPOINode(CInputStream& in);
|
||||
CSoundPOINode(std::string_view name, EPOIType type, const CCharAnimTime& time, u32 b, bool c, float d, u32 e, u32 f,
|
||||
u32 sfxId, float falloff, float maxDist);
|
||||
explicit CSoundPOINode();
|
||||
explicit CSoundPOINode(CInputStream& in);
|
||||
explicit CSoundPOINode(std::string_view name, EPOIType type, const CCharAnimTime& time, u32 b, bool c, float d, u32 e,
|
||||
u32 f, u32 sfxId, float falloff, float maxDist);
|
||||
|
||||
static CSoundPOINode CopyNodeMinusStartTime(const CSoundPOINode& node, const CCharAnimTime& startTime);
|
||||
u32 GetSfxId() const { return x38_sfxId; }
|
||||
|
|
|
@ -25,7 +25,7 @@ private:
|
|||
float x4_scale;
|
||||
|
||||
public:
|
||||
CConstantAnimationTimeScale(float scale) : x4_scale(scale) {}
|
||||
explicit CConstantAnimationTimeScale(float scale) : x4_scale(scale) {}
|
||||
|
||||
EVaryingAnimationTimeScaleType GetType() const override { return EVaryingAnimationTimeScaleType::Constant; }
|
||||
float VTimeScaleIntegral(float lowerLimit, float upperLimit) const override;
|
||||
|
@ -46,7 +46,7 @@ class CLinearAnimationTimeScale : public IVaryingAnimationTimeScale {
|
|||
static float TimeScaleIntegralWithSortedLimits(const CFunctionDescription& desc, float lowerLimit, float upperLimit);
|
||||
|
||||
public:
|
||||
CLinearAnimationTimeScale(const CCharAnimTime& t1, float y1, const CCharAnimTime& t2, float y2);
|
||||
explicit CLinearAnimationTimeScale(const CCharAnimTime& t1, float y1, const CCharAnimTime& t2, float y2);
|
||||
|
||||
EVaryingAnimationTimeScaleType GetType() const override { return EVaryingAnimationTimeScaleType::Linear; }
|
||||
float VTimeScaleIntegral(float lowerLimit, float upperLimit) const override;
|
||||
|
|
|
@ -15,7 +15,7 @@ class CTransition {
|
|||
std::shared_ptr<IMetaTrans> xc_trans;
|
||||
|
||||
public:
|
||||
CTransition(CInputStream& in);
|
||||
explicit CTransition(CInputStream& in);
|
||||
u32 GetAnimA() const { return x4_animA; }
|
||||
u32 GetAnimB() const { return x8_animB; }
|
||||
std::pair<u32, u32> GetAnimPair() const { return {x4_animA, x8_animB}; }
|
||||
|
|
|
@ -2,6 +2,7 @@
|
|||
|
||||
#include <memory>
|
||||
#include <optional>
|
||||
#include <string_view>
|
||||
|
||||
#include "Runtime/CToken.hpp"
|
||||
#include "Runtime/RetroTypes.hpp"
|
||||
|
@ -73,14 +74,15 @@ class TSubAnimTypeToken : public TLockedToken<CAllFormatsAnimSource> {};
|
|||
template <>
|
||||
class TSubAnimTypeToken<CAnimSource> : public TLockedToken<CAnimSource> {
|
||||
public:
|
||||
TSubAnimTypeToken<CAnimSource>(const TLockedToken<CAllFormatsAnimSource>& token) : TLockedToken<CAnimSource>(token) {}
|
||||
// Converting constructor
|
||||
TSubAnimTypeToken(const TLockedToken<CAllFormatsAnimSource>& token) : TLockedToken<CAnimSource>(token) {}
|
||||
|
||||
CAnimSource* GetObj() {
|
||||
CAnimSource* GetObj() override {
|
||||
CAllFormatsAnimSource* source = reinterpret_cast<CAllFormatsAnimSource*>(TLockedToken<CAnimSource>::GetObj());
|
||||
return &source->GetAsCAnimSource();
|
||||
}
|
||||
|
||||
const CAnimSource* GetObj() const {
|
||||
const CAnimSource* GetObj() const override {
|
||||
return const_cast<TSubAnimTypeToken<CAnimSource>*>(this)->GetObj();
|
||||
}
|
||||
};
|
||||
|
@ -88,16 +90,16 @@ public:
|
|||
template <>
|
||||
class TSubAnimTypeToken<CFBStreamedCompression> : public TLockedToken<CFBStreamedCompression> {
|
||||
public:
|
||||
TSubAnimTypeToken<CFBStreamedCompression>(const TLockedToken<CAllFormatsAnimSource>& token)
|
||||
: TLockedToken<CFBStreamedCompression>(token) {}
|
||||
// Converting constructor
|
||||
TSubAnimTypeToken(const TLockedToken<CAllFormatsAnimSource>& token) : TLockedToken<CFBStreamedCompression>(token) {}
|
||||
|
||||
CFBStreamedCompression* GetObj() {
|
||||
CFBStreamedCompression* GetObj() override {
|
||||
CAllFormatsAnimSource* source =
|
||||
reinterpret_cast<CAllFormatsAnimSource*>(TLockedToken<CFBStreamedCompression>::GetObj());
|
||||
return &source->GetAsCFBStreamedCompression();
|
||||
}
|
||||
|
||||
const CFBStreamedCompression* GetObj() const {
|
||||
const CFBStreamedCompression* GetObj() const override {
|
||||
return const_cast<TSubAnimTypeToken<CFBStreamedCompression>*>(this)->GetObj();
|
||||
}
|
||||
};
|
||||
|
@ -120,9 +122,9 @@ public:
|
|||
u32) const = 0;
|
||||
virtual u32 VGetSoundPOIList(const CCharAnimTime& time, CSoundPOINode* listOut, u32 capacity, u32 iterator,
|
||||
u32) const = 0;
|
||||
virtual bool VGetBoolPOIState(const char*) const = 0;
|
||||
virtual s32 VGetInt32POIState(const char*) const = 0;
|
||||
virtual CParticleData::EParentedMode VGetParticlePOIState(const char*) const = 0;
|
||||
virtual bool VGetBoolPOIState(std::string_view name) const = 0;
|
||||
virtual s32 VGetInt32POIState(std::string_view name) const = 0;
|
||||
virtual CParticleData::EParentedMode VGetParticlePOIState(std::string_view name) const = 0;
|
||||
virtual void VGetSegStatementSet(const CSegIdList& list, CSegStatementSet& setOut) const = 0;
|
||||
virtual void VGetSegStatementSet(const CSegIdList& list, CSegStatementSet& setOut,
|
||||
const CCharAnimTime& time) const = 0;
|
||||
|
|
|
@ -35,8 +35,8 @@ class CPreAdvanceIndicator {
|
|||
u16 x3c_;
|
||||
*/
|
||||
public:
|
||||
CPreAdvanceIndicator(const CCharAnimTime& time) : x0_isTime(true), x4_time(time) {}
|
||||
CPreAdvanceIndicator(const char* string) : x0_isTime(false), xc_string(string) {}
|
||||
explicit CPreAdvanceIndicator(const CCharAnimTime& time) : x0_isTime(true), x4_time(time) {}
|
||||
explicit CPreAdvanceIndicator(const char* string) : x0_isTime(false), xc_string(string) {}
|
||||
const char* GetString() const { return xc_string; }
|
||||
bool IsString() const { return !x0_isTime; }
|
||||
const CCharAnimTime& GetTime() const { return x4_time; }
|
||||
|
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue