From 866df55edf17d845fff362ff351e055e5d9b8fc7 Mon Sep 17 00:00:00 2001
From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com>
Date: Tue, 29 Jul 2025 09:25:19 +0000
Subject: [PATCH 1/4] Bump ramsey/uuid from 4.8.1 to 4.9.0 (#6748)
---
composer.json | 2 +-
composer.lock | 21 ++++++++++-----------
2 files changed, 11 insertions(+), 12 deletions(-)
diff --git a/composer.json b/composer.json
index 419f29a4a..ce4994d4f 100644
--- a/composer.json
+++ b/composer.json
@@ -48,7 +48,7 @@
"pocketmine/raklib": "~1.2.0",
"pocketmine/raklib-ipc": "~1.0.0",
"pocketmine/snooze": "^0.5.0",
- "ramsey/uuid": "~4.8.0",
+ "ramsey/uuid": "~4.9.0",
"symfony/filesystem": "~6.4.0"
},
"require-dev": {
diff --git a/composer.lock b/composer.lock
index 5981f64b3..0180fd0a6 100644
--- a/composer.lock
+++ b/composer.lock
@@ -4,7 +4,7 @@
"Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies",
"This file is @generated automatically"
],
- "content-hash": "679ab8fc31e55b5170daa34258dc0fd4",
+ "content-hash": "4dc5ea726d881d8c52d1b5299485d940",
"packages": [
{
"name": "adhocore/json-comment",
@@ -818,21 +818,20 @@
},
{
"name": "ramsey/uuid",
- "version": "4.8.1",
+ "version": "4.9.0",
"source": {
"type": "git",
"url": "https://github.com/ramsey/uuid.git",
- "reference": "fdf4dd4e2ff1813111bd0ad58d7a1ddbb5b56c28"
+ "reference": "4e0e23cc785f0724a0e838279a9eb03f28b092a0"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/ramsey/uuid/zipball/fdf4dd4e2ff1813111bd0ad58d7a1ddbb5b56c28",
- "reference": "fdf4dd4e2ff1813111bd0ad58d7a1ddbb5b56c28",
+ "url": "https://api.github.com/repos/ramsey/uuid/zipball/4e0e23cc785f0724a0e838279a9eb03f28b092a0",
+ "reference": "4e0e23cc785f0724a0e838279a9eb03f28b092a0",
"shasum": ""
},
"require": {
"brick/math": "^0.8.8 || ^0.9 || ^0.10 || ^0.11 || ^0.12 || ^0.13",
- "ext-json": "*",
"php": "^8.0",
"ramsey/collection": "^1.2 || ^2.0"
},
@@ -891,9 +890,9 @@
],
"support": {
"issues": "https://github.com/ramsey/uuid/issues",
- "source": "https://github.com/ramsey/uuid/tree/4.8.1"
+ "source": "https://github.com/ramsey/uuid/tree/4.9.0"
},
- "time": "2025-06-01T06:28:46+00:00"
+ "time": "2025-06-25T14:20:11+00:00"
},
{
"name": "symfony/filesystem",
@@ -2757,7 +2756,7 @@
],
"aliases": [],
"minimum-stability": "stable",
- "stability-flags": {},
+ "stability-flags": [],
"prefer-stable": false,
"prefer-lowest": false,
"platform": {
@@ -2788,9 +2787,9 @@
"ext-zlib": ">=1.2.11",
"composer-runtime-api": "^2.0"
},
- "platform-dev": {},
+ "platform-dev": [],
"platform-overrides": {
"php": "8.1.0"
},
- "plugin-api-version": "2.6.0"
+ "plugin-api-version": "2.3.0"
}
From 40ea6dd30d9f5c874be39c2f8a6f5d19755268c3 Mon Sep 17 00:00:00 2001
From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com>
Date: Tue, 29 Jul 2025 09:26:25 +0000
Subject: [PATCH 2/4] Bump phpstan/phpstan-strict-rules in the
development-patch-updates group (#6758)
---
composer.lock | 12 ++++++------
1 file changed, 6 insertions(+), 6 deletions(-)
diff --git a/composer.lock b/composer.lock
index 0180fd0a6..2e5e83a94 100644
--- a/composer.lock
+++ b/composer.lock
@@ -1311,16 +1311,16 @@
},
{
"name": "phpstan/phpstan-strict-rules",
- "version": "2.0.5",
+ "version": "2.0.6",
"source": {
"type": "git",
"url": "https://github.com/phpstan/phpstan-strict-rules.git",
- "reference": "1f1358da2f8e1317478c63c21beb9918c9821f6f"
+ "reference": "f9f77efa9de31992a832ff77ea52eb42d675b094"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/phpstan/phpstan-strict-rules/zipball/1f1358da2f8e1317478c63c21beb9918c9821f6f",
- "reference": "1f1358da2f8e1317478c63c21beb9918c9821f6f",
+ "url": "https://api.github.com/repos/phpstan/phpstan-strict-rules/zipball/f9f77efa9de31992a832ff77ea52eb42d675b094",
+ "reference": "f9f77efa9de31992a832ff77ea52eb42d675b094",
"shasum": ""
},
"require": {
@@ -1353,9 +1353,9 @@
"description": "Extra strict and opinionated rules for PHPStan",
"support": {
"issues": "https://github.com/phpstan/phpstan-strict-rules/issues",
- "source": "https://github.com/phpstan/phpstan-strict-rules/tree/2.0.5"
+ "source": "https://github.com/phpstan/phpstan-strict-rules/tree/2.0.6"
},
- "time": "2025-07-17T12:01:44+00:00"
+ "time": "2025-07-21T12:19:29+00:00"
},
{
"name": "phpunit/php-code-coverage",
From a83c62a4a2e5eea17fdfc3eb2bfd55f31534a9e3 Mon Sep 17 00:00:00 2001
From: "Dylan T."
-
+
From cc17e68072c1bcadefcab3c7ddb42cdb27be0dad Mon Sep 17 00:00:00 2001
From: Hugo_ <55756021+Dhaiven@users.noreply.github.com>
Date: Thu, 31 Jul 2025 08:48:47 +0200
Subject: [PATCH 4/4] Add blocks interfaces for commons properties (#6639)
---
src/block/ActivatorRail.php | 3 +-
src/block/AmethystCluster.php | 3 +-
src/block/Anvil.php | 3 +-
src/block/Barrel.php | 3 +-
src/block/BaseBanner.php | 3 +-
src/block/BaseBigDripleaf.php | 3 +-
src/block/BaseCoral.php | 3 +-
src/block/BaseSign.php | 3 +-
src/block/Bed.php | 4 +-
src/block/Bell.php | 3 +-
src/block/BoneBlock.php | 3 +-
src/block/Button.php | 3 +-
src/block/Cactus.php | 3 +-
src/block/CakeWithCandle.php | 3 +-
src/block/CakeWithDyedCandle.php | 3 +-
src/block/Campfire.php | 4 +-
src/block/Candle.php | 3 +-
src/block/Carpet.php | 3 +-
src/block/CarvedPumpkin.php | 3 +-
src/block/CaveVines.php | 3 +-
src/block/Chain.php | 3 +-
src/block/ChemistryTable.php | 3 +-
src/block/Chest.php | 3 +-
src/block/ChiseledBookshelf.php | 3 +-
src/block/ChorusFlower.php | 3 +-
src/block/CocoaBlock.php | 4 +-
src/block/Concrete.php | 3 +-
src/block/ConcretePowder.php | 3 +-
src/block/CopperBulb.php | 4 +-
src/block/CoralBlock.php | 3 +-
src/block/Crops.php | 3 +-
src/block/DaylightSensor.php | 3 +-
src/block/Door.php | 3 +-
src/block/DoublePitcherCrop.php | 3 +-
src/block/DyedCandle.php | 3 +-
src/block/DyedShulkerBox.php | 3 +-
src/block/EndPortalFrame.php | 3 +-
src/block/EndRod.php | 3 +-
src/block/EnderChest.php | 3 +-
src/block/FenceGate.php | 4 +-
src/block/Fire.php | 3 +-
src/block/FloorBanner.php | 3 +-
src/block/FloorSign.php | 3 +-
src/block/FrostedIce.php | 3 +-
src/block/Furnace.php | 3 +-
src/block/GlazedTerracotta.php | 4 +-
src/block/GlowLichen.php | 3 +-
src/block/HayBale.php | 3 +-
src/block/Hopper.php | 3 +-
src/block/ItemFrame.php | 3 +-
src/block/Ladder.php | 3 +-
src/block/Lectern.php | 3 +-
src/block/LightningRod.php | 3 +-
src/block/Loom.php | 3 +-
src/block/NetherVines.php | 3 +-
src/block/NetherWartPlant.php | 3 +-
src/block/PinkPetals.php | 3 +-
src/block/PitcherCrop.php | 3 +-
src/block/Planks.php | 3 +-
src/block/PoweredRail.php | 3 +-
src/block/RedstoneComparator.php | 5 +-
src/block/RedstoneLamp.php | 3 +-
src/block/RedstoneOre.php | 3 +-
src/block/RedstoneRepeater.php | 4 +-
src/block/RedstoneTorch.php | 3 +-
src/block/RedstoneWire.php | 3 +-
src/block/ResinClump.php | 3 +-
src/block/ShulkerBox.php | 3 +-
src/block/SimplePillar.php | 3 +-
src/block/SmallDripleaf.php | 3 +-
src/block/StainedGlass.php | 3 +-
src/block/StainedGlassPane.php | 3 +-
src/block/StainedHardenedClay.php | 3 +-
src/block/StainedHardenedGlass.php | 3 +-
src/block/StainedHardenedGlassPane.php | 3 +-
src/block/Stair.php | 3 +-
src/block/Stonecutter.php | 3 +-
src/block/Sugarcane.php | 3 +-
src/block/SweetBerryBush.php | 3 +-
src/block/Trapdoor.php | 3 +-
src/block/TripwireHook.php | 3 +-
src/block/WallBanner.php | 3 +-
src/block/WallCoralFan.php | 3 +-
src/block/WallSign.php | 3 +-
src/block/WeightedPressurePlate.php | 3 +-
src/block/Wood.php | 4 +-
src/block/WoodenButton.php | 3 +-
src/block/WoodenDoor.php | 3 +-
src/block/WoodenFence.php | 3 +-
src/block/WoodenPressurePlate.php | 3 +-
src/block/WoodenSlab.php | 3 +-
src/block/WoodenStairs.php | 3 +-
src/block/WoodenTrapdoor.php | 3 +-
src/block/Wool.php | 3 +-
src/block/utils/Ageable.php | 34 ++++++++++++
.../utils/AnalogRedstoneSignalEmitter.php | 34 ++++++++++++
src/block/utils/AnyFacing.php | 41 ++++++++++++++
src/block/utils/Colored.php | 34 ++++++++++++
src/block/utils/CoralMaterial.php | 41 ++++++++++++++
src/block/utils/HorizontalFacing.php | 41 ++++++++++++++
src/block/utils/Lightable.php | 34 ++++++++++++
src/block/utils/MultiFacing.php | 54 +++++++++++++++++++
src/block/utils/PillarRotation.php | 39 ++++++++++++++
src/block/utils/PoweredByRedstone.php | 34 ++++++++++++
src/block/utils/SignLikeRotation.php | 39 ++++++++++++++
src/block/utils/WoodMaterial.php | 29 ++++++++++
106 files changed, 652 insertions(+), 94 deletions(-)
create mode 100644 src/block/utils/Ageable.php
create mode 100644 src/block/utils/AnalogRedstoneSignalEmitter.php
create mode 100644 src/block/utils/AnyFacing.php
create mode 100644 src/block/utils/Colored.php
create mode 100644 src/block/utils/CoralMaterial.php
create mode 100644 src/block/utils/HorizontalFacing.php
create mode 100644 src/block/utils/Lightable.php
create mode 100644 src/block/utils/MultiFacing.php
create mode 100644 src/block/utils/PillarRotation.php
create mode 100644 src/block/utils/PoweredByRedstone.php
create mode 100644 src/block/utils/SignLikeRotation.php
create mode 100644 src/block/utils/WoodMaterial.php
diff --git a/src/block/ActivatorRail.php b/src/block/ActivatorRail.php
index dcd0ef93b..da15eb1e8 100644
--- a/src/block/ActivatorRail.php
+++ b/src/block/ActivatorRail.php
@@ -23,9 +23,10 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\PoweredByRedstone;
use pocketmine\block\utils\RailPoweredByRedstoneTrait;
-class ActivatorRail extends StraightOnlyRail{
+class ActivatorRail extends StraightOnlyRail implements PoweredByRedstone{
use RailPoweredByRedstoneTrait;
//TODO
diff --git a/src/block/AmethystCluster.php b/src/block/AmethystCluster.php
index 639490456..8a750e974 100644
--- a/src/block/AmethystCluster.php
+++ b/src/block/AmethystCluster.php
@@ -24,6 +24,7 @@ declare(strict_types=1);
namespace pocketmine\block;
use pocketmine\block\utils\AmethystTrait;
+use pocketmine\block\utils\AnyFacing;
use pocketmine\block\utils\AnyFacingTrait;
use pocketmine\block\utils\FortuneDropHelper;
use pocketmine\block\utils\SupportType;
@@ -38,7 +39,7 @@ use pocketmine\player\Player;
use pocketmine\utils\AssumptionFailedError;
use pocketmine\world\BlockTransaction;
-final class AmethystCluster extends Transparent{
+final class AmethystCluster extends Transparent implements AnyFacing{
use AmethystTrait;
use AnyFacingTrait;
diff --git a/src/block/Anvil.php b/src/block/Anvil.php
index 2c48f9a7c..fcb4d045c 100644
--- a/src/block/Anvil.php
+++ b/src/block/Anvil.php
@@ -26,6 +26,7 @@ namespace pocketmine\block;
use pocketmine\block\inventory\AnvilInventory;
use pocketmine\block\utils\Fallable;
use pocketmine\block\utils\FallableTrait;
+use pocketmine\block\utils\HorizontalFacing;
use pocketmine\block\utils\HorizontalFacingTrait;
use pocketmine\block\utils\SupportType;
use pocketmine\data\runtime\RuntimeDataDescriber;
@@ -41,7 +42,7 @@ use pocketmine\world\sound\AnvilFallSound;
use pocketmine\world\sound\Sound;
use function round;
-class Anvil extends Transparent implements Fallable{
+class Anvil extends Transparent implements Fallable, HorizontalFacing{
use FallableTrait;
use HorizontalFacingTrait;
diff --git a/src/block/Barrel.php b/src/block/Barrel.php
index 0f0499ab9..7b2ea356e 100644
--- a/src/block/Barrel.php
+++ b/src/block/Barrel.php
@@ -24,6 +24,7 @@ declare(strict_types=1);
namespace pocketmine\block;
use pocketmine\block\tile\Barrel as TileBarrel;
+use pocketmine\block\utils\AnyFacing;
use pocketmine\block\utils\AnyFacingTrait;
use pocketmine\data\runtime\RuntimeDataDescriber;
use pocketmine\item\Item;
@@ -33,7 +34,7 @@ use pocketmine\player\Player;
use pocketmine\world\BlockTransaction;
use function abs;
-class Barrel extends Opaque{
+class Barrel extends Opaque implements AnyFacing{
use AnyFacingTrait;
protected bool $open = false;
diff --git a/src/block/BaseBanner.php b/src/block/BaseBanner.php
index b56323453..376f1f9dc 100644
--- a/src/block/BaseBanner.php
+++ b/src/block/BaseBanner.php
@@ -25,6 +25,7 @@ namespace pocketmine\block;
use pocketmine\block\tile\Banner as TileBanner;
use pocketmine\block\utils\BannerPatternLayer;
+use pocketmine\block\utils\Colored;
use pocketmine\block\utils\ColoredTrait;
use pocketmine\block\utils\SupportType;
use pocketmine\item\Banner as ItemBanner;
@@ -36,7 +37,7 @@ use pocketmine\world\BlockTransaction;
use function assert;
use function count;
-abstract class BaseBanner extends Transparent{
+abstract class BaseBanner extends Transparent implements Colored{
use ColoredTrait;
/**
diff --git a/src/block/BaseBigDripleaf.php b/src/block/BaseBigDripleaf.php
index f0ff59cf0..94e2c12a2 100644
--- a/src/block/BaseBigDripleaf.php
+++ b/src/block/BaseBigDripleaf.php
@@ -23,6 +23,7 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\HorizontalFacing;
use pocketmine\block\utils\HorizontalFacingTrait;
use pocketmine\block\utils\SupportType;
use pocketmine\event\block\StructureGrowEvent;
@@ -33,7 +34,7 @@ use pocketmine\math\Vector3;
use pocketmine\player\Player;
use pocketmine\world\BlockTransaction;
-abstract class BaseBigDripleaf extends Transparent{
+abstract class BaseBigDripleaf extends Transparent implements HorizontalFacing{
use HorizontalFacingTrait;
abstract protected function isHead() : bool;
diff --git a/src/block/BaseCoral.php b/src/block/BaseCoral.php
index b9c595a97..c1cc9bb25 100644
--- a/src/block/BaseCoral.php
+++ b/src/block/BaseCoral.php
@@ -24,12 +24,13 @@ declare(strict_types=1);
namespace pocketmine\block;
use pocketmine\block\utils\BlockEventHelper;
+use pocketmine\block\utils\CoralMaterial;
use pocketmine\block\utils\CoralTypeTrait;
use pocketmine\block\utils\SupportType;
use pocketmine\item\Item;
use function mt_rand;
-abstract class BaseCoral extends Transparent{
+abstract class BaseCoral extends Transparent implements CoralMaterial{
use CoralTypeTrait;
public function onNearbyBlockChange() : void{
diff --git a/src/block/BaseSign.php b/src/block/BaseSign.php
index 0f5d77d58..0efaa603c 100644
--- a/src/block/BaseSign.php
+++ b/src/block/BaseSign.php
@@ -27,6 +27,7 @@ use pocketmine\block\tile\Sign as TileSign;
use pocketmine\block\utils\DyeColor;
use pocketmine\block\utils\SignText;
use pocketmine\block\utils\SupportType;
+use pocketmine\block\utils\WoodMaterial;
use pocketmine\block\utils\WoodType;
use pocketmine\block\utils\WoodTypeTrait;
use pocketmine\color\Color;
@@ -44,7 +45,7 @@ use function array_map;
use function assert;
use function strlen;
-abstract class BaseSign extends Transparent{
+abstract class BaseSign extends Transparent implements WoodMaterial{
use WoodTypeTrait;
protected SignText $text;
diff --git a/src/block/Bed.php b/src/block/Bed.php
index 133c4a9cc..21bd3a172 100644
--- a/src/block/Bed.php
+++ b/src/block/Bed.php
@@ -24,8 +24,10 @@ declare(strict_types=1);
namespace pocketmine\block;
use pocketmine\block\tile\Bed as TileBed;
+use pocketmine\block\utils\Colored;
use pocketmine\block\utils\ColoredTrait;
use pocketmine\block\utils\DyeColor;
+use pocketmine\block\utils\HorizontalFacing;
use pocketmine\block\utils\HorizontalFacingTrait;
use pocketmine\block\utils\SupportType;
use pocketmine\data\runtime\RuntimeDataDescriber;
@@ -41,7 +43,7 @@ use pocketmine\utils\TextFormat;
use pocketmine\world\BlockTransaction;
use pocketmine\world\World;
-class Bed extends Transparent{
+class Bed extends Transparent implements Colored, HorizontalFacing{
use ColoredTrait;
use HorizontalFacingTrait;
diff --git a/src/block/Bell.php b/src/block/Bell.php
index 53a6fc7fb..258abc628 100644
--- a/src/block/Bell.php
+++ b/src/block/Bell.php
@@ -25,6 +25,7 @@ namespace pocketmine\block;
use pocketmine\block\tile\Bell as TileBell;
use pocketmine\block\utils\BellAttachmentType;
+use pocketmine\block\utils\HorizontalFacing;
use pocketmine\block\utils\HorizontalFacingTrait;
use pocketmine\block\utils\SupportType;
use pocketmine\data\runtime\RuntimeDataDescriber;
@@ -38,7 +39,7 @@ use pocketmine\player\Player;
use pocketmine\world\BlockTransaction;
use pocketmine\world\sound\BellRingSound;
-final class Bell extends Transparent{
+final class Bell extends Transparent implements HorizontalFacing{
use HorizontalFacingTrait;
private BellAttachmentType $attachmentType = BellAttachmentType::FLOOR;
diff --git a/src/block/BoneBlock.php b/src/block/BoneBlock.php
index 247bdb748..465d96033 100644
--- a/src/block/BoneBlock.php
+++ b/src/block/BoneBlock.php
@@ -23,8 +23,9 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\PillarRotation;
use pocketmine\block\utils\PillarRotationTrait;
-class BoneBlock extends Opaque{
+class BoneBlock extends Opaque implements PillarRotation{
use PillarRotationTrait;
}
diff --git a/src/block/Button.php b/src/block/Button.php
index 73bd1d556..4d1f1bbc5 100644
--- a/src/block/Button.php
+++ b/src/block/Button.php
@@ -23,6 +23,7 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\AnyFacing;
use pocketmine\block\utils\AnyFacingTrait;
use pocketmine\data\runtime\RuntimeDataDescriber;
use pocketmine\item\Item;
@@ -33,7 +34,7 @@ use pocketmine\world\BlockTransaction;
use pocketmine\world\sound\RedstonePowerOffSound;
use pocketmine\world\sound\RedstonePowerOnSound;
-abstract class Button extends Flowable{
+abstract class Button extends Flowable implements AnyFacing{
use AnyFacingTrait;
protected bool $pressed = false;
diff --git a/src/block/Cactus.php b/src/block/Cactus.php
index 67b15b946..51c98786b 100644
--- a/src/block/Cactus.php
+++ b/src/block/Cactus.php
@@ -23,6 +23,7 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\Ageable;
use pocketmine\block\utils\AgeableTrait;
use pocketmine\block\utils\BlockEventHelper;
use pocketmine\block\utils\StaticSupportTrait;
@@ -33,7 +34,7 @@ use pocketmine\event\entity\EntityDamageEvent;
use pocketmine\math\AxisAlignedBB;
use pocketmine\math\Facing;
-class Cactus extends Transparent{
+class Cactus extends Transparent implements Ageable{
use AgeableTrait;
use StaticSupportTrait;
diff --git a/src/block/CakeWithCandle.php b/src/block/CakeWithCandle.php
index 546843d6c..1462776c2 100644
--- a/src/block/CakeWithCandle.php
+++ b/src/block/CakeWithCandle.php
@@ -24,6 +24,7 @@ declare(strict_types=1);
namespace pocketmine\block;
use pocketmine\block\utils\CandleTrait;
+use pocketmine\block\utils\Lightable;
use pocketmine\entity\Living;
use pocketmine\item\Item;
use pocketmine\math\AxisAlignedBB;
@@ -31,7 +32,7 @@ use pocketmine\math\Facing;
use pocketmine\math\Vector3;
use pocketmine\player\Player;
-class CakeWithCandle extends BaseCake{
+class CakeWithCandle extends BaseCake implements Lightable{
use CandleTrait {
onInteract as onInteractCandle;
}
diff --git a/src/block/CakeWithDyedCandle.php b/src/block/CakeWithDyedCandle.php
index 0dff358e1..04ab0c6eb 100644
--- a/src/block/CakeWithDyedCandle.php
+++ b/src/block/CakeWithDyedCandle.php
@@ -23,10 +23,11 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\Colored;
use pocketmine\block\utils\ColoredTrait;
use pocketmine\block\utils\DyeColor;
-class CakeWithDyedCandle extends CakeWithCandle{
+class CakeWithDyedCandle extends CakeWithCandle implements Colored{
use ColoredTrait;
public function __construct(BlockIdentifier $idInfo, string $name, BlockTypeInfo $typeInfo){
diff --git a/src/block/Campfire.php b/src/block/Campfire.php
index 9f4c42a9c..edfc87ecb 100644
--- a/src/block/Campfire.php
+++ b/src/block/Campfire.php
@@ -25,7 +25,9 @@ namespace pocketmine\block;
use pocketmine\block\inventory\CampfireInventory;
use pocketmine\block\tile\Campfire as TileCampfire;
+use pocketmine\block\utils\HorizontalFacing;
use pocketmine\block\utils\HorizontalFacingTrait;
+use pocketmine\block\utils\Lightable;
use pocketmine\block\utils\LightableTrait;
use pocketmine\block\utils\SupportType;
use pocketmine\crafting\FurnaceRecipe;
@@ -59,7 +61,7 @@ use function count;
use function min;
use function mt_rand;
-class Campfire extends Transparent{
+class Campfire extends Transparent implements Lightable, HorizontalFacing{
use HorizontalFacingTrait{
HorizontalFacingTrait::describeBlockOnlyState as encodeFacingState;
}
diff --git a/src/block/Candle.php b/src/block/Candle.php
index 7f22641e1..977f13a09 100644
--- a/src/block/Candle.php
+++ b/src/block/Candle.php
@@ -24,6 +24,7 @@ declare(strict_types=1);
namespace pocketmine\block;
use pocketmine\block\utils\CandleTrait;
+use pocketmine\block\utils\Lightable;
use pocketmine\block\utils\SupportType;
use pocketmine\data\runtime\RuntimeDataDescriber;
use pocketmine\item\Item;
@@ -35,7 +36,7 @@ use pocketmine\player\Player;
use pocketmine\utils\AssumptionFailedError;
use pocketmine\world\BlockTransaction;
-class Candle extends Transparent{
+class Candle extends Transparent implements Lightable{
use CandleTrait {
describeBlockOnlyState as encodeLitState;
getLightLevel as getBaseLightLevel;
diff --git a/src/block/Carpet.php b/src/block/Carpet.php
index 2d8e7ea47..fd8b42a09 100644
--- a/src/block/Carpet.php
+++ b/src/block/Carpet.php
@@ -23,12 +23,13 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\Colored;
use pocketmine\block\utils\ColoredTrait;
use pocketmine\block\utils\StaticSupportTrait;
use pocketmine\math\AxisAlignedBB;
use pocketmine\math\Facing;
-class Carpet extends Flowable{
+class Carpet extends Flowable implements Colored{
use ColoredTrait;
use StaticSupportTrait;
diff --git a/src/block/CarvedPumpkin.php b/src/block/CarvedPumpkin.php
index 98f3c2307..cfdb8d49d 100644
--- a/src/block/CarvedPumpkin.php
+++ b/src/block/CarvedPumpkin.php
@@ -24,7 +24,8 @@ declare(strict_types=1);
namespace pocketmine\block;
use pocketmine\block\utils\FacesOppositePlacingPlayerTrait;
+use pocketmine\block\utils\HorizontalFacing;
-class CarvedPumpkin extends Opaque{
+class CarvedPumpkin extends Opaque implements HorizontalFacing{
use FacesOppositePlacingPlayerTrait;
}
diff --git a/src/block/CaveVines.php b/src/block/CaveVines.php
index daa973507..84d7d3169 100644
--- a/src/block/CaveVines.php
+++ b/src/block/CaveVines.php
@@ -23,6 +23,7 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\Ageable;
use pocketmine\block\utils\AgeableTrait;
use pocketmine\block\utils\BlockEventHelper;
use pocketmine\block\utils\StaticSupportTrait;
@@ -39,7 +40,7 @@ use pocketmine\world\BlockTransaction;
use pocketmine\world\sound\GlowBerriesPickSound;
use function mt_rand;
-class CaveVines extends Flowable{
+class CaveVines extends Flowable implements Ageable{
use AgeableTrait;
use StaticSupportTrait;
diff --git a/src/block/Chain.php b/src/block/Chain.php
index e9cc2c9be..5ec3b1e2a 100644
--- a/src/block/Chain.php
+++ b/src/block/Chain.php
@@ -23,13 +23,14 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\PillarRotation;
use pocketmine\block\utils\PillarRotationTrait;
use pocketmine\block\utils\SupportType;
use pocketmine\math\Axis;
use pocketmine\math\AxisAlignedBB;
use pocketmine\math\Facing;
-final class Chain extends Transparent{
+final class Chain extends Transparent implements PillarRotation{
use PillarRotationTrait;
public function getSupportType(int $facing) : SupportType{
diff --git a/src/block/ChemistryTable.php b/src/block/ChemistryTable.php
index 058e40288..9b5e78f92 100644
--- a/src/block/ChemistryTable.php
+++ b/src/block/ChemistryTable.php
@@ -24,11 +24,12 @@ declare(strict_types=1);
namespace pocketmine\block;
use pocketmine\block\utils\FacesOppositePlacingPlayerTrait;
+use pocketmine\block\utils\HorizontalFacing;
use pocketmine\item\Item;
use pocketmine\math\Vector3;
use pocketmine\player\Player;
-final class ChemistryTable extends Opaque{
+final class ChemistryTable extends Opaque implements HorizontalFacing{
use FacesOppositePlacingPlayerTrait;
public function onInteract(Item $item, int $face, Vector3 $clickVector, ?Player $player = null, array &$returnedItems = []) : bool{
diff --git a/src/block/Chest.php b/src/block/Chest.php
index 7d2650007..c0dc09d9e 100644
--- a/src/block/Chest.php
+++ b/src/block/Chest.php
@@ -25,6 +25,7 @@ namespace pocketmine\block;
use pocketmine\block\tile\Chest as TileChest;
use pocketmine\block\utils\FacesOppositePlacingPlayerTrait;
+use pocketmine\block\utils\HorizontalFacing;
use pocketmine\block\utils\SupportType;
use pocketmine\event\block\ChestPairEvent;
use pocketmine\item\Item;
@@ -33,7 +34,7 @@ use pocketmine\math\Facing;
use pocketmine\math\Vector3;
use pocketmine\player\Player;
-class Chest extends Transparent{
+class Chest extends Transparent implements HorizontalFacing{
use FacesOppositePlacingPlayerTrait;
protected function recalculateCollisionBoxes() : array{
diff --git a/src/block/ChiseledBookshelf.php b/src/block/ChiseledBookshelf.php
index 73c4861bf..be49c7a91 100644
--- a/src/block/ChiseledBookshelf.php
+++ b/src/block/ChiseledBookshelf.php
@@ -26,6 +26,7 @@ namespace pocketmine\block;
use pocketmine\block\tile\ChiseledBookshelf as TileChiseledBookshelf;
use pocketmine\block\utils\ChiseledBookshelfSlot;
use pocketmine\block\utils\FacesOppositePlacingPlayerTrait;
+use pocketmine\block\utils\HorizontalFacing;
use pocketmine\block\utils\HorizontalFacingTrait;
use pocketmine\data\runtime\RuntimeDataDescriber;
use pocketmine\item\Book;
@@ -38,7 +39,7 @@ use pocketmine\math\Vector3;
use pocketmine\player\Player;
use function spl_object_id;
-class ChiseledBookshelf extends Opaque{
+class ChiseledBookshelf extends Opaque implements HorizontalFacing{
use HorizontalFacingTrait;
use FacesOppositePlacingPlayerTrait;
diff --git a/src/block/ChorusFlower.php b/src/block/ChorusFlower.php
index cc3c606d9..ef48d5a89 100644
--- a/src/block/ChorusFlower.php
+++ b/src/block/ChorusFlower.php
@@ -23,6 +23,7 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\Ageable;
use pocketmine\block\utils\AgeableTrait;
use pocketmine\block\utils\StaticSupportTrait;
use pocketmine\entity\projectile\Projectile;
@@ -40,7 +41,7 @@ use function array_rand;
use function min;
use function mt_rand;
-final class ChorusFlower extends Flowable{
+final class ChorusFlower extends Flowable implements Ageable{
use AgeableTrait;
use StaticSupportTrait;
diff --git a/src/block/CocoaBlock.php b/src/block/CocoaBlock.php
index 83e1de34b..ae09ccb0a 100644
--- a/src/block/CocoaBlock.php
+++ b/src/block/CocoaBlock.php
@@ -23,8 +23,10 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\Ageable;
use pocketmine\block\utils\AgeableTrait;
use pocketmine\block\utils\BlockEventHelper;
+use pocketmine\block\utils\HorizontalFacing;
use pocketmine\block\utils\HorizontalFacingTrait;
use pocketmine\block\utils\WoodType;
use pocketmine\data\runtime\RuntimeDataDescriber;
@@ -39,7 +41,7 @@ use pocketmine\player\Player;
use pocketmine\world\BlockTransaction;
use function mt_rand;
-class CocoaBlock extends Flowable{
+class CocoaBlock extends Flowable implements Ageable, HorizontalFacing{
use HorizontalFacingTrait;
use AgeableTrait;
diff --git a/src/block/Concrete.php b/src/block/Concrete.php
index fae6f8e2f..6cad11193 100644
--- a/src/block/Concrete.php
+++ b/src/block/Concrete.php
@@ -23,8 +23,9 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\Colored;
use pocketmine\block\utils\ColoredTrait;
-class Concrete extends Opaque{
+class Concrete extends Opaque implements Colored{
use ColoredTrait;
}
diff --git a/src/block/ConcretePowder.php b/src/block/ConcretePowder.php
index 59f14bc72..89b53053b 100644
--- a/src/block/ConcretePowder.php
+++ b/src/block/ConcretePowder.php
@@ -24,12 +24,13 @@ declare(strict_types=1);
namespace pocketmine\block;
use pocketmine\block\utils\BlockEventHelper;
+use pocketmine\block\utils\Colored;
use pocketmine\block\utils\ColoredTrait;
use pocketmine\block\utils\Fallable;
use pocketmine\block\utils\FallableTrait;
use pocketmine\math\Facing;
-class ConcretePowder extends Opaque implements Fallable{
+class ConcretePowder extends Opaque implements Fallable, Colored{
use ColoredTrait;
use FallableTrait {
onNearbyBlockChange as protected startFalling;
diff --git a/src/block/CopperBulb.php b/src/block/CopperBulb.php
index 97fc209fe..d0bdedf3c 100644
--- a/src/block/CopperBulb.php
+++ b/src/block/CopperBulb.php
@@ -26,11 +26,13 @@ namespace pocketmine\block;
use pocketmine\block\utils\CopperMaterial;
use pocketmine\block\utils\CopperOxidation;
use pocketmine\block\utils\CopperTrait;
+use pocketmine\block\utils\Lightable;
use pocketmine\block\utils\LightableTrait;
+use pocketmine\block\utils\PoweredByRedstone;
use pocketmine\block\utils\PoweredByRedstoneTrait;
use pocketmine\data\runtime\RuntimeDataDescriber;
-class CopperBulb extends Opaque implements CopperMaterial{
+class CopperBulb extends Opaque implements CopperMaterial, Lightable, PoweredByRedstone{
use CopperTrait;
use PoweredByRedstoneTrait;
use LightableTrait{
diff --git a/src/block/CoralBlock.php b/src/block/CoralBlock.php
index 3e7ca8224..c21209998 100644
--- a/src/block/CoralBlock.php
+++ b/src/block/CoralBlock.php
@@ -24,11 +24,12 @@ declare(strict_types=1);
namespace pocketmine\block;
use pocketmine\block\utils\BlockEventHelper;
+use pocketmine\block\utils\CoralMaterial;
use pocketmine\block\utils\CoralTypeTrait;
use pocketmine\item\Item;
use function mt_rand;
-final class CoralBlock extends Opaque{
+final class CoralBlock extends Opaque implements CoralMaterial{
use CoralTypeTrait;
public function onNearbyBlockChange() : void{
diff --git a/src/block/Crops.php b/src/block/Crops.php
index e90ac6236..b0488d150 100644
--- a/src/block/Crops.php
+++ b/src/block/Crops.php
@@ -23,6 +23,7 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\Ageable;
use pocketmine\block\utils\AgeableTrait;
use pocketmine\block\utils\BlockEventHelper;
use pocketmine\block\utils\CropGrowthHelper;
@@ -34,7 +35,7 @@ use pocketmine\math\Vector3;
use pocketmine\player\Player;
use function mt_rand;
-abstract class Crops extends Flowable{
+abstract class Crops extends Flowable implements Ageable{
use AgeableTrait;
use StaticSupportTrait;
diff --git a/src/block/DaylightSensor.php b/src/block/DaylightSensor.php
index 5720af529..ed56d2f44 100644
--- a/src/block/DaylightSensor.php
+++ b/src/block/DaylightSensor.php
@@ -23,6 +23,7 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\AnalogRedstoneSignalEmitter;
use pocketmine\block\utils\AnalogRedstoneSignalEmitterTrait;
use pocketmine\block\utils\SupportType;
use pocketmine\data\runtime\RuntimeDataDescriber;
@@ -36,7 +37,7 @@ use function max;
use function round;
use const M_PI;
-class DaylightSensor extends Transparent{
+class DaylightSensor extends Transparent implements AnalogRedstoneSignalEmitter{
use AnalogRedstoneSignalEmitterTrait;
protected bool $inverted = false;
diff --git a/src/block/Door.php b/src/block/Door.php
index fa88267e1..2ff53645c 100644
--- a/src/block/Door.php
+++ b/src/block/Door.php
@@ -23,6 +23,7 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\HorizontalFacing;
use pocketmine\block\utils\HorizontalFacingTrait;
use pocketmine\block\utils\SupportType;
use pocketmine\data\runtime\RuntimeDataDescriber;
@@ -34,7 +35,7 @@ use pocketmine\player\Player;
use pocketmine\world\BlockTransaction;
use pocketmine\world\sound\DoorSound;
-class Door extends Transparent{
+class Door extends Transparent implements HorizontalFacing{
use HorizontalFacingTrait;
protected bool $top = false;
diff --git a/src/block/DoublePitcherCrop.php b/src/block/DoublePitcherCrop.php
index 1233ed05d..89d9e98b5 100644
--- a/src/block/DoublePitcherCrop.php
+++ b/src/block/DoublePitcherCrop.php
@@ -23,6 +23,7 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\Ageable;
use pocketmine\block\utils\AgeableTrait;
use pocketmine\block\utils\CropGrowthHelper;
use pocketmine\data\runtime\RuntimeDataDescriber;
@@ -37,7 +38,7 @@ use pocketmine\math\Vector3;
use pocketmine\player\Player;
use pocketmine\world\BlockTransaction;
-final class DoublePitcherCrop extends DoublePlant{
+final class DoublePitcherCrop extends DoublePlant implements Ageable{
use AgeableTrait {
describeBlockOnlyState as describeAge;
}
diff --git a/src/block/DyedCandle.php b/src/block/DyedCandle.php
index a495e8d00..57a8b5923 100644
--- a/src/block/DyedCandle.php
+++ b/src/block/DyedCandle.php
@@ -23,9 +23,10 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\Colored;
use pocketmine\block\utils\ColoredTrait;
-class DyedCandle extends Candle{
+class DyedCandle extends Candle implements Colored{
use ColoredTrait;
protected function getCandleIfCompatibleType(Block $block) : ?Candle{
diff --git a/src/block/DyedShulkerBox.php b/src/block/DyedShulkerBox.php
index 5eae9237e..8be2718a2 100644
--- a/src/block/DyedShulkerBox.php
+++ b/src/block/DyedShulkerBox.php
@@ -23,8 +23,9 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\Colored;
use pocketmine\block\utils\ColoredTrait;
-final class DyedShulkerBox extends ShulkerBox{
+final class DyedShulkerBox extends ShulkerBox implements Colored{
use ColoredTrait;
}
diff --git a/src/block/EndPortalFrame.php b/src/block/EndPortalFrame.php
index ed5b77433..6c4865fdd 100644
--- a/src/block/EndPortalFrame.php
+++ b/src/block/EndPortalFrame.php
@@ -24,11 +24,12 @@ declare(strict_types=1);
namespace pocketmine\block;
use pocketmine\block\utils\FacesOppositePlacingPlayerTrait;
+use pocketmine\block\utils\HorizontalFacing;
use pocketmine\data\runtime\RuntimeDataDescriber;
use pocketmine\math\AxisAlignedBB;
use pocketmine\math\Facing;
-class EndPortalFrame extends Opaque{
+class EndPortalFrame extends Opaque implements HorizontalFacing{
use FacesOppositePlacingPlayerTrait;
protected bool $eye = false;
diff --git a/src/block/EndRod.php b/src/block/EndRod.php
index a6770f370..e3d439f6a 100644
--- a/src/block/EndRod.php
+++ b/src/block/EndRod.php
@@ -23,6 +23,7 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\AnyFacing;
use pocketmine\block\utils\AnyFacingTrait;
use pocketmine\item\Item;
use pocketmine\math\Axis;
@@ -32,7 +33,7 @@ use pocketmine\math\Vector3;
use pocketmine\player\Player;
use pocketmine\world\BlockTransaction;
-class EndRod extends Flowable{
+class EndRod extends Flowable implements AnyFacing{
use AnyFacingTrait;
public function place(BlockTransaction $tx, Item $item, Block $blockReplace, Block $blockClicked, int $face, Vector3 $clickVector, ?Player $player = null) : bool{
diff --git a/src/block/EnderChest.php b/src/block/EnderChest.php
index 6a8cf108c..5dec4f3af 100644
--- a/src/block/EnderChest.php
+++ b/src/block/EnderChest.php
@@ -26,6 +26,7 @@ namespace pocketmine\block;
use pocketmine\block\inventory\EnderChestInventory;
use pocketmine\block\tile\EnderChest as TileEnderChest;
use pocketmine\block\utils\FacesOppositePlacingPlayerTrait;
+use pocketmine\block\utils\HorizontalFacing;
use pocketmine\block\utils\SupportType;
use pocketmine\item\Item;
use pocketmine\math\AxisAlignedBB;
@@ -33,7 +34,7 @@ use pocketmine\math\Facing;
use pocketmine\math\Vector3;
use pocketmine\player\Player;
-class EnderChest extends Transparent{
+class EnderChest extends Transparent implements HorizontalFacing{
use FacesOppositePlacingPlayerTrait;
public function getLightLevel() : int{
diff --git a/src/block/FenceGate.php b/src/block/FenceGate.php
index 2bbfdf892..d8cdfe4e2 100644
--- a/src/block/FenceGate.php
+++ b/src/block/FenceGate.php
@@ -23,8 +23,10 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\HorizontalFacing;
use pocketmine\block\utils\HorizontalFacingTrait;
use pocketmine\block\utils\SupportType;
+use pocketmine\block\utils\WoodMaterial;
use pocketmine\block\utils\WoodTypeTrait;
use pocketmine\data\runtime\RuntimeDataDescriber;
use pocketmine\item\Item;
@@ -35,7 +37,7 @@ use pocketmine\player\Player;
use pocketmine\world\BlockTransaction;
use pocketmine\world\sound\DoorSound;
-class FenceGate extends Transparent{
+class FenceGate extends Transparent implements HorizontalFacing, WoodMaterial{
use WoodTypeTrait;
use HorizontalFacingTrait;
diff --git a/src/block/Fire.php b/src/block/Fire.php
index 35a7a696c..62809fb9d 100644
--- a/src/block/Fire.php
+++ b/src/block/Fire.php
@@ -23,6 +23,7 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\Ageable;
use pocketmine\block\utils\AgeableTrait;
use pocketmine\block\utils\BlockEventHelper;
use pocketmine\block\utils\SupportType;
@@ -35,7 +36,7 @@ use function max;
use function min;
use function mt_rand;
-class Fire extends BaseFire{
+class Fire extends BaseFire implements Ageable{
use AgeableTrait;
public const MAX_AGE = 15;
diff --git a/src/block/FloorBanner.php b/src/block/FloorBanner.php
index 73bc45787..ba089b6c0 100644
--- a/src/block/FloorBanner.php
+++ b/src/block/FloorBanner.php
@@ -23,6 +23,7 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\SignLikeRotation;
use pocketmine\block\utils\SignLikeRotationTrait;
use pocketmine\item\Item;
use pocketmine\math\Facing;
@@ -30,7 +31,7 @@ use pocketmine\math\Vector3;
use pocketmine\player\Player;
use pocketmine\world\BlockTransaction;
-final class FloorBanner extends BaseBanner{
+final class FloorBanner extends BaseBanner implements SignLikeRotation{
use SignLikeRotationTrait;
protected function getSupportingFace() : int{
diff --git a/src/block/FloorSign.php b/src/block/FloorSign.php
index 5615d15d8..94e51ffe8 100644
--- a/src/block/FloorSign.php
+++ b/src/block/FloorSign.php
@@ -23,6 +23,7 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\SignLikeRotation;
use pocketmine\block\utils\SignLikeRotationTrait;
use pocketmine\item\Item;
use pocketmine\math\Facing;
@@ -30,7 +31,7 @@ use pocketmine\math\Vector3;
use pocketmine\player\Player;
use pocketmine\world\BlockTransaction;
-final class FloorSign extends BaseSign{
+final class FloorSign extends BaseSign implements SignLikeRotation{
use SignLikeRotationTrait;
protected function getSupportingFace() : int{
diff --git a/src/block/FrostedIce.php b/src/block/FrostedIce.php
index 3e8592306..046d75811 100644
--- a/src/block/FrostedIce.php
+++ b/src/block/FrostedIce.php
@@ -23,11 +23,12 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\Ageable;
use pocketmine\block\utils\AgeableTrait;
use pocketmine\block\utils\BlockEventHelper;
use function mt_rand;
-class FrostedIce extends Ice{
+class FrostedIce extends Ice implements Ageable{
use AgeableTrait;
public const MAX_AGE = 3;
diff --git a/src/block/Furnace.php b/src/block/Furnace.php
index 7a64e3cd3..54480e62c 100644
--- a/src/block/Furnace.php
+++ b/src/block/Furnace.php
@@ -25,6 +25,7 @@ namespace pocketmine\block;
use pocketmine\block\tile\Furnace as TileFurnace;
use pocketmine\block\utils\FacesOppositePlacingPlayerTrait;
+use pocketmine\block\utils\Lightable;
use pocketmine\block\utils\LightableTrait;
use pocketmine\crafting\FurnaceType;
use pocketmine\data\runtime\RuntimeDataDescriber;
@@ -33,7 +34,7 @@ use pocketmine\math\Vector3;
use pocketmine\player\Player;
use function mt_rand;
-class Furnace extends Opaque{
+class Furnace extends Opaque implements Lightable{
use FacesOppositePlacingPlayerTrait;
use LightableTrait;
diff --git a/src/block/GlazedTerracotta.php b/src/block/GlazedTerracotta.php
index 15b3254e5..ccb928875 100644
--- a/src/block/GlazedTerracotta.php
+++ b/src/block/GlazedTerracotta.php
@@ -23,10 +23,12 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\Colored;
use pocketmine\block\utils\ColoredTrait;
use pocketmine\block\utils\FacesOppositePlacingPlayerTrait;
+use pocketmine\block\utils\HorizontalFacing;
-class GlazedTerracotta extends Opaque{
+class GlazedTerracotta extends Opaque implements Colored, HorizontalFacing{
use ColoredTrait;
use FacesOppositePlacingPlayerTrait;
}
diff --git a/src/block/GlowLichen.php b/src/block/GlowLichen.php
index a44c4d035..6ad8d3748 100644
--- a/src/block/GlowLichen.php
+++ b/src/block/GlowLichen.php
@@ -25,6 +25,7 @@ namespace pocketmine\block;
use pocketmine\block\utils\BlockEventHelper;
use pocketmine\block\utils\MultiAnySupportTrait;
+use pocketmine\block\utils\MultiFacing;
use pocketmine\block\utils\SupportType;
use pocketmine\item\Fertilizer;
use pocketmine\item\Item;
@@ -35,7 +36,7 @@ use pocketmine\world\World;
use function count;
use function shuffle;
-class GlowLichen extends Transparent{
+class GlowLichen extends Transparent implements MultiFacing{
use MultiAnySupportTrait;
public function getLightLevel() : int{
diff --git a/src/block/HayBale.php b/src/block/HayBale.php
index 6fdd2cb63..dacfe92fa 100644
--- a/src/block/HayBale.php
+++ b/src/block/HayBale.php
@@ -23,10 +23,11 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\PillarRotation;
use pocketmine\block\utils\PillarRotationTrait;
use pocketmine\entity\Entity;
-class HayBale extends Opaque{
+class HayBale extends Opaque implements PillarRotation{
use PillarRotationTrait;
public function getFlameEncouragement() : int{
diff --git a/src/block/Hopper.php b/src/block/Hopper.php
index 0d823674b..4956b668f 100644
--- a/src/block/Hopper.php
+++ b/src/block/Hopper.php
@@ -24,6 +24,7 @@ declare(strict_types=1);
namespace pocketmine\block;
use pocketmine\block\tile\Hopper as TileHopper;
+use pocketmine\block\utils\PoweredByRedstone;
use pocketmine\block\utils\PoweredByRedstoneTrait;
use pocketmine\block\utils\SupportType;
use pocketmine\data\runtime\RuntimeDataDescriber;
@@ -34,7 +35,7 @@ use pocketmine\math\Vector3;
use pocketmine\player\Player;
use pocketmine\world\BlockTransaction;
-class Hopper extends Transparent{
+class Hopper extends Transparent implements PoweredByRedstone{
use PoweredByRedstoneTrait;
private int $facing = Facing::DOWN;
diff --git a/src/block/ItemFrame.php b/src/block/ItemFrame.php
index c03806a3b..0fda77758 100644
--- a/src/block/ItemFrame.php
+++ b/src/block/ItemFrame.php
@@ -24,6 +24,7 @@ declare(strict_types=1);
namespace pocketmine\block;
use pocketmine\block\tile\ItemFrame as TileItemFrame;
+use pocketmine\block\utils\AnyFacing;
use pocketmine\block\utils\AnyFacingTrait;
use pocketmine\block\utils\SupportType;
use pocketmine\data\runtime\RuntimeDataDescriber;
@@ -39,7 +40,7 @@ use pocketmine\world\sound\ItemFrameRotateItemSound;
use function is_infinite;
use function is_nan;
-class ItemFrame extends Flowable{
+class ItemFrame extends Flowable implements AnyFacing{
use AnyFacingTrait;
public const ROTATIONS = 8;
diff --git a/src/block/Ladder.php b/src/block/Ladder.php
index 09c0b8f6b..6edaebbf2 100644
--- a/src/block/Ladder.php
+++ b/src/block/Ladder.php
@@ -23,6 +23,7 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\HorizontalFacing;
use pocketmine\block\utils\HorizontalFacingTrait;
use pocketmine\block\utils\SupportType;
use pocketmine\entity\Entity;
@@ -35,7 +36,7 @@ use pocketmine\math\Vector3;
use pocketmine\player\Player;
use pocketmine\world\BlockTransaction;
-class Ladder extends Transparent{
+class Ladder extends Transparent implements HorizontalFacing{
use HorizontalFacingTrait;
public function hasEntityCollision() : bool{
diff --git a/src/block/Lectern.php b/src/block/Lectern.php
index 03880b3c5..9ba01c1c5 100644
--- a/src/block/Lectern.php
+++ b/src/block/Lectern.php
@@ -25,6 +25,7 @@ namespace pocketmine\block;
use pocketmine\block\tile\Lectern as TileLectern;
use pocketmine\block\utils\FacesOppositePlacingPlayerTrait;
+use pocketmine\block\utils\HorizontalFacing;
use pocketmine\block\utils\SupportType;
use pocketmine\data\runtime\RuntimeDataDescriber;
use pocketmine\item\Item;
@@ -36,7 +37,7 @@ use pocketmine\player\Player;
use pocketmine\world\sound\LecternPlaceBookSound;
use function count;
-class Lectern extends Transparent{
+class Lectern extends Transparent implements HorizontalFacing{
use FacesOppositePlacingPlayerTrait;
protected int $viewedPage = 0;
diff --git a/src/block/LightningRod.php b/src/block/LightningRod.php
index a0dd50542..9c1971229 100644
--- a/src/block/LightningRod.php
+++ b/src/block/LightningRod.php
@@ -23,6 +23,7 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\AnyFacing;
use pocketmine\block\utils\AnyFacingTrait;
use pocketmine\item\Item;
use pocketmine\math\Axis;
@@ -32,7 +33,7 @@ use pocketmine\math\Vector3;
use pocketmine\player\Player;
use pocketmine\world\BlockTransaction;
-final class LightningRod extends Transparent{
+final class LightningRod extends Transparent implements AnyFacing{
use AnyFacingTrait;
protected function recalculateCollisionBoxes() : array{
diff --git a/src/block/Loom.php b/src/block/Loom.php
index d3dd4f3c7..a2b9fc235 100644
--- a/src/block/Loom.php
+++ b/src/block/Loom.php
@@ -25,11 +25,12 @@ namespace pocketmine\block;
use pocketmine\block\inventory\LoomInventory;
use pocketmine\block\utils\FacesOppositePlacingPlayerTrait;
+use pocketmine\block\utils\HorizontalFacing;
use pocketmine\item\Item;
use pocketmine\math\Vector3;
use pocketmine\player\Player;
-final class Loom extends Opaque{
+final class Loom extends Opaque implements HorizontalFacing{
use FacesOppositePlacingPlayerTrait;
public function onInteract(Item $item, int $face, Vector3 $clickVector, ?Player $player = null, array &$returnedItems = []) : bool{
diff --git a/src/block/NetherVines.php b/src/block/NetherVines.php
index e8729c00f..67a0b6f94 100644
--- a/src/block/NetherVines.php
+++ b/src/block/NetherVines.php
@@ -23,6 +23,7 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\Ageable;
use pocketmine\block\utils\AgeableTrait;
use pocketmine\block\utils\FortuneDropHelper;
use pocketmine\block\utils\StaticSupportTrait;
@@ -41,7 +42,7 @@ use function mt_rand;
/**
* This class is used for Weeping & Twisting vines, because they have same behaviour
*/
-class NetherVines extends Flowable{
+class NetherVines extends Flowable implements Ageable{
use AgeableTrait;
use StaticSupportTrait;
diff --git a/src/block/NetherWartPlant.php b/src/block/NetherWartPlant.php
index 34e6fd57e..df0609754 100644
--- a/src/block/NetherWartPlant.php
+++ b/src/block/NetherWartPlant.php
@@ -23,6 +23,7 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\Ageable;
use pocketmine\block\utils\AgeableTrait;
use pocketmine\block\utils\BlockEventHelper;
use pocketmine\block\utils\FortuneDropHelper;
@@ -31,7 +32,7 @@ use pocketmine\item\Item;
use pocketmine\math\Facing;
use function mt_rand;
-class NetherWartPlant extends Flowable{
+class NetherWartPlant extends Flowable implements Ageable{
use AgeableTrait;
use StaticSupportTrait;
diff --git a/src/block/PinkPetals.php b/src/block/PinkPetals.php
index 17bc4c50a..b8b6e248c 100644
--- a/src/block/PinkPetals.php
+++ b/src/block/PinkPetals.php
@@ -24,6 +24,7 @@ declare(strict_types=1);
namespace pocketmine\block;
use pocketmine\block\utils\BlockEventHelper;
+use pocketmine\block\utils\HorizontalFacing;
use pocketmine\block\utils\HorizontalFacingTrait;
use pocketmine\block\utils\StaticSupportTrait;
use pocketmine\data\runtime\RuntimeDataDescriber;
@@ -34,7 +35,7 @@ use pocketmine\math\Vector3;
use pocketmine\player\Player;
use pocketmine\world\BlockTransaction;
-class PinkPetals extends Flowable{
+class PinkPetals extends Flowable implements HorizontalFacing{
use HorizontalFacingTrait;
use StaticSupportTrait {
canBePlacedAt as supportedWhenPlacedAt;
diff --git a/src/block/PitcherCrop.php b/src/block/PitcherCrop.php
index d41aed284..1c771bb8a 100644
--- a/src/block/PitcherCrop.php
+++ b/src/block/PitcherCrop.php
@@ -23,6 +23,7 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\Ageable;
use pocketmine\block\utils\AgeableTrait;
use pocketmine\block\utils\BlockEventHelper;
use pocketmine\block\utils\CropGrowthHelper;
@@ -38,7 +39,7 @@ use pocketmine\math\Vector3;
use pocketmine\player\Player;
use pocketmine\world\BlockTransaction;
-final class PitcherCrop extends Flowable{
+final class PitcherCrop extends Flowable implements Ageable{
use AgeableTrait;
use StaticSupportTrait;
diff --git a/src/block/Planks.php b/src/block/Planks.php
index 1074f8adf..ad7956361 100644
--- a/src/block/Planks.php
+++ b/src/block/Planks.php
@@ -23,9 +23,10 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\WoodMaterial;
use pocketmine\block\utils\WoodTypeTrait;
-class Planks extends Opaque{
+class Planks extends Opaque implements WoodMaterial{
use WoodTypeTrait;
public function getFuelTime() : int{
diff --git a/src/block/PoweredRail.php b/src/block/PoweredRail.php
index 25d6dc9e3..321b19a46 100644
--- a/src/block/PoweredRail.php
+++ b/src/block/PoweredRail.php
@@ -23,8 +23,9 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\PoweredByRedstone;
use pocketmine\block\utils\RailPoweredByRedstoneTrait;
-class PoweredRail extends StraightOnlyRail{
+class PoweredRail extends StraightOnlyRail implements PoweredByRedstone{
use RailPoweredByRedstoneTrait;
}
diff --git a/src/block/RedstoneComparator.php b/src/block/RedstoneComparator.php
index 40e1ef510..88050b85a 100644
--- a/src/block/RedstoneComparator.php
+++ b/src/block/RedstoneComparator.php
@@ -24,8 +24,11 @@ declare(strict_types=1);
namespace pocketmine\block;
use pocketmine\block\tile\Comparator;
+use pocketmine\block\utils\AnalogRedstoneSignalEmitter;
use pocketmine\block\utils\AnalogRedstoneSignalEmitterTrait;
+use pocketmine\block\utils\HorizontalFacing;
use pocketmine\block\utils\HorizontalFacingTrait;
+use pocketmine\block\utils\PoweredByRedstone;
use pocketmine\block\utils\PoweredByRedstoneTrait;
use pocketmine\block\utils\StaticSupportTrait;
use pocketmine\block\utils\SupportType;
@@ -38,7 +41,7 @@ use pocketmine\player\Player;
use pocketmine\world\BlockTransaction;
use function assert;
-class RedstoneComparator extends Flowable{
+class RedstoneComparator extends Flowable implements AnalogRedstoneSignalEmitter, PoweredByRedstone, HorizontalFacing{
use HorizontalFacingTrait;
use AnalogRedstoneSignalEmitterTrait;
use PoweredByRedstoneTrait;
diff --git a/src/block/RedstoneLamp.php b/src/block/RedstoneLamp.php
index 58098c395..33a97801d 100644
--- a/src/block/RedstoneLamp.php
+++ b/src/block/RedstoneLamp.php
@@ -23,10 +23,11 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\PoweredByRedstone;
use pocketmine\block\utils\PoweredByRedstoneTrait;
use pocketmine\data\runtime\RuntimeDataDescriber;
-class RedstoneLamp extends Opaque{
+class RedstoneLamp extends Opaque implements PoweredByRedstone{
use PoweredByRedstoneTrait;
protected function describeBlockOnlyState(RuntimeDataDescriber $w) : void{
diff --git a/src/block/RedstoneOre.php b/src/block/RedstoneOre.php
index 10e701a6f..3477a3519 100644
--- a/src/block/RedstoneOre.php
+++ b/src/block/RedstoneOre.php
@@ -24,6 +24,7 @@ declare(strict_types=1);
namespace pocketmine\block;
use pocketmine\block\utils\FortuneDropHelper;
+use pocketmine\block\utils\Lightable;
use pocketmine\block\utils\LightableTrait;
use pocketmine\item\Item;
use pocketmine\item\VanillaItems;
@@ -31,7 +32,7 @@ use pocketmine\math\Vector3;
use pocketmine\player\Player;
use function mt_rand;
-class RedstoneOre extends Opaque{
+class RedstoneOre extends Opaque implements Lightable{
use LightableTrait;
public function getLightLevel() : int{
diff --git a/src/block/RedstoneRepeater.php b/src/block/RedstoneRepeater.php
index bf9d0c5da..4059ff1cc 100644
--- a/src/block/RedstoneRepeater.php
+++ b/src/block/RedstoneRepeater.php
@@ -23,7 +23,9 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\HorizontalFacing;
use pocketmine\block\utils\HorizontalFacingTrait;
+use pocketmine\block\utils\PoweredByRedstone;
use pocketmine\block\utils\PoweredByRedstoneTrait;
use pocketmine\block\utils\StaticSupportTrait;
use pocketmine\block\utils\SupportType;
@@ -35,7 +37,7 @@ use pocketmine\math\Vector3;
use pocketmine\player\Player;
use pocketmine\world\BlockTransaction;
-class RedstoneRepeater extends Flowable{
+class RedstoneRepeater extends Flowable implements PoweredByRedstone, HorizontalFacing{
use HorizontalFacingTrait;
use PoweredByRedstoneTrait;
use StaticSupportTrait;
diff --git a/src/block/RedstoneTorch.php b/src/block/RedstoneTorch.php
index 26c86038b..f73076ccc 100644
--- a/src/block/RedstoneTorch.php
+++ b/src/block/RedstoneTorch.php
@@ -23,10 +23,11 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\Lightable;
use pocketmine\block\utils\LightableTrait;
use pocketmine\data\runtime\RuntimeDataDescriber;
-class RedstoneTorch extends Torch{
+class RedstoneTorch extends Torch implements Lightable{
use LightableTrait;
public function __construct(BlockIdentifier $idInfo, string $name, BlockTypeInfo $typeInfo){
diff --git a/src/block/RedstoneWire.php b/src/block/RedstoneWire.php
index a2d293fca..6be27bcb4 100644
--- a/src/block/RedstoneWire.php
+++ b/src/block/RedstoneWire.php
@@ -23,13 +23,14 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\AnalogRedstoneSignalEmitter;
use pocketmine\block\utils\AnalogRedstoneSignalEmitterTrait;
use pocketmine\block\utils\StaticSupportTrait;
use pocketmine\item\Item;
use pocketmine\item\VanillaItems;
use pocketmine\math\Facing;
-class RedstoneWire extends Flowable{
+class RedstoneWire extends Flowable implements AnalogRedstoneSignalEmitter{
use AnalogRedstoneSignalEmitterTrait;
use StaticSupportTrait;
diff --git a/src/block/ResinClump.php b/src/block/ResinClump.php
index 75126edf3..2855a7cc3 100644
--- a/src/block/ResinClump.php
+++ b/src/block/ResinClump.php
@@ -24,9 +24,10 @@ declare(strict_types=1);
namespace pocketmine\block;
use pocketmine\block\utils\MultiAnySupportTrait;
+use pocketmine\block\utils\MultiFacing;
use pocketmine\block\utils\SupportType;
-final class ResinClump extends Transparent{
+final class ResinClump extends Transparent implements MultiFacing{
use MultiAnySupportTrait;
public function isSolid() : bool{
diff --git a/src/block/ShulkerBox.php b/src/block/ShulkerBox.php
index d557401ee..52a3b83cd 100644
--- a/src/block/ShulkerBox.php
+++ b/src/block/ShulkerBox.php
@@ -24,6 +24,7 @@ declare(strict_types=1);
namespace pocketmine\block;
use pocketmine\block\tile\ShulkerBox as TileShulkerBox;
+use pocketmine\block\utils\AnyFacing;
use pocketmine\block\utils\AnyFacingTrait;
use pocketmine\block\utils\SupportType;
use pocketmine\data\runtime\RuntimeDataDescriber;
@@ -32,7 +33,7 @@ use pocketmine\math\Vector3;
use pocketmine\player\Player;
use pocketmine\world\BlockTransaction;
-class ShulkerBox extends Opaque{
+class ShulkerBox extends Opaque implements AnyFacing{
use AnyFacingTrait;
protected function describeBlockOnlyState(RuntimeDataDescriber $w) : void{
diff --git a/src/block/SimplePillar.php b/src/block/SimplePillar.php
index 98c89f89c..6a7af96ed 100644
--- a/src/block/SimplePillar.php
+++ b/src/block/SimplePillar.php
@@ -23,12 +23,13 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\PillarRotation;
use pocketmine\block\utils\PillarRotationTrait;
/**
* @internal This class provides a general base for pillar-like blocks. It **should not** be used for contract binding
* in APIs, because not all pillar-like blocks extend this class.
*/
-class SimplePillar extends Opaque{
+class SimplePillar extends Opaque implements PillarRotation{
use PillarRotationTrait;
}
diff --git a/src/block/SmallDripleaf.php b/src/block/SmallDripleaf.php
index d192e43db..846be5c93 100644
--- a/src/block/SmallDripleaf.php
+++ b/src/block/SmallDripleaf.php
@@ -23,6 +23,7 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\HorizontalFacing;
use pocketmine\block\utils\HorizontalFacingTrait;
use pocketmine\block\utils\SupportType;
use pocketmine\data\runtime\RuntimeDataDescriber;
@@ -36,7 +37,7 @@ use pocketmine\world\BlockTransaction;
use pocketmine\world\Position;
use function mt_rand;
-class SmallDripleaf extends Transparent{
+class SmallDripleaf extends Transparent implements HorizontalFacing{
use HorizontalFacingTrait;
protected bool $top = false;
diff --git a/src/block/StainedGlass.php b/src/block/StainedGlass.php
index bc0d84877..baf4755bb 100644
--- a/src/block/StainedGlass.php
+++ b/src/block/StainedGlass.php
@@ -23,8 +23,9 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\Colored;
use pocketmine\block\utils\ColoredTrait;
-final class StainedGlass extends Glass{
+final class StainedGlass extends Glass implements Colored{
use ColoredTrait;
}
diff --git a/src/block/StainedGlassPane.php b/src/block/StainedGlassPane.php
index 18ecfdee0..897c291c7 100644
--- a/src/block/StainedGlassPane.php
+++ b/src/block/StainedGlassPane.php
@@ -23,8 +23,9 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\Colored;
use pocketmine\block\utils\ColoredTrait;
-final class StainedGlassPane extends GlassPane{
+final class StainedGlassPane extends GlassPane implements Colored{
use ColoredTrait;
}
diff --git a/src/block/StainedHardenedClay.php b/src/block/StainedHardenedClay.php
index 2c2c01ba3..765e97e4f 100644
--- a/src/block/StainedHardenedClay.php
+++ b/src/block/StainedHardenedClay.php
@@ -23,8 +23,9 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\Colored;
use pocketmine\block\utils\ColoredTrait;
-final class StainedHardenedClay extends HardenedClay{
+final class StainedHardenedClay extends HardenedClay implements Colored{
use ColoredTrait;
}
diff --git a/src/block/StainedHardenedGlass.php b/src/block/StainedHardenedGlass.php
index cc609a49a..c3a794e4d 100644
--- a/src/block/StainedHardenedGlass.php
+++ b/src/block/StainedHardenedGlass.php
@@ -23,8 +23,9 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\Colored;
use pocketmine\block\utils\ColoredTrait;
-final class StainedHardenedGlass extends HardenedGlass{
+final class StainedHardenedGlass extends HardenedGlass implements Colored{
use ColoredTrait;
}
diff --git a/src/block/StainedHardenedGlassPane.php b/src/block/StainedHardenedGlassPane.php
index 63dbe1f77..9631ff5a9 100644
--- a/src/block/StainedHardenedGlassPane.php
+++ b/src/block/StainedHardenedGlassPane.php
@@ -23,8 +23,9 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\Colored;
use pocketmine\block\utils\ColoredTrait;
-final class StainedHardenedGlassPane extends HardenedGlassPane{
+final class StainedHardenedGlassPane extends HardenedGlassPane implements Colored{
use ColoredTrait;
}
diff --git a/src/block/Stair.php b/src/block/Stair.php
index d66a9ce5c..56101de13 100644
--- a/src/block/Stair.php
+++ b/src/block/Stair.php
@@ -23,6 +23,7 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\HorizontalFacing;
use pocketmine\block\utils\HorizontalFacingTrait;
use pocketmine\block\utils\StairShape;
use pocketmine\block\utils\SupportType;
@@ -35,7 +36,7 @@ use pocketmine\math\Vector3;
use pocketmine\player\Player;
use pocketmine\world\BlockTransaction;
-class Stair extends Transparent{
+class Stair extends Transparent implements HorizontalFacing{
use HorizontalFacingTrait;
protected bool $upsideDown = false;
diff --git a/src/block/Stonecutter.php b/src/block/Stonecutter.php
index 30c19d25d..0fd259326 100644
--- a/src/block/Stonecutter.php
+++ b/src/block/Stonecutter.php
@@ -25,6 +25,7 @@ namespace pocketmine\block;
use pocketmine\block\inventory\StonecutterInventory;
use pocketmine\block\utils\FacesOppositePlacingPlayerTrait;
+use pocketmine\block\utils\HorizontalFacing;
use pocketmine\block\utils\SupportType;
use pocketmine\item\Item;
use pocketmine\math\AxisAlignedBB;
@@ -32,7 +33,7 @@ use pocketmine\math\Facing;
use pocketmine\math\Vector3;
use pocketmine\player\Player;
-class Stonecutter extends Transparent{
+class Stonecutter extends Transparent implements HorizontalFacing{
use FacesOppositePlacingPlayerTrait;
public function onInteract(Item $item, int $face, Vector3 $clickVector, ?Player $player = null, array &$returnedItems = []) : bool{
diff --git a/src/block/Sugarcane.php b/src/block/Sugarcane.php
index 2da2dc9b9..0874413c5 100644
--- a/src/block/Sugarcane.php
+++ b/src/block/Sugarcane.php
@@ -23,6 +23,7 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\Ageable;
use pocketmine\block\utils\AgeableTrait;
use pocketmine\block\utils\BlockEventHelper;
use pocketmine\block\utils\StaticSupportTrait;
@@ -34,7 +35,7 @@ use pocketmine\player\Player;
use pocketmine\world\BlockTransaction;
use pocketmine\world\Position;
-class Sugarcane extends Flowable{
+class Sugarcane extends Flowable implements Ageable{
use AgeableTrait;
use StaticSupportTrait {
onNearbyBlockChange as onSupportBlockChange;
diff --git a/src/block/SweetBerryBush.php b/src/block/SweetBerryBush.php
index eabdde118..881b7359f 100644
--- a/src/block/SweetBerryBush.php
+++ b/src/block/SweetBerryBush.php
@@ -23,6 +23,7 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\Ageable;
use pocketmine\block\utils\AgeableTrait;
use pocketmine\block\utils\BlockEventHelper;
use pocketmine\block\utils\FortuneDropHelper;
@@ -39,7 +40,7 @@ use pocketmine\player\Player;
use pocketmine\world\sound\SweetBerriesPickSound;
use function mt_rand;
-class SweetBerryBush extends Flowable{
+class SweetBerryBush extends Flowable implements Ageable{
use AgeableTrait;
use StaticSupportTrait;
diff --git a/src/block/Trapdoor.php b/src/block/Trapdoor.php
index a903e1b5e..5e8a7dc3f 100644
--- a/src/block/Trapdoor.php
+++ b/src/block/Trapdoor.php
@@ -23,6 +23,7 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\HorizontalFacing;
use pocketmine\block\utils\HorizontalFacingTrait;
use pocketmine\block\utils\SupportType;
use pocketmine\data\runtime\RuntimeDataDescriber;
@@ -34,7 +35,7 @@ use pocketmine\player\Player;
use pocketmine\world\BlockTransaction;
use pocketmine\world\sound\DoorSound;
-class Trapdoor extends Transparent{
+class Trapdoor extends Transparent implements HorizontalFacing{
use HorizontalFacingTrait;
protected bool $open = false;
diff --git a/src/block/TripwireHook.php b/src/block/TripwireHook.php
index 325819825..4e40cf62e 100644
--- a/src/block/TripwireHook.php
+++ b/src/block/TripwireHook.php
@@ -23,6 +23,7 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\HorizontalFacing;
use pocketmine\block\utils\HorizontalFacingTrait;
use pocketmine\data\runtime\RuntimeDataDescriber;
use pocketmine\item\Item;
@@ -32,7 +33,7 @@ use pocketmine\math\Vector3;
use pocketmine\player\Player;
use pocketmine\world\BlockTransaction;
-class TripwireHook extends Flowable{
+class TripwireHook extends Flowable implements HorizontalFacing{
use HorizontalFacingTrait;
protected bool $connected = false;
diff --git a/src/block/WallBanner.php b/src/block/WallBanner.php
index 5182fe9f8..ddb157cda 100644
--- a/src/block/WallBanner.php
+++ b/src/block/WallBanner.php
@@ -23,6 +23,7 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\HorizontalFacing;
use pocketmine\block\utils\HorizontalFacingTrait;
use pocketmine\item\Item;
use pocketmine\math\Axis;
@@ -31,7 +32,7 @@ use pocketmine\math\Vector3;
use pocketmine\player\Player;
use pocketmine\world\BlockTransaction;
-final class WallBanner extends BaseBanner{
+final class WallBanner extends BaseBanner implements HorizontalFacing{
use HorizontalFacingTrait;
protected function getSupportingFace() : int{
diff --git a/src/block/WallCoralFan.php b/src/block/WallCoralFan.php
index f9dece1cd..67745a537 100644
--- a/src/block/WallCoralFan.php
+++ b/src/block/WallCoralFan.php
@@ -23,6 +23,7 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\HorizontalFacing;
use pocketmine\block\utils\HorizontalFacingTrait;
use pocketmine\data\runtime\RuntimeDataDescriber;
use pocketmine\item\Item;
@@ -33,7 +34,7 @@ use pocketmine\math\Vector3;
use pocketmine\player\Player;
use pocketmine\world\BlockTransaction;
-final class WallCoralFan extends BaseCoral{
+final class WallCoralFan extends BaseCoral implements HorizontalFacing{
use HorizontalFacingTrait;
protected function describeBlockOnlyState(RuntimeDataDescriber $w) : void{
diff --git a/src/block/WallSign.php b/src/block/WallSign.php
index 07826eae7..c6b42608d 100644
--- a/src/block/WallSign.php
+++ b/src/block/WallSign.php
@@ -23,6 +23,7 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\HorizontalFacing;
use pocketmine\block\utils\HorizontalFacingTrait;
use pocketmine\item\Item;
use pocketmine\math\Axis;
@@ -31,7 +32,7 @@ use pocketmine\math\Vector3;
use pocketmine\player\Player;
use pocketmine\world\BlockTransaction;
-final class WallSign extends BaseSign{
+final class WallSign extends BaseSign implements HorizontalFacing{
use HorizontalFacingTrait;
protected function getSupportingFace() : int{
diff --git a/src/block/WeightedPressurePlate.php b/src/block/WeightedPressurePlate.php
index 726b31f6b..065f8b2c8 100644
--- a/src/block/WeightedPressurePlate.php
+++ b/src/block/WeightedPressurePlate.php
@@ -23,13 +23,14 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\AnalogRedstoneSignalEmitter;
use pocketmine\block\utils\AnalogRedstoneSignalEmitterTrait;
use function ceil;
use function count;
use function max;
use function min;
-class WeightedPressurePlate extends PressurePlate{
+class WeightedPressurePlate extends PressurePlate implements AnalogRedstoneSignalEmitter{
use AnalogRedstoneSignalEmitterTrait;
private readonly float $signalStrengthFactor;
diff --git a/src/block/Wood.php b/src/block/Wood.php
index 127533b98..7aa667bc8 100644
--- a/src/block/Wood.php
+++ b/src/block/Wood.php
@@ -23,7 +23,9 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\PillarRotation;
use pocketmine\block\utils\PillarRotationTrait;
+use pocketmine\block\utils\WoodMaterial;
use pocketmine\block\utils\WoodTypeTrait;
use pocketmine\data\runtime\RuntimeDataDescriber;
use pocketmine\item\Axe;
@@ -32,7 +34,7 @@ use pocketmine\math\Vector3;
use pocketmine\player\Player;
use pocketmine\world\sound\ItemUseOnBlockSound;
-class Wood extends Opaque{
+class Wood extends Opaque implements PillarRotation, WoodMaterial{
use PillarRotationTrait;
use WoodTypeTrait;
diff --git a/src/block/WoodenButton.php b/src/block/WoodenButton.php
index 7ba8a7af0..4eed3a50e 100644
--- a/src/block/WoodenButton.php
+++ b/src/block/WoodenButton.php
@@ -23,9 +23,10 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\WoodMaterial;
use pocketmine\block\utils\WoodTypeTrait;
-class WoodenButton extends Button{
+class WoodenButton extends Button implements WoodMaterial{
use WoodTypeTrait;
protected function getActivationTime() : int{
diff --git a/src/block/WoodenDoor.php b/src/block/WoodenDoor.php
index 96f349e49..b7918a820 100644
--- a/src/block/WoodenDoor.php
+++ b/src/block/WoodenDoor.php
@@ -23,9 +23,10 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\WoodMaterial;
use pocketmine\block\utils\WoodTypeTrait;
-class WoodenDoor extends Door{
+class WoodenDoor extends Door implements WoodMaterial{
use WoodTypeTrait;
public function getFuelTime() : int{
diff --git a/src/block/WoodenFence.php b/src/block/WoodenFence.php
index c12043a86..73c8da44d 100644
--- a/src/block/WoodenFence.php
+++ b/src/block/WoodenFence.php
@@ -23,9 +23,10 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\WoodMaterial;
use pocketmine\block\utils\WoodTypeTrait;
-class WoodenFence extends Fence{
+class WoodenFence extends Fence implements WoodMaterial{
use WoodTypeTrait;
public function getFuelTime() : int{
diff --git a/src/block/WoodenPressurePlate.php b/src/block/WoodenPressurePlate.php
index a629c2f1c..6d638788b 100644
--- a/src/block/WoodenPressurePlate.php
+++ b/src/block/WoodenPressurePlate.php
@@ -23,10 +23,11 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\WoodMaterial;
use pocketmine\block\utils\WoodType;
use pocketmine\block\utils\WoodTypeTrait;
-class WoodenPressurePlate extends SimplePressurePlate{
+class WoodenPressurePlate extends SimplePressurePlate implements WoodMaterial{
use WoodTypeTrait;
public function __construct(
diff --git a/src/block/WoodenSlab.php b/src/block/WoodenSlab.php
index b388a36ea..3ed606c64 100644
--- a/src/block/WoodenSlab.php
+++ b/src/block/WoodenSlab.php
@@ -23,9 +23,10 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\WoodMaterial;
use pocketmine\block\utils\WoodTypeTrait;
-class WoodenSlab extends Slab{
+class WoodenSlab extends Slab implements WoodMaterial{
use WoodTypeTrait;
public function getFuelTime() : int{
diff --git a/src/block/WoodenStairs.php b/src/block/WoodenStairs.php
index 0d9ba62ce..8da3fceb6 100644
--- a/src/block/WoodenStairs.php
+++ b/src/block/WoodenStairs.php
@@ -23,9 +23,10 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\WoodMaterial;
use pocketmine\block\utils\WoodTypeTrait;
-class WoodenStairs extends Stair{
+class WoodenStairs extends Stair implements WoodMaterial{
use WoodTypeTrait;
public function getFuelTime() : int{
diff --git a/src/block/WoodenTrapdoor.php b/src/block/WoodenTrapdoor.php
index c0a6623a1..2b796df52 100644
--- a/src/block/WoodenTrapdoor.php
+++ b/src/block/WoodenTrapdoor.php
@@ -23,9 +23,10 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\WoodMaterial;
use pocketmine\block\utils\WoodTypeTrait;
-class WoodenTrapdoor extends Trapdoor{
+class WoodenTrapdoor extends Trapdoor implements WoodMaterial{
use WoodTypeTrait;
public function getFuelTime() : int{
diff --git a/src/block/Wool.php b/src/block/Wool.php
index 0b008ac04..d47c27d27 100644
--- a/src/block/Wool.php
+++ b/src/block/Wool.php
@@ -23,9 +23,10 @@ declare(strict_types=1);
namespace pocketmine\block;
+use pocketmine\block\utils\Colored;
use pocketmine\block\utils\ColoredTrait;
-class Wool extends Opaque{
+class Wool extends Opaque implements Colored{
use ColoredTrait;
public function getFlameEncouragement() : int{
diff --git a/src/block/utils/Ageable.php b/src/block/utils/Ageable.php
new file mode 100644
index 000000000..31fe3f459
--- /dev/null
+++ b/src/block/utils/Ageable.php
@@ -0,0 +1,34 @@
+