diff options
author | Tiger Wang <ziwei.tiger@hotmail.co.uk> | 2013-09-17 21:59:36 +0200 |
---|---|---|
committer | Tiger Wang <ziwei.tiger@hotmail.co.uk> | 2013-09-17 21:59:36 +0200 |
commit | a3a3a6ebe6bc7f861f08922754aa986505f56756 (patch) | |
tree | 6a6313503002c9389978efcaa5924dd2e53a7e47 | |
parent | Fixed undead burning (diff) | |
download | cuberite-a3a3a6ebe6bc7f861f08922754aa986505f56756.tar cuberite-a3a3a6ebe6bc7f861f08922754aa986505f56756.tar.gz cuberite-a3a3a6ebe6bc7f861f08922754aa986505f56756.tar.bz2 cuberite-a3a3a6ebe6bc7f861f08922754aa986505f56756.tar.lz cuberite-a3a3a6ebe6bc7f861f08922754aa986505f56756.tar.xz cuberite-a3a3a6ebe6bc7f861f08922754aa986505f56756.tar.zst cuberite-a3a3a6ebe6bc7f861f08922754aa986505f56756.zip |
-rw-r--r-- | source/Blocks/BlockWood.h | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/source/Blocks/BlockWood.h b/source/Blocks/BlockWood.h index 4e2246506..dd4544586 100644 --- a/source/Blocks/BlockWood.h +++ b/source/Blocks/BlockWood.h @@ -15,6 +15,51 @@ public: { } + + virtual bool GetPlacementBlockTypeMeta( + cWorld * a_World, cPlayer * a_Player, + int a_BlockX, int a_BlockY, int a_BlockZ, char a_BlockFace, + int a_CursorX, int a_CursorY, int a_CursorZ, + BLOCKTYPE & a_BlockType, NIBBLETYPE & a_BlockMeta + ) override + { + a_BlockType = m_BlockType; + NIBBLETYPE Meta = a_Player->GetEquippedItem().m_ItemDamage; + a_BlockMeta = BlockFaceToMetaData(a_BlockFace, Meta); + return true; + } + + + inline static NIBBLETYPE BlockFaceToMetaData(char a_BlockFace, NIBBLETYPE a_WoodMeta) + { + switch (a_BlockFace) + { + case BLOCK_FACE_YM: + case BLOCK_FACE_YP: + { + return a_WoodMeta; // Top or bottom, just return original + } + + case BLOCK_FACE_ZP: + case BLOCK_FACE_ZM: + { + return a_WoodMeta | 0x8; // North or south + } + + case BLOCK_FACE_XP: + case BLOCK_FACE_XM: + { + return a_WoodMeta | 0x4; // East or west + } + + default: + { + ASSERT(!"Unhandled block face!"); + return a_WoodMeta | 0xC; // No idea, give a special meta (all sides bark) + } + } + } + virtual const char * GetStepSound(void) override { |