#ifndef __DNAMP1_MLVL_HPP__ #define __DNAMP1_MLVL_HPP__ #include "../DNACommon/PAK.hpp" #include "../DNACommon/MLVL.hpp" #include "DNAMP1.hpp" namespace DataSpec { namespace DNAMP1 { struct MLVL : BigYAML { DECL_YAML Value magic; Value version; UniqueID32 worldNameId; UniqueID32 saveWorldId; UniqueID32 worldSkyboxId; Value memRelayLinkCount; struct MemRelayLink : BigYAML { DECL_YAML Value memRelayId; Value targetId; Value msg; Value active; }; Vector memRelayLinks; Value areaCount; Value unknown1; struct Area : BigYAML { DECL_YAML UniqueID32 areaNameId; Value transformMtx[3]; Value aabb[2]; UniqueID32 areaMREAId; Value areaId; Value attachedAreaCount; Vector attachedAreas; Value padding; Value depCount; struct Dependency : BigYAML { DECL_YAML UniqueID32 id; DNAFourCC type; }; Vector deps; Value depLayerCount; Vector depLayers; Value dockCount; struct Dock : BigYAML { DECL_YAML Value endpointCount; struct Endpoint : BigYAML { DECL_YAML Value areaIdx; Value dockIdx; }; Vector endpoints; Value planeVertCount; Vector planeVerts; }; Vector docks; }; Vector areas; UniqueID32 worldMap; Value unknown2; Value unknown3; Value audioGroupCount; struct AudioGroup : BigYAML { DECL_YAML Value groupId; UniqueID32 agscId; }; Vector audioGroups; String<-1> unkString; Value layerFlagCount; struct LayerFlags : BigYAML { DECL_YAML Value layerCount; Value flags; }; Vector layerFlags; Value layerNameCount; Vector, DNA_COUNT(layerNameCount)> layerNames; Value layerNameOffsetCount; Vector layerNameOffsets; void readMeta(athena::io::YAMLDocReader& __dna_docin) { /* worldSkyboxId */ __dna_docin.enumerate("worldSkyboxId", worldSkyboxId); /* audioGroupCount squelched */ /* audioGroups */ audioGroupCount = __dna_docin.enumerate("audioGroups", audioGroups); } void writeMeta(athena::io::YAMLDocWriter& __dna_docout) const { /* worldSkyboxId */ __dna_docout.enumerate("worldSkyboxId", worldSkyboxId); /* audioGroupCount squelched */ /* audioGroups */ __dna_docout.enumerate("audioGroups", audioGroups); } static bool Extract(const SpecBase& dataSpec, PAKEntryReadStream& rs, const hecl::ProjectPath& outPath, PAKRouter& pakRouter, const PAK::Entry& entry, bool force, hecl::BlenderToken& btok, std::function fileChanged); using World = hecl::BlenderConnection::DataStream::World; static bool Cook(const hecl::ProjectPath& outPath, const hecl::ProjectPath& inPath, const World& wld); }; } } #endif // __DNAMP1_MLVL_HPP__