mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-09 19:49:35 +01:00
Expand Structure Block API
By: Senmori <thesenmori@gmail.com>
This commit is contained in:
parent
4377f7fede
commit
9355bb0ed9
2 changed files with 207 additions and 1 deletions
36
paper-server/nms-patches/TileEntityStructure.patch
Normal file
36
paper-server/nms-patches/TileEntityStructure.patch
Normal file
|
@ -0,0 +1,36 @@
|
|||
--- a/net/minecraft/server/TileEntityStructure.java
|
||||
+++ b/net/minecraft/server/TileEntityStructure.java
|
||||
@@ -10,20 +10,20 @@
|
||||
|
||||
public class TileEntityStructure extends TileEntity {
|
||||
|
||||
- private String a = "";
|
||||
- private String f = "";
|
||||
- private String g = "";
|
||||
- private BlockPosition h = new BlockPosition(0, 1, 0);
|
||||
- private BlockPosition i;
|
||||
- private EnumBlockMirror j;
|
||||
- private EnumBlockRotation k;
|
||||
- private TileEntityStructure.UsageMode l;
|
||||
- private boolean m;
|
||||
+ private String a = ""; // PAIL: rename name
|
||||
+ public String f = ""; // PAIL: private -> public
|
||||
+ public String g = ""; // PAIL: private -> public
|
||||
+ public BlockPosition h = new BlockPosition(0, 1, 0); // PAIL: private -> public
|
||||
+ public BlockPosition i; // PAIL: private -> public
|
||||
+ public EnumBlockMirror j; // PAIL: private -> public
|
||||
+ public EnumBlockRotation k; // PAIL: private -> public
|
||||
+ private TileEntityStructure.UsageMode l; // PAIL: rename
|
||||
+ public boolean m; // PAIL: private -> public
|
||||
private boolean n;
|
||||
- private boolean o;
|
||||
- private boolean p;
|
||||
- private float q;
|
||||
- private long r;
|
||||
+ public boolean o; // PAIL: private -> public
|
||||
+ public boolean p; // PAIL: private -> public
|
||||
+ public float q; // PAIL: private -> public
|
||||
+ public long r; // PAIL: private -> public
|
||||
|
||||
public TileEntityStructure() {
|
||||
this.i = BlockPosition.ZERO;
|
|
@ -1,10 +1,24 @@
|
|||
package org.bukkit.craftbukkit.block;
|
||||
|
||||
import com.google.common.base.Preconditions;
|
||||
import net.minecraft.server.BlockPosition;
|
||||
import net.minecraft.server.EnumBlockMirror;
|
||||
import net.minecraft.server.EnumBlockRotation;
|
||||
import net.minecraft.server.TileEntityStructure;
|
||||
import org.apache.commons.lang3.Validate;
|
||||
import org.bukkit.Material;
|
||||
import org.bukkit.block.Block;
|
||||
import org.bukkit.block.Structure;
|
||||
import org.bukkit.block.structure.Mirror;
|
||||
import org.bukkit.block.structure.StructureRotation;
|
||||
import org.bukkit.block.structure.UsageMode;
|
||||
import org.bukkit.craftbukkit.entity.CraftLivingEntity;
|
||||
import org.bukkit.entity.LivingEntity;
|
||||
import org.bukkit.util.BlockVector;
|
||||
|
||||
public class CraftStructureBlock extends CraftBlockEntityState<TileEntityStructure> {
|
||||
public class CraftStructureBlock extends CraftBlockEntityState<TileEntityStructure> implements Structure {
|
||||
|
||||
private static final int MAX_SIZE = 32;
|
||||
|
||||
public CraftStructureBlock(Block block) {
|
||||
super(block, TileEntityStructure.class);
|
||||
|
@ -13,4 +27,160 @@ public class CraftStructureBlock extends CraftBlockEntityState<TileEntityStructu
|
|||
public CraftStructureBlock(Material material, TileEntityStructure structure) {
|
||||
super(material, structure);
|
||||
}
|
||||
|
||||
@Override
|
||||
public String getStructureName() {
|
||||
return getSnapshot().a(); // PAIL: rename getStructureName
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setStructureName(String name) {
|
||||
Preconditions.checkArgument(name != null, "Structure Name cannot be null");
|
||||
getSnapshot().a(name); // PAIL: rename setStructureName
|
||||
}
|
||||
|
||||
@Override
|
||||
public String getAuthor() {
|
||||
return getSnapshot().f;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setAuthor(String author) {
|
||||
Preconditions.checkArgument(author != null && !author.isEmpty(), "Author name cannot be null nor empty");
|
||||
getSnapshot().f = author; // PAIL: rename author
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setAuthor(LivingEntity entity) {
|
||||
Preconditions.checkArgument(entity != null, "Structure Block author entity cannot be null");
|
||||
getSnapshot().a(((CraftLivingEntity) entity).getHandle()); // PAIL: rename setAuthor
|
||||
}
|
||||
|
||||
@Override
|
||||
public BlockVector getRelativePosition() {
|
||||
return new BlockVector(getSnapshot().h.getX(), getSnapshot().h.getY(), getSnapshot().h.getZ()); // PAIL: rename relativePosition
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setRelativePosition(BlockVector vector) {
|
||||
Validate.isTrue(isBetween(vector.getBlockX(), -MAX_SIZE, MAX_SIZE), "Structure Size (X) must be between -" + MAX_SIZE + " and " + MAX_SIZE);
|
||||
Validate.isTrue(isBetween(vector.getBlockY(), -MAX_SIZE, MAX_SIZE), "Structure Size (Y) must be between -" + MAX_SIZE + " and " + MAX_SIZE);
|
||||
Validate.isTrue(isBetween(vector.getBlockZ(), -MAX_SIZE, MAX_SIZE), "Structure Size (Z) must be between -" + MAX_SIZE + " and " + MAX_SIZE);
|
||||
getSnapshot().h = new BlockPosition(vector.getBlockX(), vector.getBlockY(), vector.getBlockZ()); // PAIL: rename relativePosition
|
||||
}
|
||||
|
||||
@Override
|
||||
public BlockVector getStructureSize() {
|
||||
return new BlockVector(getSnapshot().i.getX(), getSnapshot().i.getY(), getSnapshot().i.getZ()); // PAIL: rename size
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setStructureSize(BlockVector vector) {
|
||||
Validate.isTrue(isBetween(vector.getBlockX(), 0, MAX_SIZE), "Structure Size (X) must be between 0 and " + MAX_SIZE);
|
||||
Validate.isTrue(isBetween(vector.getBlockY(), 0, MAX_SIZE), "Structure Size (Y) must be between 0 and " + MAX_SIZE);
|
||||
Validate.isTrue(isBetween(vector.getBlockZ(), 0, MAX_SIZE), "Structure Size (Z) must be between 0 and " + MAX_SIZE);
|
||||
getSnapshot().c(new BlockPosition(vector.getBlockX(), vector.getBlockY(), vector.getBlockZ())); // PAIL: setStructureSize
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setMirror(Mirror mirror) {
|
||||
getSnapshot().j = EnumBlockMirror.valueOf(mirror.name()); // PAIL: rename mirror
|
||||
}
|
||||
|
||||
@Override
|
||||
public Mirror getMirror() {
|
||||
return Mirror.valueOf(getSnapshot().j.name()); // PAIL: rename mirror
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setRotation(StructureRotation rotation) {
|
||||
getSnapshot().k = EnumBlockRotation.valueOf(rotation.name()); // PAIL: rename rotation
|
||||
}
|
||||
|
||||
@Override
|
||||
public StructureRotation getRotation() {
|
||||
return StructureRotation.valueOf(getSnapshot().k.name()); // PAIL: rename rotation
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setUsageMode(UsageMode mode) {
|
||||
getSnapshot().a(TileEntityStructure.UsageMode.valueOf(mode.name())); // PAIL: rename setUsageMode
|
||||
}
|
||||
|
||||
@Override
|
||||
public UsageMode getUsageMode() {
|
||||
return UsageMode.valueOf(getSnapshot().k().name()); // PAIL rename getUsageMode
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setIgnoreEntities(boolean flag) {
|
||||
getSnapshot().m = flag; // PAIL: rename ignoreEntities
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean isIgnoreEntities() {
|
||||
return getSnapshot().m; // PAIL: rename ignoreEntities
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setShowAir(boolean showAir) {
|
||||
getSnapshot().o = showAir; // PAIL rename showAir
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean isShowAir() {
|
||||
return getSnapshot().o; // PAIL: rename showAir
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setBoundingBoxVisible(boolean showBoundingBox) {
|
||||
getSnapshot().p = showBoundingBox; // PAIL: rename boundingBoxVisible
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean isBoundingBoxVisible() {
|
||||
return getSnapshot().p; // PAIL: rename boundingBoxVisible
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setIntegrity(float integrity) {
|
||||
Validate.isTrue(isBetween(integrity, 0.0f, 1.0f), "Integrity must be between 0.0f and 1.0f");
|
||||
getSnapshot().q = integrity; // PAIL: rename integrity
|
||||
}
|
||||
|
||||
@Override
|
||||
public float getIntegrity() {
|
||||
return getSnapshot().q; // PAIL: rename integrity
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setSeed(long seed) {
|
||||
getSnapshot().r = seed; // PAIL: rename seed
|
||||
}
|
||||
|
||||
@Override
|
||||
public long getSeed() {
|
||||
return getSnapshot().r; // PAIL: rename seed
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setMetadata(String metadata) {
|
||||
Validate.notNull(metadata, "Structure metadata cannot be null");
|
||||
if (getUsageMode() == UsageMode.DATA) {
|
||||
getSnapshot().g = metadata; // PAIL: rename metadata
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public String getMetadata() {
|
||||
return getSnapshot().g; // PAIL: rename metadata
|
||||
}
|
||||
|
||||
private static boolean isBetween(int num, int min, int max) {
|
||||
return num >= min && num <= max;
|
||||
}
|
||||
|
||||
private static boolean isBetween(float num, float min, float max) {
|
||||
return num >= min && num <= max;
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue