mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-10 03:52:45 +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;
|
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 net.minecraft.server.TileEntityStructure;
|
||||||
|
import org.apache.commons.lang3.Validate;
|
||||||
import org.bukkit.Material;
|
import org.bukkit.Material;
|
||||||
import org.bukkit.block.Block;
|
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) {
|
public CraftStructureBlock(Block block) {
|
||||||
super(block, TileEntityStructure.class);
|
super(block, TileEntityStructure.class);
|
||||||
|
@ -13,4 +27,160 @@ public class CraftStructureBlock extends CraftBlockEntityState<TileEntityStructu
|
||||||
public CraftStructureBlock(Material material, TileEntityStructure structure) {
|
public CraftStructureBlock(Material material, TileEntityStructure structure) {
|
||||||
super(material, 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