Bucket: implement MaybeConsumable, fixes #3306

this is a nauseating fix, but it's only needed for stable.
This commit is contained in:
Dylan K. Taylor 2020-02-21 17:49:55 +00:00
parent 44182dccbd
commit 2f1fad2745
5 changed files with 49 additions and 2 deletions

View File

@ -81,6 +81,7 @@ use pocketmine\item\Durable;
use pocketmine\item\enchantment\EnchantmentInstance;
use pocketmine\item\enchantment\MeleeWeaponEnchantment;
use pocketmine\item\Item;
use pocketmine\item\MaybeConsumable;
use pocketmine\item\WritableBook;
use pocketmine\item\WrittenBook;
use pocketmine\lang\TextContainer;
@ -2451,7 +2452,7 @@ class Player extends Human implements CommandSender, ChunkLoader, IPlayer{
case InventoryTransactionPacket::USE_ITEM_ACTION_CLICK_AIR:
if($this->isUsingItem()){
$slot = $this->inventory->getItemInHand();
if($slot instanceof Consumable){
if($slot instanceof Consumable and !($slot instanceof MaybeConsumable and !$slot->canBeConsumed())){
$ev = new PlayerItemConsumeEvent($this, $slot);
if($this->hasItemCooldown($slot)){
$ev->setCancelled();

View File

@ -38,6 +38,7 @@ use pocketmine\item\Durable;
use pocketmine\item\enchantment\Enchantment;
use pocketmine\item\FoodSource;
use pocketmine\item\Item;
use pocketmine\item\MaybeConsumable;
use pocketmine\item\Totem;
use pocketmine\level\Level;
use pocketmine\nbt\NBT;
@ -296,6 +297,10 @@ class Human extends Creature implements ProjectileSource, InventoryHolder{
}
public function consumeObject(Consumable $consumable) : bool{
if($consumable instanceof MaybeConsumable and !$consumable->canBeConsumed()){
return false;
}
if($consumable instanceof FoodSource){
if($consumable->requiresHunger() and !$this->isHungry()){
return false;

View File

@ -37,6 +37,7 @@ use pocketmine\item\Consumable;
use pocketmine\item\Durable;
use pocketmine\item\enchantment\Enchantment;
use pocketmine\item\Item;
use pocketmine\item\MaybeConsumable;
use pocketmine\math\Vector3;
use pocketmine\math\VoxelRayTrace;
use pocketmine\nbt\tag\ByteTag;
@ -359,6 +360,10 @@ abstract class Living extends Entity implements Damageable{
* etc.
*/
public function consumeObject(Consumable $consumable) : bool{
if($consumable instanceof MaybeConsumable and !$consumable->canBeConsumed()){
return false;
}
foreach($consumable->getAdditionalEffects() as $effect){
$this->addEffect($effect);
}

View File

@ -33,7 +33,7 @@ use pocketmine\event\player\PlayerBucketFillEvent;
use pocketmine\math\Vector3;
use pocketmine\Player;
class Bucket extends Item implements Consumable{
class Bucket extends Item implements MaybeConsumable{
public function __construct(int $meta = 0){
parent::__construct(self::BUCKET, $meta, "Bucket");
}

View File

@ -0,0 +1,36 @@
<?php
/*
*
* ____ _ _ __ __ _ __ __ ____
* | _ \ ___ ___| | _____| |_| \/ (_)_ __ ___ | \/ | _ \
* | |_) / _ \ / __| |/ / _ \ __| |\/| | | '_ \ / _ \_____| |\/| | |_) |
* | __/ (_) | (__| < __/ |_| | | | | | | | __/_____| | | | __/
* |_| \___/ \___|_|\_\___|\__|_| |_|_|_| |_|\___| |_| |_|_|
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* @author PocketMine Team
* @link http://www.pocketmine.net/
*
*
*/
declare(strict_types=1);
namespace pocketmine\item;
/**
* Items which are sometimes (but not always) consumable should implement this interface.
*
* Note: If implementing custom items, consider making separate items instead of using this.
* This interface serves as a workaround for the consumability of buckets and shouldn't
* really be used for anything else.
*/
interface MaybeConsumable extends Consumable{
public function canBeConsumed() : bool;
}