mirror of
https://github.com/zeldaret/mm.git
synced 2026-06-19 23:23:07 -04:00
b6904aa2cc
* remove ZAPD submodule * git subrepo clone https://github.com/zeldaret/ZAPD.git tools/ZAPD subrepo: subdir: "tools/ZAPD" merged: "ca229f19" upstream: origin: "https://github.com/zeldaret/ZAPD.git" branch: "master" commit: "ca229f19" git-subrepo: version: "0.4.3" origin: "???" commit: "???" * git subrepo clone https://github.com/simonlindholm/decomp-permuter.git tools/decomp-permuter subrepo: subdir: "tools/decomp-permuter" merged: "1e4b85a7" upstream: origin: "https://github.com/simonlindholm/decomp-permuter.git" branch: "main" commit: "1e4b85a7" git-subrepo: version: "0.4.3" origin: "???" commit: "???" * Remove asm-differ * git subrepo clone https://github.com/simonlindholm/asm-differ.git tools/asm-differ subrepo: subdir: "tools/asm-differ" merged: "eaf72269" upstream: origin: "https://github.com/simonlindholm/asm-differ.git" branch: "master" commit: "eaf72269" git-subrepo: version: "0.4.3" origin: "???" commit: "???" * remove asm-processor * git subrepo clone https://github.com/simonlindholm/asm-processor.git tools/asm-processor subrepo: subdir: "tools/asm-processor" merged: "85288fcd" upstream: origin: "https://github.com/simonlindholm/asm-processor.git" branch: "master" commit: "85288fcd" git-subrepo: version: "0.4.3" origin: "???" commit: "???" * remove .gitmodules file * Update REAMDE * Update warnings
87 lines
1.9 KiB
C++
87 lines
1.9 KiB
C++
#include "ZArray.h"
|
|
#include <cassert>
|
|
#include "Globals.h"
|
|
#include "StringHelper.h"
|
|
#include "ZFile.h"
|
|
|
|
REGISTER_ZFILENODE(Array, ZArray);
|
|
|
|
ZArray::ZArray(ZFile* nParent) : ZResource(nParent)
|
|
{
|
|
canHaveInner = true;
|
|
RegisterRequiredAttribute("Count");
|
|
}
|
|
|
|
ZArray::~ZArray()
|
|
{
|
|
for (auto res : resList)
|
|
delete res;
|
|
}
|
|
|
|
void ZArray::ParseXML(tinyxml2::XMLElement* reader)
|
|
{
|
|
ZResource::ParseXML(reader);
|
|
|
|
arrayCnt = StringHelper::StrToL(registeredAttributes.at("Count").value, 0);
|
|
// TODO: do a better check.
|
|
assert(arrayCnt > 0);
|
|
|
|
tinyxml2::XMLElement* child = reader->FirstChildElement();
|
|
if (child == nullptr)
|
|
throw std::runtime_error(
|
|
StringHelper::Sprintf("Error! Array needs at least one sub-element.\n"));
|
|
|
|
childName = child->Name();
|
|
|
|
auto nodeMap = ZFile::GetNodeMap();
|
|
size_t childIndex = rawDataIndex;
|
|
for (size_t i = 0; i < arrayCnt; i++)
|
|
{
|
|
ZResource* res = nodeMap->at(childName)(parent);
|
|
if (!res->DoesSupportArray())
|
|
{
|
|
throw std::runtime_error(StringHelper::Sprintf(
|
|
"Error! Resource %s does not support being wrapped in an array!\n",
|
|
childName.c_str()));
|
|
}
|
|
res->parent = parent;
|
|
res->SetInnerNode(true);
|
|
res->ExtractFromXML(child, rawData, childIndex);
|
|
|
|
childIndex += res->GetRawDataSize();
|
|
resList.push_back(res);
|
|
}
|
|
}
|
|
|
|
std::string ZArray::GetSourceOutputCode(const std::string& prefix)
|
|
{
|
|
std::string output = "";
|
|
|
|
for (size_t i = 0; i < arrayCnt; i++)
|
|
{
|
|
output += resList.at(i)->GetBodySourceCode();
|
|
|
|
if (i < arrayCnt - 1)
|
|
output += ",\n";
|
|
}
|
|
|
|
if (parent != nullptr)
|
|
parent->AddDeclarationArray(rawDataIndex, DeclarationAlignment::None, GetRawDataSize(),
|
|
resList.at(0)->GetSourceTypeName(), name, arrayCnt, output);
|
|
|
|
return "";
|
|
}
|
|
|
|
size_t ZArray::GetRawDataSize() const
|
|
{
|
|
size_t size = 0;
|
|
for (auto res : resList)
|
|
size += res->GetRawDataSize();
|
|
return size;
|
|
}
|
|
|
|
ZResourceType ZArray::GetResourceType() const
|
|
{
|
|
return ZResourceType::Array;
|
|
}
|