SPIGOT-7083: Add Boat.WoodenType, Boat.Status; deprecate TreeSpecies

By: Doc <nachito94@msn.com>
This commit is contained in:
Bukkit/Spigot 2022-07-05 20:40:27 +10:00
parent 16583c1d7c
commit 73d53d00e8
2 changed files with 73 additions and 0 deletions

View file

@ -6,7 +6,10 @@ import org.jetbrains.annotations.Nullable;
/**
* Represents the different species of trees regardless of size.
*
* @deprecated Deprecated, see usage methods for replacement(s)
*/
@Deprecated
public enum TreeSpecies {
/**

View file

@ -1,5 +1,6 @@
package org.bukkit.entity;
import org.bukkit.Material;
import org.bukkit.TreeSpecies;
import org.jetbrains.annotations.NotNull;
@ -12,7 +13,9 @@ public interface Boat extends Vehicle {
* Gets the wood type of the boat.
*
* @return the wood type
* @deprecated deprecated in favor of {@link #getBoatType()}
*/
@Deprecated
@NotNull
TreeSpecies getWoodType();
@ -20,9 +23,26 @@ public interface Boat extends Vehicle {
* Sets the wood type of the boat.
*
* @param species the new wood type
* @deprecated deprecated in favor of {@link #setBoatType(Type)}
*/
@Deprecated
void setWoodType(@NotNull TreeSpecies species);
/**
* Gets the type of the boat.
*
* @return the boat type
*/
@NotNull
Type getBoatType();
/**
* Sets the type of the boat.
*
* @param type the new type
*/
void setBoatType(@NotNull Type type);
/**
* Gets the maximum speed of a boat. The speed is unrelated to the
* velocity.
@ -103,4 +123,54 @@ public interface Boat extends Vehicle {
*/
@Deprecated
public void setWorkOnLand(boolean workOnLand);
/**
* Gets the status of the boat.
*
* @return the status
*/
@NotNull
public Status getStatus();
/**
* Represents the type of boats.
*/
public enum Type {
OAK(Material.OAK_PLANKS),
SPRUCE(Material.SPRUCE_PLANKS),
BIRCH(Material.BIRCH_PLANKS),
JUNGLE(Material.JUNGLE_PLANKS),
ACACIA(Material.ACACIA_PLANKS),
DARK_OAK(Material.DARK_OAK_PLANKS),
MANGROVE(Material.MANGROVE_PLANKS),
;
private final Material materialBlock;
private Type(Material materialBlock) {
this.materialBlock = materialBlock;
}
/**
* Gets the material of the boat type.
*
* @return a material
*/
@NotNull
public Material getMaterial() {
return this.materialBlock;
}
}
/**
* Represents the status of the boat.
*/
public enum Status {
IN_WATER,
UNDER_WATER,
UNDER_FLOWING_WATER,
ON_LAND,
IN_AIR;
}
}