diff options
author | Tiger Wang <ziwei.tiger@hotmail.co.uk> | 2014-07-20 14:39:14 +0200 |
---|---|---|
committer | Tiger Wang <ziwei.tiger@hotmail.co.uk> | 2014-07-20 14:39:14 +0200 |
commit | ba24f50e5ec36c4f4a119900e2dce9ff4b037ca9 (patch) | |
tree | 3e65e9559be11ea9365cf2dc708b209eb530e164 /src/LineBlockTracer.cpp | |
parent | NBTChunkSerializer.cpp: Added break after serializing the splash potion (diff) | |
download | cuberite-ba24f50e5ec36c4f4a119900e2dce9ff4b037ca9.tar cuberite-ba24f50e5ec36c4f4a119900e2dce9ff4b037ca9.tar.gz cuberite-ba24f50e5ec36c4f4a119900e2dce9ff4b037ca9.tar.bz2 cuberite-ba24f50e5ec36c4f4a119900e2dce9ff4b037ca9.tar.lz cuberite-ba24f50e5ec36c4f4a119900e2dce9ff4b037ca9.tar.xz cuberite-ba24f50e5ec36c4f4a119900e2dce9ff4b037ca9.tar.zst cuberite-ba24f50e5ec36c4f4a119900e2dce9ff4b037ca9.zip |
Diffstat (limited to '')
-rw-r--r-- | src/LineBlockTracer.cpp | 40 |
1 files changed, 20 insertions, 20 deletions
diff --git a/src/LineBlockTracer.cpp b/src/LineBlockTracer.cpp index 2395aa43e..f03e796d1 100644 --- a/src/LineBlockTracer.cpp +++ b/src/LineBlockTracer.cpp @@ -212,6 +212,26 @@ bool cLineBlockTracer::Item(cChunk * a_Chunk) return true; } + if ((m_CurrentY < 0) || (m_CurrentY >= cChunkDef::Height)) + { + // We've gone out of the world, that's the end of this trace + double IntersectX, IntersectZ; + CalcXZIntersection(m_CurrentY, IntersectX, IntersectZ); + if (m_Callbacks->OnOutOfWorld(IntersectX, m_CurrentY, IntersectZ)) + { + // The callback terminated the trace + return false; + } + m_Callbacks->OnNoMoreHits(); + return true; + } + + // Update the current chunk + if (a_Chunk != NULL) + { + a_Chunk = a_Chunk->GetNeighborChunk(m_CurrentX, m_CurrentZ); + } + if (a_Chunk->IsValid()) { BLOCKTYPE BlockType; @@ -233,26 +253,6 @@ bool cLineBlockTracer::Item(cChunk * a_Chunk) return false; } } - - // Update the current chunk - if (a_Chunk != NULL) - { - a_Chunk = a_Chunk->GetNeighborChunk(m_CurrentX, m_CurrentZ); - } - - if ((m_CurrentY < 0) || (m_CurrentY >= cChunkDef::Height)) - { - // We've gone out of the world, that's the end of this trace - double IntersectX, IntersectZ; - CalcXZIntersection(m_CurrentY, IntersectX, IntersectZ); - if (m_Callbacks->OnOutOfWorld(IntersectX, m_CurrentY, IntersectZ)) - { - // The callback terminated the trace - return false; - } - m_Callbacks->OnNoMoreHits(); - return true; - } } } |