#pragma once #include "../../DNACommon/DNACommon.hpp" #include "IScriptObject.hpp" #include "Parameters.hpp" namespace DataSpec::DNAMP1 { struct Seedling : IScriptObject { AT_DECL_DNA_YAML AT_DECL_DNAV String<-1> name; Value location; Value orientation; Value scale; PatternedInfo patternedInfo; ActorParameters actorParameters; UniqueID32 unknown1; UniqueID32 unknown2; DamageInfo damageInfo1; DamageInfo damageInfo2; Value unknown3; Value unknown4; Value unknown5; Value unknown6; void addCMDLRigPairs(PAKRouter& pakRouter, CharacterAssociations& charAssoc) const { actorParameters.addCMDLRigPairs(pakRouter, charAssoc, patternedInfo.animationParameters); } void nameIDs(PAKRouter& pakRouter) const { if (unknown1.isValid()) { PAK::Entry* ent = (PAK::Entry*)pakRouter.lookupEntry(unknown1); ent->name = name + "_unk1"; } if (unknown2.isValid()) { PAK::Entry* ent = (PAK::Entry*)pakRouter.lookupEntry(unknown2); ent->name = name + "_unk2"; } patternedInfo.nameIDs(pakRouter, name + "_patterned"); actorParameters.nameIDs(pakRouter, name + "_actp"); } void gatherDependencies(std::vector& pathsOut, std::vector& lazyOut) const { g_curSpec->flattenDependencies(unknown1, pathsOut); g_curSpec->flattenDependencies(unknown2, pathsOut); patternedInfo.depIDs(pathsOut); actorParameters.depIDs(pathsOut, lazyOut); } void gatherScans(std::vector& scansOut) const { actorParameters.scanIDs(scansOut); } }; } // namespace DataSpec::DNAMP1