diff options
author | Tiger Wang <ziwei.tiger@hotmail.co.uk> | 2013-09-16 20:18:36 +0200 |
---|---|---|
committer | Tiger Wang <ziwei.tiger@hotmail.co.uk> | 2013-09-16 20:18:36 +0200 |
commit | 506a69333959e40441f6de1e11683365a06538fe (patch) | |
tree | f3e96e272a0e9ac10d46448bdce39661bffbc058 /source | |
parent | Merge pull request #171 from tonibm19/patch-5 (diff) | |
download | cuberite-506a69333959e40441f6de1e11683365a06538fe.tar cuberite-506a69333959e40441f6de1e11683365a06538fe.tar.gz cuberite-506a69333959e40441f6de1e11683365a06538fe.tar.bz2 cuberite-506a69333959e40441f6de1e11683365a06538fe.tar.lz cuberite-506a69333959e40441f6de1e11683365a06538fe.tar.xz cuberite-506a69333959e40441f6de1e11683365a06538fe.tar.zst cuberite-506a69333959e40441f6de1e11683365a06538fe.zip |
Diffstat (limited to 'source')
-rw-r--r-- | source/Blocks/BlockTorch.h | 15 |
1 files changed, 8 insertions, 7 deletions
diff --git a/source/Blocks/BlockTorch.h b/source/Blocks/BlockTorch.h index b9e0dbf27..acacf3f9b 100644 --- a/source/Blocks/BlockTorch.h +++ b/source/Blocks/BlockTorch.h @@ -138,10 +138,6 @@ public: /// Finds a suitable face to place the torch, returning BLOCK_FACE_NONE on failure static char FindSuitableFace(cWorld * a_World, int a_BlockX, int a_BlockY, int a_BlockZ) { - // TODO: If placing a torch from below, check all 4 XZ neighbors, place it on that neighbor instead - // How to propagate that change up? - // Simon: The easiest way is to calculate the position two times, shouldn't cost much cpu power :) - for (int i = 0; i <= 5; i++) { AddFaceDirection(a_BlockX, a_BlockY, a_BlockZ, i, true); @@ -152,12 +148,12 @@ public: (BlockInQuestion == E_BLOCK_FENCE) || (BlockInQuestion == E_BLOCK_NETHER_BRICK_FENCE) || (BlockInQuestion == E_BLOCK_COBBLESTONE_WALL)) && - (i = 1) + (i = BLOCK_FACE_TOP) ) { return i; } - else if ( g_BlockIsTorchPlaceable[BlockInQuestion] ) + else if ((g_BlockIsTorchPlaceable[BlockInQuestion]) && (i != BLOCK_FACE_BOTTOM)) { return i; } @@ -193,7 +189,12 @@ public: BLOCKTYPE BlockInQuestion; a_Chunk.UnboundedRelGetBlockType(a_RelX, a_RelY, a_RelZ, BlockInQuestion); - if ((BlockInQuestion == E_BLOCK_GLASS) || (BlockInQuestion == E_BLOCK_FENCE) || (BlockInQuestion == E_BLOCK_NETHER_BRICK_FENCE)) + if ( + (BlockInQuestion == E_BLOCK_GLASS) || + (BlockInQuestion == E_BLOCK_FENCE) || + (BlockInQuestion == E_BLOCK_NETHER_BRICK_FENCE) || + (BlockInQuestion == E_BLOCK_COBBLESTONE_WALL) + ) { // Torches can be placed on tops of glass and fences, despite them being 'untorcheable' // No need to check for upright orientation, it was done when the torch was placed |