aboutsummaryrefslogtreecommitdiff
path: root/Minecraft.World/StructureFeatureSavedData.cpp
diff options
context:
space:
mode:
authorLoki Rautio <lokirautio@gmail.com>2026-03-04 03:56:03 -0600
committerLoki Rautio <lokirautio@gmail.com>2026-03-04 03:56:03 -0600
commit42aec6dac53dffa6afe072560a7e1d4986112538 (patch)
tree0836426857391df1b6a83f6368a183f83ec9b104 /Minecraft.World/StructureFeatureSavedData.cpp
parentc9d58eeac7c72f0b3038e084667b4d89a6249fce (diff)
parentef9b6fd500dfabd9463267b0dd9e29577eea8a2b (diff)
Merge branch 'main' into pr/win64-world-saves
# Conflicts: # Minecraft.Client/MinecraftServer.cpp # README.md
Diffstat (limited to 'Minecraft.World/StructureFeatureSavedData.cpp')
-rw-r--r--Minecraft.World/StructureFeatureSavedData.cpp47
1 files changed, 47 insertions, 0 deletions
diff --git a/Minecraft.World/StructureFeatureSavedData.cpp b/Minecraft.World/StructureFeatureSavedData.cpp
new file mode 100644
index 00000000..6c2aa412
--- /dev/null
+++ b/Minecraft.World/StructureFeatureSavedData.cpp
@@ -0,0 +1,47 @@
+#include "stdafx.h"
+
+#include "StructureFeatureSavedData.h"
+
+wstring StructureFeatureSavedData::TAG_FEATURES = L"Features";
+
+StructureFeatureSavedData::StructureFeatureSavedData(const wstring &idName) : SavedData(idName)
+{
+ this->pieceTags = new CompoundTag(TAG_FEATURES);
+}
+
+StructureFeatureSavedData::~StructureFeatureSavedData()
+{
+ delete pieceTags;
+}
+
+void StructureFeatureSavedData::load(CompoundTag *tag)
+{
+ this->pieceTags = tag->getCompound(TAG_FEATURES);
+}
+
+void StructureFeatureSavedData::save(CompoundTag *tag)
+{
+ tag->put(TAG_FEATURES, pieceTags->copy() );
+}
+
+CompoundTag *StructureFeatureSavedData::getFeatureTag(int chunkX, int chunkZ)
+{
+ return pieceTags->getCompound(createFeatureTagId(chunkX, chunkZ));
+}
+
+void StructureFeatureSavedData::putFeatureTag(CompoundTag *tag, int chunkX, int chunkZ)
+{
+ wstring name = createFeatureTagId(chunkX, chunkZ);
+ tag->setName(name);
+ pieceTags->put(name, tag);
+}
+
+wstring StructureFeatureSavedData::createFeatureTagId(int chunkX, int chunkZ)
+{
+ return L"[" + _toString<int>(chunkX) + L"," + _toString<int>(chunkZ) + L"]";
+}
+
+CompoundTag *StructureFeatureSavedData::getFullTag()
+{
+ return pieceTags;
+} \ No newline at end of file