2021-06-11 14:02:28 +02:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
2021-09-20 19:30:04 +10:00
|
|
|
From: Madeline Miller <mnmiller1@me.com>
|
2021-06-11 14:02:28 +02:00
|
|
|
Date: Thu, 31 Dec 2020 12:48:19 +1000
|
|
|
|
Subject: [PATCH] Implement API to get Material from Boats and Minecarts
|
|
|
|
|
|
|
|
|
|
|
|
diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftBoat.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftBoat.java
|
2023-10-26 16:34:58 -07:00
|
|
|
index f332bd4e6f663147c9ef6ce03d926feb74b55e93..d161cbf9c83cd78593864850b98f688da2c85aa5 100644
|
2021-06-11 14:02:28 +02:00
|
|
|
--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftBoat.java
|
|
|
|
+++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftBoat.java
|
2023-08-13 16:32:51 -07:00
|
|
|
@@ -79,6 +79,13 @@ public class CraftBoat extends CraftVehicle implements Boat {
|
2021-06-14 11:50:22 -07:00
|
|
|
this.getHandle().landBoats = workOnLand;
|
2021-06-11 14:02:28 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
+ // Paper start
|
|
|
|
+ @Override
|
2021-06-14 11:50:22 -07:00
|
|
|
+ public org.bukkit.Material getBoatMaterial() {
|
2022-08-01 23:02:23 +10:00
|
|
|
+ return org.bukkit.craftbukkit.util.CraftMagicNumbers.getMaterial(this.getHandle().getDropItem());
|
2021-06-11 14:02:28 +02:00
|
|
|
+ }
|
|
|
|
+ // Paper end
|
|
|
|
+
|
|
|
|
@Override
|
2022-07-12 10:16:05 -07:00
|
|
|
public Status getStatus() {
|
|
|
|
return CraftBoat.boatStatusFromNms(this.getHandle().status);
|
2021-06-11 14:02:28 +02:00
|
|
|
diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftMinecart.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftMinecart.java
|
2023-10-26 16:34:58 -07:00
|
|
|
index ee010d53f8c671d17d68f3f43dca9978e23ac8ab..8920af5a0dfe737c1f38d906b53e6a278456d2aa 100644
|
2021-06-11 14:02:28 +02:00
|
|
|
--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftMinecart.java
|
|
|
|
+++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftMinecart.java
|
|
|
|
@@ -1,8 +1,10 @@
|
|
|
|
package org.bukkit.craftbukkit.entity;
|
|
|
|
|
|
|
|
import net.minecraft.world.entity.vehicle.AbstractMinecart;
|
|
|
|
+import net.minecraft.world.item.Items; // Paper
|
|
|
|
import net.minecraft.world.level.block.Blocks;
|
|
|
|
import net.minecraft.world.level.block.state.BlockState;
|
|
|
|
+import org.bukkit.Material; // Paper
|
|
|
|
import org.bukkit.block.data.BlockData;
|
|
|
|
import org.bukkit.craftbukkit.CraftServer;
|
|
|
|
import org.bukkit.craftbukkit.block.data.CraftBlockData;
|
2021-11-24 09:37:07 -08:00
|
|
|
@@ -68,6 +70,22 @@ public abstract class CraftMinecart extends CraftVehicle implements Minecart {
|
2021-06-14 11:50:22 -07:00
|
|
|
this.getHandle().setDerailedVelocityMod(derailed);
|
2021-06-11 14:02:28 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
+ // Paper start
|
|
|
|
+ @Override
|
|
|
|
+ public Material getMinecartMaterial() {
|
2021-11-24 09:37:07 -08:00
|
|
|
+ net.minecraft.world.item.Item minecartItem = switch (getHandle().getMinecartType()) {
|
|
|
|
+ case CHEST -> Items.CHEST_MINECART;
|
|
|
|
+ case FURNACE -> Items.FURNACE_MINECART;
|
|
|
|
+ case TNT -> Items.TNT_MINECART;
|
|
|
|
+ case HOPPER -> Items.HOPPER_MINECART;
|
|
|
|
+ case COMMAND_BLOCK -> Items.COMMAND_BLOCK_MINECART;
|
|
|
|
+ case RIDEABLE, SPAWNER -> Items.MINECART;
|
|
|
|
+ };
|
2021-06-11 14:02:28 +02:00
|
|
|
+
|
|
|
|
+ return CraftMagicNumbers.getMaterial(minecartItem);
|
|
|
|
+ }
|
|
|
|
+ // Paper end
|
|
|
|
+
|
|
|
|
@Override
|
|
|
|
public AbstractMinecart getHandle() {
|
2023-10-26 16:34:58 -07:00
|
|
|
return (AbstractMinecart) this.entity;
|