summaryrefslogtreecommitdiffstats
path: root/src/Blocks/BlockSeaLantern.h
diff options
context:
space:
mode:
Diffstat (limited to 'src/Blocks/BlockSeaLantern.h')
-rw-r--r--src/Blocks/BlockSeaLantern.h17
1 files changed, 13 insertions, 4 deletions
diff --git a/src/Blocks/BlockSeaLantern.h b/src/Blocks/BlockSeaLantern.h
index c24476e0b..1fab10a11 100644
--- a/src/Blocks/BlockSeaLantern.h
+++ b/src/Blocks/BlockSeaLantern.h
@@ -6,7 +6,6 @@
-
class cBlockSeaLanternHandler :
public cBlockHandler
{
@@ -20,8 +19,18 @@ private:
virtual cItems ConvertToPickups(NIBBLETYPE a_BlockMeta, cBlockEntity * a_BlockEntity, const cEntity * a_Digger, const cItem * a_Tool) const override
{
- // Reset meta to 0
- // TODO: Handle the Fortune enchantment
- return cItem(E_ITEM_PRISMARINE_CRYSTALS, GetRandomProvider().RandInt<char>(2, 3), 0);
+ // Drop self only when using silk-touch:
+ if (ToolHasSilkTouch(a_Tool))
+ {
+ return cItem(E_BLOCK_SEA_LANTERN, 1, 0);
+ }
+ else
+ {
+ unsigned int DropNum = GetRandomProvider().RandInt<char>(2, 3 + ToolFortuneLevel(a_Tool));
+ // cap the dropnum to the max amount of 5
+ DropNum = std::min<unsigned int>(DropNum, 5);
+ // Reset meta to 0
+ return cItem(E_ITEM_PRISMARINE_CRYSTALS, DropNum, 0);
+ }
}
} ;