diff options
author | Mattes D <github@xoft.cz> | 2014-02-24 18:30:44 +0100 |
---|---|---|
committer | Mattes D <github@xoft.cz> | 2014-02-24 18:30:44 +0100 |
commit | 23093fd4d1b1bc5f6d7aae8b5ba6a4cce90921d6 (patch) | |
tree | dd8975008870688e77b33a20072fd54e7e34bb9c /src/Mobs/Mooshroom.cpp | |
parent | Merge pull request #722 from mc-server/CompileFix_C++03 (diff) | |
parent | Fixed Formatting, added compiler warning suppressing methods, fixed comments (diff) | |
download | cuberite-23093fd4d1b1bc5f6d7aae8b5ba6a4cce90921d6.tar cuberite-23093fd4d1b1bc5f6d7aae8b5ba6a4cce90921d6.tar.gz cuberite-23093fd4d1b1bc5f6d7aae8b5ba6a4cce90921d6.tar.bz2 cuberite-23093fd4d1b1bc5f6d7aae8b5ba6a4cce90921d6.tar.lz cuberite-23093fd4d1b1bc5f6d7aae8b5ba6a4cce90921d6.tar.xz cuberite-23093fd4d1b1bc5f6d7aae8b5ba6a4cce90921d6.tar.zst cuberite-23093fd4d1b1bc5f6d7aae8b5ba6a4cce90921d6.zip |
Diffstat (limited to '')
-rw-r--r-- | src/Mobs/Mooshroom.cpp | 48 |
1 files changed, 45 insertions, 3 deletions
diff --git a/src/Mobs/Mooshroom.cpp b/src/Mobs/Mooshroom.cpp index 88101cd83..8e4c52ae6 100644 --- a/src/Mobs/Mooshroom.cpp +++ b/src/Mobs/Mooshroom.cpp @@ -2,11 +2,12 @@ #include "Globals.h" // NOTE: MSVC stupidness requires this to be the same across all modules #include "Mooshroom.h" +#include "../Entities/Player.h" + -// TODO: Milk Cow @@ -23,9 +24,50 @@ cMooshroom::cMooshroom(void) : void cMooshroom::GetDrops(cItems & a_Drops, cEntity * a_Killer) { - AddRandomDropItem(a_Drops, 0, 2, E_ITEM_LEATHER); - AddRandomDropItem(a_Drops, 1, 3, IsOnFire() ? E_ITEM_STEAK : E_ITEM_RAW_BEEF); + int LootingLevel = 0; + if (a_Killer != NULL) + { + LootingLevel = a_Killer->GetEquippedWeapon().m_Enchantments.GetLevel(cEnchantments::enchLooting); + } + AddRandomDropItem(a_Drops, 0, 2 + LootingLevel, E_ITEM_LEATHER); + AddRandomDropItem(a_Drops, 1, 3 + LootingLevel, IsOnFire() ? E_ITEM_STEAK : E_ITEM_RAW_BEEF); } + + +void cMooshroom::OnRightClicked(cPlayer & a_Player) +{ + switch (a_Player.GetEquippedItem().m_ItemType) + { + case E_ITEM_BUCKET: + { + if (!a_Player.IsGameModeCreative()) + { + a_Player.GetInventory().RemoveOneEquippedItem(); + a_Player.GetInventory().AddItem(E_ITEM_MILK); + } + } break; + case E_ITEM_BOWL: + { + if (!a_Player.IsGameModeCreative()) + { + a_Player.GetInventory().RemoveOneEquippedItem(); + a_Player.GetInventory().AddItem(E_ITEM_MUSHROOM_SOUP); + } + } break; + case E_ITEM_SHEARS: + { + if (!a_Player.IsGameModeCreative()) + { + a_Player.UseEquippedItem(); + } + + cItems Drops; + Drops.push_back(cItem(E_BLOCK_RED_MUSHROOM, 5, 0)); + m_World->SpawnItemPickups(Drops, GetPosX(), GetPosY(), GetPosZ(), 10); + } break; + } +} + |