aboutsummaryrefslogtreecommitdiff
path: root/Minecraft.World/HellSpringFeature.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'Minecraft.World/HellSpringFeature.cpp')
-rw-r--r--Minecraft.World/HellSpringFeature.cpp42
1 files changed, 42 insertions, 0 deletions
diff --git a/Minecraft.World/HellSpringFeature.cpp b/Minecraft.World/HellSpringFeature.cpp
new file mode 100644
index 00000000..cfd2d74f
--- /dev/null
+++ b/Minecraft.World/HellSpringFeature.cpp
@@ -0,0 +1,42 @@
+#include "stdafx.h"
+#include "net.minecraft.world.level.h"
+#include "HellSpringFeature.h"
+#include "net.minecraft.world.level.tile.h"
+
+HellSpringFeature::HellSpringFeature(int tile)
+{
+ this->tile = tile;
+}
+
+bool HellSpringFeature::place(Level *level, Random *random, int x, int y, int z)
+{
+ if (level->getTile(x, y + 1, z) != Tile::hellRock_Id) return false;
+ if (level->getTile(x, y - 1, z) != Tile::hellRock_Id) return false;
+
+ if (level->getTile(x, y, z) != 0 && level->getTile(x, y, z) != Tile::hellRock_Id) return false;
+
+ int rockCount = 0;
+ if (level->getTile(x - 1, y, z) == Tile::hellRock_Id) rockCount++;
+ if (level->getTile(x + 1, y, z) == Tile::hellRock_Id) rockCount++;
+ if (level->getTile(x, y, z - 1) == Tile::hellRock_Id) rockCount++;
+ if (level->getTile(x, y, z + 1) == Tile::hellRock_Id) rockCount++;
+ if (level->getTile(x, y - 1, z) == Tile::hellRock_Id) rockCount++;
+
+ int holeCount = 0;
+ if (level->isEmptyTile(x - 1, y, z)) holeCount++;
+ if (level->isEmptyTile(x + 1, y, z)) holeCount++;
+ if (level->isEmptyTile(x, y, z - 1)) holeCount++;
+ if (level->isEmptyTile(x, y, z + 1)) holeCount++;
+ if (level->isEmptyTile(x, y - 1, z)) holeCount++;
+
+ if (rockCount == 4 && holeCount == 1)
+ {
+ level->setTile(x, y, z, tile);
+ level->setInstaTick(true);
+ Tile::tiles[tile]->tick(level, x, y, z, random);
+ level->setInstaTick(false);
+ }
+
+ return true;
+
+} \ No newline at end of file