aboutsummaryrefslogtreecommitdiff
path: root/Minecraft.World/MapCloningRecipe.h
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/MapCloningRecipe.h
parentc9d58eeac7c72f0b3038e084667b4d89a6249fce (diff)
parentef9b6fd500dfabd9463267b0dd9e29577eea8a2b (diff)
Merge branch 'main' into pr/win64-world-saves
# Conflicts: # Minecraft.Client/MinecraftServer.cpp # README.md
Diffstat (limited to 'Minecraft.World/MapCloningRecipe.h')
-rw-r--r--Minecraft.World/MapCloningRecipe.h63
1 files changed, 63 insertions, 0 deletions
diff --git a/Minecraft.World/MapCloningRecipe.h b/Minecraft.World/MapCloningRecipe.h
new file mode 100644
index 00000000..272f9b86
--- /dev/null
+++ b/Minecraft.World/MapCloningRecipe.h
@@ -0,0 +1,63 @@
+#pragma once
+
+/*
+class MapCloningRecipe implements Recipy {
+ @Override
+ public boolean matches(CraftingContainer craftSlots, Level level) {
+ int count = 0;
+ ItemInstance source = null;
+
+ for (int slot = 0; slot < craftSlots.getContainerSize(); slot++) {
+ ItemInstance item = craftSlots.getItem(slot);
+ if (item == null) continue;
+
+ if (item.id == Item.map.id) {
+ if (source != null) return false;
+ source = item;
+ } else if (item.id == Item.emptyMap.id) {
+ count++;
+ } else {
+ return false;
+ }
+ }
+
+ return source != null && count > 0;
+ }
+
+ @Override
+ public ItemInstance assemble(CraftingContainer craftSlots) {
+ int count = 0;
+ ItemInstance source = null;
+
+ for (int slot = 0; slot < craftSlots.getContainerSize(); slot++) {
+ ItemInstance item = craftSlots.getItem(slot);
+ if (item == null) continue;
+
+ if (item.id == Item.map.id) {
+ if (source != null) return null;
+ source = item;
+ } else if (item.id == Item.emptyMap.id) {
+ count++;
+ } else {
+ return null;
+ }
+ }
+
+ if (source == null || count < 1) return null;
+
+ ItemInstance result = new ItemInstance(Item.map, count + 1, source.getAuxValue());
+ if (source.hasCustomHoverName()) result.setHoverName(source.getHoverName());
+ return result;
+ }
+
+ @Override
+ public int size() {
+ return 9;
+ }
+
+ @Override
+ public ItemInstance getResultItem() {
+ return null;
+ }
+};
+*/ \ No newline at end of file