From 4df23d19b7be2f274974e3dfe91e716e6296f11c Mon Sep 17 00:00:00 2001 From: "madmaxoft@gmail.com" Date: Sat, 29 Sep 2012 13:59:32 +0000 Subject: Unified folder name-casing git-svn-id: http://mc-server.googlecode.com/svn/trunk@902 0a769ca7-a7f5-676a-18bf-c427514a06d6 --- source/Blocks/BlockSapling.h | 56 ++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 56 insertions(+) create mode 100644 source/Blocks/BlockSapling.h (limited to 'source/Blocks/BlockSapling.h') diff --git a/source/Blocks/BlockSapling.h b/source/Blocks/BlockSapling.h new file mode 100644 index 000000000..c9862349a --- /dev/null +++ b/source/Blocks/BlockSapling.h @@ -0,0 +1,56 @@ +#pragma once +#include "BlockHandler.h" +#include "../World.h" + +class cBlockSaplingHandler : public cBlockHandler +{ +public: + cBlockSaplingHandler(BLOCKTYPE a_BlockID) + : cBlockHandler(a_BlockID) + { + } + + virtual bool NeedsRandomTicks() override + { + return true; + } + + virtual NIBBLETYPE GetDropMeta(NIBBLETYPE a_BlockMeta) override + { + return a_BlockMeta & 3; //Only the first 2 bits contain the display information the others are for growing + } + + virtual bool CanBeAt(cWorld *a_World, int a_X, int a_Y, int a_Z) override + { + return IsBlockTypeOfDirt(a_World->GetBlock(a_X, a_Y - 1, a_Z)); + } + + virtual bool AllowBlockOnTop() override + { + return false; + } + + void OnUpdate(cWorld *a_World, int a_X, int a_Y, int a_Z) override + { + NIBBLETYPE Meta = a_World->GetBlockMeta(a_X, a_Y, a_Z); + + if ((Meta & 0x08) != 0) + { + a_World->GrowTree(a_X, a_Y, a_Z); + } + else + { + a_World->SetBlockMeta(a_X, a_Y, a_Z, Meta | 0x08); + } + } + + virtual bool CanBePlacedOnSide() override + { + return false; + } + + virtual AString GetStepSound(void) override + { + return "step.grass"; + } +}; -- cgit v1.2.3