diff options
Diffstat (limited to '')
-rw-r--r-- | src/Mobs/NewSlime.cpp | 61 |
1 files changed, 61 insertions, 0 deletions
diff --git a/src/Mobs/NewSlime.cpp b/src/Mobs/NewSlime.cpp new file mode 100644 index 000000000..60f0021ab --- /dev/null +++ b/src/Mobs/NewSlime.cpp @@ -0,0 +1,61 @@ + +#include "Globals.h" // NOTE: MSVC stupidness requires this to be the same across all modules + +#include "NewSlime.h" +#include "FastRandom.h" +#include "World.h" + + + + + +cNewSlime::cNewSlime(int a_Size) : + super("Slime", + mtSlime, + Printf("mob.slime.%s", GetSizeName(a_Size).c_str()), + Printf("mob.slime.%s", GetSizeName(a_Size).c_str()), + 0.6 * a_Size, + 0.6 * a_Size + ), + m_Size(a_Size) +{ +} + + + + + +void cNewSlime::GetDrops(cItems & a_Drops, cEntity * a_Killer) +{ + int LootingLevel = 0; + if (a_Killer != NULL) + { + LootingLevel = a_Killer->GetEquippedWeapon().m_Enchantments.GetLevel(cEnchantments::enchLooting); + } + + // Only slimes with the size 1 can drop slimeballs. + if (m_Size == 1) + { + AddRandomDropItem(a_Drops, 0, 2 + LootingLevel, E_ITEM_SLIMEBALL); + } +} + + + + + +const AString cNewSlime::GetSizeName(int a_Size) const +{ + if (a_Size > 1) + { + return "big"; + } + else + { + return "small"; + } +} + + + + |