summaryrefslogtreecommitdiffstats
path: root/nms-patches
diff options
context:
space:
mode:
Diffstat (limited to 'nms-patches')
-rw-r--r--nms-patches/AdvancementDataPlayer.patch4
-rw-r--r--nms-patches/Advancements.patch4
-rw-r--r--nms-patches/Block.patch8
-rw-r--r--nms-patches/BlockBed.patch2
-rw-r--r--nms-patches/BlockButtonAbstract.patch16
-rw-r--r--nms-patches/BlockCactus.patch4
-rw-r--r--nms-patches/BlockCake.patch2
-rw-r--r--nms-patches/BlockCauldron.patch4
-rw-r--r--nms-patches/BlockCocoa.patch12
-rw-r--r--nms-patches/BlockCoralFan.patch4
-rw-r--r--nms-patches/BlockCoralFanWall.patch4
-rw-r--r--nms-patches/BlockCoralPlant.patch4
-rw-r--r--nms-patches/BlockDaylightDetector.patch4
-rw-r--r--nms-patches/BlockDiodeAbstract.patch4
-rw-r--r--nms-patches/BlockDoor.patch8
-rw-r--r--nms-patches/BlockFire.patch6
-rw-r--r--nms-patches/BlockFluids.patch10
-rw-r--r--nms-patches/BlockKelp.patch2
-rw-r--r--nms-patches/BlockLeaves.patch2
-rw-r--r--nms-patches/BlockLever.patch2
-rw-r--r--nms-patches/BlockMinecartDetector.patch2
-rw-r--r--nms-patches/BlockNetherWart.patch2
-rw-r--r--nms-patches/BlockNote.patch4
-rw-r--r--nms-patches/BlockObserver.patch6
-rw-r--r--nms-patches/BlockPiston.patch6
-rw-r--r--nms-patches/BlockPortal.patch18
-rw-r--r--nms-patches/BlockPoweredRail.patch4
-rw-r--r--nms-patches/BlockPressurePlateBinary.patch2
-rw-r--r--nms-patches/BlockPumpkinCarved.patch2
-rw-r--r--nms-patches/BlockRedstoneComparator.patch6
-rw-r--r--nms-patches/BlockRedstoneLamp.patch2
-rw-r--r--nms-patches/BlockRedstoneOre.patch12
-rw-r--r--nms-patches/BlockRedstoneTorch.patch6
-rw-r--r--nms-patches/BlockRedstoneWire.patch2
-rw-r--r--nms-patches/BlockReed.patch6
-rw-r--r--nms-patches/BlockSnow.patch2
-rw-r--r--nms-patches/BlockSoil.patch8
-rw-r--r--nms-patches/BlockSponge.patch8
-rw-r--r--nms-patches/BlockStem.patch6
-rw-r--r--nms-patches/BlockTrapdoor.patch8
-rw-r--r--nms-patches/BlockTripwire.patch2
-rw-r--r--nms-patches/BlockTripwireHook.patch2
-rw-r--r--nms-patches/BlockVine.patch22
-rw-r--r--nms-patches/Chunk.patch4
-rw-r--r--nms-patches/ChunkProviderServer.patch2
-rw-r--r--nms-patches/ChunkRegionLoader.patch2
-rw-r--r--nms-patches/CommandDispatcher.patch18
-rw-r--r--nms-patches/CommandForceload.patch2
-rw-r--r--nms-patches/Container.patch10
-rw-r--r--nms-patches/ContainerAnvil.patch12
-rw-r--r--nms-patches/CrashReport.patch2
-rw-r--r--nms-patches/DataConverterRegistry.patch2
-rw-r--r--nms-patches/DispenserRegistry.patch8
-rw-r--r--nms-patches/DragonControllerManager.patch2
-rw-r--r--nms-patches/EnchantmentFrostWalker.patch12
-rw-r--r--nms-patches/EnderDragonBattle.patch11
-rw-r--r--nms-patches/Entity.patch10
-rw-r--r--nms-patches/EntityAreaEffectCloud.patch4
-rw-r--r--nms-patches/EntityArmorStand.patch18
-rw-r--r--nms-patches/EntityBoat.patch8
-rw-r--r--nms-patches/EntityCreeper.patch2
-rw-r--r--nms-patches/EntityEnderman.patch2
-rw-r--r--nms-patches/EntityFish.patch2
-rw-r--r--nms-patches/EntityHuman.patch40
-rw-r--r--nms-patches/EntityInsentient.patch12
-rw-r--r--nms-patches/EntityItemFrame.patch6
-rw-r--r--nms-patches/EntityLiving.patch14
-rw-r--r--nms-patches/EntityMinecartAbstract.patch26
-rw-r--r--nms-patches/EntityPlayer.patch18
-rw-r--r--nms-patches/EntityProjectile.patch2
-rw-r--r--nms-patches/EntityRabbit.patch6
-rw-r--r--nms-patches/EntitySheep.patch6
-rw-r--r--nms-patches/EntityShulker.patch4
-rw-r--r--nms-patches/EntitySmallFireball.patch2
-rw-r--r--nms-patches/EntityThrownTrident.patch9
-rw-r--r--nms-patches/EntityTippedArrow.patch2
-rw-r--r--nms-patches/EntityTurtle.patch2
-rw-r--r--nms-patches/EntityVillager.patch2
-rw-r--r--nms-patches/EntityWither.patch11
-rw-r--r--nms-patches/EntityZombie.patch12
-rw-r--r--nms-patches/EntityZombieVillager.patch2
-rw-r--r--nms-patches/FluidTypeFlowing.patch4
-rw-r--r--nms-patches/HandshakeListener.patch2
-rw-r--r--nms-patches/ItemBoat.patch4
-rw-r--r--nms-patches/ItemBucket.patch4
-rw-r--r--nms-patches/ItemTrident.patch2
-rw-r--r--nms-patches/ItemWaterLily.patch2
-rw-r--r--nms-patches/LoginListener.patch2
-rw-r--r--nms-patches/LootTableInfo.patch6
-rw-r--r--nms-patches/MethodProfiler.patch6
-rw-r--r--nms-patches/MinecraftServer.patch8
-rw-r--r--nms-patches/MojangsonParser.patch20
-rw-r--r--nms-patches/PacketPlayInSettings.patch11
-rw-r--r--nms-patches/PathfinderGoalRemoveBlock.patch2
-rw-r--r--nms-patches/PlayerConnection.patch75
-rw-r--r--nms-patches/PlayerList.patch12
-rw-r--r--nms-patches/RecipeFireworks.patch6
-rw-r--r--nms-patches/RecipeFireworksFade.patch2
-rw-r--r--nms-patches/RecipeFireworksStar.patch8
-rw-r--r--nms-patches/SpawnerCreature.patch2
-rw-r--r--nms-patches/TileEntityBrewingStand.patch2
-rw-r--r--nms-patches/TileEntityEndGateway.patch8
-rw-r--r--nms-patches/TileEntityFurnace.patch2
-rw-r--r--nms-patches/TileEntityShulkerBox.patch2
-rw-r--r--nms-patches/World.patch4
-rw-r--r--nms-patches/WorldData.patch2
-rw-r--r--nms-patches/WorldGenVillagePieces.patch2
-rw-r--r--nms-patches/WorldGenWitchHut.patch4
108 files changed, 354 insertions, 403 deletions
diff --git a/nms-patches/AdvancementDataPlayer.patch b/nms-patches/AdvancementDataPlayer.patch
index 7636d583..3030c606 100644
--- a/nms-patches/AdvancementDataPlayer.patch
+++ b/nms-patches/AdvancementDataPlayer.patch
@@ -40,10 +40,10 @@
Advancement advancement = this.d.getAdvancementData().a((MinecraftKey) entry.getKey());
if (advancement == null) {
-- AdvancementDataPlayer.a.warn("Ignored advancement \'{}\' in progress file {} - it doesn\'t exist anymore?", entry.getKey(), this.e);
+- AdvancementDataPlayer.a.warn("Ignored advancement '{}' in progress file {} - it doesn't exist anymore?", entry.getKey(), this.e);
+ // CraftBukkit start
+ if (((MinecraftKey) entry.getKey()).b().equals("minecraft")) {
-+ AdvancementDataPlayer.a.warn("Ignored advancement \'{}\' in progress file {} - it doesn\'t exist anymore?", entry.getKey(), this.e);
++ AdvancementDataPlayer.a.warn("Ignored advancement '{}' in progress file {} - it doesn't exist anymore?", entry.getKey(), this.e);
+ }
+ // CraftBukkit end
} else {
diff --git a/nms-patches/Advancements.patch b/nms-patches/Advancements.patch
index 9871ffc7..0312dbf8 100644
--- a/nms-patches/Advancements.patch
+++ b/nms-patches/Advancements.patch
@@ -4,8 +4,8 @@
}
}
-- Advancements.a.info("Loaded {} advancements", Integer.valueOf(this.advancements.size()));
-+ // Advancements.a.info("Loaded {} advancements", Integer.valueOf(this.advancements.size())); // CraftBukkit - moved to AdvancementDataWorld#reload
+- Advancements.a.info("Loaded {} advancements", this.advancements.size());
++ // Advancements.a.info("Loaded {} advancements", this.advancements.size()); // CraftBukkit - moved to AdvancementDataWorld#reload
}
public void a() {
diff --git a/nms-patches/Block.patch b/nms-patches/Block.patch
index 87c30356..ee800c52 100644
--- a/nms-patches/Block.patch
+++ b/nms-patches/Block.patch
@@ -18,7 +18,7 @@
this.a(blockstatelist_a);
this.blockStateList = blockstatelist_a.a(BlockData::new);
-@@ -409,7 +409,8 @@
+@@ -406,7 +406,8 @@
int j = this.getDropCount(iblockdata, i, world, blockposition, world.random);
for (int k = 0; k < j; ++k) {
@@ -28,7 +28,7 @@
Item item = this.getDropType(iblockdata, world, blockposition, i).getItem();
if (item != Items.AIR) {
-@@ -430,7 +431,13 @@
+@@ -427,7 +428,13 @@
EntityItem entityitem = new EntityItem(world, (double) blockposition.getX() + d0, (double) blockposition.getY() + d1, (double) blockposition.getZ() + d2, itemstack);
entityitem.n();
@@ -43,7 +43,7 @@
}
}
-@@ -649,7 +656,7 @@
+@@ -646,7 +653,7 @@
}
public String toString() {
@@ -52,7 +52,7 @@
}
public static boolean c(Block block) {
-@@ -1398,8 +1405,14 @@
+@@ -1395,8 +1402,14 @@
}
diff --git a/nms-patches/BlockBed.patch b/nms-patches/BlockBed.patch
index ae0c3dfd..344cff1a 100644
--- a/nms-patches/BlockBed.patch
+++ b/nms-patches/BlockBed.patch
@@ -7,7 +7,7 @@
- if (world.worldProvider.canRespawn() && world.getBiome(blockposition) != Biomes.NETHER) {
+ // CraftBukkit - moved world and biome check into EntityHuman
+ if (true || world.worldProvider.canRespawn() && world.getBiome(blockposition) != Biomes.NETHER) {
- if (((Boolean) iblockdata.get(BlockBed.OCCUPIED)).booleanValue()) {
+ if ((Boolean) iblockdata.get(BlockBed.OCCUPIED)) {
EntityHuman entityhuman1 = this.a(world, blockposition);
@@ -59,10 +60,22 @@
diff --git a/nms-patches/BlockButtonAbstract.patch b/nms-patches/BlockButtonAbstract.patch
index 84ea0233..1700b694 100644
--- a/nms-patches/BlockButtonAbstract.patch
+++ b/nms-patches/BlockButtonAbstract.patch
@@ -12,8 +12,8 @@
public abstract class BlockButtonAbstract extends BlockAttachable {
public static final BlockStateBoolean POWERED = BlockProperties.t;
-@@ -77,6 +82,19 @@
- if (((Boolean) iblockdata.get(BlockButtonAbstract.POWERED)).booleanValue()) {
+@@ -72,6 +77,19 @@
+ if ((Boolean) iblockdata.get(BlockButtonAbstract.POWERED)) {
return true;
} else {
+ // CraftBukkit start
@@ -29,10 +29,10 @@
+ return true;
+ }
+ // CraftBukkit end
- world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockButtonAbstract.POWERED, Boolean.valueOf(true)), 3);
+ world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockButtonAbstract.POWERED, true), 3);
this.a(entityhuman, world, blockposition, true);
this.c(iblockdata, world, blockposition);
-@@ -118,6 +136,16 @@
+@@ -113,6 +131,16 @@
if (this.E) {
this.b(iblockdata, world, blockposition);
} else {
@@ -46,12 +46,12 @@
+ return;
+ }
+ // CraftBukkit end
- world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockButtonAbstract.POWERED, Boolean.valueOf(false)), 3);
+ world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockButtonAbstract.POWERED, false), 3);
this.c(iblockdata, world, blockposition);
this.a((EntityHuman) null, world, blockposition, false);
-@@ -137,7 +165,44 @@
+@@ -132,7 +160,44 @@
boolean flag = !list.isEmpty();
- boolean flag1 = ((Boolean) iblockdata.get(BlockButtonAbstract.POWERED)).booleanValue();
+ boolean flag1 = (Boolean) iblockdata.get(BlockButtonAbstract.POWERED);
+ // CraftBukkit start - Call interact event when arrows turn on wooden buttons
+ if (flag1 != flag && flag) {
@@ -91,6 +91,6 @@
+ return;
+ }
+ // CraftBukkit end
- world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockButtonAbstract.POWERED, Boolean.valueOf(flag)), 3);
+ world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockButtonAbstract.POWERED, flag), 3);
this.c(iblockdata, world, blockposition);
this.a((EntityHuman) null, world, blockposition, flag);
diff --git a/nms-patches/BlockCactus.patch b/nms-patches/BlockCactus.patch
index 2103c424..b98d62b0 100644
--- a/nms-patches/BlockCactus.patch
+++ b/nms-patches/BlockCactus.patch
@@ -10,12 +10,12 @@
public static final BlockStateInteger AGE = BlockProperties.X;
@@ -31,7 +33,7 @@
- int j = ((Integer) iblockdata.get(BlockCactus.AGE)).intValue();
+ int j = (Integer) iblockdata.get(BlockCactus.AGE);
if (j == 15) {
- world.setTypeUpdate(blockposition1, this.getBlockData());
+ CraftEventFactory.handleBlockGrowEvent(world, blockposition1, this.getBlockData()); // CraftBukkit
- IBlockData iblockdata1 = (IBlockData) iblockdata.set(BlockCactus.AGE, Integer.valueOf(0));
+ IBlockData iblockdata1 = (IBlockData) iblockdata.set(BlockCactus.AGE, 0);
world.setTypeAndData(blockposition, iblockdata1, 4);
@@ -92,7 +94,9 @@
diff --git a/nms-patches/BlockCake.patch b/nms-patches/BlockCake.patch
index 4830491d..cb5c7675 100644
--- a/nms-patches/BlockCake.patch
+++ b/nms-patches/BlockCake.patch
@@ -17,6 +17,6 @@
+
+ ((EntityPlayer) entityhuman).getBukkitEntity().sendHealthUpdate();
+ // CraftBukkit end
- int i = ((Integer) iblockdata.get(BlockCake.BITES)).intValue();
+ int i = (Integer) iblockdata.get(BlockCake.BITES);
if (i < 6) {
diff --git a/nms-patches/BlockCauldron.patch b/nms-patches/BlockCauldron.patch
index 7539f8d7..fdea6141 100644
--- a/nms-patches/BlockCauldron.patch
+++ b/nms-patches/BlockCauldron.patch
@@ -143,7 +143,7 @@
+ // CraftBukkit start
public void a(World world, BlockPosition blockposition, IBlockData iblockdata, int i) {
-- world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockCauldron.LEVEL, Integer.valueOf(MathHelper.clamp(i, 0, 3))), 2);
+- world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockCauldron.LEVEL, MathHelper.clamp(i, 0, 3)), 2);
+ this.changeLevel(world, blockposition, iblockdata, i, null, CauldronLevelChangeEvent.ChangeReason.UNKNOWN);
+ }
+
@@ -167,7 +167,7 @@
@@ -185,7 +238,7 @@
IBlockData iblockdata = world.getType(blockposition);
- if (((Integer) iblockdata.get(BlockCauldron.LEVEL)).intValue() < 3) {
+ if ((Integer) iblockdata.get(BlockCauldron.LEVEL) < 3) {
- world.setTypeAndData(blockposition, (IBlockData) iblockdata.a((IBlockState) BlockCauldron.LEVEL), 2);
+ this.a(world, blockposition, (IBlockData) iblockdata.a((IBlockState) BlockCauldron.LEVEL), 2); // CraftBukkit
}
diff --git a/nms-patches/BlockCocoa.patch b/nms-patches/BlockCocoa.patch
index 16a4ec30..7ee24a95 100644
--- a/nms-patches/BlockCocoa.patch
+++ b/nms-patches/BlockCocoa.patch
@@ -10,20 +10,20 @@
public static final BlockStateInteger AGE = BlockProperties.T;
@@ -21,7 +23,7 @@
- int i = ((Integer) iblockdata.get(BlockCocoa.AGE)).intValue();
+ int i = (Integer) iblockdata.get(BlockCocoa.AGE);
if (i < 2) {
-- world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockCocoa.AGE, Integer.valueOf(i + 1)), 2);
-+ CraftEventFactory.handleBlockGrowEvent(world, blockposition, (IBlockData) iblockdata.set(BlockCocoa.AGE, Integer.valueOf(i + 1)), 2); // CraftBukkkit
+- world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockCocoa.AGE, i + 1), 2);
++ CraftEventFactory.handleBlockGrowEvent(world, blockposition, (IBlockData) iblockdata.set(BlockCocoa.AGE, i + 1), 2); // CraftBukkkit
}
}
-@@ -109,7 +111,7 @@
+@@ -106,7 +108,7 @@
}
public void b(World world, Random random, BlockPosition blockposition, IBlockData iblockdata) {
-- world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockCocoa.AGE, Integer.valueOf(((Integer) iblockdata.get(BlockCocoa.AGE)).intValue() + 1)), 2);
-+ CraftEventFactory.handleBlockGrowEvent(world, blockposition, (IBlockData) iblockdata.set(BlockCocoa.AGE, Integer.valueOf(((Integer) iblockdata.get(BlockCocoa.AGE)).intValue() + 1)), 2); // CraftBukkit
+- world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockCocoa.AGE, (Integer) iblockdata.get(BlockCocoa.AGE) + 1), 2);
++ CraftEventFactory.handleBlockGrowEvent(world, blockposition, (IBlockData) iblockdata.set(BlockCocoa.AGE, (Integer) iblockdata.get(BlockCocoa.AGE) + 1), 2); // CraftBukkit
}
public TextureType c() {
diff --git a/nms-patches/BlockCoralFan.patch b/nms-patches/BlockCoralFan.patch
index 707d5e90..94a22488 100644
--- a/nms-patches/BlockCoralFan.patch
+++ b/nms-patches/BlockCoralFan.patch
@@ -5,10 +5,10 @@
public void a(IBlockData iblockdata, World world, BlockPosition blockposition, Random random) {
if (!b_(iblockdata, world, blockposition)) {
+ // CraftBukkit start
-+ if (org.bukkit.craftbukkit.event.CraftEventFactory.callBlockFadeEvent(world, blockposition, this.a.getBlockData().set(BlockCoralFan.b, Boolean.valueOf(false))).isCancelled()) {
++ if (org.bukkit.craftbukkit.event.CraftEventFactory.callBlockFadeEvent(world, blockposition, this.a.getBlockData().set(BlockCoralFan.b, false)).isCancelled()) {
+ return;
+ }
+ // CraftBukkit end
- world.setTypeAndData(blockposition, (IBlockData) this.a.getBlockData().set(BlockCoralFan.b, Boolean.valueOf(false)), 2);
+ world.setTypeAndData(blockposition, (IBlockData) this.a.getBlockData().set(BlockCoralFan.b, false), 2);
}
diff --git a/nms-patches/BlockCoralFanWall.patch b/nms-patches/BlockCoralFanWall.patch
index 87e1d415..224ce09c 100644
--- a/nms-patches/BlockCoralFanWall.patch
+++ b/nms-patches/BlockCoralFanWall.patch
@@ -5,10 +5,10 @@
public void a(IBlockData iblockdata, World world, BlockPosition blockposition, Random random) {
if (!b_(iblockdata, world, blockposition)) {
+ // CraftBukkit start
-+ if (org.bukkit.craftbukkit.event.CraftEventFactory.callBlockFadeEvent(world, blockposition, this.c.getBlockData().set(BlockCoralFanWall.b, Boolean.valueOf(false)).set(BlockCoralFanWall.a, iblockdata.get(BlockCoralFanWall.a))).isCancelled()) {
++ if (org.bukkit.craftbukkit.event.CraftEventFactory.callBlockFadeEvent(world, blockposition, this.c.getBlockData().set(BlockCoralFanWall.b, false).set(BlockCoralFanWall.a, iblockdata.get(BlockCoralFanWall.a))).isCancelled()) {
+ return;
+ }
+ // CraftBukkit end
- world.setTypeAndData(blockposition, (IBlockData) ((IBlockData) this.c.getBlockData().set(BlockCoralFanWall.b, Boolean.valueOf(false))).set(BlockCoralFanWall.a, iblockdata.get(BlockCoralFanWall.a)), 2);
+ world.setTypeAndData(blockposition, (IBlockData) ((IBlockData) this.c.getBlockData().set(BlockCoralFanWall.b, false)).set(BlockCoralFanWall.a, iblockdata.get(BlockCoralFanWall.a)), 2);
}
diff --git a/nms-patches/BlockCoralPlant.patch b/nms-patches/BlockCoralPlant.patch
index dc5e8cdb..65177b83 100644
--- a/nms-patches/BlockCoralPlant.patch
+++ b/nms-patches/BlockCoralPlant.patch
@@ -5,10 +5,10 @@
public void a(IBlockData iblockdata, World world, BlockPosition blockposition, Random random) {
if (!b_(iblockdata, world, blockposition)) {
+ // CraftBukkit start
-+ if (org.bukkit.craftbukkit.event.CraftEventFactory.callBlockFadeEvent(world, blockposition, this.c.getBlockData().set(BlockCoralPlant.b, Boolean.valueOf(false))).isCancelled()) {
++ if (org.bukkit.craftbukkit.event.CraftEventFactory.callBlockFadeEvent(world, blockposition, this.c.getBlockData().set(BlockCoralPlant.b, false)).isCancelled()) {
+ return;
+ }
+ // CraftBukkit end
- world.setTypeAndData(blockposition, (IBlockData) this.c.getBlockData().set(BlockCoralPlant.b, Boolean.valueOf(false)), 2);
+ world.setTypeAndData(blockposition, (IBlockData) this.c.getBlockData().set(BlockCoralPlant.b, false), 2);
}
diff --git a/nms-patches/BlockDaylightDetector.patch b/nms-patches/BlockDaylightDetector.patch
index b62dbbf6..83622a4c 100644
--- a/nms-patches/BlockDaylightDetector.patch
+++ b/nms-patches/BlockDaylightDetector.patch
@@ -3,8 +3,8 @@
@@ -36,6 +36,7 @@
i = MathHelper.clamp(i, 0, 15);
- if (((Integer) iblockdata.get(BlockDaylightDetector.POWER)).intValue() != i) {
+ if ((Integer) iblockdata.get(BlockDaylightDetector.POWER) != i) {
+ i = org.bukkit.craftbukkit.event.CraftEventFactory.callRedstoneChange(world, blockposition, ((Integer) iblockdata.get(POWER)), i).getNewCurrent(); // CraftBukkit - Call BlockRedstoneEvent
- world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockDaylightDetector.POWER, Integer.valueOf(i)), 3);
+ world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockDaylightDetector.POWER, i), 3);
}
diff --git a/nms-patches/BlockDiodeAbstract.patch b/nms-patches/BlockDiodeAbstract.patch
index 02a9b093..8b0ee45d 100644
--- a/nms-patches/BlockDiodeAbstract.patch
+++ b/nms-patches/BlockDiodeAbstract.patch
@@ -18,13 +18,13 @@
+ return;
+ }
+ // CraftBukkit end
- world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockDiodeAbstract.c, Boolean.valueOf(false)), 2);
+ world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockDiodeAbstract.c, false), 2);
} else if (!flag) {
+ // CraftBukkit start
+ if (CraftEventFactory.callRedstoneChange(world, blockposition, 0, 15).getNewCurrent() != 15) {
+ return;
+ }
+ // CraftBukkit end
- world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockDiodeAbstract.c, Boolean.valueOf(true)), 2);
+ world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockDiodeAbstract.c, true), 2);
if (!flag1) {
world.J().a(blockposition, this, this.k(iblockdata), TickListPriority.HIGH);
diff --git a/nms-patches/BlockDoor.patch b/nms-patches/BlockDoor.patch
index e47addb1..2ace0dc8 100644
--- a/nms-patches/BlockDoor.patch
+++ b/nms-patches/BlockDoor.patch
@@ -9,7 +9,7 @@
public class BlockDoor extends Block {
public static final BlockStateDirection FACING = BlockFacingHorizontal.FACING;
-@@ -169,9 +171,24 @@
+@@ -163,9 +165,24 @@
}
public void doPhysics(IBlockData iblockdata, World world, BlockPosition blockposition, Block block, BlockPosition blockposition1) {
@@ -24,15 +24,15 @@
+ int power = bukkitBlock.getBlockPower();
+ int powerTop = blockTop.getBlockPower();
+ if (powerTop > power) power = powerTop;
-+ int oldPower = ((Boolean) iblockdata.get(BlockDoor.POWERED)).booleanValue() ? 15 : 0;
++ int oldPower = (Boolean) iblockdata.get(BlockDoor.POWERED) ? 15 : 0;
+
+ if (oldPower == 0 ^ power == 0) {
+ BlockRedstoneEvent eventRedstone = new BlockRedstoneEvent(bukkitBlock, oldPower, power);
+ world.getServer().getPluginManager().callEvent(eventRedstone);
-- if (block != this && flag != ((Boolean) iblockdata.get(BlockDoor.POWERED)).booleanValue()) {
+- if (block != this && flag != (Boolean) iblockdata.get(BlockDoor.POWERED)) {
+ boolean flag = eventRedstone.getNewCurrent() > 0;
+ // CraftBukkit end
- if (flag != ((Boolean) iblockdata.get(BlockDoor.OPEN)).booleanValue()) {
+ if (flag != (Boolean) iblockdata.get(BlockDoor.OPEN)) {
this.b(world, blockposition, flag);
}
diff --git a/nms-patches/BlockFire.patch b/nms-patches/BlockFire.patch
index 0e2e82e0..d36f2df3 100644
--- a/nms-patches/BlockFire.patch
+++ b/nms-patches/BlockFire.patch
@@ -49,7 +49,7 @@
Block block = world.getType(blockposition.down()).getBlock();
@@ -90,7 +113,7 @@
- int i = ((Integer) iblockdata.get(BlockFire.AGE)).intValue();
+ int i = (Integer) iblockdata.get(BlockFire.AGE);
if (!flag && world.isRaining() && this.a(world, blockposition) && random.nextFloat() < 0.2F + (float) i * 0.03F) {
- world.setAir(blockposition);
@@ -99,14 +99,14 @@
if (i2 > 0 && random.nextInt(k1) <= i2 && (!world.isRaining() || !this.a(world, (BlockPosition) blockposition_mutableblockposition))) {
int j2 = Math.min(15, i + random.nextInt(5) / 4);
-- world.setTypeAndData(blockposition_mutableblockposition, (IBlockData) this.a((IBlockAccess) world, (BlockPosition) blockposition_mutableblockposition).set(BlockFire.AGE, Integer.valueOf(j2)), 3);
+- world.setTypeAndData(blockposition_mutableblockposition, (IBlockData) this.a((IBlockAccess) world, (BlockPosition) blockposition_mutableblockposition).set(BlockFire.AGE, j2), 3);
+ // CraftBukkit start - Call to stop spread of fire
+ if (world.getType(blockposition_mutableblockposition) != Blocks.FIRE) {
+ if (CraftEventFactory.callBlockIgniteEvent(world, blockposition_mutableblockposition, blockposition).isCancelled()) {
+ continue;
+ }
+
-+ CraftEventFactory.handleBlockSpreadEvent(world, blockposition, blockposition_mutableblockposition, (IBlockData) this.a((IBlockAccess) world, (BlockPosition) blockposition_mutableblockposition).set(BlockFire.AGE, Integer.valueOf(j2)), 3); // CraftBukkit
++ CraftEventFactory.handleBlockSpreadEvent(world, blockposition, blockposition_mutableblockposition, (IBlockData) this.a((IBlockAccess) world, (BlockPosition) blockposition_mutableblockposition).set(BlockFire.AGE, j2), 3); // CraftBukkit
+ }
+ // CraftBukkit end
}
diff --git a/nms-patches/BlockFluids.patch b/nms-patches/BlockFluids.patch
index b2f16b46..d34dd16f 100644
--- a/nms-patches/BlockFluids.patch
+++ b/nms-patches/BlockFluids.patch
@@ -2,20 +2,20 @@
+++ b/net/minecraft/server/BlockFluids.java
@@ -57,10 +57,10 @@
public VoxelShape a(IBlockData iblockdata, IBlockAccess iblockaccess, BlockPosition blockposition) {
- Fluid fluid = iblockaccess.b(blockposition.up());
+ Fluid fluid = iblockaccess.getFluid(blockposition.up());
- return fluid.c().a((FluidType) this.b) ? VoxelShapes.b() : (VoxelShape) this.o.computeIfAbsent(iblockdata, (iblockdata) -> {
- Fluid fluid = iblockdata.s();
+ return fluid.c().a((FluidType) this.b) ? VoxelShapes.b() : (VoxelShape) this.o.computeIfAbsent(iblockdata, (iblockdata1) -> { // CraftBukkit - decompile errors
+ Fluid fluid1 = iblockdata1.s();
-- return VoxelShapes.a(0.0D, 0.0D, 0.0D, 1.0D, (double) fluid.f(), 1.0D);
-+ return VoxelShapes.a(0.0D, 0.0D, 0.0D, 1.0D, (double) fluid1.f(), 1.0D);
+- return VoxelShapes.create(0.0D, 0.0D, 0.0D, 1.0D, (double) fluid.getHeight(), 1.0D);
++ return VoxelShapes.create(0.0D, 0.0D, 0.0D, 1.0D, (double) fluid1.getHeight(), 1.0D);
});
}
@@ -117,14 +117,20 @@
- Fluid fluid = world.b(blockposition);
+ Fluid fluid = world.getFluid(blockposition);
if (fluid.d()) {
- world.setTypeUpdate(blockposition, Blocks.OBSIDIAN.getBlockData());
@@ -28,7 +28,7 @@
return false;
}
- if (fluid.f() >= 0.44444445F) {
+ if (fluid.getHeight() >= 0.44444445F) {
- world.setTypeUpdate(blockposition, Blocks.COBBLESTONE.getBlockData());
- this.fizz(world, blockposition);
+ // CraftBukkit start
diff --git a/nms-patches/BlockKelp.patch b/nms-patches/BlockKelp.patch
index b014e434..b73d089a 100644
--- a/nms-patches/BlockKelp.patch
+++ b/nms-patches/BlockKelp.patch
@@ -3,7 +3,7 @@
@@ -52,7 +52,7 @@
IBlockData iblockdata1 = world.getType(blockposition1);
- if (iblockdata1.getBlock() == Blocks.WATER && ((Integer) iblockdata.get(BlockKelp.a)).intValue() < 25 && random.nextDouble() < 0.14D) {
+ if (iblockdata1.getBlock() == Blocks.WATER && (Integer) iblockdata.get(BlockKelp.a) < 25 && random.nextDouble() < 0.14D) {
- world.setTypeUpdate(blockposition1, (IBlockData) iblockdata.a((IBlockState) BlockKelp.a));
+ org.bukkit.craftbukkit.event.CraftEventFactory.handleBlockSpreadEvent(world, blockposition, blockposition1, (IBlockData) iblockdata.a((IBlockState) BlockKelp.a)); // CraftBukkit
}
diff --git a/nms-patches/BlockLeaves.patch b/nms-patches/BlockLeaves.patch
index cce3360d..673d04fd 100644
--- a/nms-patches/BlockLeaves.patch
+++ b/nms-patches/BlockLeaves.patch
@@ -12,7 +12,7 @@
@@ -20,6 +22,14 @@
public void b(IBlockData iblockdata, World world, BlockPosition blockposition, Random random) {
- if (!((Boolean) iblockdata.get(BlockLeaves.PERSISTENT)).booleanValue() && ((Integer) iblockdata.get(BlockLeaves.DISTANCE)).intValue() == 7) {
+ if (!(Boolean) iblockdata.get(BlockLeaves.PERSISTENT) && (Integer) iblockdata.get(BlockLeaves.DISTANCE) == 7) {
+ // CraftBukkit start
+ LeavesDecayEvent event = new LeavesDecayEvent(world.getWorld().getBlockAt(blockposition.getX(), blockposition.getY(), blockposition.getZ()));
+ world.getServer().getPluginManager().callEvent(event);
diff --git a/nms-patches/BlockLever.patch b/nms-patches/BlockLever.patch
index 391ba432..1470d8a0 100644
--- a/nms-patches/BlockLever.patch
+++ b/nms-patches/BlockLever.patch
@@ -8,7 +8,7 @@
public class BlockLever extends BlockAttachable {
public static final BlockStateBoolean POWERED = BlockProperties.t;
-@@ -73,6 +75,20 @@
+@@ -66,6 +68,20 @@
return true;
} else {
diff --git a/nms-patches/BlockMinecartDetector.patch b/nms-patches/BlockMinecartDetector.patch
index 16fe0b49..b186b00d 100644
--- a/nms-patches/BlockMinecartDetector.patch
+++ b/nms-patches/BlockMinecartDetector.patch
@@ -25,5 +25,5 @@
+ // CraftBukkit end
+
if (flag1 && !flag) {
- world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockMinecartDetector.POWERED, Boolean.valueOf(true)), 3);
+ world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockMinecartDetector.POWERED, true), 3);
this.b(world, blockposition, iblockdata, true);
diff --git a/nms-patches/BlockNetherWart.patch b/nms-patches/BlockNetherWart.patch
index f0aca39f..04fc8289 100644
--- a/nms-patches/BlockNetherWart.patch
+++ b/nms-patches/BlockNetherWart.patch
@@ -3,7 +3,7 @@
@@ -25,7 +25,7 @@
if (i < 3 && random.nextInt(10) == 0) {
- iblockdata = (IBlockData) iblockdata.set(BlockNetherWart.AGE, Integer.valueOf(i + 1));
+ iblockdata = (IBlockData) iblockdata.set(BlockNetherWart.AGE, i + 1);
- world.setTypeAndData(blockposition, iblockdata, 2);
+ org.bukkit.craftbukkit.event.CraftEventFactory.handleBlockGrowEvent(world, blockposition, iblockdata, 2); // CraftBukkit
}
diff --git a/nms-patches/BlockNote.patch b/nms-patches/BlockNote.patch
index 246b882b..5d8f67d5 100644
--- a/nms-patches/BlockNote.patch
+++ b/nms-patches/BlockNote.patch
@@ -2,13 +2,13 @@
+++ b/net/minecraft/server/BlockNote.java
@@ -24,7 +24,7 @@
- if (flag != ((Boolean) iblockdata.get(BlockNote.POWERED)).booleanValue()) {
+ if (flag != (Boolean) iblockdata.get(BlockNote.POWERED)) {
if (flag) {
- this.play(world, blockposition);
+ this.play(world, blockposition, iblockdata); // CraftBukkit
}
- world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockNote.POWERED, Boolean.valueOf(flag)), 3);
+ world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockNote.POWERED, flag), 3);
@@ -32,9 +32,14 @@
}
diff --git a/nms-patches/BlockObserver.patch b/nms-patches/BlockObserver.patch
index f6b97dcc..592fe5ac 100644
--- a/nms-patches/BlockObserver.patch
+++ b/nms-patches/BlockObserver.patch
@@ -12,19 +12,19 @@
@@ -25,8 +27,18 @@
public void a(IBlockData iblockdata, World world, BlockPosition blockposition, Random random) {
- if (((Boolean) iblockdata.get(BlockObserver.b)).booleanValue()) {
+ if ((Boolean) iblockdata.get(BlockObserver.b)) {
+ // CraftBukkit start
+ if (CraftEventFactory.callRedstoneChange(world, blockposition, 15, 0).getNewCurrent() != 0) {
+ return;
+ }
+ // CraftBukkit end
- world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockObserver.b, Boolean.valueOf(false)), 2);
+ world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockObserver.b, false), 2);
} else {
+ // CraftBukkit start
+ if (CraftEventFactory.callRedstoneChange(world, blockposition, 0, 15).getNewCurrent() != 15) {
+ return;
+ }
+ // CraftBukkit end
- world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockObserver.b, Boolean.valueOf(true)), 2);
+ world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockObserver.b, true), 2);
world.J().a(blockposition, this, 2);
}
diff --git a/nms-patches/BlockPiston.patch b/nms-patches/BlockPiston.patch
index 5f29fcd2..bc3b1489 100644
--- a/nms-patches/BlockPiston.patch
+++ b/nms-patches/BlockPiston.patch
@@ -19,7 +19,7 @@
public class BlockPiston extends BlockDirectional {
public static final BlockStateBoolean EXTENDED = BlockProperties.f;
-@@ -111,6 +123,18 @@
+@@ -106,6 +118,18 @@
}
}
@@ -38,7 +38,7 @@
world.playBlockAction(blockposition, this, b0, enumdirection.a());
}
-@@ -285,6 +309,48 @@
+@@ -278,6 +302,48 @@
IBlockData[] aiblockdata = new IBlockData[j];
EnumDirection enumdirection1 = flag ? enumdirection : enumdirection.opposite();
HashSet hashset = Sets.newHashSet(list);
@@ -85,5 +85,5 @@
+ }
+ // CraftBukkit end
- int k;
BlockPosition blockposition3;
+ int k;
diff --git a/nms-patches/BlockPortal.patch b/nms-patches/BlockPortal.patch
index 5863e7e6..571debd1 100644
--- a/nms-patches/BlockPortal.patch
+++ b/nms-patches/BlockPortal.patch
@@ -13,7 +13,7 @@
public class BlockPortal extends Block {
public static final BlockStateEnum<EnumDirection.EnumAxis> AXIS = BlockProperties.z;
-@@ -37,7 +43,8 @@
+@@ -36,7 +42,8 @@
}
if (i > 0 && !world.getType(blockposition1.up()).isOccluding()) {
@@ -23,7 +23,7 @@
if (entity != null) {
entity.portalCooldown = entity.aQ();
-@@ -55,8 +62,10 @@
+@@ -54,8 +61,10 @@
BlockPortal.Shape blockportal_shape = this.b(generatoraccess, blockposition);
if (blockportal_shape != null) {
@@ -36,7 +36,7 @@
} else {
return false;
}
-@@ -93,6 +102,10 @@
+@@ -92,6 +101,10 @@
public void a(IBlockData iblockdata, World world, BlockPosition blockposition, Entity entity) {
if (!entity.isPassenger() && !entity.isVehicle() && entity.bm()) {
@@ -47,7 +47,7 @@
entity.e(blockposition);
}
-@@ -193,6 +206,7 @@
+@@ -189,6 +202,7 @@
private BlockPosition position;
private int height;
private int width;
@@ -55,7 +55,7 @@
public Shape(GeneratorAccess generatoraccess, BlockPosition blockposition, EnumDirection.EnumAxis enumdirection_enumaxis) {
this.a = generatoraccess;
-@@ -251,6 +265,9 @@
+@@ -247,6 +261,9 @@
}
protected int c() {
@@ -65,7 +65,7 @@
int i;
label56:
-@@ -273,11 +290,21 @@
+@@ -269,11 +286,21 @@
block = this.a.getType(blockposition.shift(this.d)).getBlock();
if (block != Blocks.OBSIDIAN) {
break label56;
@@ -87,7 +87,7 @@
}
}
}
-@@ -287,6 +314,11 @@
+@@ -283,6 +310,11 @@
if (this.a.getType(this.position.shift(this.c, i).up(this.height)).getBlock() != Blocks.OBSIDIAN) {
this.height = 0;
break;
@@ -99,7 +99,7 @@
}
}
-@@ -310,7 +342,27 @@
+@@ -306,7 +338,27 @@
return this.position != null && this.width >= 2 && this.width <= 21 && this.height >= 3 && this.height <= 21;
}
@@ -128,7 +128,7 @@
for (int i = 0; i < this.width; ++i) {
BlockPosition blockposition = this.position.shift(this.c, i);
-@@ -319,6 +371,7 @@
+@@ -315,6 +367,7 @@
}
}
diff --git a/nms-patches/BlockPoweredRail.patch b/nms-patches/BlockPoweredRail.patch
index 43ee707d..fa6a5cb2 100644
--- a/nms-patches/BlockPoweredRail.patch
+++ b/nms-patches/BlockPoweredRail.patch
@@ -8,7 +8,7 @@
public class BlockPoweredRail extends BlockMinecartTrackAbstract {
public static final BlockStateEnum<BlockPropertyTrackPosition> SHAPE = BlockProperties.S;
-@@ -106,6 +108,13 @@
+@@ -101,6 +103,13 @@
boolean flag1 = world.isBlockIndirectlyPowered(blockposition) || this.a(world, blockposition, iblockdata, true, 0) || this.a(world, blockposition, iblockdata, false, 0);
if (flag1 != flag) {
@@ -19,6 +19,6 @@
+ return;
+ }
+ // CraftBukkit end
- world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockPoweredRail.POWERED, Boolean.valueOf(flag1)), 3);
+ world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockPoweredRail.POWERED, flag1), 3);
world.applyPhysics(blockposition.down(), this);
if (((BlockPropertyTrackPosition) iblockdata.get(BlockPoweredRail.SHAPE)).c()) {
diff --git a/nms-patches/BlockPressurePlateBinary.patch b/nms-patches/BlockPressurePlateBinary.patch
index 6607944b..1ceb7dd8 100644
--- a/nms-patches/BlockPressurePlateBinary.patch
+++ b/nms-patches/BlockPressurePlateBinary.patch
@@ -9,7 +9,7 @@
public class BlockPressurePlateBinary extends BlockPressurePlateAbstract {
public static final BlockStateBoolean POWERED = BlockProperties.t;
-@@ -63,6 +65,26 @@
+@@ -61,6 +63,26 @@
while (iterator.hasNext()) {
Entity entity = (Entity) iterator.next();
diff --git a/nms-patches/BlockPumpkinCarved.patch b/nms-patches/BlockPumpkinCarved.patch
index 336d8eb7..b4d7417f 100644
--- a/nms-patches/BlockPumpkinCarved.patch
+++ b/nms-patches/BlockPumpkinCarved.patch
@@ -14,7 +14,7 @@
public static final BlockStateDirection a = BlockFacingHorizontal.FACING;
@@ -38,18 +44,24 @@
- int j;
+ ShapeDetectorBlock shapedetectorblock;
int k;
+ BlockStateListPopulator blockList = new BlockStateListPopulator(world); // CraftBukkit - Use BlockStateListPopulator
diff --git a/nms-patches/BlockRedstoneComparator.patch b/nms-patches/BlockRedstoneComparator.patch
index 82052199..6e839dfc 100644
--- a/nms-patches/BlockRedstoneComparator.patch
+++ b/nms-patches/BlockRedstoneComparator.patch
@@ -20,7 +20,7 @@
});
@@ -118,8 +121,18 @@
- boolean flag1 = ((Boolean) iblockdata.get(BlockRedstoneComparator.c)).booleanValue();
+ boolean flag1 = (Boolean) iblockdata.get(BlockRedstoneComparator.c);
if (flag1 && !flag) {
+ // CraftBukkit start
@@ -28,13 +28,13 @@
+ return;
+ }
+ // CraftBukkit end
- world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockRedstoneComparator.c, Boolean.valueOf(false)), 2);
+ world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockRedstoneComparator.c, false), 2);
} else if (!flag1 && flag) {
+ // CraftBukkit start
+ if (CraftEventFactory.callRedstoneChange(world, blockposition, 0, 15).getNewCurrent() != 15) {
+ return;
+ }
+ // CraftBukkit end
- world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockRedstoneComparator.c, Boolean.valueOf(true)), 2);
+ world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockRedstoneComparator.c, true), 2);
}
diff --git a/nms-patches/BlockRedstoneLamp.patch b/nms-patches/BlockRedstoneLamp.patch
index 3b484aeb..72a465e3 100644
--- a/nms-patches/BlockRedstoneLamp.patch
+++ b/nms-patches/BlockRedstoneLamp.patch
@@ -24,7 +24,7 @@
@@ -43,6 +50,11 @@
public void a(IBlockData iblockdata, World world, BlockPosition blockposition, Random random) {
if (!world.isClientSide) {
- if (((Boolean) iblockdata.get(BlockRedstoneLamp.a)).booleanValue() && !world.isBlockIndirectlyPowered(blockposition)) {
+ if ((Boolean) iblockdata.get(BlockRedstoneLamp.a) && !world.isBlockIndirectlyPowered(blockposition)) {
+ // CraftBukkit start
+ if (CraftEventFactory.callRedstoneChange(world, blockposition, 15, 0).getNewCurrent() != 0) {
+ return;
diff --git a/nms-patches/BlockRedstoneOre.patch b/nms-patches/BlockRedstoneOre.patch
index e9312c2c..01d88722 100644
--- a/nms-patches/BlockRedstoneOre.patch
+++ b/nms-patches/BlockRedstoneOre.patch
@@ -53,25 +53,25 @@
- private static void interact(IBlockData iblockdata, World world, BlockPosition blockposition) {
+ private static void interact(IBlockData iblockdata, World world, BlockPosition blockposition, Entity entity) { // CraftBukkit - add Entity
playEffect(world, blockposition);
- if (!((Boolean) iblockdata.get(BlockRedstoneOre.a)).booleanValue()) {
+ if (!(Boolean) iblockdata.get(BlockRedstoneOre.a)) {
+ // CraftBukkit start
-+ if (CraftEventFactory.callEntityChangeBlockEvent(entity, blockposition, iblockdata.set(BlockRedstoneOre.a, Boolean.valueOf(true))).isCancelled()) {
++ if (CraftEventFactory.callEntityChangeBlockEvent(entity, blockposition, iblockdata.set(BlockRedstoneOre.a, true)).isCancelled()) {
+ return;
+ }
+ // CraftBukkit end
- world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockRedstoneOre.a, Boolean.valueOf(true)), 3);
+ world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockRedstoneOre.a, true), 3);
}
@@ -40,6 +66,11 @@
public void a(IBlockData iblockdata, World world, BlockPosition blockposition, Random random) {
- if (((Boolean) iblockdata.get(BlockRedstoneOre.a)).booleanValue()) {
+ if ((Boolean) iblockdata.get(BlockRedstoneOre.a)) {
+ // CraftBukkit start
-+ if (CraftEventFactory.callBlockFadeEvent(world, blockposition, iblockdata.set(BlockRedstoneOre.a, Boolean.valueOf(false))).isCancelled()) {
++ if (CraftEventFactory.callBlockFadeEvent(world, blockposition, iblockdata.set(BlockRedstoneOre.a, false)).isCancelled()) {
+ return;
+ }
+ // CraftBukkit end
- world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockRedstoneOre.a, Boolean.valueOf(false)), 3);
+ world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockRedstoneOre.a, false), 3);
}
@@ -59,12 +90,25 @@
diff --git a/nms-patches/BlockRedstoneTorch.patch b/nms-patches/BlockRedstoneTorch.patch
index 4506c4b4..dc2c7e5d 100644
--- a/nms-patches/BlockRedstoneTorch.patch
+++ b/nms-patches/BlockRedstoneTorch.patch
@@ -20,7 +20,7 @@
+
+ BlockRedstoneEvent event = new BlockRedstoneEvent(block, oldCurrent, oldCurrent);
+ // CraftBukkit end
- if (((Boolean) iblockdata.get(BlockRedstoneTorch.LIT)).booleanValue()) {
+ if ((Boolean) iblockdata.get(BlockRedstoneTorch.LIT)) {
if (flag) {
+ // CraftBukkit start
+ if (oldCurrent != 0) {
@@ -31,7 +31,7 @@
+ }
+ }
+ // CraftBukkit end
- world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockRedstoneTorch.LIT, Boolean.valueOf(false)), 3);
+ world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockRedstoneTorch.LIT, false), 3);
if (a(world, blockposition, true)) {
world.a((EntityHuman) null, blockposition, SoundEffects.BLOCK_REDSTONE_TORCH_BURNOUT, SoundCategory.BLOCKS, 0.5F, 2.6F + (world.random.nextFloat() - world.random.nextFloat()) * 0.8F);
@@ -83,6 +101,15 @@
@@ -47,7 +47,7 @@
+ }
+ }
+ // CraftBukkit end
- world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockRedstoneTorch.LIT, Boolean.valueOf(true)), 3);
+ world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockRedstoneTorch.LIT, true), 3);
}
@@ -112,7 +139,7 @@
diff --git a/nms-patches/BlockRedstoneWire.patch b/nms-patches/BlockRedstoneWire.patch
index f6f436ac..d3568cb3 100644
--- a/nms-patches/BlockRedstoneWire.patch
+++ b/nms-patches/BlockRedstoneWire.patch
@@ -23,5 +23,5 @@
+ // CraftBukkit end
+
if (i != j) {
- iblockdata = (IBlockData) iblockdata.set(BlockRedstoneWire.POWER, Integer.valueOf(j));
+ iblockdata = (IBlockData) iblockdata.set(BlockRedstoneWire.POWER, j);
if (world.getType(blockposition) == iblockdata1) {
diff --git a/nms-patches/BlockReed.patch b/nms-patches/BlockReed.patch
index 4bdaf9e7..f7713a70 100644
--- a/nms-patches/BlockReed.patch
+++ b/nms-patches/BlockReed.patch
@@ -1,11 +1,11 @@
--- a/net/minecraft/server/BlockReed.java
+++ b/net/minecraft/server/BlockReed.java
@@ -29,7 +29,7 @@
- int j = ((Integer) iblockdata.get(BlockReed.AGE)).intValue();
+ int j = (Integer) iblockdata.get(BlockReed.AGE);
if (j == 15) {
- world.setTypeUpdate(blockposition.up(), this.getBlockData());
+ org.bukkit.craftbukkit.event.CraftEventFactory.handleBlockGrowEvent(world, blockposition.up(), this.getBlockData()); // CraftBukkit
- world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockReed.AGE, Integer.valueOf(0)), 4);
+ world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockReed.AGE, 0), 4);
} else {
- world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockReed.AGE, Integer.valueOf(j + 1)), 4);
+ world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockReed.AGE, j + 1), 4);
diff --git a/nms-patches/BlockSnow.patch b/nms-patches/BlockSnow.patch
index 00bda675..70e7ffc8 100644
--- a/nms-patches/BlockSnow.patch
+++ b/nms-patches/BlockSnow.patch
@@ -1,6 +1,6 @@
--- a/net/minecraft/server/BlockSnow.java
+++ b/net/minecraft/server/BlockSnow.java
-@@ -88,6 +88,11 @@
+@@ -85,6 +85,11 @@
public void a(IBlockData iblockdata, World world, BlockPosition blockposition, Random random) {
if (world.getBrightness(EnumSkyBlock.BLOCK, blockposition) > 11) {
diff --git a/nms-patches/BlockSoil.patch b/nms-patches/BlockSoil.patch
index 75bc8516..e562c66d 100644
--- a/nms-patches/BlockSoil.patch
+++ b/nms-patches/BlockSoil.patch
@@ -16,14 +16,14 @@
if (!a((IWorldReader) world, blockposition) && !world.isRainingAt(blockposition.up())) {
if (i > 0) {
-- world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockSoil.MOISTURE, Integer.valueOf(i - 1)), 2);
-+ org.bukkit.craftbukkit.event.CraftEventFactory.handleMoistureChangeEvent(world, blockposition, (IBlockData) iblockdata.set(BlockSoil.MOISTURE, Integer.valueOf(i - 1)), 2); // CraftBukkit
+- world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockSoil.MOISTURE, i - 1), 2);
++ org.bukkit.craftbukkit.event.CraftEventFactory.handleMoistureChangeEvent(world, blockposition, (IBlockData) iblockdata.set(BlockSoil.MOISTURE, i - 1), 2); // CraftBukkit
} else if (!a((IBlockAccess) world, blockposition)) {
b(iblockdata, world, blockposition);
}
} else if (i < 7) {
-- world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockSoil.MOISTURE, Integer.valueOf(7)), 2);
-+ org.bukkit.craftbukkit.event.CraftEventFactory.handleMoistureChangeEvent(world, blockposition, (IBlockData) iblockdata.set(BlockSoil.MOISTURE, Integer.valueOf(7)), 2); // CraftBukkit
+- world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockSoil.MOISTURE, 7), 2);
++ org.bukkit.craftbukkit.event.CraftEventFactory.handleMoistureChangeEvent(world, blockposition, (IBlockData) iblockdata.set(BlockSoil.MOISTURE, 7), 2); // CraftBukkit
}
}
diff --git a/nms-patches/BlockSponge.patch b/nms-patches/BlockSponge.patch
index c6dac0b0..a2e22a37 100644
--- a/nms-patches/BlockSponge.patch
+++ b/nms-patches/BlockSponge.patch
@@ -15,7 +15,7 @@
@@ -33,6 +39,7 @@
- linkedlist.add(new Tuple(blockposition, Integer.valueOf(0)));
+ linkedlist.add(new Tuple(blockposition, 0));
int i = 0;
+ BlockStateListPopulator blockList = new BlockStateListPopulator(world); // CraftBukkit - Use BlockStateListPopulator
@@ -29,14 +29,14 @@
+ if (iblockdata.getBlock() instanceof IFluidSource && ((IFluidSource) iblockdata.getBlock()).a(blockList, blockposition2, iblockdata) != FluidTypes.a) { // CraftBukkit
++i;
if (j < 6) {
- linkedlist.add(new Tuple(blockposition2, Integer.valueOf(j + 1)));
+ linkedlist.add(new Tuple(blockposition2, j + 1));
}
} else if (iblockdata.getBlock() instanceof BlockFluids) {
- world.setTypeAndData(blockposition2, Blocks.AIR.getBlockData(), 3);
+ blockList.setTypeAndData(blockposition2, Blocks.AIR.getBlockData(), 3); // CraftBukkit
++i;
if (j < 6) {
- linkedlist.add(new Tuple(blockposition2, Integer.valueOf(j + 1)));
+ linkedlist.add(new Tuple(blockposition2, j + 1));
}
} else if (material == Material.WATER_PLANT || material == Material.REPLACEABLE_WATER_PLANT) {
- iblockdata.a(world, blockposition2, 0);
@@ -45,7 +45,7 @@
+ blockList.setTypeAndData(blockposition2, Blocks.AIR.getBlockData(), 3); // CraftBukkit
++i;
if (j < 6) {
- linkedlist.add(new Tuple(blockposition2, Integer.valueOf(j + 1)));
+ linkedlist.add(new Tuple(blockposition2, j + 1));
@@ -75,6 +82,31 @@
break;
}
diff --git a/nms-patches/BlockStem.patch b/nms-patches/BlockStem.patch
index 6b2a498b..89d850bf 100644
--- a/nms-patches/BlockStem.patch
+++ b/nms-patches/BlockStem.patch
@@ -12,7 +12,7 @@
@@ -33,14 +35,18 @@
if (i < 7) {
- iblockdata = (IBlockData) iblockdata.set(BlockStem.AGE, Integer.valueOf(i + 1));
+ iblockdata = (IBlockData) iblockdata.set(BlockStem.AGE, i + 1);
- world.setTypeAndData(blockposition, iblockdata, 2);
+ CraftEventFactory.handleBlockGrowEvent(world, blockposition, iblockdata, 2); // CraftBukkit
} else {
@@ -31,8 +31,8 @@
}
}
@@ -94,7 +100,7 @@
- int i = Math.min(7, ((Integer) iblockdata.get(BlockStem.AGE)).intValue() + MathHelper.nextInt(world.random, 2, 5));
- IBlockData iblockdata1 = (IBlockData) iblockdata.set(BlockStem.AGE, Integer.valueOf(i));
+ int i = Math.min(7, (Integer) iblockdata.get(BlockStem.AGE) + MathHelper.nextInt(world.random, 2, 5));
+ IBlockData iblockdata1 = (IBlockData) iblockdata.set(BlockStem.AGE, i);
- world.setTypeAndData(blockposition, iblockdata1, 2);
+ CraftEventFactory.handleBlockGrowEvent(world, blockposition, iblockdata1, 2); // CraftBukkit
diff --git a/nms-patches/BlockTrapdoor.patch b/nms-patches/BlockTrapdoor.patch
index c809229b..7625283d 100644
--- a/nms-patches/BlockTrapdoor.patch
+++ b/nms-patches/BlockTrapdoor.patch
@@ -8,10 +8,10 @@
public class BlockTrapdoor extends BlockFacingHorizontal implements IFluidSource, IFluidContainer {
-@@ -94,6 +95,19 @@
+@@ -88,6 +89,19 @@
boolean flag = world.isBlockIndirectlyPowered(blockposition);
- if (flag != ((Boolean) iblockdata.get(BlockTrapdoor.c)).booleanValue()) {
+ if (flag != (Boolean) iblockdata.get(BlockTrapdoor.c)) {
+ // CraftBukkit start
+ org.bukkit.World bworld = world.getWorld();
+ org.bukkit.block.Block bblock = bworld.getBlockAt(blockposition.getX(), blockposition.getY(), blockposition.getZ());
@@ -25,6 +25,6 @@
+ flag = eventRedstone.getNewCurrent() > 0;
+ }
+ // CraftBukkit end
- if (((Boolean) iblockdata.get(BlockTrapdoor.OPEN)).booleanValue() != flag) {
- iblockdata = (IBlockData) iblockdata.set(BlockTrapdoor.OPEN, Boolean.valueOf(flag));
+ if ((Boolean) iblockdata.get(BlockTrapdoor.OPEN) != flag) {
+ iblockdata = (IBlockData) iblockdata.set(BlockTrapdoor.OPEN, flag);
this.a((EntityHuman) null, world, blockposition, flag);
diff --git a/nms-patches/BlockTripwire.patch b/nms-patches/BlockTripwire.patch
index 598b9c1b..9b2c04bd 100644
--- a/nms-patches/BlockTripwire.patch
+++ b/nms-patches/BlockTripwire.patch
@@ -48,5 +48,5 @@
+ // CraftBukkit end
+
if (flag1 != flag) {
- iblockdata = (IBlockData) iblockdata.set(BlockTripwire.POWERED, Boolean.valueOf(flag1));
+ iblockdata = (IBlockData) iblockdata.set(BlockTripwire.POWERED, flag1);
world.setTypeAndData(blockposition, iblockdata, 3);
diff --git a/nms-patches/BlockTripwireHook.patch b/nms-patches/BlockTripwireHook.patch
index dcc5409e..2495fbbb 100644
--- a/nms-patches/BlockTripwireHook.patch
+++ b/nms-patches/BlockTripwireHook.patch
@@ -9,7 +9,7 @@
public class BlockTripwireHook extends Block {
public static final BlockStateDirection FACING = BlockFacingHorizontal.FACING;
-@@ -137,6 +139,17 @@
+@@ -134,6 +136,17 @@
this.a(world, blockposition1, flag4, flag5, flag2, flag3);
}
diff --git a/nms-patches/BlockVine.patch b/nms-patches/BlockVine.patch
index f309579c..c563ec8f 100644
--- a/nms-patches/BlockVine.patch
+++ b/nms-patches/BlockVine.patch
@@ -17,28 +17,28 @@
+ BlockPosition source = blockposition;
+
if (flag && this.b((IBlockAccess) world, blockposition3, enumdirection1)) {
-- world.setTypeAndData(blockposition2, (IBlockData) this.getBlockData().set(getDirection(enumdirection1), Boolean.valueOf(true)), 2);
-+ CraftEventFactory.handleBlockSpreadEvent(world, source, blockposition2, (IBlockData) this.getBlockData().set(getDirection(enumdirection1), Boolean.valueOf(true)), 2);
+- world.setTypeAndData(blockposition2, (IBlockData) this.getBlockData().set(getDirection(enumdirection1), true), 2);
++ CraftEventFactory.handleBlockSpreadEvent(world, source, blockposition2, (IBlockData) this.getBlockData().set(getDirection(enumdirection1), true), 2);
} else if (flag1 && this.b((IBlockAccess) world, blockposition4, enumdirection2)) {
-- world.setTypeAndData(blockposition2, (IBlockData) this.getBlockData().set(getDirection(enumdirection2), Boolean.valueOf(true)), 2);
-+ CraftEventFactory.handleBlockSpreadEvent(world, source, blockposition2, (IBlockData) this.getBlockData().set(getDirection(enumdirection2), Boolean.valueOf(true)), 2);
+- world.setTypeAndData(blockposition2, (IBlockData) this.getBlockData().set(getDirection(enumdirection2), true), 2);
++ CraftEventFactory.handleBlockSpreadEvent(world, source, blockposition2, (IBlockData) this.getBlockData().set(getDirection(enumdirection2), true), 2);
} else {
EnumDirection enumdirection3 = enumdirection.opposite();
if (flag && world.isEmpty(blockposition3) && this.b((IBlockAccess) world, blockposition.shift(enumdirection1), enumdirection3)) {
-- world.setTypeAndData(blockposition3, (IBlockData) this.getBlockData().set(getDirection(enumdirection3), Boolean.valueOf(true)), 2);
-+ CraftEventFactory.handleBlockSpreadEvent(world, source, blockposition3, (IBlockData) this.getBlockData().set(getDirection(enumdirection3), Boolean.valueOf(true)), 2);
+- world.setTypeAndData(blockposition3, (IBlockData) this.getBlockData().set(getDirection(enumdirection3), true), 2);
++ CraftEventFactory.handleBlockSpreadEvent(world, source, blockposition3, (IBlockData) this.getBlockData().set(getDirection(enumdirection3), true), 2);
} else if (flag1 && world.isEmpty(blockposition4) && this.b((IBlockAccess) world, blockposition.shift(enumdirection2), enumdirection3)) {
-- world.setTypeAndData(blockposition4, (IBlockData) this.getBlockData().set(getDirection(enumdirection3), Boolean.valueOf(true)), 2);
-+ CraftEventFactory.handleBlockSpreadEvent(world, source, blockposition4, (IBlockData) this.getBlockData().set(getDirection(enumdirection3), Boolean.valueOf(true)), 2);
+- world.setTypeAndData(blockposition4, (IBlockData) this.getBlockData().set(getDirection(enumdirection3), true), 2);
++ CraftEventFactory.handleBlockSpreadEvent(world, source, blockposition4, (IBlockData) this.getBlockData().set(getDirection(enumdirection3), true), 2);
} else if ((double) world.random.nextFloat() < 0.05D && this.b((IBlockAccess) world, blockposition2.up(), EnumDirection.UP)) {
-- world.setTypeAndData(blockposition2, (IBlockData) this.getBlockData().set(BlockVine.UP, Boolean.valueOf(true)), 2);
-+ CraftEventFactory.handleBlockSpreadEvent(world, source, blockposition2, (IBlockData) this.getBlockData().set(BlockVine.UP, Boolean.valueOf(true)), 2);
+- world.setTypeAndData(blockposition2, (IBlockData) this.getBlockData().set(BlockVine.UP, true), 2);
++ CraftEventFactory.handleBlockSpreadEvent(world, source, blockposition2, (IBlockData) this.getBlockData().set(BlockVine.UP, true), 2);
}
+ // CraftBukkit end
}
} else if (this.b((IBlockAccess) world, blockposition2, enumdirection)) {
- world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(getDirection(enumdirection), Boolean.valueOf(true)), 2);
+ world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(getDirection(enumdirection), true), 2);
@@ -226,7 +232,7 @@
}
diff --git a/nms-patches/Chunk.patch b/nms-patches/Chunk.patch
index 2fd6ed68..d87b2e2d 100644
--- a/nms-patches/Chunk.patch
+++ b/nms-patches/Chunk.patch
@@ -239,9 +239,9 @@
if (this.t instanceof ProtoChunkTickList) {
- ((ProtoChunkTickList) this.t).a(this.world.I(), (blockposition) -> {
-- return this.world.b(blockposition).c();
+- return this.world.getFluid(blockposition).c();
+ ((ProtoChunkTickList<FluidType>) this.t).a(this.world.I(), (blockposition1) -> { // CraftBukkit - decompile error
-+ return this.world.b(blockposition1).c();
++ return this.world.getFluid(blockposition1).c();
});
}
diff --git a/nms-patches/ChunkProviderServer.patch b/nms-patches/ChunkProviderServer.patch
index 48ee4e8d..1a02616c 100644
--- a/nms-patches/ChunkProviderServer.patch
+++ b/nms-patches/ChunkProviderServer.patch
@@ -34,7 +34,7 @@
+ this.chunks.put(ChunkCoordIntPair.a(i, j), chunk1);
});
} catch (Exception exception) {
- ChunkProviderServer.a.error("Couldn\'t load chunk", exception);
+ ChunkProviderServer.a.error("Couldn't load chunk", exception);
@@ -103,7 +109,7 @@
try {
this.batchScheduler.b();
diff --git a/nms-patches/ChunkRegionLoader.patch b/nms-patches/ChunkRegionLoader.patch
index bff72d18..352c4680 100644
--- a/nms-patches/ChunkRegionLoader.patch
+++ b/nms-patches/ChunkRegionLoader.patch
@@ -131,7 +131,7 @@
ChunkStatus.Type chunkstatus_type = this.a(nbttagcompound);
@@ -151,10 +209,28 @@
- ChunkRegionLoader.a.error("Chunk file at {},{} is in the wrong location; relocating. (Expected {}, {}, got {}, {})", Integer.valueOf(i), Integer.valueOf(j), Integer.valueOf(i), Integer.valueOf(j), Integer.valueOf(chunk.locX), Integer.valueOf(chunk.locZ));
+ ChunkRegionLoader.a.error("Chunk file at {},{} is in the wrong location; relocating. (Expected {}, {}, got {}, {})", i, j, i, j, chunk.locX, chunk.locZ);
nbttagcompound1.setInt("xPos", i);
nbttagcompound1.setInt("zPos", j);
+
diff --git a/nms-patches/CommandDispatcher.patch b/nms-patches/CommandDispatcher.patch
index 2d4a01d3..dde0a788 100644
--- a/nms-patches/CommandDispatcher.patch
+++ b/nms-patches/CommandDispatcher.patch
@@ -85,7 +85,7 @@
+ // CraftBukkit end
StringReader stringreader = new StringReader(s);
- if (stringreader.canRead() && stringreader.peek() == 47) {
+ if(stringreader.canRead() && stringreader.peek() == 47) {
@@ -128,7 +182,6 @@
byte b0;
@@ -104,22 +104,22 @@
+ return b0;
} catch (CommandSyntaxException commandsyntaxexception) {
commandlistenerwrapper.sendFailureMessage(ChatComponentUtils.a(commandsyntaxexception.getRawMessage()));
- if (commandsyntaxexception.getInput() != null && commandsyntaxexception.getCursor() >= 0) {
+ if(commandsyntaxexception.getInput() != null && commandsyntaxexception.getCursor() >= 0) {
int j = Math.min(commandsyntaxexception.getInput().length(), commandsyntaxexception.getCursor());
- IChatBaseComponent ichatbasecomponent = (new ChatComponentText("")).a(EnumChatFormat.GRAY).a((chatmodifier) -> {
- chatmodifier.setChatClickable(new ChatClickable(ChatClickable.EnumClickAction.SUGGEST_COMMAND, s));
- });
+ chatcomponenttext = new ChatComponentText("");
- if (j > 10) {
+ if(j > 10) {
- ichatbasecomponent.a("...");
+ chatcomponenttext.a("...");
}
- ichatbasecomponent.a(commandsyntaxexception.getInput().substring(Math.max(0, j - 10), j));
+ chatcomponenttext.a(commandsyntaxexception.getInput().substring(Math.max(0, j - 10), j));
- if (j < commandsyntaxexception.getInput().length()) {
-- IChatBaseComponent ichatbasecomponent1 = (new ChatComponentText(commandsyntaxexception.getInput().substring(j))).a(new EnumChatFormat[] { EnumChatFormat.RED, EnumChatFormat.UNDERLINE});
+ if(j < commandsyntaxexception.getInput().length()) {
+- IChatBaseComponent ichatbasecomponent1 = (new ChatComponentText(commandsyntaxexception.getInput().substring(j))).a(new EnumChatFormat[]{EnumChatFormat.RED, EnumChatFormat.UNDERLINE});
+ ChatComponentText chatcomponenttext1 = new ChatComponentText(commandsyntaxexception.getInput().substring(j));
- ichatbasecomponent.addSibling(ichatbasecomponent1);
@@ -128,7 +128,7 @@
+ chatcomponenttext.addSibling(chatcomponenttext1);
}
-- ichatbasecomponent.addSibling((new ChatMessage("command.context.here", new Object[0])).a(new EnumChatFormat[] { EnumChatFormat.RED, EnumChatFormat.ITALIC}));
+- ichatbasecomponent.addSibling((new ChatMessage("command.context.here", new Object[0])).a(new EnumChatFormat[]{EnumChatFormat.RED, EnumChatFormat.ITALIC}));
- commandlistenerwrapper.sendFailureMessage(ichatbasecomponent);
+ ChatMessage chatmessage = new ChatMessage("command.context.here", new Object[0]);
+
@@ -147,17 +147,17 @@
- chatcomponenttext = new ChatComponentText;
- }
-
-- chatcomponenttext.<init>(exception.getMessage() == null ? exception.getClass().getName() : exception.getMessage());
+- chatcomponenttext.<init>(exception.getMessage() == null?exception.getClass().getName():exception.getMessage());
- ChatComponentText chatcomponenttext1 = chatcomponenttext;
+ ChatMessage chatmessage1 = new ChatMessage("command.failed", new Object[0]);
-- if (CommandDispatcher.a.isDebugEnabled()) {
+- if(CommandDispatcher.a.isDebugEnabled()) {
- StackTraceElement[] astacktraceelement = exception.getStackTrace();
+ chatcomponenttext = new ChatComponentText(exception.getMessage() == null ? exception.getClass().getName() : exception.getMessage());
+ if (CommandDispatcher.a.isDebugEnabled()) {
+ StackTraceElement[] astacktraceelement = exception.getStackTrace();
-- for (int k = 0; k < Math.min(astacktraceelement.length, 3); ++k) {
+- for(int k = 0; k < Math.min(astacktraceelement.length, 3); ++k) {
- chatcomponenttext1.a("\n\n").a(astacktraceelement[k].getMethodName()).a("\n ").a(astacktraceelement[k].getFileName()).a(":").a(String.valueOf(astacktraceelement[k].getLineNumber()));
+ for (int k = 0; k < Math.min(astacktraceelement.length, 3); ++k) {
+ chatcomponenttext.a("\n\n" + astacktraceelement[k].getMethodName() + "\n " + astacktraceelement[k].getFileName() + ":" + astacktraceelement[k].getLineNumber());
diff --git a/nms-patches/CommandForceload.patch b/nms-patches/CommandForceload.patch
index 98f73811..42e58521 100644
--- a/nms-patches/CommandForceload.patch
+++ b/nms-patches/CommandForceload.patch
@@ -36,7 +36,7 @@
return 0;
@@ -106,7 +106,7 @@
if (i2 > 256L) {
- throw CommandForceload.a.create(Integer.valueOf(256), Long.valueOf(i2));
+ throw CommandForceload.a.create(256, i2);
} else {
- DimensionManager dimensionmanager = commandlistenerwrapper.getWorld().o().getDimensionManager();
+ DimensionManager dimensionmanager = commandlistenerwrapper.getWorld().dimension; // CraftBukkit
diff --git a/nms-patches/Container.patch b/nms-patches/Container.patch
index ef86d902..ae9b1e78 100644
--- a/nms-patches/Container.patch
+++ b/nms-patches/Container.patch
@@ -38,7 +38,7 @@
protected Slot a(Slot slot) {
@@ -128,6 +151,7 @@
- l = playerinventory.getCarried().getCount();
+ k = playerinventory.getCarried().getCount();
Iterator iterator = this.h.iterator();
+ Map<Integer, ItemStack> draggedSlots = new HashMap<Integer, ItemStack>(); // CraftBukkit - Store slots from drag in map (raw slot id -> new stack)
@@ -48,19 +48,19 @@
@@ -143,12 +167,48 @@
}
- l -= itemstack4.getCount() - j1;
+ k -= itemstack4.getCount() - j1;
- slot1.set(itemstack4);
+ // slot1.set(itemstack4);
+ draggedSlots.put(slot1.rawSlotIndex, itemstack4); // CraftBukkit - Put in map instead of setting
}
}
-- itemstack2.setCount(l);
+- itemstack2.setCount(k);
- playerinventory.setCarried(itemstack2);
+ // CraftBukkit start - InventoryDragEvent
+ InventoryView view = getBukkitView();
+ org.bukkit.inventory.ItemStack newcursor = CraftItemStack.asCraftMirror(itemstack2);
-+ newcursor.setAmount(l);
++ newcursor.setAmount(k);
+ Map<Integer, org.bukkit.inventory.ItemStack> eventmap = new HashMap<Integer, org.bukkit.inventory.ItemStack>();
+ for (Map.Entry<Integer, ItemStack> ditem : draggedSlots.entrySet()) {
+ eventmap.put(ditem.getKey(), CraftItemStack.asBukkitCopy(ditem.getValue()));
@@ -126,7 +126,7 @@
}
}
} else if (inventoryclicktype == InventoryClickType.SWAP && j >= 0 && j < 9) {
-@@ -567,6 +639,7 @@
+@@ -565,6 +637,7 @@
if (inventorycraftresult.a(world, entityplayer, irecipe) && irecipe != null) {
itemstack = irecipe.craftItem(iinventory);
}
diff --git a/nms-patches/ContainerAnvil.patch b/nms-patches/ContainerAnvil.patch
index c5787ca8..890b2c47 100644
--- a/nms-patches/ContainerAnvil.patch
+++ b/nms-patches/ContainerAnvil.patch
@@ -46,7 +46,7 @@
return;
}
@@ -144,7 +155,7 @@
- this.k = l;
+ this.k = i1;
} else {
if (!flag && (itemstack1.getItem() != itemstack2.getItem() || !itemstack1.e())) {
- this.g.setItem(0, ItemStack.a);
@@ -54,7 +54,7 @@
this.levelCost = 0;
return;
}
-@@ -237,7 +248,7 @@
+@@ -234,7 +245,7 @@
}
if (flag2 && !flag1) {
@@ -63,7 +63,7 @@
this.levelCost = 0;
return;
}
-@@ -261,11 +272,11 @@
+@@ -258,11 +269,11 @@
itemstack1 = ItemStack.a;
}
@@ -78,7 +78,7 @@
itemstack1 = ItemStack.a;
}
-@@ -284,7 +295,7 @@
+@@ -281,7 +292,7 @@
EnchantmentManager.a(map, itemstack1);
}
@@ -87,7 +87,7 @@
this.b();
}
}
-@@ -302,6 +313,7 @@
+@@ -299,6 +310,7 @@
}
public boolean canUse(EntityHuman entityhuman) {
@@ -95,7 +95,7 @@
return !this.i.getType(this.j).a(TagsBlock.ANVIL) ? false : entityhuman.d((double) this.j.getX() + 0.5D, (double) this.j.getY() + 0.5D, (double) this.j.getZ() + 0.5D) <= 64.0D;
}
-@@ -357,4 +369,33 @@
+@@ -354,4 +366,33 @@
this.d();
}
diff --git a/nms-patches/CrashReport.patch b/nms-patches/CrashReport.patch
index 7e9cb276..65a7265d 100644
--- a/nms-patches/CrashReport.patch
+++ b/nms-patches/CrashReport.patch
@@ -2,7 +2,7 @@
+++ b/net/minecraft/server/CrashReport.java
@@ -63,6 +63,7 @@
- return String.format("%d total; %s", new Object[] { Integer.valueOf(list.size()), list.stream().collect(Collectors.joining(" "))});
+ return String.format("%d total; %s", new Object[] { list.size(), list.stream().collect(Collectors.joining(" "))});
});
+ this.d.a("CraftBukkit Information", (CrashReportCallable) new org.bukkit.craftbukkit.CraftCrashReport()); // CraftBukkit
}
diff --git a/nms-patches/DataConverterRegistry.patch b/nms-patches/DataConverterRegistry.patch
index c09a8ab1..b20d22e5 100644
--- a/nms-patches/DataConverterRegistry.patch
+++ b/nms-patches/DataConverterRegistry.patch
@@ -22,7 +22,7 @@
+ datafixerbuilder.addFixer(new com.mojang.datafixers.DataFix(schema47, false) {
+ @Override
+ protected com.mojang.datafixers.TypeRewriteRule makeRule() {
-+ return this.fixTypeEverywhereTyped("Player CustomName", this.getInputSchema().getType(DataConverterTypes.b), (typed) -> {
++ return this.fixTypeEverywhereTyped("Player CustomName", this.getInputSchema().getType(DataConverterTypes.PLAYER), (typed) -> {
+ return typed.update(DSL.remainderFinder(), (dynamic) -> {
+ return DataConverterCustomNameEntity.a(dynamic);
+ });
diff --git a/nms-patches/DispenserRegistry.patch b/nms-patches/DispenserRegistry.patch
index bba3fef2..55a8defc 100644
--- a/nms-patches/DispenserRegistry.patch
+++ b/nms-patches/DispenserRegistry.patch
@@ -426,7 +426,7 @@
+
this.a = true;
if (world.isEmpty(blockposition) && BlockWitherSkull.b(world, blockposition, itemstack)) {
- world.setTypeAndData(blockposition, (IBlockData) Blocks.WITHER_SKELETON_SKULL.getBlockData().set(BlockSkull.a, Integer.valueOf(enumdirection.k() == EnumDirection.EnumAxis.Y ? 0 : enumdirection.opposite().get2DRotationValue() * 4)), 3);
+ world.setTypeAndData(blockposition, (IBlockData) Blocks.WITHER_SKELETON_SKULL.getBlockData().set(BlockSkull.a, enumdirection.k() == EnumDirection.EnumAxis.Y ? 0 : enumdirection.opposite().get2DRotationValue() * 4), 3);
@@ -318,6 +610,30 @@
BlockPosition blockposition = isourceblock.getBlockPosition().shift((EnumDirection) isourceblock.e().get(BlockDispenser.FACING));
BlockPumpkinCarved blockpumpkincarved = (BlockPumpkinCarved) Blocks.CARVED_PUMPKIN;
@@ -518,8 +518,8 @@
+ String s1 = (String) function.apply(object); // CraftBukkit - decompile error
if (!localelanguage.b(s)) {
- DispenserRegistry.c.warn("Missing translation for {}: {} (key: \'{}\')", s1, iregistry.getKey(object), s);
-@@ -487,6 +848,30 @@
+ DispenserRegistry.c.warn("Missing translation for {}: {} (key: '{}')", s1, iregistry.getKey(object), s);
+@@ -482,6 +843,30 @@
BlockPosition blockposition = isourceblock.getBlockPosition().shift(enumdirection);
EnumDirection enumdirection1 = isourceblock.getWorld().isEmpty(blockposition.down()) ? enumdirection : EnumDirection.UP;
@@ -550,7 +550,7 @@
this.a = ((ItemBlock) item).a((BlockActionContext) (new DispenserRegistry.b(isourceblock.getWorld(), blockposition, enumdirection, itemstack, enumdirection1))) == EnumInteractionResult.SUCCESS;
if (this.a) {
itemstack.subtract(1);
-@@ -540,12 +925,40 @@
+@@ -535,12 +920,40 @@
d3 = 0.0D;
}
diff --git a/nms-patches/DragonControllerManager.patch b/nms-patches/DragonControllerManager.patch
index d637a25d..45c6e6d3 100644
--- a/nms-patches/DragonControllerManager.patch
+++ b/nms-patches/DragonControllerManager.patch
@@ -30,7 +30,7 @@
+
this.currentDragonController = this.b(dragoncontrollerphase);
if (!this.enderDragon.world.isClientSide) {
- this.enderDragon.getDataWatcher().set(EntityEnderDragon.PHASE, Integer.valueOf(dragoncontrollerphase.b()));
+ this.enderDragon.getDataWatcher().set(EntityEnderDragon.PHASE, dragoncontrollerphase.b());
@@ -42,6 +59,6 @@
this.dragonControllers[i] = dragoncontrollerphase.a(this.enderDragon);
}
diff --git a/nms-patches/EnchantmentFrostWalker.patch b/nms-patches/EnchantmentFrostWalker.patch
index 8b86af35..5b87723d 100644
--- a/nms-patches/EnchantmentFrostWalker.patch
+++ b/nms-patches/EnchantmentFrostWalker.patch
@@ -1,18 +1,20 @@
--- a/net/minecraft/server/EnchantmentFrostWalker.java
+++ b/net/minecraft/server/EnchantmentFrostWalker.java
-@@ -1,5 +1,8 @@
+@@ -1,6 +1,10 @@
package net.minecraft.server;
+ import java.util.Iterator;
++// CraftBukkit start
+import org.bukkit.craftbukkit.util.CraftMagicNumbers;
+import org.bukkit.event.block.EntityBlockFormEvent;
-+
- import java.util.Iterator;
++// CraftBukkit end
public class EnchantmentFrostWalker extends Enchantment {
-@@ -42,8 +45,11 @@
+
+@@ -42,8 +46,11 @@
IBlockData iblockdata2 = world.getType(blockposition_mutableblockposition1);
- if (iblockdata2.getMaterial() == Material.WATER && ((Integer) iblockdata2.get(BlockFluids.LEVEL)).intValue() == 0 && iblockdata.canPlace(world, blockposition_mutableblockposition1) && world.a(iblockdata, (BlockPosition) blockposition_mutableblockposition1)) {
+ if (iblockdata2.getMaterial() == Material.WATER && (Integer) iblockdata2.get(BlockFluids.LEVEL) == 0 && iblockdata.canPlace(world, blockposition_mutableblockposition1) && world.a(iblockdata, (BlockPosition) blockposition_mutableblockposition1)) {
- world.setTypeUpdate(blockposition_mutableblockposition1, iblockdata);
- world.J().a(blockposition_mutableblockposition1.h(), Blocks.FROSTED_ICE, MathHelper.nextInt(entityliving.getRandom(), 60, 120));
+ // CraftBukkit Start - Call EntityBlockFormEvent for Frost Walker
diff --git a/nms-patches/EnderDragonBattle.patch b/nms-patches/EnderDragonBattle.patch
deleted file mode 100644
index e5d6df48..00000000
--- a/nms-patches/EnderDragonBattle.patch
+++ /dev/null
@@ -1,11 +0,0 @@
---- a/net/minecraft/server/EnderDragonBattle.java
-+++ b/net/minecraft/server/EnderDragonBattle.java
-@@ -21,7 +21,7 @@
-
- private static final Logger a = LogManager.getLogger();
- private static final Predicate<Entity> b = IEntitySelector.a.and(IEntitySelector.a(0.0D, 128.0D, 0.0D, 192.0D));
-- private final BossBattleServer c;
-+ public final BossBattleServer c; // PAIL private -> public, rename bossBattleServer
- private final WorldServer d;
- private final List<Integer> e;
- private final ShapeDetector f;
diff --git a/nms-patches/Entity.patch b/nms-patches/Entity.patch
index f73dae4b..ab58cf20 100644
--- a/nms-patches/Entity.patch
+++ b/nms-patches/Entity.patch
@@ -322,8 +322,8 @@
return true;
@@ -1319,6 +1506,18 @@
try {
- nbttagcompound.set("Pos", this.a(new double[] { this.locX, this.locY, this.locZ}));
- nbttagcompound.set("Motion", this.a(new double[] { this.motX, this.motY, this.motZ}));
+ nbttagcompound.set("Pos", this.a(this.locX, this.locY, this.locZ));
+ nbttagcompound.set("Motion", this.a(this.motX, this.motY, this.motZ));
+
+ // CraftBukkit start - Checking for NaN pitch/yaw and resetting to zero
+ // TODO: make sure this is the best way to address this.
@@ -336,7 +336,7 @@
+ }
+ // CraftBukkit end
+
- nbttagcompound.set("Rotation", this.a(new float[] { this.yaw, this.pitch}));
+ nbttagcompound.set("Rotation", this.a(this.yaw, this.pitch));
nbttagcompound.setFloat("FallDistance", this.fallDistance);
nbttagcompound.setShort("Fire", (short) this.fireTicks);
@@ -1328,6 +1527,12 @@
@@ -547,14 +547,14 @@
}
public void setAirTicks(int i) {
-- this.datawatcher.set(Entity.aD, Integer.valueOf(i));
+- this.datawatcher.set(Entity.aD, i);
+ // CraftBukkit start
+ EntityAirChangeEvent event = new EntityAirChangeEvent(this.getBukkitEntity(), i);
+ event.getEntity().getServer().getPluginManager().callEvent(event);
+ if (event.isCancelled()) {
+ return;
+ }
-+ this.datawatcher.set(Entity.aD, Integer.valueOf(event.getAmount()));
++ this.datawatcher.set(Entity.aD, event.getAmount());
+ // CraftBukkit end
}
diff --git a/nms-patches/EntityAreaEffectCloud.patch b/nms-patches/EntityAreaEffectCloud.patch
index a3cc245e..d4ecf157 100644
--- a/nms-patches/EntityAreaEffectCloud.patch
+++ b/nms-patches/EntityAreaEffectCloud.patch
@@ -32,7 +32,7 @@
+ // CraftBukkit end
+
public int getColor() {
- return ((Integer) this.getDataWatcher().get(EntityAreaEffectCloud.c)).intValue();
+ return (Integer) this.getDataWatcher().get(EntityAreaEffectCloud.c);
}
@@ -245,6 +265,7 @@
if (!list.isEmpty()) {
@@ -57,7 +57,7 @@
+ if (entity instanceof CraftLivingEntity) {
+ EntityLiving entityliving = ((CraftLivingEntity) entity).getHandle();
+ // CraftBukkit end
- this.h.put(entityliving, Integer.valueOf(this.ticksLived + this.reapplicationDelay));
+ this.h.put(entityliving, this.ticksLived + this.reapplicationDelay);
Iterator iterator3 = arraylist.iterator();
@@ -263,7 +295,7 @@
diff --git a/nms-patches/EntityArmorStand.patch b/nms-patches/EntityArmorStand.patch
index 12b02bfb..e94f1ec9 100644
--- a/nms-patches/EntityArmorStand.patch
+++ b/nms-patches/EntityArmorStand.patch
@@ -30,7 +30,7 @@
public final void setSize(float f, float f1) {
double d0 = this.locX;
double d1 = this.locY;
-@@ -357,6 +373,21 @@
+@@ -354,6 +370,21 @@
if (itemstack1.isEmpty() || (this.bH & 1 << enumitemslot.c() + 8) == 0) {
if (!itemstack1.isEmpty() || (this.bH & 1 << enumitemslot.c() + 16) == 0) {
ItemStack itemstack2;
@@ -52,7 +52,7 @@
if (entityhuman.abilities.canInstantlyBuild && itemstack1.isEmpty() && !itemstack.isEmpty()) {
itemstack2 = itemstack.cloneItemStack();
-@@ -378,14 +409,19 @@
+@@ -375,14 +406,19 @@
}
public boolean damageEntity(DamageSource damagesource, float f) {
@@ -74,7 +74,7 @@
return false;
} else if (DamageSource.FIRE.equals(damagesource)) {
if (this.isBurning()) {
-@@ -409,7 +445,7 @@
+@@ -406,7 +442,7 @@
} else if (damagesource.v()) {
this.F();
this.A();
@@ -83,7 +83,7 @@
return false;
} else {
long i = this.world.getTime();
-@@ -420,7 +456,7 @@
+@@ -417,7 +453,7 @@
} else {
this.B();
this.A();
@@ -92,7 +92,7 @@
}
return true;
-@@ -447,7 +483,7 @@
+@@ -444,7 +480,7 @@
f1 -= f;
if (f1 <= 0.5F) {
this.D();
@@ -101,7 +101,7 @@
} else {
this.setHealth(f1);
}
-@@ -455,7 +491,7 @@
+@@ -452,7 +488,7 @@
}
private void B() {
@@ -110,7 +110,7 @@
this.D();
}
-@@ -468,7 +504,7 @@
+@@ -465,7 +501,7 @@
for (i = 0; i < this.bE.size(); ++i) {
itemstack = (ItemStack) this.bE.get(i);
if (!itemstack.isEmpty()) {
@@ -119,7 +119,7 @@
this.bE.set(i, ItemStack.a);
}
}
-@@ -476,7 +512,7 @@
+@@ -473,7 +509,7 @@
for (i = 0; i < this.bF.size(); ++i) {
itemstack = (ItemStack) this.bF.get(i);
if (!itemstack.isEmpty()) {
@@ -128,7 +128,7 @@
this.bF.set(i, ItemStack.a);
}
}
-@@ -588,6 +624,7 @@
+@@ -585,6 +621,7 @@
}
public void killEntity() {
diff --git a/nms-patches/EntityBoat.patch b/nms-patches/EntityBoat.patch
index 57e18afe..8f6ab3b4 100644
--- a/nms-patches/EntityBoat.patch
+++ b/nms-patches/EntityBoat.patch
@@ -93,7 +93,7 @@
super.collide(entity);
}
-@@ -173,6 +228,7 @@
+@@ -168,6 +223,7 @@
return this.getDirection().e();
}
@@ -101,7 +101,7 @@
public void tick() {
this.aM = this.aL;
this.aL = this.s();
-@@ -217,6 +273,22 @@
+@@ -212,6 +268,22 @@
this.motZ = 0.0D;
}
@@ -124,7 +124,7 @@
this.q();
for (int i = 0; i <= 1; ++i) {
-@@ -737,6 +809,11 @@
+@@ -730,6 +802,11 @@
this.c(this.fallDistance, 1.0F);
if (!this.world.isClientSide && !this.dead) {
@@ -136,7 +136,7 @@
this.die();
if (this.world.getGameRules().getBoolean("doEntityDrops")) {
int i;
-@@ -750,6 +827,7 @@
+@@ -743,6 +820,7 @@
}
}
}
diff --git a/nms-patches/EntityCreeper.patch b/nms-patches/EntityCreeper.patch
index 4a0912c6..855f9b89 100644
--- a/nms-patches/EntityCreeper.patch
+++ b/nms-patches/EntityCreeper.patch
@@ -32,7 +32,7 @@
public void onLightningStrike(EntityLightning entitylightning) {
super.onLightningStrike(entitylightning);
-- this.datawatcher.set(EntityCreeper.b, Boolean.valueOf(true));
+- this.datawatcher.set(EntityCreeper.b, true);
+ // CraftBukkit start
+ if (CraftEventFactory.callCreeperPowerEvent(this, entitylightning, org.bukkit.event.entity.CreeperPowerEvent.PowerCause.LIGHTNING).isCancelled()) {
+ return;
diff --git a/nms-patches/EntityEnderman.patch b/nms-patches/EntityEnderman.patch
index 2aec00aa..f39be4b0 100644
--- a/nms-patches/EntityEnderman.patch
+++ b/nms-patches/EntityEnderman.patch
@@ -44,7 +44,7 @@
}
@@ -277,8 +295,12 @@
- boolean flag = movingobjectposition != null && movingobjectposition.a().equals(blockposition);
+ boolean flag = movingobjectposition != null && movingobjectposition.getBlockPosition().equals(blockposition);
if (block.a(TagsBlock.ENDERMAN_HOLDABLE) && flag) {
- this.enderman.setCarried(iblockdata);
diff --git a/nms-patches/EntityFish.patch b/nms-patches/EntityFish.patch
index 5aeed7d6..303b99e0 100644
--- a/nms-patches/EntityFish.patch
+++ b/nms-patches/EntityFish.patch
@@ -12,7 +12,7 @@
@@ -47,6 +47,7 @@
public void setFromBucket(boolean flag) {
- this.datawatcher.set(EntityFish.a, Boolean.valueOf(flag));
+ this.datawatcher.set(EntityFish.a, flag);
+ this.persistent = this.isPersistent(); // CraftBukkit - SPIGOT-4106 update persistence
}
diff --git a/nms-patches/EntityHuman.patch b/nms-patches/EntityHuman.patch
index d633c8aa..06172c79 100644
--- a/nms-patches/EntityHuman.patch
+++ b/nms-patches/EntityHuman.patch
@@ -117,7 +117,7 @@
ItemStack itemstack1 = this.a(entityitem);
if (flag1) {
-@@ -655,6 +704,13 @@
+@@ -652,6 +701,13 @@
this.a(true, true, false);
}
@@ -131,7 +131,7 @@
if (nbttagcompound.hasKeyOfType("SpawnX", 99) && nbttagcompound.hasKeyOfType("SpawnY", 99) && nbttagcompound.hasKeyOfType("SpawnZ", 99)) {
this.e = new BlockPosition(nbttagcompound.getInt("SpawnX"), nbttagcompound.getInt("SpawnY"), nbttagcompound.getInt("SpawnZ"));
this.f = nbttagcompound.getBoolean("SpawnForced");
-@@ -705,6 +761,7 @@
+@@ -702,6 +758,7 @@
if (!this.getShoulderEntityRight().isEmpty()) {
nbttagcompound.set("ShoulderEntityRight", this.getShoulderEntityRight());
}
@@ -139,7 +139,7 @@
}
-@@ -722,10 +779,10 @@
+@@ -719,10 +776,10 @@
this.a(true, true, false);
}
@@ -152,7 +152,7 @@
}
if (this.world.getDifficulty() == EnumDifficulty.EASY) {
-@@ -737,7 +794,13 @@
+@@ -734,7 +791,13 @@
}
}
@@ -167,7 +167,7 @@
}
}
}
-@@ -751,10 +814,29 @@
+@@ -748,10 +811,29 @@
}
public boolean a(EntityHuman entityhuman) {
@@ -200,7 +200,7 @@
}
protected void damageArmor(float f) {
-@@ -797,7 +879,12 @@
+@@ -794,7 +876,12 @@
return (float) i / (float) this.inventory.armor.size();
}
@@ -214,7 +214,7 @@
if (!this.isInvulnerable(damagesource)) {
f = this.applyArmorModifier(damagesource, f);
f = this.applyMagicModifier(damagesource, f);
-@@ -823,6 +910,7 @@
+@@ -820,6 +907,7 @@
}
}
@@ -222,7 +222,7 @@
}
public void openSign(TileEntitySign tileentitysign) {}
-@@ -944,8 +1032,15 @@
+@@ -941,8 +1029,15 @@
if (entity instanceof EntityLiving) {
f3 = ((EntityLiving) entity).getHealth();
if (j > 0 && !entity.isBurning()) {
@@ -240,7 +240,7 @@
}
}
-@@ -976,8 +1071,11 @@
+@@ -973,8 +1068,11 @@
EntityLiving entityliving = (EntityLiving) iterator.next();
if (entityliving != this && entityliving != entity && !this.r(entityliving) && (!(entityliving instanceof EntityArmorStand) || !((EntityArmorStand) entityliving).isMarker()) && this.h(entityliving) < 9.0D) {
@@ -253,7 +253,7 @@
}
}
-@@ -986,11 +1084,28 @@
+@@ -983,11 +1081,28 @@
}
if (entity instanceof EntityPlayer && entity.velocityChanged) {
@@ -282,7 +282,7 @@
}
if (flag2) {
-@@ -1039,7 +1154,14 @@
+@@ -1036,7 +1151,14 @@
this.a(StatisticList.DAMAGE_DEALT, Math.round(f5 * 10.0F));
if (j > 0) {
@@ -298,7 +298,7 @@
}
if (this.world instanceof WorldServer && f5 > 2.0F) {
-@@ -1055,6 +1177,11 @@
+@@ -1052,6 +1174,11 @@
if (flag4) {
entity.extinguish();
}
@@ -310,7 +310,7 @@
}
}
-@@ -1116,15 +1243,15 @@
+@@ -1113,15 +1240,15 @@
return this.h;
}
@@ -330,7 +330,7 @@
return EntityHuman.EnumBedResult.NOT_POSSIBLE_HERE;
}
-@@ -1146,6 +1273,26 @@
+@@ -1143,6 +1270,26 @@
}
}
}
@@ -357,7 +357,7 @@
if (this.isPassenger()) {
this.stopRiding();
-@@ -1212,6 +1359,24 @@
+@@ -1209,6 +1356,24 @@
this.world.everyoneSleeping();
}
@@ -382,7 +382,7 @@
this.sleepTicks = flag ? 0 : 100;
if (flag2) {
this.setRespawnPosition(this.bedPosition, false);
-@@ -1263,9 +1428,11 @@
+@@ -1260,9 +1425,11 @@
if (blockposition != null) {
this.e = blockposition;
this.f = flag;
@@ -394,7 +394,7 @@
}
}
-@@ -1331,7 +1498,11 @@
+@@ -1328,7 +1495,11 @@
this.motY = d3 * 0.6D;
this.aU = f3;
this.fallDistance = 0.0F;
@@ -407,7 +407,7 @@
} else {
super.a(f, f1, f2);
}
-@@ -1631,13 +1802,17 @@
+@@ -1628,13 +1799,17 @@
}
protected void releaseShoulderEntities() {
@@ -430,7 +430,7 @@
if (!this.world.isClientSide && !nbttagcompound.isEmpty()) {
Entity entity = EntityTypes.a(nbttagcompound, this.world);
-@@ -1646,9 +1821,10 @@
+@@ -1643,9 +1818,10 @@
}
entity.setPosition(this.locX, this.locY + 0.699999988079071D, this.locZ);
@@ -442,7 +442,7 @@
}
public abstract boolean isSpectator();
-@@ -1859,7 +2035,7 @@
+@@ -1856,7 +2032,7 @@
return entitymonster.c(this.a);
}
diff --git a/nms-patches/EntityInsentient.patch b/nms-patches/EntityInsentient.patch
index ff3997b7..ab2f0d2f 100644
--- a/nms-patches/EntityInsentient.patch
+++ b/nms-patches/EntityInsentient.patch
@@ -135,7 +135,7 @@
}
this.setSlot(enumitemslot, itemstack);
-@@ -554,11 +624,11 @@
+@@ -553,11 +623,11 @@
double d2 = entityhuman.locZ - this.locZ;
double d3 = d0 * d0 + d1 * d1 + d2 * d2;
@@ -149,7 +149,7 @@
this.die();
} else if (d3 < 1024.0D) {
this.ticksFarFromPlayer = 0;
-@@ -942,12 +1012,24 @@
+@@ -931,12 +1001,24 @@
public final boolean b(EntityHuman entityhuman, EnumHand enumhand) {
if (this.isLeashed() && this.getLeashHolder() == entityhuman) {
@@ -174,7 +174,7 @@
this.setLeashHolder(entityhuman, true);
itemstack.subtract(1);
return true;
-@@ -968,10 +1050,12 @@
+@@ -957,10 +1039,12 @@
if (this.bK) {
if (!this.isAlive()) {
@@ -187,7 +187,7 @@
this.unleash(true, true);
}
}
-@@ -982,7 +1066,9 @@
+@@ -971,7 +1055,9 @@
this.bK = false;
this.leashHolder = null;
if (!this.world.isClientSide && flag1) {
@@ -197,7 +197,7 @@
}
if (!this.world.isClientSide && flag && this.world instanceof WorldServer) {
-@@ -1052,6 +1138,7 @@
+@@ -1041,6 +1127,7 @@
this.setLeashHolder(entityleash, true);
} else {
@@ -205,7 +205,7 @@
this.unleash(false, true);
}
}
-@@ -1147,7 +1234,14 @@
+@@ -1136,7 +1223,14 @@
int j = EnchantmentManager.getFireAspectEnchantmentLevel(this);
if (j > 0) {
diff --git a/nms-patches/EntityItemFrame.patch b/nms-patches/EntityItemFrame.patch
index f28cedd2..19d54451 100644
--- a/nms-patches/EntityItemFrame.patch
+++ b/nms-patches/EntityItemFrame.patch
@@ -1,6 +1,6 @@
--- a/net/minecraft/server/EntityItemFrame.java
+++ b/net/minecraft/server/EntityItemFrame.java
-@@ -97,6 +97,11 @@
+@@ -95,6 +95,11 @@
return false;
} else if (!damagesource.isExplosion() && !this.getItem().isEmpty()) {
if (!this.world.isClientSide) {
@@ -12,7 +12,7 @@
this.b(damagesource.getEntity(), false);
this.a(SoundEffects.ENTITY_ITEM_FRAME_REMOVE_ITEM, 1.0F, 1.0F);
}
-@@ -170,6 +175,12 @@
+@@ -168,6 +173,12 @@
}
public void setItem(ItemStack itemstack, boolean flag) {
@@ -25,7 +25,7 @@
if (!itemstack.isEmpty()) {
itemstack = itemstack.cloneItemStack();
itemstack.setCount(1);
-@@ -177,7 +188,7 @@
+@@ -175,7 +186,7 @@
}
this.getDataWatcher().set(EntityItemFrame.e, itemstack);
diff --git a/nms-patches/EntityLiving.patch b/nms-patches/EntityLiving.patch
index 81bd53e5..1fada008 100644
--- a/nms-patches/EntityLiving.patch
+++ b/nms-patches/EntityLiving.patch
@@ -203,7 +203,7 @@
if (this.updateEffects) {
if (!this.world.isClientSide) {
@@ -569,7 +672,13 @@
- this.datawatcher.set(EntityLiving.g, Integer.valueOf(0));
+ this.datawatcher.set(EntityLiving.g, 0);
}
+ // CraftBukkit start
@@ -352,7 +352,7 @@
+ return (float) ((EntityPlayer) this).getBukkitEntity().getHealth();
+ }
+ // CraftBukkit end
- return ((Float) this.datawatcher.get(EntityLiving.HEALTH)).floatValue();
+ return (Float) this.datawatcher.get(EntityLiving.HEALTH);
}
public void setHealth(float f) {
@@ -372,7 +372,7 @@
+ return;
+ }
+ // CraftBukkit end
- this.datawatcher.set(EntityLiving.HEALTH, Float.valueOf(MathHelper.a(f, 0.0F, this.getMaxHealth())));
+ this.datawatcher.set(EntityLiving.HEALTH, MathHelper.a(f, 0.0F, this.getMaxHealth()));
}
@@ -711,15 +911,17 @@
@@ -733,7 +733,7 @@
this.setFlag(7, false);
}
} else {
-@@ -1910,6 +2296,7 @@
+@@ -1907,6 +2293,7 @@
}
if (!this.world.isClientSide) {
@@ -741,7 +741,7 @@
this.setFlag(7, flag);
}
-@@ -2037,11 +2424,11 @@
+@@ -2034,11 +2421,11 @@
}
public boolean isInteractable() {
@@ -755,7 +755,7 @@
}
protected void aA() {
-@@ -2201,7 +2588,27 @@
+@@ -2198,7 +2585,27 @@
protected void q() {
if (!this.activeItem.isEmpty() && this.isHandRaised()) {
this.b(this.activeItem, 16);
@@ -784,7 +784,7 @@
this.da();
}
-@@ -2280,10 +2687,18 @@
+@@ -2277,10 +2684,18 @@
}
if (flag1) {
diff --git a/nms-patches/EntityMinecartAbstract.patch b/nms-patches/EntityMinecartAbstract.patch
index 3e1c0d16..0ddb6149 100644
--- a/nms-patches/EntityMinecartAbstract.patch
+++ b/nms-patches/EntityMinecartAbstract.patch
@@ -34,7 +34,7 @@
protected EntityMinecartAbstract(EntityTypes<?> entitytypes, World world) {
super(entitytypes, world);
this.j = true;
-@@ -98,6 +118,19 @@
+@@ -92,6 +112,19 @@
if (this.isInvulnerable(damagesource)) {
return false;
} else {
@@ -54,7 +54,7 @@
this.k(-this.u());
this.d(10);
this.aA();
-@@ -105,6 +138,15 @@
+@@ -99,6 +132,15 @@
boolean flag = damagesource.getEntity() instanceof EntityHuman && ((EntityHuman) damagesource.getEntity()).abilities.canInstantlyBuild;
if (flag || this.getDamage() > 40.0F) {
@@ -70,7 +70,7 @@
this.ejectPassengers();
if (flag && !this.hasCustomName()) {
this.die();
-@@ -143,6 +185,14 @@
+@@ -137,6 +179,14 @@
}
public void tick() {
@@ -85,7 +85,7 @@
if (this.getType() > 0) {
this.d(this.getType() - 1);
}
-@@ -157,6 +207,8 @@
+@@ -151,6 +201,8 @@
int i;
@@ -94,7 +94,7 @@
if (!this.world.isClientSide && this.world instanceof WorldServer) {
this.world.methodProfiler.a("portal");
MinecraftServer minecraftserver = this.world.getMinecraftServer();
-@@ -196,6 +248,7 @@
+@@ -190,6 +242,7 @@
this.world.methodProfiler.e();
}
@@ -102,7 +102,7 @@
if (this.world.isClientSide) {
if (this.aw > 0) {
-@@ -263,6 +316,18 @@
+@@ -257,6 +310,18 @@
}
this.setYawPitch(this.yaw, this.pitch);
@@ -121,7 +121,7 @@
if (this.v() == EntityMinecartAbstract.EnumMinecartType.RIDEABLE && this.motX * this.motX + this.motZ * this.motZ > 0.01D) {
List list = this.world.getEntities(this, this.getBoundingBox().grow(0.20000000298023224D, 0.0D, 0.20000000298023224D), IEntitySelector.a(this));
-@@ -271,8 +336,24 @@
+@@ -265,8 +330,24 @@
Entity entity = (Entity) list.get(l);
if (!(entity instanceof EntityHuman) && !(entity instanceof EntityIronGolem) && !(entity instanceof EntityMinecartAbstract) && !this.isVehicle() && !entity.isPassenger()) {
@@ -146,7 +146,7 @@
entity.collide(this);
}
}
-@@ -284,6 +365,14 @@
+@@ -278,6 +359,14 @@
Entity entity1 = (Entity) iterator.next();
if (!this.w(entity1) && entity1.isCollidable() && entity1 instanceof EntityMinecartAbstract) {
@@ -161,7 +161,7 @@
entity1.collide(this);
}
}
-@@ -294,7 +383,7 @@
+@@ -288,7 +377,7 @@
}
protected double p() {
@@ -170,7 +170,7 @@
}
public void a(int i, int j, int k, boolean flag) {}
-@@ -305,16 +394,20 @@
+@@ -299,16 +388,20 @@
this.motX = MathHelper.a(this.motX, -d0, d0);
this.motZ = MathHelper.a(this.motZ, -d0, d0);
if (this.onGround) {
@@ -197,7 +197,7 @@
}
}
-@@ -502,7 +595,7 @@
+@@ -493,7 +586,7 @@
}
protected void r() {
@@ -206,7 +206,7 @@
this.motX *= 0.996999979019165D;
this.motY *= 0.0D;
this.motZ *= 0.996999979019165D;
-@@ -599,6 +692,14 @@
+@@ -590,6 +683,14 @@
if (!this.world.isClientSide) {
if (!entity.noclip && !this.noclip) {
if (!this.w(entity)) {
@@ -221,7 +221,7 @@
double d0 = entity.locX - this.locX;
double d1 = entity.locZ - this.locZ;
double d2 = d0 * d0 + d1 * d1;
-@@ -745,4 +846,26 @@
+@@ -736,4 +837,26 @@
return this.i;
}
}
diff --git a/nms-patches/EntityPlayer.patch b/nms-patches/EntityPlayer.patch
index cfe55347..e1d1c6f2 100644
--- a/nms-patches/EntityPlayer.patch
+++ b/nms-patches/EntityPlayer.patch
@@ -583,11 +583,27 @@
+ PlayerLocaleChangeEvent event = new PlayerLocaleChangeEvent(getBukkitEntity(), packetplayinsettings.b());
+ this.server.server.getPluginManager().callEvent(event);
+ }
-+ this.clientViewDistance = packetplayinsettings.b;
++ this.clientViewDistance = packetplayinsettings.viewDistance;
+ // CraftBukkit end
this.locale = packetplayinsettings.b();
this.cs = packetplayinsettings.d();
this.ct = packetplayinsettings.e();
+@@ -1023,13 +1285,13 @@
+ if (entity instanceof EntityHuman) {
+ this.playerConnection.sendPacket(new PacketPlayOutEntityDestroy(new int[] { entity.getId()}));
+ } else {
+- this.removeQueue.add(entity.getId());
++ this.removeQueue.add((Integer) entity.getId()); // CraftBukkit - decompile error
+ }
+
+ }
+
+ public void d(Entity entity) {
+- this.removeQueue.remove(entity.getId());
++ this.removeQueue.remove((Integer) entity.getId()); // CraftBukkit - decompile error
+ }
+
+ protected void C() {
@@ -1053,7 +1315,7 @@
this.cv = (Entity) (entity == null ? this : entity);
if (entity1 != this.cv) {
diff --git a/nms-patches/EntityProjectile.patch b/nms-patches/EntityProjectile.patch
index 3e8aa8a0..176dade1 100644
--- a/nms-patches/EntityProjectile.patch
+++ b/nms-patches/EntityProjectile.patch
@@ -18,7 +18,7 @@
flag = true;
} else {
@@ -148,6 +149,11 @@
- this.e(movingobjectposition.a());
+ this.e(movingobjectposition.getBlockPosition());
} else {
this.a(movingobjectposition);
+ // CraftBukkit start
diff --git a/nms-patches/EntityRabbit.patch b/nms-patches/EntityRabbit.patch
index 91309d3b..131620cc 100644
--- a/nms-patches/EntityRabbit.patch
+++ b/nms-patches/EntityRabbit.patch
@@ -18,7 +18,7 @@
@@ -397,9 +403,23 @@
Integer integer = (Integer) iblockdata.get(BlockCarrots.AGE);
- if (integer.intValue() == 0) {
+ if (integer == 0) {
+ // CraftBukkit start
+ if (org.bukkit.craftbukkit.event.CraftEventFactory.callEntityChangeBlockEvent(this.f, blockposition, Blocks.AIR.getBlockData()).isCancelled()) {
+ return;
@@ -31,11 +31,11 @@
+ if (org.bukkit.craftbukkit.event.CraftEventFactory.callEntityChangeBlockEvent(
+ this.f,
+ blockposition,
-+ iblockdata.set(BlockCarrots.AGE, Integer.valueOf(integer.intValue() - 1))
++ iblockdata.set(BlockCarrots.AGE, integer - 1)
+ ).isCancelled()) {
+ return;
+ }
+ // CraftBukkit end
- world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockCarrots.AGE, Integer.valueOf(integer.intValue() - 1)), 2);
+ world.setTypeAndData(blockposition, (IBlockData) iblockdata.set(BlockCarrots.AGE, integer - 1), 2);
world.triggerEffect(2001, blockposition, Block.getCombinedId(iblockdata));
}
diff --git a/nms-patches/EntitySheep.patch b/nms-patches/EntitySheep.patch
index f7966714..5df9a4f1 100644
--- a/nms-patches/EntitySheep.patch
+++ b/nms-patches/EntitySheep.patch
@@ -30,7 +30,7 @@
enummap.put(EnumColor.WHITE, Blocks.WHITE_WOOL);
enummap.put(EnumColor.ORANGE, Blocks.ORANGE_WOOL);
enummap.put(EnumColor.MAGENTA, Blocks.MAGENTA_WOOL);
-@@ -158,11 +171,22 @@
+@@ -143,11 +156,22 @@
if (itemstack.getItem() == Items.SHEARS && !this.isSheared() && !this.isBaby()) {
if (!this.world.isClientSide) {
@@ -53,7 +53,7 @@
if (entityitem != null) {
entityitem.motY += (double) (this.random.nextFloat() * 0.05F);
-@@ -247,6 +271,12 @@
+@@ -232,6 +256,12 @@
}
public void x() {
@@ -66,7 +66,7 @@
this.setSheared(false);
if (this.isBaby()) {
this.setAge(60);
-@@ -267,6 +297,7 @@
+@@ -252,6 +282,7 @@
this.container.setItem(0, new ItemStack(ItemDye.a(enumcolor)));
this.container.setItem(1, new ItemStack(ItemDye.a(enumcolor1)));
diff --git a/nms-patches/EntityShulker.patch b/nms-patches/EntityShulker.patch
index 4ccadf23..3eaf40b8 100644
--- a/nms-patches/EntityShulker.patch
+++ b/nms-patches/EntityShulker.patch
@@ -11,7 +11,7 @@
public class EntityShulker extends EntityGolem implements IMonster {
-@@ -326,8 +330,17 @@
+@@ -321,8 +325,17 @@
EnumDirection enumdirection = aenumdirection[k];
if (this.world.q(blockposition1.shift(enumdirection))) {
@@ -31,7 +31,7 @@
break;
}
}
-@@ -372,6 +385,7 @@
+@@ -367,6 +380,7 @@
this.locX = (double) blockposition.getX() + 0.5D;
this.locY = (double) blockposition.getY();
this.locZ = (double) blockposition.getZ() + 0.5D;
diff --git a/nms-patches/EntitySmallFireball.patch b/nms-patches/EntitySmallFireball.patch
index 46d5a041..61eae8ba 100644
--- a/nms-patches/EntitySmallFireball.patch
+++ b/nms-patches/EntitySmallFireball.patch
@@ -45,7 +45,7 @@
- if (flag) {
+ // CraftBukkit start
+ if (isIncendiary) {
- BlockPosition blockposition = movingobjectposition.a().shift(movingobjectposition.direction);
+ BlockPosition blockposition = movingobjectposition.getBlockPosition().shift(movingobjectposition.direction);
if (this.world.isEmpty(blockposition)) {
- this.world.setTypeUpdate(blockposition, Blocks.FIRE.getBlockData());
diff --git a/nms-patches/EntityThrownTrident.patch b/nms-patches/EntityThrownTrident.patch
index c96db447..8e2d4415 100644
--- a/nms-patches/EntityThrownTrident.patch
+++ b/nms-patches/EntityThrownTrident.patch
@@ -1,14 +1,5 @@
--- a/net/minecraft/server/EntityThrownTrident.java
+++ b/net/minecraft/server/EntityThrownTrident.java
-@@ -5,7 +5,7 @@
- public class EntityThrownTrident extends EntityArrow {
-
- private static final DataWatcherObject<Byte> h = DataWatcher.a(EntityThrownTrident.class, DataWatcherRegistry.a);
-- private ItemStack aw;
-+ public ItemStack aw; // PAIL
- private boolean ax;
- public int g;
-
@@ -122,7 +122,7 @@
EntityLightning entitylightning = new EntityLightning(this.world, (double) blockposition.getX() + 0.5D, (double) blockposition.getY(), (double) blockposition.getZ() + 0.5D, false);
diff --git a/nms-patches/EntityTippedArrow.patch b/nms-patches/EntityTippedArrow.patch
index 5628df20..b834c094 100644
--- a/nms-patches/EntityTippedArrow.patch
+++ b/nms-patches/EntityTippedArrow.patch
@@ -24,7 +24,7 @@
+ // CraftBukkit end
+
public int getColor() {
- return ((Integer) this.datawatcher.get(EntityTippedArrow.g)).intValue();
+ return (Integer) this.datawatcher.get(EntityTippedArrow.g);
}
@@ -180,7 +199,7 @@
diff --git a/nms-patches/EntityTurtle.patch b/nms-patches/EntityTurtle.patch
index 33cf763f..fbe0c15f 100644
--- a/nms-patches/EntityTurtle.patch
+++ b/nms-patches/EntityTurtle.patch
@@ -27,7 +27,7 @@
+ // CraftBukkit start
+ if (!org.bukkit.craftbukkit.event.CraftEventFactory.callEntityChangeBlockEvent(this.f, this.d.up(), Blocks.TURTLE_EGG.getBlockData().set(BlockTurtleEgg.b, Integer.valueOf(this.f.random.nextInt(4) + 1))).isCancelled()) {
world.a((EntityHuman) null, blockposition, SoundEffects.ENTITY_TURTLE_LAY_EGG, SoundCategory.BLOCKS, 0.3F, 0.9F + world.random.nextFloat() * 0.2F);
- world.setTypeAndData(this.d.up(), (IBlockData) Blocks.TURTLE_EGG.getBlockData().set(BlockTurtleEgg.b, Integer.valueOf(this.f.random.nextInt(4) + 1)), 3);
+ world.setTypeAndData(this.d.up(), (IBlockData) Blocks.TURTLE_EGG.getBlockData().set(BlockTurtleEgg.b, this.f.random.nextInt(4) + 1), 3);
+ }
+ // CraftBukkit end
this.f.s(false);
diff --git a/nms-patches/EntityVillager.patch b/nms-patches/EntityVillager.patch
index 515d8695..9c952cb6 100644
--- a/nms-patches/EntityVillager.patch
+++ b/nms-patches/EntityVillager.patch
@@ -73,7 +73,7 @@
}
}
-@@ -574,7 +604,12 @@
+@@ -569,7 +599,12 @@
entitywitch.setCustomNameVisible(this.getCustomNameVisible());
}
diff --git a/nms-patches/EntityWither.patch b/nms-patches/EntityWither.patch
index 920308ca..d6da6879 100644
--- a/nms-patches/EntityWither.patch
+++ b/nms-patches/EntityWither.patch
@@ -13,15 +13,6 @@
public class EntityWither extends EntityMonster implements IRangedEntity {
private static final DataWatcherObject<Integer> a = DataWatcher.a(EntityWither.class, DataWatcherRegistry.b);
-@@ -19,7 +25,7 @@
- private final int[] bI = new int[2];
- private final int[] bJ = new int[2];
- private int bK;
-- private final BossBattleServer bL;
-+ public final BossBattleServer bL; // PAIL private -> public, rename bossBattleServer
- private static final Predicate<Entity> bM = (entity) -> {
- return entity instanceof EntityLiving && ((EntityLiving) entity).getMonsterType() != EnumMonsterType.UNDEAD && ((EntityLiving) entity).df();
- };
@@ -181,13 +187,38 @@
if (this.dz() > 0) {
i = this.dz() - 1;
@@ -84,4 +75,4 @@
+ this.heal(1.0F, EntityRegainHealthEvent.RegainReason.REGEN); // CraftBukkit
}
- this.bL.setProgress(this.getHealth() / this.getMaxHealth());
+ this.bossBattle.setProgress(this.getHealth() / this.getMaxHealth());
diff --git a/nms-patches/EntityZombie.patch b/nms-patches/EntityZombie.patch
index b85809fe..1a0a9240 100644
--- a/nms-patches/EntityZombie.patch
+++ b/nms-patches/EntityZombie.patch
@@ -17,7 +17,7 @@
protected static final IAttribute c = (new AttributeRanged((IAttribute) null, "zombie.spawnReinforcements", 0.0D, 0.0D, 1.0D)).a("Spawn Reinforcements Chance");
@@ -21,6 +30,7 @@
- private int bJ;
+ private int drownedConversionTime;
private float bK;
private float bL;
+ private int lastTick = MinecraftServer.currentTick; // CraftBukkit - add field
@@ -28,15 +28,15 @@
public void tick() {
if (!this.world.isClientSide) {
-- if (this.dG()) {
-- --this.bJ;
+- if (this.isDrownConverting()) {
+- --this.drownedConversionTime;
+ // CraftBukkit start - Use wall time instead of ticks for conversion
-+ if (this.dG() && this.isAlive()) {
++ if (this.isDrownConverting() && this.isAlive()) {
+ int elapsedTicks = MinecraftServer.currentTick - this.lastTick;
+ this.lastTick = MinecraftServer.currentTick;
-+ this.bJ -= elapsedTicks;
++ this.drownedConversionTime -= elapsedTicks;
+ // CraftBukkit end
- if (this.bJ < 0) {
+ if (this.drownedConversionTime < 0) {
this.dE();
}
@@ -182,7 +196,14 @@
diff --git a/nms-patches/EntityZombieVillager.patch b/nms-patches/EntityZombieVillager.patch
index be60d420..e1a51981 100644
--- a/nms-patches/EntityZombieVillager.patch
+++ b/nms-patches/EntityZombieVillager.patch
@@ -37,7 +37,7 @@
@@ -100,8 +110,10 @@
this.bD = uuid;
this.conversionTime = i;
- this.getDataWatcher().set(EntityZombieVillager.a, Boolean.valueOf(true));
+ this.getDataWatcher().set(EntityZombieVillager.a, true);
- this.removeEffect(MobEffects.WEAKNESS);
- this.addEffect(new MobEffect(MobEffects.INCREASE_DAMAGE, i, Math.min(this.world.getDifficulty().a() - 1, 0)));
+ // CraftBukkit start
diff --git a/nms-patches/FluidTypeFlowing.patch b/nms-patches/FluidTypeFlowing.patch
index 13a30e10..f4e9cb65 100644
--- a/nms-patches/FluidTypeFlowing.patch
+++ b/nms-patches/FluidTypeFlowing.patch
@@ -23,7 +23,7 @@
@@ -145,6 +150,15 @@
Fluid fluid1 = this.a((IWorldReader) generatoraccess, blockposition1, iblockdata1);
- if (this.a(generatoraccess, blockposition, iblockdata, EnumDirection.DOWN, blockposition1, iblockdata1, generatoraccess.b(blockposition1), fluid1.c())) {
+ if (this.a(generatoraccess, blockposition, iblockdata, EnumDirection.DOWN, blockposition1, iblockdata1, generatoraccess.getFluid(blockposition1), fluid1.c())) {
+ // CraftBukkit start
+ org.bukkit.block.Block source = CraftBlock.at(generatoraccess, blockposition);
+ BlockFromToEvent event = new BlockFromToEvent(source, BlockFace.DOWN);
@@ -39,7 +39,7 @@
@@ -175,6 +189,15 @@
IBlockData iblockdata1 = generatoraccess.getType(blockposition1);
- if (this.a(generatoraccess, blockposition, iblockdata, enumdirection, blockposition1, iblockdata1, generatoraccess.b(blockposition1), fluid1.c())) {
+ if (this.a(generatoraccess, blockposition, iblockdata, enumdirection, blockposition1, iblockdata1, generatoraccess.getFluid(blockposition1), fluid1.c())) {
+ // CraftBukkit start
+ org.bukkit.block.Block source = CraftBlock.at(generatoraccess, blockposition);
+ BlockFromToEvent event = new BlockFromToEvent(source, org.bukkit.craftbukkit.block.CraftBlock.notchToBlockFace(enumdirection));
diff --git a/nms-patches/HandshakeListener.patch b/nms-patches/HandshakeListener.patch
index f4e8251d..1a5a7dcd 100644
--- a/nms-patches/HandshakeListener.patch
+++ b/nms-patches/HandshakeListener.patch
@@ -67,4 +67,4 @@
+ ((LoginListener) this.b.i()).hostname = packethandshakinginsetprotocol.hostname + ":" + packethandshakinginsetprotocol.port; // CraftBukkit - set hostname
}
break;
-
+ case STATUS:
diff --git a/nms-patches/ItemBoat.patch b/nms-patches/ItemBoat.patch
index e51c9eb5..4d4748e7 100644
--- a/nms-patches/ItemBoat.patch
+++ b/nms-patches/ItemBoat.patch
@@ -5,13 +5,13 @@
return new InteractionResultWrapper(EnumInteractionResult.PASS, itemstack);
} else if (movingobjectposition.type == MovingObjectPosition.EnumMovingObjectType.BLOCK) {
+ // CraftBukkit start - Boat placement
-+ org.bukkit.event.player.PlayerInteractEvent event = org.bukkit.craftbukkit.event.CraftEventFactory.callPlayerInteractEvent(entityhuman, org.bukkit.event.block.Action.RIGHT_CLICK_BLOCK, movingobjectposition.a(), movingobjectposition.direction, itemstack, enumhand);
++ org.bukkit.event.player.PlayerInteractEvent event = org.bukkit.craftbukkit.event.CraftEventFactory.callPlayerInteractEvent(entityhuman, org.bukkit.event.block.Action.RIGHT_CLICK_BLOCK, movingobjectposition.getBlockPosition(), movingobjectposition.direction, itemstack, enumhand);
+
+ if (event.isCancelled()) {
+ return new InteractionResultWrapper(EnumInteractionResult.PASS, itemstack);
+ }
+ // CraftBukkit end
- BlockPosition blockposition = movingobjectposition.a();
+ BlockPosition blockposition = movingobjectposition.getBlockPosition();
Block block = world.getType(blockposition).getBlock();
EntityBoat entityboat = new EntityBoat(world, movingobjectposition.pos.x, movingobjectposition.pos.y, movingobjectposition.pos.z);
@@ -62,7 +69,7 @@
diff --git a/nms-patches/ItemBucket.patch b/nms-patches/ItemBucket.patch
index 3c055ca4..44c3067f 100644
--- a/nms-patches/ItemBucket.patch
+++ b/nms-patches/ItemBucket.patch
@@ -87,8 +87,8 @@
boolean flag1 = material.isReplaceable();
if (!world.isEmpty(blockposition) && !flag && !flag1 && (!(iblockdata.getBlock() instanceof IFluidContainer) || !((IFluidContainer) iblockdata.getBlock()).canPlace(world, blockposition, iblockdata, this.fluidType))) {
-- return movingobjectposition == null ? false : this.a(entityhuman, world, movingobjectposition.a().shift(movingobjectposition.direction), (MovingObjectPosition) null);
-+ return movingobjectposition == null ? false : this.a(entityhuman, world, movingobjectposition.a().shift(movingobjectposition.direction), (MovingObjectPosition) null, enumdirection, clicked, itemstack); // CraftBukkit
+- return movingobjectposition == null ? false : this.a(entityhuman, world, movingobjectposition.getBlockPosition().shift(movingobjectposition.direction), (MovingObjectPosition) null);
++ return movingobjectposition == null ? false : this.a(entityhuman, world, movingobjectposition.getBlockPosition().shift(movingobjectposition.direction), (MovingObjectPosition) null, enumdirection, clicked, itemstack); // CraftBukkit
} else {
+ // CraftBukkit start
+ if (entityhuman != null) {
diff --git a/nms-patches/ItemTrident.patch b/nms-patches/ItemTrident.patch
index 5a6f1c02..dff94670 100644
--- a/nms-patches/ItemTrident.patch
+++ b/nms-patches/ItemTrident.patch
@@ -37,7 +37,7 @@
+ }
+
+ itemstack.damage(1, entityhuman);
-+ entitythrowntrident.aw = itemstack.cloneItemStack(); // SPIGOT-4511 update since damage call moved
++ entitythrowntrident.trident = itemstack.cloneItemStack(); // SPIGOT-4511 update since damage call moved
+ // CraftBukkit end
+
if (!entityhuman.abilities.canInstantlyBuild) {
diff --git a/nms-patches/ItemWaterLily.patch b/nms-patches/ItemWaterLily.patch
index 0e9db92f..6dcc7f1d 100644
--- a/nms-patches/ItemWaterLily.patch
+++ b/nms-patches/ItemWaterLily.patch
@@ -1,7 +1,7 @@
--- a/net/minecraft/server/ItemWaterLily.java
+++ b/net/minecraft/server/ItemWaterLily.java
@@ -30,7 +30,15 @@
- Fluid fluid = world.b(blockposition);
+ Fluid fluid = world.getFluid(blockposition);
if ((fluid.c() == FluidTypes.c || material == Material.ICE) && world.isEmpty(blockposition1)) {
+ // CraftBukkit start - special case for handling block placement with water lilies
diff --git a/nms-patches/LoginListener.patch b/nms-patches/LoginListener.patch
index 75e20b64..774aad17 100644
--- a/nms-patches/LoginListener.patch
+++ b/nms-patches/LoginListener.patch
@@ -116,7 +116,7 @@
} else if (LoginListener.this.server.H()) {
@@ -160,6 +220,11 @@
LoginListener.this.disconnect(new ChatMessage("multiplayer.disconnect.authservers_down", new Object[0]));
- LoginListener.c.error("Couldn\'t verify username because servers are unavailable");
+ LoginListener.c.error("Couldn't verify username because servers are unavailable");
}
+ // CraftBukkit start - catch all exceptions
+ } catch (Exception exception) {
diff --git a/nms-patches/LootTableInfo.patch b/nms-patches/LootTableInfo.patch
index 44c1d298..41fb44e6 100644
--- a/nms-patches/LootTableInfo.patch
+++ b/nms-patches/LootTableInfo.patch
@@ -26,7 +26,7 @@
}
@Nullable
-@@ -127,11 +130,11 @@
+@@ -124,11 +127,11 @@
return LootTableInfo.EntityTarget.a(jsonreader.nextString());
}
@@ -40,7 +40,7 @@
this.a(jsonwriter, (LootTableInfo.EntityTarget) object);
}
}
-@@ -141,6 +144,7 @@
+@@ -138,6 +141,7 @@
private final WorldServer a;
private float b;
@@ -48,7 +48,7 @@
private Entity c;
private EntityHuman d;
private DamageSource e;
-@@ -175,8 +179,15 @@
+@@ -172,8 +176,15 @@
return this;
}
diff --git a/nms-patches/MethodProfiler.patch b/nms-patches/MethodProfiler.patch
index 97e1ed3f..0b8930e6 100644
--- a/nms-patches/MethodProfiler.patch
+++ b/nms-patches/MethodProfiler.patch
@@ -38,14 +38,14 @@
+ if (!ENABLED) return; // CraftBukkit
if (this.d && !this.c.isEmpty()) {
long i = SystemUtils.c();
- long j = ((Long) this.c.remove(this.c.size() - 1)).longValue();
+ long j = (Long) this.c.remove(this.c.size() - 1);
@@ -92,6 +97,7 @@
}
public List<MethodProfiler.ProfilerInfo> b(String s) {
+ if (!ENABLED) return Collections.emptyList(); // CraftBukkit
- long i = this.f.containsKey("root") ? ((Long) this.f.get("root")).longValue() : 0L;
- long j = this.f.containsKey(s) ? ((Long) this.f.get(s)).longValue() : -1L;
+ long i = this.f.containsKey("root") ? (Long) this.f.get("root") : 0L;
+ long j = this.f.containsKey(s) ? (Long) this.f.get(s) : -1L;
ArrayList arraylist = Lists.newArrayList();
@@ -154,11 +160,13 @@
}
diff --git a/nms-patches/MinecraftServer.patch b/nms-patches/MinecraftServer.patch
index ea6c46a1..c4053f53 100644
--- a/nms-patches/MinecraftServer.patch
+++ b/nms-patches/MinecraftServer.patch
@@ -261,9 +261,9 @@
- this.getPlayerList().setPlayerFileData(worldserver);
- if (worlddata.P() != null) {
-- this.aP().a(worlddata.P());
+- this.getBossBattleCustomData().a(worlddata.P());
+ if (worlddata.P() != null) {
-+ this.aP().a(worlddata.P());
++ this.getBossBattleCustomData().a(worlddata.P());
+ }
}
+ this.a(this.getDifficulty());
@@ -373,7 +373,7 @@
+ this.server.getPluginManager().callEvent(new org.bukkit.event.world.WorldLoadEvent(world.getWorld()));
+ }
+ // CraftBukkit end
- MinecraftServer.LOGGER.info("Time elapsed: {} ms", Long.valueOf(stopwatch.elapsed(TimeUnit.MILLISECONDS)));
+ MinecraftServer.LOGGER.info("Time elapsed: {} ms", stopwatch.elapsed(TimeUnit.MILLISECONDS));
Iterator iterator = DimensionManager.b().iterator();
@@ -419,6 +571,10 @@
@@ -426,7 +426,7 @@
long j = i / 50L;
+ if (server.getWarnOnOverload()) // CraftBukkit
- MinecraftServer.LOGGER.warn("Can\'t keep up! Is the server overloaded? Running {}ms or {} ticks behind", Long.valueOf(i), Long.valueOf(j));
+ MinecraftServer.LOGGER.warn("Can't keep up! Is the server overloaded? Running {}ms or {} ticks behind", i, j);
this.aa += j * 50L;
this.Q = this.aa;
}
diff --git a/nms-patches/MojangsonParser.patch b/nms-patches/MojangsonParser.patch
deleted file mode 100644
index abbaae7a..00000000
--- a/nms-patches/MojangsonParser.patch
+++ /dev/null
@@ -1,20 +0,0 @@
---- a/net/minecraft/server/MojangsonParser.java
-+++ b/net/minecraft/server/MojangsonParser.java
-@@ -82,7 +82,7 @@
- }
- }
-
-- private NBTBase b(String s) {
-+ public NBTBase b(String s) { // PAIL
- try {
- if (MojangsonParser.i.matcher(s).matches()) {
- return new NBTTagFloat(Float.parseFloat(s.substring(0, s.length() - 1)));
-@@ -207,7 +207,7 @@
- }
- }
-
-- private NBTBase h() throws CommandSyntaxException {
-+ public NBTBase h() throws CommandSyntaxException { // PAIL
- this.a('[');
- int i = this.n.getCursor();
- char c0 = this.n.read();
diff --git a/nms-patches/PacketPlayInSettings.patch b/nms-patches/PacketPlayInSettings.patch
deleted file mode 100644
index da404809..00000000
--- a/nms-patches/PacketPlayInSettings.patch
+++ /dev/null
@@ -1,11 +0,0 @@
---- a/net/minecraft/server/PacketPlayInSettings.java
-+++ b/net/minecraft/server/PacketPlayInSettings.java
-@@ -5,7 +5,7 @@
- public class PacketPlayInSettings implements Packet<PacketListenerPlayIn> {
-
- private String a;
-- private int b;
-+ public int b; // PAIL
- private EntityHuman.EnumChatVisibility c;
- private boolean d;
- private int e;
diff --git a/nms-patches/PathfinderGoalRemoveBlock.patch b/nms-patches/PathfinderGoalRemoveBlock.patch
index b97b1742..7da7e60e 100644
--- a/nms-patches/PathfinderGoalRemoveBlock.patch
+++ b/nms-patches/PathfinderGoalRemoveBlock.patch
@@ -16,7 +16,7 @@
if (this.h > 60) {
+ // CraftBukkit start - Step on eggs
-+ EntityInteractEvent event = new EntityInteractEvent(this.g.getBukkitEntity(), CraftBlock.at(world, blockposition1));
++ EntityInteractEvent event = new EntityInteractEvent(this.entity.getBukkitEntity(), CraftBlock.at(world, blockposition1));
+ world.getServer().getPluginManager().callEvent((EntityInteractEvent) event);
+
+ if (event.isCancelled()) {
diff --git a/nms-patches/PlayerConnection.patch b/nms-patches/PlayerConnection.patch
index e4c3a7e2..dc4ef720 100644
--- a/nms-patches/PlayerConnection.patch
+++ b/nms-patches/PlayerConnection.patch
@@ -209,7 +209,7 @@
+
+ if (d10 - d9 > Math.max(100.0D, Math.pow((double) (10.0F * (float) i * speed), 2)) && (!this.minecraftServer.H() || !this.minecraftServer.G().equals(entity.getDisplayName().getString()))) {
+ // CraftBukkit end
- PlayerConnection.LOGGER.warn("{} (vehicle of {}) moved too quickly! {},{},{}", entity.getDisplayName().getString(), this.player.getDisplayName().getString(), Double.valueOf(d6), Double.valueOf(d7), Double.valueOf(d8));
+ PlayerConnection.LOGGER.warn("{} (vehicle of {}) moved too quickly! {},{},{}", entity.getDisplayName().getString(), this.player.getDisplayName().getString(), d6, d7, d8);
this.networkManager.sendPacket(new PacketPlayOutVehicleMove(entity));
return;
@@ -222,14 +358,72 @@
@@ -325,7 +325,7 @@
});
}
-@@ -492,6 +694,15 @@
+@@ -490,6 +692,15 @@
}
public void a(PacketPlayInBEdit packetplayinbedit) {
@@ -341,7 +341,7 @@
ItemStack itemstack = packetplayinbedit.b();
if (!itemstack.isEmpty()) {
-@@ -516,11 +727,13 @@
+@@ -514,11 +725,13 @@
}
itemstack2.a("pages", (NBTBase) nbttaglist);
@@ -357,7 +357,7 @@
}
}
-@@ -560,7 +773,7 @@
+@@ -558,7 +771,7 @@
} else {
WorldServer worldserver = this.minecraftServer.getWorldServer(this.player.dimension);
@@ -366,7 +366,7 @@
if (this.e == 0) {
this.syncPosition();
}
-@@ -570,13 +783,21 @@
+@@ -568,13 +781,21 @@
this.A = this.e;
this.a(this.teleportPos.x, this.teleportPos.y, this.teleportPos.z, this.player.yaw, this.player.pitch);
}
@@ -389,7 +389,7 @@
double d0 = this.player.locX;
double d1 = this.player.locY;
double d2 = this.player.locZ;
-@@ -601,15 +822,33 @@
+@@ -599,15 +820,33 @@
++this.receivedMovePackets;
int i = this.receivedMovePackets - this.processedMovePackets;
@@ -400,7 +400,7 @@
+ this.lastTick = (int) (System.currentTimeMillis() / 50);
+
+ if (i > Math.max(this.allowedPlayerTicks, 5)) {
- PlayerConnection.LOGGER.debug("{} is sending move packets too frequently ({} packets since last tick)", this.player.getDisplayName().getString(), Integer.valueOf(i));
+ PlayerConnection.LOGGER.debug("{} is sending move packets too frequently ({} packets since last tick)", this.player.getDisplayName().getString(), i);
i = 1;
}
@@ -422,10 +422,10 @@
- if (d11 - d10 > (double) (f2 * (float) i) && (!this.minecraftServer.H() || !this.minecraftServer.G().equals(this.player.getProfile().getName()))) {
+ if (d11 - d10 > Math.max(f2, Math.pow((double) (10.0F * (float) i * speed), 2)) && (!this.minecraftServer.H() || !this.minecraftServer.G().equals(this.player.getProfile().getName()))) {
+ // CraftBukkit end
- PlayerConnection.LOGGER.warn("{} moved too quickly! {},{},{}", this.player.getDisplayName().getString(), Double.valueOf(d7), Double.valueOf(d8), Double.valueOf(d9));
+ PlayerConnection.LOGGER.warn("{} moved too quickly! {},{},{}", this.player.getDisplayName().getString(), d7, d8, d9);
this.a(this.player.locX, this.player.locY, this.player.locZ, this.player.yaw, this.player.pitch);
return;
-@@ -655,6 +894,69 @@
+@@ -653,6 +892,69 @@
}
}
@@ -495,7 +495,7 @@
this.B = d12 >= -0.03125D;
this.B &= !this.minecraftServer.getAllowFlight() && !this.player.abilities.canFly;
this.B &= !this.player.hasEffect(MobEffects.LEVITATION) && !this.player.dc() && !worldserver.a(this.player.getBoundingBox().g(0.0625D).b(0.0D, -0.55D, 0.0D));
-@@ -672,10 +974,76 @@
+@@ -670,10 +972,76 @@
}
public void a(double d0, double d1, double d2, float f, float f1) {
@@ -573,7 +573,7 @@
double d3 = set.contains(PacketPlayOutPosition.EnumPlayerTeleportFlags.X) ? this.player.locX : 0.0D;
double d4 = set.contains(PacketPlayOutPosition.EnumPlayerTeleportFlags.Y) ? this.player.locY : 0.0D;
double d5 = set.contains(PacketPlayOutPosition.EnumPlayerTeleportFlags.Z) ? this.player.locZ : 0.0D;
-@@ -687,6 +1055,14 @@
+@@ -685,6 +1053,14 @@
this.teleportAwait = 0;
}
@@ -588,7 +588,7 @@
this.A = this.e;
this.player.setLocation(d0, d1, d2, f, f1);
this.player.playerConnection.sendPacket(new PacketPlayOutPosition(d0 - d3, d1 - d4, d2 - d5, f - f2, f1 - f3, set, this.teleportAwait));
-@@ -694,6 +1070,7 @@
+@@ -692,6 +1068,7 @@
public void a(PacketPlayInBlockDig packetplayinblockdig) {
PlayerConnectionUtils.ensureMainThread(packetplayinblockdig, this, this.player.getWorldServer());
@@ -596,7 +596,7 @@
WorldServer worldserver = this.minecraftServer.getWorldServer(this.player.dimension);
BlockPosition blockposition = packetplayinblockdig.b();
-@@ -703,14 +1080,46 @@
+@@ -701,13 +1078,45 @@
if (!this.player.isSpectator()) {
ItemStack itemstack = this.player.b(EnumHand.OFF_HAND);
@@ -624,7 +624,6 @@
}
return;
-
case DROP_ITEM:
if (!this.player.isSpectator()) {
+ // limit how quickly items can be dropped
@@ -645,7 +644,7 @@
this.player.a(false);
}
-@@ -744,7 +1153,15 @@
+@@ -738,7 +1147,15 @@
if (!this.minecraftServer.a(worldserver, blockposition, this.player) && worldserver.getWorldBorder().a(blockposition)) {
this.player.playerInteractManager.a(blockposition, packetplayinblockdig.c());
} else {
@@ -661,7 +660,7 @@
}
} else {
if (packetplayinblockdig.d() == PacketPlayInBlockDig.EnumPlayerDigType.STOP_DESTROY_BLOCK) {
-@@ -764,10 +1181,12 @@
+@@ -757,10 +1174,12 @@
default:
throw new IllegalArgumentException("Invalid player action");
}
@@ -674,7 +673,7 @@
WorldServer worldserver = this.minecraftServer.getWorldServer(this.player.dimension);
EnumHand enumhand = packetplayinuseitem.d();
ItemStack itemstack = this.player.b(enumhand);
-@@ -780,6 +1199,13 @@
+@@ -773,6 +1192,13 @@
this.player.playerConnection.sendPacket(new PacketPlayOutChat(ichatbasecomponent, ChatMessageType.GAME_INFO));
} else if (this.teleportPos == null && this.player.d((double) blockposition.getX() + 0.5D, (double) blockposition.getY() + 0.5D, (double) blockposition.getZ() + 0.5D) < 64.0D && !this.minecraftServer.a(worldserver, blockposition, this.player) && worldserver.getWorldBorder().a(blockposition)) {
@@ -688,7 +687,7 @@
this.player.playerInteractManager.a(this.player, worldserver, itemstack, enumhand, blockposition, enumdirection, packetplayinuseitem.e(), packetplayinuseitem.f(), packetplayinuseitem.g());
}
-@@ -789,13 +1215,52 @@
+@@ -782,13 +1208,52 @@
public void a(PacketPlayInBlockPlace packetplayinblockplace) {
PlayerConnectionUtils.ensureMainThread(packetplayinblockplace, this, this.player.getWorldServer());
@@ -728,7 +727,7 @@
+ player.playerInteractManager.firedInteract = false;
+ cancelled = player.playerInteractManager.interactResult;
+ } else {
-+ org.bukkit.event.player.PlayerInteractEvent event = CraftEventFactory.callPlayerInteractEvent(player, Action.RIGHT_CLICK_BLOCK, movingobjectposition.a(), movingobjectposition.direction, itemstack, true, enumhand);
++ org.bukkit.event.player.PlayerInteractEvent event = CraftEventFactory.callPlayerInteractEvent(player, Action.RIGHT_CLICK_BLOCK, movingobjectposition.getBlockPosition(), movingobjectposition.direction, itemstack, true, enumhand);
+ cancelled = event.useItemInHand() == Event.Result.DENY;
+ }
+ }
@@ -742,7 +741,7 @@
}
}
-@@ -815,13 +1280,18 @@
+@@ -808,13 +1273,18 @@
}
if (entity != null) {
@@ -763,7 +762,7 @@
public void a(PacketPlayInBoatMove packetplayinboatmove) {
PlayerConnectionUtils.ensureMainThread(packetplayinboatmove, this, this.player.getWorldServer());
-@@ -834,11 +1304,26 @@
+@@ -827,11 +1297,26 @@
}
public void a(IChatBaseComponent ichatbasecomponent) {
@@ -791,7 +790,7 @@
if (this.minecraftServer.H() && this.player.getDisplayName().getString().equals(this.minecraftServer.G())) {
PlayerConnection.LOGGER.info("Stopping singleplayer server as player logged out");
this.minecraftServer.safeShutdown();
-@@ -864,6 +1349,15 @@
+@@ -857,6 +1342,15 @@
}
}
@@ -807,7 +806,7 @@
try {
this.networkManager.sendPacket(packet, genericfuturelistener);
} catch (Throwable throwable) {
-@@ -879,17 +1373,37 @@
+@@ -872,17 +1366,37 @@
public void a(PacketPlayInHeldItemSlot packetplayinhelditemslot) {
PlayerConnectionUtils.ensureMainThread(packetplayinhelditemslot, this, this.player.getWorldServer());
@@ -847,7 +846,7 @@
this.sendPacket(new PacketPlayOutChat((new ChatMessage("chat.cannotSend", new Object[0])).a(EnumChatFormat.RED)));
} else {
this.player.resetIdleTimer();
-@@ -899,39 +1413,249 @@
+@@ -892,39 +1406,249 @@
for (int i = 0; i < s.length(); ++i) {
if (!SharedConstants.isAllowedChatCharacter(s.charAt(i))) {
@@ -1104,7 +1103,7 @@
this.player.resetIdleTimer();
IJumpable ijumpable;
-@@ -1003,6 +1727,7 @@
+@@ -987,6 +1711,7 @@
public void a(PacketPlayInUseEntity packetplayinuseentity) {
PlayerConnectionUtils.ensureMainThread(packetplayinuseentity, this, this.player.getWorldServer());
@@ -1112,7 +1111,7 @@
WorldServer worldserver = this.minecraftServer.getWorldServer(this.player.dimension);
Entity entity = packetplayinuseentity.a((World) worldserver);
-@@ -1018,20 +1743,73 @@
+@@ -1002,20 +1727,73 @@
if (this.player.h(entity) < d0) {
EnumHand enumhand;
@@ -1187,7 +1186,7 @@
}
}
}
-@@ -1047,7 +1825,8 @@
+@@ -1031,7 +1809,8 @@
case PERFORM_RESPAWN:
if (this.player.viewingCredits) {
this.player.viewingCredits = false;
@@ -1197,7 +1196,7 @@
CriterionTriggers.v.a(this.player, DimensionManager.THE_END, DimensionManager.OVERWORLD);
} else {
if (this.player.getHealth() > 0.0F) {
-@@ -1070,14 +1849,20 @@
+@@ -1053,14 +1832,20 @@
public void a(PacketPlayInCloseWindow packetplayinclosewindow) {
PlayerConnectionUtils.ensureMainThread(packetplayinclosewindow, this, this.player.getWorldServer());
@@ -1220,7 +1219,7 @@
NonNullList nonnulllist = NonNullList.a();
for (int i = 0; i < this.player.activeContainer.slots.size(); ++i) {
-@@ -1086,8 +1871,274 @@
+@@ -1069,8 +1854,274 @@
this.player.a(this.player.activeContainer, nonnulllist);
} else {
@@ -1496,7 +1495,7 @@
if (ItemStack.matches(packetplayinwindowclick.f(), itemstack)) {
this.player.playerConnection.sendPacket(new PacketPlayOutTransaction(packetplayinwindowclick.b(), packetplayinwindowclick.e(), true));
this.player.f = true;
-@@ -1130,6 +2181,7 @@
+@@ -1113,6 +2164,7 @@
public void a(PacketPlayInEnchantItem packetplayinenchantitem) {
PlayerConnectionUtils.ensureMainThread(packetplayinenchantitem, this, this.player.getWorldServer());
@@ -1504,7 +1503,7 @@
this.player.resetIdleTimer();
if (this.player.activeContainer.windowId == packetplayinenchantitem.b() && this.player.activeContainer.c(this.player) && !this.player.isSpectator()) {
this.player.activeContainer.a(this.player, packetplayinenchantitem.c());
-@@ -1161,6 +2213,43 @@
+@@ -1144,6 +2196,43 @@
boolean flag1 = packetplayinsetcreativeslot.b() >= 1 && packetplayinsetcreativeslot.b() <= 45;
boolean flag2 = itemstack.isEmpty() || itemstack.getDamage() >= 0 && itemstack.getCount() <= 64 && !itemstack.isEmpty();
@@ -1548,15 +1547,15 @@
if (flag1 && flag2) {
if (itemstack.isEmpty()) {
-@@ -1184,6 +2273,7 @@
+@@ -1167,6 +2256,7 @@
public void a(PacketPlayInTransaction packetplayintransaction) {
PlayerConnectionUtils.ensureMainThread(packetplayintransaction, this, this.player.getWorldServer());
+ if (this.player.isFrozen()) return; // CraftBukkit
Short oshort = (Short) this.k.get(this.player.activeContainer.windowId);
- if (oshort != null && packetplayintransaction.c() == oshort.shortValue() && this.player.activeContainer.windowId == packetplayintransaction.b() && !this.player.activeContainer.c(this.player) && !this.player.isSpectator()) {
-@@ -1194,6 +2284,7 @@
+ if (oshort != null && packetplayintransaction.c() == oshort && this.player.activeContainer.windowId == packetplayintransaction.b() && !this.player.activeContainer.c(this.player) && !this.player.isSpectator()) {
+@@ -1177,6 +2267,7 @@
public void a(PacketPlayInUpdateSign packetplayinupdatesign) {
PlayerConnectionUtils.ensureMainThread(packetplayinupdatesign, this, this.player.getWorldServer());
@@ -1564,7 +1563,7 @@
this.player.resetIdleTimer();
WorldServer worldserver = this.minecraftServer.getWorldServer(this.player.dimension);
BlockPosition blockposition = packetplayinupdatesign.b();
-@@ -1210,14 +2301,30 @@
+@@ -1193,14 +2284,30 @@
if (!tileentitysign.d() || tileentitysign.e() != this.player) {
this.minecraftServer.warning("Player " + this.player.getDisplayName().getString() + " just tried to change non-editable sign");
@@ -1596,7 +1595,7 @@
tileentitysign.update();
worldserver.notify(blockposition, iblockdata, iblockdata, 3);
-@@ -1226,6 +2333,7 @@
+@@ -1209,6 +2316,7 @@
}
public void a(PacketPlayInKeepAlive packetplayinkeepalive) {
@@ -1604,7 +1603,7 @@
if (this.g && packetplayinkeepalive.b() == this.h) {
int i = (int) (SystemUtils.b() - this.f);
-@@ -1239,7 +2347,17 @@
+@@ -1222,7 +2330,17 @@
public void a(PacketPlayInAbilities packetplayinabilities) {
PlayerConnectionUtils.ensureMainThread(packetplayinabilities, this, this.player.getWorldServer());
@@ -1623,7 +1622,7 @@
}
public void a(PacketPlayInSettings packetplayinsettings) {
-@@ -1247,5 +2365,47 @@
+@@ -1230,5 +2348,47 @@
this.player.a(packetplayinsettings);
}
diff --git a/nms-patches/PlayerList.patch b/nms-patches/PlayerList.patch
index 09fd484b..8fe54067 100644
--- a/nms-patches/PlayerList.patch
+++ b/nms-patches/PlayerList.patch
@@ -32,7 +32,7 @@
public static final File a = new File("banned-players.json");
@@ -28,14 +51,16 @@
private static final Logger f = LogManager.getLogger();
- private static final SimpleDateFormat g = new SimpleDateFormat("yyyy-MM-dd \'at\' HH:mm:ss z");
+ private static final SimpleDateFormat g = new SimpleDateFormat("yyyy-MM-dd 'at' HH:mm:ss z");
private final MinecraftServer server;
- public final List<EntityPlayer> players = Lists.newArrayList();
+ public final List<EntityPlayer> players = new java.util.concurrent.CopyOnWriteArrayList(); // CraftBukkit - ArrayList -> CopyOnWriteArrayList: Iterator safety
@@ -93,9 +93,9 @@
s1 = networkmanager.getSocketAddress().toString();
}
-- PlayerList.f.info("{}[{}] logged in with entity id {} at ({}, {}, {})", entityplayer.getDisplayName().getString(), s1, Integer.valueOf(entityplayer.getId()), Double.valueOf(entityplayer.locX), Double.valueOf(entityplayer.locY), Double.valueOf(entityplayer.locZ));
+- PlayerList.f.info("{}[{}] logged in with entity id {} at ({}, {}, {})", entityplayer.getDisplayName().getString(), s1, entityplayer.getId(), entityplayer.locX, entityplayer.locY, entityplayer.locZ);
+ // CraftBukkit - Moved message to after join
-+ // PlayerList.f.info("{}[{}] logged in with entity id {} at ({}, {}, {})", entityplayer.getDisplayName().getString(), s1, Integer.valueOf(entityplayer.getId()), Double.valueOf(entityplayer.locX), Double.valueOf(entityplayer.locY), Double.valueOf(entityplayer.locZ));
++ // PlayerList.f.info("{}[{}] logged in with entity id {} at ({}, {}, {})", entityplayer.getDisplayName().getString(), s1, entityplayer.getId(), entityplayer.locX, entityplayer.locY, entityplayer.locZ);
WorldServer worldserver = this.server.getWorldServer(entityplayer.dimension);
WorldData worlddata = worldserver.getWorldData();
@@ -125,7 +125,7 @@
entityplayer.syncInventory();
+ // CraftBukkit - Moved from above, added world
-+ PlayerList.f.info("{}[{}] logged in with entity id {} at ([{}]{}, {}, {})", entityplayer.getDisplayName().getString(), s1, Integer.valueOf(entityplayer.getId()), entityplayer.world.worldData.getName(), Double.valueOf(entityplayer.locX), Double.valueOf(entityplayer.locY), Double.valueOf(entityplayer.locZ));
++ PlayerList.f.info("{}[{}] logged in with entity id {} at ([{}]{}, {}, {})", entityplayer.getDisplayName().getString(), s1, entityplayer.getId(), entityplayer.world.worldData.getName(), entityplayer.locX, entityplayer.locY, entityplayer.locZ);
}
public void sendScoreboard(ScoreboardServer scoreboardserver, EntityPlayer entityplayer) {
@@ -235,12 +235,12 @@
- worldserver.addEntity(entityplayer);
- this.a(entityplayer, (WorldServer) null);
-- this.server.aP().a(entityplayer);
+- this.server.getBossBattleCustomData().a(entityplayer);
+ // CraftBukkit start - Only add if the player wasn't moved in the event
+ if (entityplayer.world == worldserver && !worldserver.players.contains(entityplayer)) {
+ worldserver.addEntity(entityplayer);
+ this.a(entityplayer, (WorldServer) null);
-+ this.server.aP().a(entityplayer);
++ this.server.getBossBattleCustomData().a(entityplayer);
+ }
+ // CraftBukkit end
}
diff --git a/nms-patches/RecipeFireworks.patch b/nms-patches/RecipeFireworks.patch
index 22a7a3b8..5ce9b621 100644
--- a/nms-patches/RecipeFireworks.patch
+++ b/nms-patches/RecipeFireworks.patch
@@ -6,9 +6,9 @@
-public class RecipeFireworks extends IRecipeComplex {
+public class RecipeFireworks extends ShapelessRecipes implements IRecipe { // CraftBukkit - added extends
- private static final RecipeItemStack a = RecipeItemStack.a(new IMaterial[] { Items.PAPER});
- private static final RecipeItemStack b = RecipeItemStack.a(new IMaterial[] { Items.GUNPOWDER});
- private static final RecipeItemStack c = RecipeItemStack.a(new IMaterial[] { Items.FIREWORK_STAR});
+ private static final RecipeItemStack a = RecipeItemStack.a(Items.PAPER);
+ private static final RecipeItemStack b = RecipeItemStack.a(Items.GUNPOWDER);
+ private static final RecipeItemStack c = RecipeItemStack.a(Items.FIREWORK_STAR);
+ // CraftBukkit start - Delegate to new parent class with bogus info
public RecipeFireworks(MinecraftKey minecraftkey) {
diff --git a/nms-patches/RecipeFireworksFade.patch b/nms-patches/RecipeFireworksFade.patch
index 31b863eb..d974fe8f 100644
--- a/nms-patches/RecipeFireworksFade.patch
+++ b/nms-patches/RecipeFireworksFade.patch
@@ -7,7 +7,7 @@
-public class RecipeFireworksFade extends IRecipeComplex {
+public class RecipeFireworksFade extends ShapelessRecipes implements IRecipe { // CraftBukkit - added extends
- private static final RecipeItemStack a = RecipeItemStack.a(new IMaterial[] { Items.FIREWORK_STAR});
+ private static final RecipeItemStack a = RecipeItemStack.a(Items.FIREWORK_STAR);
+ // CraftBukkit start - Delegate to new parent class with bogus info
public RecipeFireworksFade(MinecraftKey minecraftkey) {
diff --git a/nms-patches/RecipeFireworksStar.patch b/nms-patches/RecipeFireworksStar.patch
index e4900565..80e004ff 100644
--- a/nms-patches/RecipeFireworksStar.patch
+++ b/nms-patches/RecipeFireworksStar.patch
@@ -7,9 +7,9 @@
-public class RecipeFireworksStar extends IRecipeComplex {
+public class RecipeFireworksStar extends ShapelessRecipes implements IRecipe { // CraftBukkit - added extends
- private static final RecipeItemStack a = RecipeItemStack.a(new IMaterial[] { Items.FIRE_CHARGE, Items.FEATHER, Items.GOLD_NUGGET, Items.SKELETON_SKULL, Items.WITHER_SKELETON_SKULL, Items.CREEPER_HEAD, Items.PLAYER_HEAD, Items.DRAGON_HEAD, Items.ZOMBIE_HEAD});
- private static final RecipeItemStack b = RecipeItemStack.a(new IMaterial[] { Items.DIAMOND});
- private static final RecipeItemStack c = RecipeItemStack.a(new IMaterial[] { Items.GLOWSTONE_DUST});
+ private static final RecipeItemStack a = RecipeItemStack.a(Items.FIRE_CHARGE, Items.FEATHER, Items.GOLD_NUGGET, Items.SKELETON_SKULL, Items.WITHER_SKELETON_SKULL, Items.CREEPER_HEAD, Items.PLAYER_HEAD, Items.DRAGON_HEAD, Items.ZOMBIE_HEAD);
+ private static final RecipeItemStack b = RecipeItemStack.a(Items.DIAMOND);
+ private static final RecipeItemStack c = RecipeItemStack.a(Items.GLOWSTONE_DUST);
- private static final Map<Item, ItemFireworks.EffectType> d = (Map) SystemUtils.a((Object) Maps.newHashMap(), (hashmap) -> {
+ private static final Map<Item, ItemFireworks.EffectType> d = (Map) SystemUtils.a(Maps.newHashMap(), (hashmap) -> { // CraftBukkit - decompile error
hashmap.put(Items.FIRE_CHARGE, ItemFireworks.EffectType.LARGE_BALL);
@@ -17,7 +17,7 @@
hashmap.put(Items.GOLD_NUGGET, ItemFireworks.EffectType.STAR);
@@ -26,9 +26,11 @@
});
- private static final RecipeItemStack e = RecipeItemStack.a(new IMaterial[] { Items.GUNPOWDER});
+ private static final RecipeItemStack e = RecipeItemStack.a(Items.GUNPOWDER);
+ // CraftBukkit start - Delegate to new parent class with bogus info
public RecipeFireworksStar(MinecraftKey minecraftkey) {
diff --git a/nms-patches/SpawnerCreature.patch b/nms-patches/SpawnerCreature.patch
index 2482e10f..02863545 100644
--- a/nms-patches/SpawnerCreature.patch
+++ b/nms-patches/SpawnerCreature.patch
@@ -99,7 +99,7 @@
} else {
entityinsentient.die();
}
-@@ -260,7 +296,7 @@
+@@ -259,7 +295,7 @@
entityinsentient.setPositionRotation(d0, (double) blockposition.getY(), d1, random.nextFloat() * 360.0F, 0.0F);
if (entityinsentient.a(generatoraccess, false) && entityinsentient.a((IWorldReader) generatoraccess)) {
groupdataentity = entityinsentient.prepare(generatoraccess.getDamageScaler(new BlockPosition(entityinsentient)), groupdataentity, (NBTTagCompound) null);
diff --git a/nms-patches/TileEntityBrewingStand.patch b/nms-patches/TileEntityBrewingStand.patch
index 527d9d4b..07d875a4 100644
--- a/nms-patches/TileEntityBrewingStand.patch
+++ b/nms-patches/TileEntityBrewingStand.patch
@@ -63,7 +63,7 @@
+ return;
+ }
+
-+ this.fuelLevel = event.getFuelPower(); // PAIL fuelLevel
++ this.fuelLevel = event.getFuelPower();
+ if (this.fuelLevel > 0 && event.isConsuming()) {
+ itemstack.subtract(1);
+ }
diff --git a/nms-patches/TileEntityEndGateway.patch b/nms-patches/TileEntityEndGateway.patch
index 5487c6ed..585f0f16 100644
--- a/nms-patches/TileEntityEndGateway.patch
+++ b/nms-patches/TileEntityEndGateway.patch
@@ -1,6 +1,6 @@
--- a/net/minecraft/server/TileEntityEndGateway.java
+++ b/net/minecraft/server/TileEntityEndGateway.java
-@@ -6,11 +6,17 @@
+@@ -6,6 +6,12 @@
import javax.annotation.Nullable;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
@@ -13,12 +13,6 @@
public class TileEntityEndGateway extends TileEntityEnderPortal implements ITickable {
- private static final Logger a = LogManager.getLogger();
-- private long e;
-+ public long e; // PAIL
- private int f;
- public BlockPosition exitPortal;
- public boolean exactTeleport;
@@ -113,6 +119,26 @@
if (this.exitPortal != null) {
BlockPosition blockposition = this.exactTeleport ? this.exitPortal : this.i();
diff --git a/nms-patches/TileEntityFurnace.patch b/nms-patches/TileEntityFurnace.patch
index f23a4027..e71bc3fd 100644
--- a/nms-patches/TileEntityFurnace.patch
+++ b/nms-patches/TileEntityFurnace.patch
@@ -83,7 +83,7 @@
@@ -270,6 +315,7 @@
if (flag != this.isBurning()) {
flag1 = true;
- this.world.setTypeAndData(this.position, (IBlockData) this.world.getType(this.position).set(BlockFurnace.LIT, Boolean.valueOf(this.isBurning())), 3);
+ this.world.setTypeAndData(this.position, (IBlockData) this.world.getType(this.position).set(BlockFurnace.LIT, this.isBurning()), 3);
+ this.invalidateBlockCache(); // CraftBukkit - Invalidate tile entity's cached block type
}
}
diff --git a/nms-patches/TileEntityShulkerBox.patch b/nms-patches/TileEntityShulkerBox.patch
index bb9e5db4..435fe1e2 100644
--- a/nms-patches/TileEntityShulkerBox.patch
+++ b/nms-patches/TileEntityShulkerBox.patch
@@ -43,7 +43,7 @@
public TileEntityShulkerBox(@Nullable EnumColor enumcolor) {
super(TileEntityTypes.SHULKER_BOX);
this.e = NonNullList.a(27, ItemStack.a);
-@@ -148,7 +177,7 @@
+@@ -143,7 +172,7 @@
}
public int getMaxStackSize() {
diff --git a/nms-patches/World.patch b/nms-patches/World.patch
index d017d986..012f4cfe 100644
--- a/nms-patches/World.patch
+++ b/nms-patches/World.patch
@@ -237,7 +237,7 @@
+ // CraftBukkit end
+
public boolean setAir(BlockPosition blockposition) {
- Fluid fluid = this.b(blockposition);
+ Fluid fluid = this.getFluid(blockposition);
@@ -234,6 +412,11 @@
@@ -392,8 +392,8 @@
try {
++entity.ticksLived;
@@ -804,8 +1067,10 @@
- CrashReportSystemDetails crashreportsystemdetails1;
CrashReport crashreport1;
+ CrashReportSystemDetails crashreportsystemdetails1;
- for (i = 0; i < this.entityList.size(); ++i) {
- entity = (Entity) this.entityList.get(i);
diff --git a/nms-patches/WorldData.patch b/nms-patches/WorldData.patch
index fbd4882b..68d3fb5d 100644
--- a/nms-patches/WorldData.patch
+++ b/nms-patches/WorldData.patch
@@ -83,7 +83,7 @@
}
public boolean isDifficultyLocked() {
-@@ -724,4 +758,12 @@
+@@ -723,4 +757,12 @@
public void c(@Nullable NBTTagCompound nbttagcompound) {
this.U = nbttagcompound;
}
diff --git a/nms-patches/WorldGenVillagePieces.patch b/nms-patches/WorldGenVillagePieces.patch
index e55f15ce..6a889953 100644
--- a/nms-patches/WorldGenVillagePieces.patch
+++ b/nms-patches/WorldGenVillagePieces.patch
@@ -1,6 +1,6 @@
--- a/net/minecraft/server/WorldGenVillagePieces.java
+++ b/net/minecraft/server/WorldGenVillagePieces.java
-@@ -1662,14 +1662,14 @@
+@@ -1647,14 +1647,14 @@
entityzombievillager.prepare(generatoraccess.getDamageScaler(new BlockPosition(entityzombievillager)), (GroupDataEntity) null, (NBTTagCompound) null);
entityzombievillager.setProfession(this.c(i1, 0));
entityzombievillager.di();
diff --git a/nms-patches/WorldGenWitchHut.patch b/nms-patches/WorldGenWitchHut.patch
index 70c91680..e3b94d87 100644
--- a/nms-patches/WorldGenWitchHut.patch
+++ b/nms-patches/WorldGenWitchHut.patch
@@ -2,8 +2,8 @@
+++ b/net/minecraft/server/WorldGenWitchHut.java
@@ -86,7 +86,7 @@
entitywitch.di();
- entitywitch.setPositionRotation((double) i + 0.5D, (double) j, (double) k + 0.5D, 0.0F, 0.0F);
- entitywitch.prepare(generatoraccess.getDamageScaler(new BlockPosition(i, j, k)), (GroupDataEntity) null, (NBTTagCompound) null);
+ entitywitch.setPositionRotation((double) j + 0.5D, (double) i, (double) k + 0.5D, 0.0F, 0.0F);
+ entitywitch.prepare(generatoraccess.getDamageScaler(new BlockPosition(j, i, k)), (GroupDataEntity) null, (NBTTagCompound) null);
- generatoraccess.addEntity(entitywitch);
+ generatoraccess.addEntity(entitywitch, org.bukkit.event.entity.CreatureSpawnEvent.SpawnReason.CHUNK_GEN); // CraftBukkit - add SpawnReason
}