aboutsummaryrefslogtreecommitdiff
path: root/Minecraft.World/EnderpearlItem.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'Minecraft.World/EnderpearlItem.cpp')
-rw-r--r--Minecraft.World/EnderpearlItem.cpp34
1 files changed, 34 insertions, 0 deletions
diff --git a/Minecraft.World/EnderpearlItem.cpp b/Minecraft.World/EnderpearlItem.cpp
new file mode 100644
index 00000000..7a9b6e52
--- /dev/null
+++ b/Minecraft.World/EnderpearlItem.cpp
@@ -0,0 +1,34 @@
+#include "stdafx.h"
+#include "net.minecraft.world.level.h"
+#include "net.minecraft.world.entity.player.h"
+#include "net.minecraft.world.entity.projectile.h"
+#include "EnderpearlItem.h"
+#include "SoundTypes.h"
+
+EnderpearlItem::EnderpearlItem(int id) : Item(id)
+{
+ this->maxStackSize = 16;
+}
+
+bool EnderpearlItem::TestUse(Level *level, shared_ptr<Player> player)
+{
+ return true;
+}
+
+shared_ptr<ItemInstance> EnderpearlItem::use(shared_ptr<ItemInstance> instance, Level *level, shared_ptr<Player> player)
+{
+ // 4J-PB - Not sure why this was disabled for creative mode, so commenting out
+ //if (player->abilities.instabuild) return instance;
+ if (player->riding != NULL) return instance;
+ if (!player->abilities.instabuild)
+ {
+ instance->count--;
+ }
+
+ level->playSound(player, eSoundType_RANDOM_BOW, 0.5f, 0.4f / (random->nextFloat() * 0.4f + 0.8f));
+ if (!level->isClientSide)
+ {
+ level->addEntity( shared_ptr<ThrownEnderpearl>( new ThrownEnderpearl(level, player) ) );
+ }
+ return instance;
+} \ No newline at end of file