summaryrefslogtreecommitdiffstats
path: root/src/Mobs/Sheep.cpp
diff options
context:
space:
mode:
authorSTRWarrior <niels.breuker@hotmail.nl>2014-01-25 21:19:52 +0100
committerSTRWarrior <niels.breuker@hotmail.nl>2014-01-25 21:19:52 +0100
commit7b8dc01db32be3d780f38ffbe788500f82983d62 (patch)
treebc6dbbfbac2616d80dc878ff7f0c2880f47115af /src/Mobs/Sheep.cpp
parentFixed *nix compilation for previous commit. (diff)
downloadcuberite-7b8dc01db32be3d780f38ffbe788500f82983d62.tar
cuberite-7b8dc01db32be3d780f38ffbe788500f82983d62.tar.gz
cuberite-7b8dc01db32be3d780f38ffbe788500f82983d62.tar.bz2
cuberite-7b8dc01db32be3d780f38ffbe788500f82983d62.tar.lz
cuberite-7b8dc01db32be3d780f38ffbe788500f82983d62.tar.xz
cuberite-7b8dc01db32be3d780f38ffbe788500f82983d62.tar.zst
cuberite-7b8dc01db32be3d780f38ffbe788500f82983d62.zip
Diffstat (limited to '')
-rw-r--r--src/Mobs/Sheep.cpp39
1 files changed, 38 insertions, 1 deletions
diff --git a/src/Mobs/Sheep.cpp b/src/Mobs/Sheep.cpp
index bda4ccff8..702108ae4 100644
--- a/src/Mobs/Sheep.cpp
+++ b/src/Mobs/Sheep.cpp
@@ -13,7 +13,8 @@
cSheep::cSheep(int a_Color) :
super("Sheep", mtSheep, "mob.sheep.say", "mob.sheep.say", 0.6, 1.3),
m_IsSheared(false),
- m_WoolColor(a_Color)
+ m_WoolColor(a_Color),
+ m_TimeToStopEating(-1)
{
}
@@ -60,3 +61,39 @@ void cSheep::OnRightClicked(cPlayer & a_Player)
m_World->BroadcastEntityMetadata(*this);
}
}
+
+
+
+
+
+void cSheep::Tick(float a_Dt, cChunk & a_Chunk)
+{
+ // The sheep should not move when he's eating so only handle the physics.
+ if (m_TimeToStopEating > 0)
+ {
+ HandlePhysics(a_Dt, a_Chunk);
+ m_TimeToStopEating--;
+ if (m_TimeToStopEating == 0)
+ {
+ if (m_World->GetBlock((int) GetPosX(), (int) GetPosY() - 1, (int) GetPosZ()) == E_BLOCK_GRASS)
+ {
+ // The sheep ate the grass so we change it to dirt.
+ m_World->SetBlock((int) GetPosX(), (int) GetPosY() - 1, (int) GetPosZ(), E_BLOCK_DIRT, 0);
+ m_IsSheared = false;
+ m_World->BroadcastEntityMetadata(*this);
+ }
+ }
+ }
+ else
+ {
+ super::Tick(a_Dt, a_Chunk);
+ if (m_World->GetTickRandomNumber(600) == 1)
+ {
+ if (m_World->GetBlock((int) GetPosX(), (int) GetPosY() - 1, (int) GetPosZ()) == E_BLOCK_GRASS)
+ {
+ m_World->BroadcastEntityStatus(*this, 10);
+ m_TimeToStopEating = 40;
+ }
+ }
+ }
+}