diff options
author | wiseoldman95 <softwatt@gmx.com> | 2015-04-29 18:24:14 +0200 |
---|---|---|
committer | wiseoldman95 <softwatt@gmx.com> | 2015-05-01 12:18:47 +0200 |
commit | 1b0e21e0b270b3938b81df119d5a741a3e1e1257 (patch) | |
tree | 7caec55ca1792af1d0e3bcb7a8b44eeff65ac15f /src/Mobs/Skeleton.cpp | |
parent | Merge pull request #1924 from mc-server/BlockAreaCountNonAir (diff) | |
download | cuberite-1b0e21e0b270b3938b81df119d5a741a3e1e1257.tar cuberite-1b0e21e0b270b3938b81df119d5a741a3e1e1257.tar.gz cuberite-1b0e21e0b270b3938b81df119d5a741a3e1e1257.tar.bz2 cuberite-1b0e21e0b270b3938b81df119d5a741a3e1e1257.tar.lz cuberite-1b0e21e0b270b3938b81df119d5a741a3e1e1257.tar.xz cuberite-1b0e21e0b270b3938b81df119d5a741a3e1e1257.tar.zst cuberite-1b0e21e0b270b3938b81df119d5a741a3e1e1257.zip |
Diffstat (limited to '')
-rw-r--r-- | src/Mobs/Skeleton.cpp | 15 |
1 files changed, 8 insertions, 7 deletions
diff --git a/src/Mobs/Skeleton.cpp b/src/Mobs/Skeleton.cpp index 331c8e8ad..ef049f8d4 100644 --- a/src/Mobs/Skeleton.cpp +++ b/src/Mobs/Skeleton.cpp @@ -37,7 +37,7 @@ void cSkeleton::GetDrops(cItems & a_Drops, cEntity * a_Killer) else { AddRandomDropItem(a_Drops, 0, 2 + LootingLevel, E_ITEM_ARROW); - + } AddRandomDropItem(a_Drops, 0, 2 + LootingLevel, E_ITEM_BONE); AddRandomArmorDropItem(a_Drops, LootingLevel); @@ -50,17 +50,18 @@ void cSkeleton::GetDrops(cItems & a_Drops, cEntity * a_Killer) void cSkeleton::MoveToPosition(const Vector3d & a_Position) { - // If the destination is sufficiently skylight challenged AND the skeleton isn't on fire then block the movement + // Todo use WouldBurnAt(), not sure how to obtain a chunk though... + super::MoveToPosition(a_Position); // Look at the player and update m_Destination to hit them if they're close + + // If the destination is sufficiently skylight challenged AND the skeleton isn't on fire AND we weren't attacked recently then block the movement if ( !IsOnFire() && - (m_World->GetBlockSkyLight((int)floor(a_Position.x), (int)floor(a_Position.y), (int)floor(a_Position.z)) - m_World->GetSkyDarkness() > 8) + (m_World->GetBlockSkyLight((int)floor(a_Position.x), (int)floor(a_Position.y), (int)floor(a_Position.z)) - m_World->GetSkyDarkness() > 8) && + m_TicksSinceLastDamaged == 100 ) { - m_bMovingToDestination = false; - return; + StopMovingToPosition(); } - - super::MoveToPosition(a_Position); } |