mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-24 01:06:01 +01:00
Add an enum for Nether Wart growth stages. Adds BUKKIT-1599
By: GJ <gjmcferrin@gmail.com>
This commit is contained in:
parent
d0f458656a
commit
410adb8404
3 changed files with 106 additions and 1 deletions
|
@ -29,6 +29,7 @@ import org.bukkit.material.LongGrass;
|
|||
import org.bukkit.material.MaterialData;
|
||||
import org.bukkit.material.MonsterEggs;
|
||||
import org.bukkit.material.Mushroom;
|
||||
import org.bukkit.material.NetherWarts;
|
||||
import org.bukkit.material.PistonBaseMaterial;
|
||||
import org.bukkit.material.PistonExtensionMaterial;
|
||||
import org.bukkit.material.PoweredRail;
|
||||
|
@ -176,7 +177,7 @@ public enum Material {
|
|||
NETHER_BRICK(112),
|
||||
NETHER_FENCE(113),
|
||||
NETHER_BRICK_STAIRS(114, Stairs.class),
|
||||
NETHER_WARTS(115, MaterialData.class),
|
||||
NETHER_WARTS(115, NetherWarts.class),
|
||||
ENCHANTMENT_TABLE(116),
|
||||
BREWING_STAND(117, MaterialData.class),
|
||||
CAULDRON(118, Cauldron.class),
|
||||
|
|
20
paper-api/src/main/java/org/bukkit/NetherWartsState.java
Normal file
20
paper-api/src/main/java/org/bukkit/NetherWartsState.java
Normal file
|
@ -0,0 +1,20 @@
|
|||
package org.bukkit;
|
||||
|
||||
public enum NetherWartsState {
|
||||
/**
|
||||
* State when first seeded
|
||||
*/
|
||||
SEEDED,
|
||||
/**
|
||||
* First growth stage
|
||||
*/
|
||||
STAGE_ONE,
|
||||
/**
|
||||
* Second growth stage
|
||||
*/
|
||||
STAGE_TWO,
|
||||
/**
|
||||
* Ready to harvest
|
||||
*/
|
||||
RIPE;
|
||||
}
|
84
paper-api/src/main/java/org/bukkit/material/NetherWarts.java
Normal file
84
paper-api/src/main/java/org/bukkit/material/NetherWarts.java
Normal file
|
@ -0,0 +1,84 @@
|
|||
package org.bukkit.material;
|
||||
|
||||
import org.bukkit.Material;
|
||||
import org.bukkit.NetherWartsState;
|
||||
|
||||
/**
|
||||
* Represents nether wart
|
||||
*/
|
||||
public class NetherWarts extends MaterialData {
|
||||
public NetherWarts() {
|
||||
super(Material.NETHER_WARTS);
|
||||
}
|
||||
|
||||
public NetherWarts(NetherWartsState state) {
|
||||
this();
|
||||
setState(state);
|
||||
}
|
||||
|
||||
public NetherWarts(final int type) {
|
||||
super(type);
|
||||
}
|
||||
|
||||
public NetherWarts(final Material type) {
|
||||
super (type);
|
||||
}
|
||||
|
||||
public NetherWarts(final int type, final byte data) {
|
||||
super(type, data);
|
||||
}
|
||||
|
||||
public NetherWarts(final Material type, final byte data) {
|
||||
super(type, data);
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets the current growth state of this nether wart
|
||||
*
|
||||
* @return NetherWartsState of this nether wart
|
||||
*/
|
||||
public NetherWartsState getState() {
|
||||
switch (getData()) {
|
||||
case 0:
|
||||
return NetherWartsState.SEEDED;
|
||||
case 1:
|
||||
return NetherWartsState.STAGE_ONE;
|
||||
case 2:
|
||||
return NetherWartsState.STAGE_TWO;
|
||||
default:
|
||||
return NetherWartsState.RIPE;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Sets the growth state of this nether wart
|
||||
*
|
||||
* @param state New growth state of this nether wart
|
||||
*/
|
||||
public void setState(NetherWartsState state) {
|
||||
switch (state) {
|
||||
case SEEDED:
|
||||
setData((byte) 0x0);
|
||||
return;
|
||||
case STAGE_ONE:
|
||||
setData((byte) 0x1);
|
||||
return;
|
||||
case STAGE_TWO:
|
||||
setData((byte) 0x2);
|
||||
return;
|
||||
case RIPE:
|
||||
setData((byte) 0x3);
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return getState() + " " + super.toString();
|
||||
}
|
||||
|
||||
@Override
|
||||
public NetherWarts clone() {
|
||||
return (NetherWarts) super.clone();
|
||||
}
|
||||
}
|
Loading…
Add table
Reference in a new issue