SPIGOT-7083: Add Boat.WoodenType, Boat.Status; deprecate TreeSpecies
By: Doc <nachito94@msn.com>
This commit is contained in:
@@ -1,9 +1,12 @@
|
||||
package org.bukkit.craftbukkit.entity;
|
||||
|
||||
import com.google.common.base.Preconditions;
|
||||
import java.util.stream.Collectors;
|
||||
import net.minecraft.world.entity.vehicle.EntityBoat;
|
||||
import org.bukkit.TreeSpecies;
|
||||
import org.bukkit.craftbukkit.CraftServer;
|
||||
import org.bukkit.entity.Boat;
|
||||
import org.bukkit.entity.Entity;
|
||||
import org.bukkit.entity.EntityType;
|
||||
|
||||
public class CraftBoat extends CraftVehicle implements Boat {
|
||||
@@ -22,6 +25,18 @@ public class CraftBoat extends CraftVehicle implements Boat {
|
||||
getHandle().setType(getBoatType(species));
|
||||
}
|
||||
|
||||
@Override
|
||||
public Type getBoatType() {
|
||||
return boatTypeFromNms(getHandle().getBoatType());
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setBoatType(Type type) {
|
||||
Preconditions.checkArgument(type != null, "Boat.Type cannot be null");
|
||||
|
||||
getHandle().setType(boatTypeToNms(type));
|
||||
}
|
||||
|
||||
@Override
|
||||
public double getMaxSpeed() {
|
||||
return getHandle().maxSpeed;
|
||||
@@ -66,6 +81,11 @@ public class CraftBoat extends CraftVehicle implements Boat {
|
||||
getHandle().landBoats = workOnLand;
|
||||
}
|
||||
|
||||
@Override
|
||||
public Status getStatus() {
|
||||
return boatStatusFromNms(getHandle().status);
|
||||
}
|
||||
|
||||
@Override
|
||||
public EntityBoat getHandle() {
|
||||
return (EntityBoat) entity;
|
||||
@@ -73,7 +93,7 @@ public class CraftBoat extends CraftVehicle implements Boat {
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return "CraftBoat";
|
||||
return "CraftBoat{boatType=" + getBoatType() + ",status=" + getStatus() + ",passengers=" + getPassengers().stream().map(Entity::toString).collect(Collectors.joining("-", "{", "}")) + "}";
|
||||
}
|
||||
|
||||
@Override
|
||||
@@ -81,6 +101,44 @@ public class CraftBoat extends CraftVehicle implements Boat {
|
||||
return EntityType.BOAT;
|
||||
}
|
||||
|
||||
public static Boat.Type boatTypeFromNms(EntityBoat.EnumBoatType boatType) {
|
||||
return switch (boatType) {
|
||||
default -> throw new EnumConstantNotPresentException(Type.class, boatType.name());
|
||||
case OAK -> Type.OAK;
|
||||
case BIRCH -> Type.BIRCH;
|
||||
case ACACIA -> Type.ACACIA;
|
||||
case JUNGLE -> Type.JUNGLE;
|
||||
case SPRUCE -> Type.SPRUCE;
|
||||
case DARK_OAK -> Type.DARK_OAK;
|
||||
case MANGROVE -> Type.MANGROVE;
|
||||
};
|
||||
}
|
||||
|
||||
public static EntityBoat.EnumBoatType boatTypeToNms(Boat.Type type) {
|
||||
return switch (type) {
|
||||
default -> throw new EnumConstantNotPresentException(EntityBoat.EnumBoatType.class, type.name());
|
||||
case MANGROVE -> EntityBoat.EnumBoatType.MANGROVE;
|
||||
case SPRUCE -> EntityBoat.EnumBoatType.SPRUCE;
|
||||
case DARK_OAK -> EntityBoat.EnumBoatType.DARK_OAK;
|
||||
case JUNGLE -> EntityBoat.EnumBoatType.JUNGLE;
|
||||
case ACACIA -> EntityBoat.EnumBoatType.ACACIA;
|
||||
case BIRCH -> EntityBoat.EnumBoatType.BIRCH;
|
||||
case OAK -> EntityBoat.EnumBoatType.OAK;
|
||||
};
|
||||
}
|
||||
|
||||
public static Status boatStatusFromNms(EntityBoat.EnumStatus enumStatus) {
|
||||
return switch (enumStatus) {
|
||||
default -> throw new EnumConstantNotPresentException(Status.class, enumStatus.name());
|
||||
case IN_AIR -> Status.IN_AIR;
|
||||
case ON_LAND -> Status.ON_LAND;
|
||||
case UNDER_WATER -> Status.UNDER_WATER;
|
||||
case UNDER_FLOWING_WATER -> Status.UNDER_FLOWING_WATER;
|
||||
case IN_WATER -> Status.IN_WATER;
|
||||
};
|
||||
}
|
||||
|
||||
@Deprecated
|
||||
public static TreeSpecies getTreeSpecies(EntityBoat.EnumBoatType boatType) {
|
||||
switch (boatType) {
|
||||
case SPRUCE:
|
||||
@@ -99,6 +157,7 @@ public class CraftBoat extends CraftVehicle implements Boat {
|
||||
}
|
||||
}
|
||||
|
||||
@Deprecated
|
||||
public static EntityBoat.EnumBoatType getBoatType(TreeSpecies species) {
|
||||
switch (species) {
|
||||
case REDWOOD:
|
||||
|
||||
Reference in New Issue
Block a user