mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-06 18:50:51 +01:00
5460c17f8a
Should work around quite a few issues and this 'feature' is relatively worthless anyway
390 lines
12 KiB
Diff
390 lines
12 KiB
Diff
From 341f3417d0859e5ffede7045f1f81dfe43b12d0d Mon Sep 17 00:00:00 2001
|
|
From: Zach Brown <Zbob750@live.com>
|
|
Date: Thu, 27 Nov 2014 23:53:56 -0600
|
|
Subject: [PATCH] mc-dev imports
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/BlockMinecartTrackAbstract.java b/src/main/java/net/minecraft/server/BlockMinecartTrackAbstract.java
|
|
new file mode 100644
|
|
index 0000000..063177d
|
|
--- /dev/null
|
|
+++ b/src/main/java/net/minecraft/server/BlockMinecartTrackAbstract.java
|
|
@@ -0,0 +1,120 @@
|
|
+package net.minecraft.server;
|
|
+
|
|
+public abstract class BlockMinecartTrackAbstract extends Block {
|
|
+
|
|
+ protected final boolean a;
|
|
+
|
|
+ public static boolean d(World world, BlockPosition blockposition) {
|
|
+ return d(world.getType(blockposition));
|
|
+ }
|
|
+
|
|
+ public static boolean d(IBlockData iblockdata) {
|
|
+ Block block = iblockdata.getBlock();
|
|
+
|
|
+ return block == Blocks.RAIL || block == Blocks.GOLDEN_RAIL || block == Blocks.DETECTOR_RAIL || block == Blocks.ACTIVATOR_RAIL;
|
|
+ }
|
|
+
|
|
+ protected BlockMinecartTrackAbstract(boolean flag) {
|
|
+ super(Material.ORIENTABLE);
|
|
+ this.a = flag;
|
|
+ this.a(0.0F, 0.0F, 0.0F, 1.0F, 0.125F, 1.0F);
|
|
+ this.a(CreativeModeTab.e);
|
|
+ }
|
|
+
|
|
+ public AxisAlignedBB a(World world, BlockPosition blockposition, IBlockData iblockdata) {
|
|
+ return null;
|
|
+ }
|
|
+
|
|
+ public boolean c() {
|
|
+ return false;
|
|
+ }
|
|
+
|
|
+ public MovingObjectPosition a(World world, BlockPosition blockposition, Vec3D vec3d, Vec3D vec3d1) {
|
|
+ this.updateShape(world, blockposition);
|
|
+ return super.a(world, blockposition, vec3d, vec3d1);
|
|
+ }
|
|
+
|
|
+ public void updateShape(IBlockAccess iblockaccess, BlockPosition blockposition) {
|
|
+ IBlockData iblockdata = iblockaccess.getType(blockposition);
|
|
+ EnumTrackPosition enumtrackposition = iblockdata.getBlock() == this ? (EnumTrackPosition) iblockdata.get(this.l()) : null;
|
|
+
|
|
+ if (enumtrackposition != null && enumtrackposition.c()) {
|
|
+ this.a(0.0F, 0.0F, 0.0F, 1.0F, 0.625F, 1.0F);
|
|
+ } else {
|
|
+ this.a(0.0F, 0.0F, 0.0F, 1.0F, 0.125F, 1.0F);
|
|
+ }
|
|
+
|
|
+ }
|
|
+
|
|
+ public boolean d() {
|
|
+ return false;
|
|
+ }
|
|
+
|
|
+ public boolean canPlace(World world, BlockPosition blockposition) {
|
|
+ return World.a((IBlockAccess) world, blockposition.down());
|
|
+ }
|
|
+
|
|
+ public void onPlace(World world, BlockPosition blockposition, IBlockData iblockdata) {
|
|
+ if (!world.isStatic) {
|
|
+ iblockdata = this.a(world, blockposition, iblockdata, true);
|
|
+ if (this.a) {
|
|
+ this.doPhysics(world, blockposition, iblockdata, this);
|
|
+ }
|
|
+ }
|
|
+
|
|
+ }
|
|
+
|
|
+ public void doPhysics(World world, BlockPosition blockposition, IBlockData iblockdata, Block block) {
|
|
+ if (!world.isStatic) {
|
|
+ EnumTrackPosition enumtrackposition = (EnumTrackPosition) iblockdata.get(this.l());
|
|
+ boolean flag = false;
|
|
+
|
|
+ if (!World.a((IBlockAccess) world, blockposition.down())) {
|
|
+ flag = true;
|
|
+ }
|
|
+
|
|
+ if (enumtrackposition == EnumTrackPosition.ASCENDING_EAST && !World.a((IBlockAccess) world, blockposition.east())) {
|
|
+ flag = true;
|
|
+ } else if (enumtrackposition == EnumTrackPosition.ASCENDING_WEST && !World.a((IBlockAccess) world, blockposition.west())) {
|
|
+ flag = true;
|
|
+ } else if (enumtrackposition == EnumTrackPosition.ASCENDING_NORTH && !World.a((IBlockAccess) world, blockposition.north())) {
|
|
+ flag = true;
|
|
+ } else if (enumtrackposition == EnumTrackPosition.ASCENDING_SOUTH && !World.a((IBlockAccess) world, blockposition.south())) {
|
|
+ flag = true;
|
|
+ }
|
|
+
|
|
+ if (flag) {
|
|
+ this.b(world, blockposition, iblockdata, 0);
|
|
+ world.setAir(blockposition);
|
|
+ } else {
|
|
+ this.b(world, blockposition, iblockdata, block);
|
|
+ }
|
|
+
|
|
+ }
|
|
+ }
|
|
+
|
|
+ protected void b(World world, BlockPosition blockposition, IBlockData iblockdata, Block block) {}
|
|
+
|
|
+ protected IBlockData a(World world, BlockPosition blockposition, IBlockData iblockdata, boolean flag) {
|
|
+ return world.isStatic ? iblockdata : (new MinecartTrackLogic(this, world, blockposition, iblockdata)).a(world.isBlockIndirectlyPowered(blockposition), flag).b();
|
|
+ }
|
|
+
|
|
+ public int i() {
|
|
+ return 0;
|
|
+ }
|
|
+
|
|
+ public void remove(World world, BlockPosition blockposition, IBlockData iblockdata) {
|
|
+ super.remove(world, blockposition, iblockdata);
|
|
+ if (((EnumTrackPosition) iblockdata.get(this.l())).c()) {
|
|
+ world.applyPhysics(blockposition.up(), this);
|
|
+ }
|
|
+
|
|
+ if (this.a) {
|
|
+ world.applyPhysics(blockposition, this);
|
|
+ world.applyPhysics(blockposition.down(), this);
|
|
+ }
|
|
+
|
|
+ }
|
|
+
|
|
+ public abstract IBlockState l();
|
|
+}
|
|
diff --git a/src/main/java/net/minecraft/server/MobEffectAttackDamage.java b/src/main/java/net/minecraft/server/MobEffectAttackDamage.java
|
|
new file mode 100644
|
|
index 0000000..620685a
|
|
--- /dev/null
|
|
+++ b/src/main/java/net/minecraft/server/MobEffectAttackDamage.java
|
|
@@ -0,0 +1,12 @@
|
|
+package net.minecraft.server;
|
|
+
|
|
+public class MobEffectAttackDamage extends MobEffectList {
|
|
+
|
|
+ protected MobEffectAttackDamage(int i, MinecraftKey minecraftkey, boolean flag, int j) {
|
|
+ super(i, minecraftkey, flag, j);
|
|
+ }
|
|
+
|
|
+ public double a(int i, AttributeModifier attributemodifier) {
|
|
+ return this.id == MobEffectList.WEAKNESS.id ? (double) (-0.5F * (float) (i + 1)) : 1.3D * (double) (i + 1);
|
|
+ }
|
|
+}
|
|
diff --git a/src/main/java/net/minecraft/server/PacketPlayOutPlayerListHeaderFooter.java b/src/main/java/net/minecraft/server/PacketPlayOutPlayerListHeaderFooter.java
|
|
new file mode 100644
|
|
index 0000000..985e437
|
|
--- /dev/null
|
|
+++ b/src/main/java/net/minecraft/server/PacketPlayOutPlayerListHeaderFooter.java
|
|
@@ -0,0 +1,31 @@
|
|
+package net.minecraft.server;
|
|
+
|
|
+public class PacketPlayOutPlayerListHeaderFooter implements Packet {
|
|
+
|
|
+ private IChatBaseComponent a;
|
|
+ private IChatBaseComponent b;
|
|
+
|
|
+ public PacketPlayOutPlayerListHeaderFooter() {}
|
|
+
|
|
+ public PacketPlayOutPlayerListHeaderFooter(IChatBaseComponent ichatbasecomponent) {
|
|
+ this.a = ichatbasecomponent;
|
|
+ }
|
|
+
|
|
+ public void a(PacketDataSerializer packetdataserializer) {
|
|
+ this.a = packetdataserializer.d();
|
|
+ this.b = packetdataserializer.d();
|
|
+ }
|
|
+
|
|
+ public void b(PacketDataSerializer packetdataserializer) {
|
|
+ packetdataserializer.a(this.a);
|
|
+ packetdataserializer.a(this.b);
|
|
+ }
|
|
+
|
|
+ public void a(PacketListenerPlayOut packetlistenerplayout) {
|
|
+ packetlistenerplayout.a(this);
|
|
+ }
|
|
+
|
|
+ public void a(PacketListener packetlistener) {
|
|
+ this.a((PacketListenerPlayOut) packetlistener);
|
|
+ }
|
|
+}
|
|
diff --git a/src/main/java/net/minecraft/server/TileEntityEnderChest.java b/src/main/java/net/minecraft/server/TileEntityEnderChest.java
|
|
new file mode 100644
|
|
index 0000000..794cdc8
|
|
--- /dev/null
|
|
+++ b/src/main/java/net/minecraft/server/TileEntityEnderChest.java
|
|
@@ -0,0 +1,87 @@
|
|
+package net.minecraft.server;
|
|
+
|
|
+public class TileEntityEnderChest extends TileEntity implements IUpdatePlayerListBox {
|
|
+
|
|
+ public float a;
|
|
+ public float f;
|
|
+ public int g;
|
|
+ private int h;
|
|
+
|
|
+ public TileEntityEnderChest() {}
|
|
+
|
|
+ public void c() {
|
|
+ if (++this.h % 20 * 4 == 0) {
|
|
+ this.world.playBlockAction(this.position, Blocks.ENDER_CHEST, 1, this.g);
|
|
+ }
|
|
+
|
|
+ this.f = this.a;
|
|
+ int i = this.position.getX();
|
|
+ int j = this.position.getY();
|
|
+ int k = this.position.getZ();
|
|
+ float f = 0.1F;
|
|
+ double d0;
|
|
+
|
|
+ if (this.g > 0 && this.a == 0.0F) {
|
|
+ double d1 = (double) i + 0.5D;
|
|
+
|
|
+ d0 = (double) k + 0.5D;
|
|
+ this.world.makeSound(d1, (double) j + 0.5D, d0, "random.chestopen", 0.5F, this.world.random.nextFloat() * 0.1F + 0.9F);
|
|
+ }
|
|
+
|
|
+ if (this.g == 0 && this.a > 0.0F || this.g > 0 && this.a < 1.0F) {
|
|
+ float f1 = this.a;
|
|
+
|
|
+ if (this.g > 0) {
|
|
+ this.a += f;
|
|
+ } else {
|
|
+ this.a -= f;
|
|
+ }
|
|
+
|
|
+ if (this.a > 1.0F) {
|
|
+ this.a = 1.0F;
|
|
+ }
|
|
+
|
|
+ float f2 = 0.5F;
|
|
+
|
|
+ if (this.a < f2 && f1 >= f2) {
|
|
+ d0 = (double) i + 0.5D;
|
|
+ double d2 = (double) k + 0.5D;
|
|
+
|
|
+ this.world.makeSound(d0, (double) j + 0.5D, d2, "random.chestclosed", 0.5F, this.world.random.nextFloat() * 0.1F + 0.9F);
|
|
+ }
|
|
+
|
|
+ if (this.a < 0.0F) {
|
|
+ this.a = 0.0F;
|
|
+ }
|
|
+ }
|
|
+
|
|
+ }
|
|
+
|
|
+ public boolean c(int i, int j) {
|
|
+ if (i == 1) {
|
|
+ this.g = j;
|
|
+ return true;
|
|
+ } else {
|
|
+ return super.c(i, j);
|
|
+ }
|
|
+ }
|
|
+
|
|
+ public void y() {
|
|
+ this.E();
|
|
+ super.y();
|
|
+ }
|
|
+
|
|
+ public void b() {
|
|
+ ++this.g;
|
|
+ this.world.playBlockAction(this.position, Blocks.ENDER_CHEST, 1, this.g);
|
|
+ }
|
|
+
|
|
+ public void d() {
|
|
+ --this.g;
|
|
+ this.world.playBlockAction(this.position, Blocks.ENDER_CHEST, 1, this.g);
|
|
+ }
|
|
+
|
|
+ public boolean a(EntityHuman entityhuman) {
|
|
+ return this.world.getTileEntity(this.position) != this ? false : entityhuman.e((double) this.position.getX() + 0.5D, (double) this.position.getY() + 0.5D, (double) this.position.getZ() + 0.5D) <= 64.0D;
|
|
+ }
|
|
+}
|
|
diff --git a/src/main/java/net/minecraft/server/TileEntityLightDetector.java b/src/main/java/net/minecraft/server/TileEntityLightDetector.java
|
|
new file mode 100644
|
|
index 0000000..7b6f8ae
|
|
--- /dev/null
|
|
+++ b/src/main/java/net/minecraft/server/TileEntityLightDetector.java
|
|
@@ -0,0 +1,16 @@
|
|
+package net.minecraft.server;
|
|
+
|
|
+public class TileEntityLightDetector extends TileEntity implements IUpdatePlayerListBox {
|
|
+
|
|
+ public TileEntityLightDetector() {}
|
|
+
|
|
+ public void c() {
|
|
+ if (this.world != null && !this.world.isStatic && this.world.getTime() % 20L == 0L) {
|
|
+ this.e = this.w();
|
|
+ if (this.e instanceof BlockDaylightDetector) {
|
|
+ ((BlockDaylightDetector) this.e).d(this.world, this.position);
|
|
+ }
|
|
+ }
|
|
+
|
|
+ }
|
|
+}
|
|
diff --git a/src/main/java/net/minecraft/server/Slot.java b/src/main/java/net/minecraft/server/Slot.java
|
|
new file mode 100644
|
|
index 0000000..375989f
|
|
--- /dev/null
|
|
+++ b/src/main/java/net/minecraft/server/Slot.java
|
|
@@ -0,0 +1,79 @@
|
|
+package net.minecraft.server;
|
|
+
|
|
+public class Slot {
|
|
+
|
|
+ public final int index;
|
|
+ public final IInventory inventory;
|
|
+ public int rawSlotIndex;
|
|
+ public int f;
|
|
+ public int g;
|
|
+
|
|
+ public Slot(IInventory iinventory, int i, int j, int k) {
|
|
+ this.inventory = iinventory;
|
|
+ this.index = i;
|
|
+ this.f = j;
|
|
+ this.g = k;
|
|
+ }
|
|
+
|
|
+ public void a(ItemStack itemstack, ItemStack itemstack1) {
|
|
+ if (itemstack != null && itemstack1 != null) {
|
|
+ if (itemstack.getItem() == itemstack1.getItem()) {
|
|
+ int i = itemstack1.count - itemstack.count;
|
|
+
|
|
+ if (i > 0) {
|
|
+ this.a(itemstack, i);
|
|
+ }
|
|
+
|
|
+ }
|
|
+ }
|
|
+ }
|
|
+
|
|
+ protected void a(ItemStack itemstack, int i) {}
|
|
+
|
|
+ protected void c(ItemStack itemstack) {}
|
|
+
|
|
+ public void a(EntityHuman entityhuman, ItemStack itemstack) {
|
|
+ this.f();
|
|
+ }
|
|
+
|
|
+ public boolean isAllowed(ItemStack itemstack) {
|
|
+ return true;
|
|
+ }
|
|
+
|
|
+ public ItemStack getItem() {
|
|
+ return this.inventory.getItem(this.index);
|
|
+ }
|
|
+
|
|
+ public boolean hasItem() {
|
|
+ return this.getItem() != null;
|
|
+ }
|
|
+
|
|
+ public void set(ItemStack itemstack) {
|
|
+ this.inventory.setItem(this.index, itemstack);
|
|
+ this.f();
|
|
+ }
|
|
+
|
|
+ public void f() {
|
|
+ this.inventory.update();
|
|
+ }
|
|
+
|
|
+ public int getMaxStackSize() {
|
|
+ return this.inventory.getMaxStackSize();
|
|
+ }
|
|
+
|
|
+ public int getMaxStackSize(ItemStack itemstack) {
|
|
+ return this.getMaxStackSize();
|
|
+ }
|
|
+
|
|
+ public ItemStack a(int i) {
|
|
+ return this.inventory.splitStack(this.index, i);
|
|
+ }
|
|
+
|
|
+ public boolean a(IInventory iinventory, int i) {
|
|
+ return iinventory == this.inventory && i == this.index;
|
|
+ }
|
|
+
|
|
+ public boolean isAllowed(EntityHuman entityhuman) {
|
|
+ return true;
|
|
+ }
|
|
+}
|
|
--
|
|
1.9.1
|
|
|