diff options
228 files changed, 6143 insertions, 5159 deletions
diff --git a/maps.yml b/maps.yml new file mode 100644 index 00000000..d52675af --- /dev/null +++ b/maps.yml @@ -0,0 +1,15 @@ +members: + "org/bukkit/entity/Damageable _INVALID_damage (I)V": damage + "org/bukkit/entity/Damageable _INVALID_damage (ILorg/bukkit/entity/Entity;)V": damage + "org/bukkit/entity/Damageable _INVALID_getHealth ()I": getHealth + "org/bukkit/entity/Damageable _INVALID_setHealth (I)V": setHealth + "org/bukkit/entity/Damageable _INVALID_getMaxHealth ()I": getMaxHealth + "org/bukkit/entity/Damageable _INVALID_setMaxHealth (I)V": setMaxHealth + "org/bukkit/entity/LivingEntity _INVALID_getLastDamage ()I": getLastDamage + "org/bukkit/entity/LivingEntity _INVALID_setLastDamage (I)V": setLastDamage + "org/bukkit/event/entity/EntityDamageEvent _INVALID_getDamage ()I": getDamage + "org/bukkit/event/entity/EntityDamageEvent _INVALID_setDamage (I)V": setDamage + "org/bukkit/event/vehicle/VehicleDamageEvent _INVALID_getDamage ()I": getDamage + "org/bukkit/event/vehicle/VehicleDamageEvent _INVALID_setDamage (I)V": setDamage + "org/bukkit/event/entity/EntityRegainHealthEvent _INVALID_getAmount ()I": getAmount + "org/bukkit/event/entity/EntityRegainHealthEvent _INVALID_setAmount (I)V": setAmount @@ -4,7 +4,7 @@ <groupId>org.bukkit</groupId> <artifactId>craftbukkit</artifactId> <packaging>jar</packaging> - <version>1.5.2-R1.1-SNAPSHOT</version> + <version>1.6.1-R0.1-SNAPSHOT</version> <name>CraftBukkit</name> <url>http://www.bukkit.org</url> @@ -12,8 +12,8 @@ <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <api.version>unknown</api.version> <junit.version>4.11</junit.version> - <minecraft.version>1.5.2</minecraft.version> - <minecraft_version>1_5_R3</minecraft_version> + <minecraft.version>1.6.1</minecraft.version> + <minecraft_version>1_6_R1</minecraft_version> </properties> <scm> @@ -206,7 +206,7 @@ </manifestSections> </archive> </configuration> - </plugin> + </plugin> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-shade-plugin</artifactId> @@ -278,8 +278,8 @@ <artifactId>maven-compiler-plugin</artifactId> <version>2.0.2</version> <configuration> - <source>1.5</source> - <target>1.5</target> + <source>1.6</source> + <target>1.6</target> </configuration> </plugin> <plugin> @@ -294,6 +294,24 @@ </excludes> </configuration> </plugin> + <plugin> + <groupId>com.wolvereness</groupId> + <artifactId>overmapped</artifactId> + <version>0.0.1</version> + <executions> + <execution> + <phase>package</phase> + <goals> + <goal>map</goal> + </goals> + <configuration> + <maps>${basedir}/maps.yml</maps> + <input>${basedir}/target/${project.artifactId}-${project.version}.jar</input> + <original>${basedir}/target/unmapped-${project.artifactId}-${project.version}.jar</original> + </configuration> + </execution> + </executions> + </plugin> </plugins> <pluginManagement> <plugins> diff --git a/src/main/java/net/minecraft/server/AABBPool.java b/src/main/java/net/minecraft/server/AABBPool.java index ed6ffd36..e3b765c6 100644 --- a/src/main/java/net/minecraft/server/AABBPool.java +++ b/src/main/java/net/minecraft/server/AABBPool.java @@ -8,9 +8,9 @@ public class AABBPool { private final int a; private final int b; private final List pool = new ArrayList(); - private int d = 0; - private int largestSize = 0; - private int resizeTime = 0; + private int d; + private int largestSize; + private int resizeTime; public AABBPool(int i, int j) { this.a = i; diff --git a/src/main/java/net/minecraft/server/Block.java b/src/main/java/net/minecraft/server/Block.java index 4392cb2d..2a85c1c1 100644 --- a/src/main/java/net/minecraft/server/Block.java +++ b/src/main/java/net/minecraft/server/Block.java @@ -6,188 +6,194 @@ import java.util.Random; public class Block { private CreativeModeTab creativeTab; - public static final StepSound f = new StepSound("stone", 1.0F, 1.0F); - public static final StepSound g = new StepSound("wood", 1.0F, 1.0F); - public static final StepSound h = new StepSound("gravel", 1.0F, 1.0F); - public static final StepSound i = new StepSound("grass", 1.0F, 1.0F); - public static final StepSound j = new StepSound("stone", 1.0F, 1.0F); - public static final StepSound k = new StepSound("stone", 1.0F, 1.5F); - public static final StepSound l = new StepSoundStone("stone", 1.0F, 1.0F); - public static final StepSound m = new StepSound("cloth", 1.0F, 1.0F); - public static final StepSound n = new StepSound("sand", 1.0F, 1.0F); - public static final StepSound o = new StepSound("snow", 1.0F, 1.0F); - public static final StepSound p = new StepSoundLadder("ladder", 1.0F, 1.0F); - public static final StepSound q = new StepSoundAnvil("anvil", 0.3F, 1.0F); + protected String f; + public static final StepSound g = new StepSound("stone", 1.0F, 1.0F); + public static final StepSound h = new StepSound("wood", 1.0F, 1.0F); + public static final StepSound i = new StepSound("gravel", 1.0F, 1.0F); + public static final StepSound j = new StepSound("grass", 1.0F, 1.0F); + public static final StepSound k = new StepSound("stone", 1.0F, 1.0F); + public static final StepSound l = new StepSound("stone", 1.0F, 1.5F); + public static final StepSound m = new StepSoundStone("stone", 1.0F, 1.0F); + public static final StepSound n = new StepSound("cloth", 1.0F, 1.0F); + public static final StepSound o = new StepSound("sand", 1.0F, 1.0F); + public static final StepSound p = new StepSound("snow", 1.0F, 1.0F); + public static final StepSound q = new StepSoundLadder("ladder", 1.0F, 1.0F); + public static final StepSound r = new StepSoundAnvil("anvil", 0.3F, 1.0F); public static final Block[] byId = new Block[4096]; - public static final boolean[] s = new boolean[4096]; + public static final boolean[] t = new boolean[4096]; public static final int[] lightBlock = new int[4096]; - public static final boolean[] u = new boolean[4096]; + public static final boolean[] v = new boolean[4096]; public static final int[] lightEmission = new int[4096]; - public static boolean[] w = new boolean[4096]; - public static final Block STONE = (new BlockStone(1)).c(1.5F).b(10.0F).a(j).c("stone"); - public static final BlockGrass GRASS = (BlockGrass) (new BlockGrass(2)).c(0.6F).a(i).c("grass"); - public static final Block DIRT = (new BlockDirt(3)).c(0.5F).a(h).c("dirt"); - public static final Block COBBLESTONE = (new Block(4, Material.STONE)).c(2.0F).b(10.0F).a(j).c("stonebrick").a(CreativeModeTab.b); - public static final Block WOOD = (new BlockWood(5)).c(2.0F).b(5.0F).a(g).c("wood"); - public static final Block SAPLING = (new BlockSapling(6)).c(0.0F).a(i).c("sapling"); - public static final Block BEDROCK = (new Block(7, Material.STONE)).r().b(6000000.0F).a(j).c("bedrock").D().a(CreativeModeTab.b); - public static final BlockFluids WATER = (BlockFluids) (new BlockFlowing(8, Material.WATER)).c(100.0F).k(3).c("water").D(); - public static final Block STATIONARY_WATER = (new BlockStationary(9, Material.WATER)).c(100.0F).k(3).c("water").D(); - public static final BlockFluids LAVA = (BlockFluids) (new BlockFlowing(10, Material.LAVA)).c(0.0F).a(1.0F).c("lava").D(); - public static final Block STATIONARY_LAVA = (new BlockStationary(11, Material.LAVA)).c(100.0F).a(1.0F).c("lava").D(); - public static final Block SAND = (new BlockSand(12)).c(0.5F).a(n).c("sand"); - public static final Block GRAVEL = (new BlockGravel(13)).c(0.6F).a(h).c("gravel"); - public static final Block GOLD_ORE = (new BlockOre(14)).c(3.0F).b(5.0F).a(j).c("oreGold"); - public static final Block IRON_ORE = (new BlockOre(15)).c(3.0F).b(5.0F).a(j).c("oreIron"); - public static final Block COAL_ORE = (new BlockOre(16)).c(3.0F).b(5.0F).a(j).c("oreCoal"); - public static final Block LOG = (new BlockLog(17)).c(2.0F).a(g).c("log"); - public static final BlockLeaves LEAVES = (BlockLeaves) (new BlockLeaves(18)).c(0.2F).k(1).a(i).c("leaves"); - public static final Block SPONGE = (new BlockSponge(19)).c(0.6F).a(i).c("sponge"); - public static final Block GLASS = (new BlockGlass(20, Material.SHATTERABLE, false)).c(0.3F).a(l).c("glass"); - public static final Block LAPIS_ORE = (new BlockOre(21)).c(3.0F).b(5.0F).a(j).c("oreLapis"); - public static final Block LAPIS_BLOCK = (new Block(22, Material.STONE)).c(3.0F).b(5.0F).a(j).c("blockLapis").a(CreativeModeTab.b); - public static final Block DISPENSER = (new BlockDispenser(23)).c(3.5F).a(j).c("dispenser"); - public static final Block SANDSTONE = (new BlockSandStone(24)).a(j).c(0.8F).c("sandStone"); - public static final Block NOTE_BLOCK = (new BlockNote(25)).c(0.8F).c("musicBlock"); - public static final Block BED = (new BlockBed(26)).c(0.2F).c("bed").D(); - public static final Block GOLDEN_RAIL = (new BlockPoweredRail(27)).c(0.7F).a(k).c("goldenRail"); - public static final Block DETECTOR_RAIL = (new BlockMinecartDetector(28)).c(0.7F).a(k).c("detectorRail"); + public static boolean[] x = new boolean[4096]; + public static final Block STONE = (new BlockStone(1)).c(1.5F).b(10.0F).a(k).c("stone").d("stone"); + public static final BlockGrass GRASS = (BlockGrass) (new BlockGrass(2)).c(0.6F).a(j).c("grass").d("grass"); + public static final Block DIRT = (new BlockDirt(3)).c(0.5F).a(i).c("dirt").d("dirt"); + public static final Block COBBLESTONE = (new Block(4, Material.STONE)).c(2.0F).b(10.0F).a(k).c("stonebrick").a(CreativeModeTab.b).d("cobblestone"); + public static final Block WOOD = (new BlockWood(5)).c(2.0F).b(5.0F).a(h).c("wood").d("planks"); + public static final Block SAPLING = (new BlockSapling(6)).c(0.0F).a(j).c("sapling").d("sapling"); + public static final Block BEDROCK = (new Block(7, Material.STONE)).r().b(6000000.0F).a(k).c("bedrock").C().a(CreativeModeTab.b).d("bedrock"); + public static final BlockFluids WATER = (BlockFluids) (new BlockFlowing(8, Material.WATER)).c(100.0F).k(3).c("water").C().d("water_flow"); + public static final Block STATIONARY_WATER = (new BlockStationary(9, Material.WATER)).c(100.0F).k(3).c("water").C().d("water_still"); + public static final BlockFluids LAVA = (BlockFluids) (new BlockFlowing(10, Material.LAVA)).c(0.0F).a(1.0F).c("lava").C().d("lava_flow"); + public static final Block STATIONARY_LAVA = (new BlockStationary(11, Material.LAVA)).c(100.0F).a(1.0F).c("lava").C().d("lava_still"); + public static final Block SAND = (new BlockSand(12)).c(0.5F).a(o).c("sand").d("sand"); + public static final Block GRAVEL = (new BlockGravel(13)).c(0.6F).a(i).c("gravel").d("gravel"); + public static final Block GOLD_ORE = (new BlockOre(14)).c(3.0F).b(5.0F).a(k).c("oreGold").d("gold_ore"); + public static final Block IRON_ORE = (new BlockOre(15)).c(3.0F).b(5.0F).a(k).c("oreIron").d("iron_ore"); + public static final Block COAL_ORE = (new BlockOre(16)).c(3.0F).b(5.0F).a(k).c("oreCoal").d("coal_ore"); + public static final Block LOG = (new BlockLog(17)).c(2.0F).a(h).c("log").d("log"); + public static final BlockLeaves LEAVES = (BlockLeaves) (new BlockLeaves(18)).c(0.2F).k(1).a(j).c("leaves").d("leaves"); + public static final Block SPONGE = (new BlockSponge(19)).c(0.6F).a(j).c("sponge").d("sponge"); + public static final Block GLASS = (new BlockGlass(20, Material.SHATTERABLE, false)).c(0.3F).a(m).c("glass").d("glass"); + public static final Block LAPIS_ORE = (new BlockOre(21)).c(3.0F).b(5.0F).a(k).c("oreLapis").d("lapis_ore"); + public static final Block LAPIS_BLOCK = (new Block(22, Material.STONE)).c(3.0F).b(5.0F).a(k).c("blockLapis").a(CreativeModeTab.b).d("lapis_block"); + public static final Block DISPENSER = (new BlockDispenser(23)).c(3.5F).a(k).c("dispenser").d("dispenser"); + public static final Block SANDSTONE = (new BlockSandStone(24)).a(k).c(0.8F).c("sandStone").d("sandstone"); + public static final Block NOTE_BLOCK = (new BlockNote(25)).c(0.8F).c("musicBlock").d("noteblock"); + public static final Block BED = (new BlockBed(26)).c(0.2F).c("bed").C().d("bed"); + public static final Block GOLDEN_RAIL = (new BlockPoweredRail(27)).c(0.7F).a(l).c("goldenRail").d("rail_golden"); + public static final Block DETECTOR_RAIL = (new BlockMinecartDetector(28)).c(0.7F).a(l).c("detectorRail").d("rail_detector"); public static final BlockPiston PISTON_STICKY = (BlockPiston) (new BlockPiston(29, true)).c("pistonStickyBase"); - public static final Block WEB = (new BlockWeb(30)).k(1).c(4.0F).c("web"); - public static final BlockLongGrass LONG_GRASS = (BlockLongGrass) (new BlockLongGrass(31)).c(0.0F).a(i).c("tallgrass"); - public static final BlockDeadBush DEAD_BUSH = (BlockDeadBush) (new BlockDeadBush(32)).c(0.0F).a(i).c("deadbush"); + public static final Block WEB = (new BlockWeb(30)).k(1).c(4.0F).c("web").d("web"); + public static final BlockLongGrass LONG_GRASS = (BlockLongGrass) (new BlockLongGrass(31)).c(0.0F).a(j).c("tallgrass"); + public static final BlockDeadBush DEAD_BUSH = (BlockDeadBush) (new BlockDeadBush(32)).c(0.0F).a(j).c("deadbush").d("deadbush"); public static final BlockPiston PISTON = (BlockPiston) (new BlockPiston(33, false)).c("pistonBase"); public static final BlockPistonExtension PISTON_EXTENSION = new BlockPistonExtension(34); - public static final Block WOOL = (new BlockCloth()).c(0.8F).a(m).c("cloth"); + public static final Block WOOL = (new BlockCloth(35, Material.CLOTH)).c(0.8F).a(n).c("cloth").d("wool_colored"); public static final BlockPistonMoving PISTON_MOVING = new BlockPistonMoving(36); - public static final BlockFlower YELLOW_FLOWER = (BlockFlower) (new BlockFlower(37)).c(0.0F).a(i).c("flower"); - public static final BlockFlower RED_ROSE = (BlockFlower) (new BlockFlower(38)).c(0.0F).a(i).c("rose"); - public static final BlockFlower BROWN_MUSHROOM = (BlockFlower) (new BlockMushroom(39, "mushroom_brown")).c(0.0F).a(i).a(0.125F).c("mushroom"); - public static final BlockFlower RED_MUSHROOM = (BlockFlower) (new BlockMushroom(40, "mushroom_red")).c(0.0F).a(i).c("mushroom"); - public static final Block GOLD_BLOCK = (new BlockOreBlock(41)).c(3.0F).b(10.0F).a(k).c("blockGold"); - public static final Block IRON_BLOCK = (new BlockOreBlock(42)).c(5.0F).b(10.0F).a(k).c("blockIron"); - public static final BlockStepAbstract DOUBLE_STEP = (BlockStepAbstract) (new BlockStep(43, true)).c(2.0F).b(10.0F).a(j).c("stoneSlab"); - public static final BlockStepAbstract STEP = (BlockStepAbstract) (new BlockStep(44, false)).c(2.0F).b(10.0F).a(j).c("stoneSlab"); - public static final Block BRICK = (new Block(45, Material.STONE)).c(2.0F).b(10.0F).a(j).c("brick").a(CreativeModeTab.b); - public static final Block TNT = (new BlockTNT(46)).c(0.0F).a(i).c("tnt"); - public static final Block BOOKSHELF = (new BlockBookshelf(47)).c(1.5F).a(g).c("bookshelf"); - public static final Block MOSSY_COBBLESTONE = (new Block(48, Material.STONE)).c(2.0F).b(10.0F).a(j).c("stoneMoss").a(CreativeModeTab.b); - public static final Block OBSIDIAN = (new BlockObsidian(49)).c(50.0F).b(2000.0F).a(j).c("obsidian"); - public static final Block TORCH = (new BlockTorch(50)).c(0.0F).a(0.9375F).a(g).c("torch"); - public static final BlockFire FIRE = (BlockFire) (new BlockFire(51)).c(0.0F).a(1.0F).a(g).c("fire").D(); - public static final Block MOB_SPAWNER = (new BlockMobSpawner(52)).c(5.0F).a(k).c("mobSpawner").D(); + public static final BlockFlower YELLOW_FLOWER = (BlockFlower) (new BlockFlower(37)).c(0.0F).a(j).c("flower").d("flower_dandelion"); + public static final BlockFlower RED_ROSE = (BlockFlower) (new BlockFlower(38)).c(0.0F).a(j).c("rose").d("flower_rose"); + public static final BlockFlower BROWN_MUSHROOM = (BlockFlower) (new BlockMushroom(39)).c(0.0F).a(j).a(0.125F).c("mushroom").d("mushroom_brown"); + public static final BlockFlower RED_MUSHROOM = (BlockFlower) (new BlockMushroom(40)).c(0.0F).a(j).c("mushroom").d("mushroom_red"); + public static final Block GOLD_BLOCK = (new BlockOreBlock(41)).c(3.0F).b(10.0F).a(l).c("blockGold").d("gold_block"); + public static final Block IRON_BLOCK = (new BlockOreBlock(42)).c(5.0F).b(10.0F).a(l).c("blockIron").d("iron_block"); + public static final BlockStepAbstract DOUBLE_STEP = (BlockStepAbstract) (new BlockStep(43, true)).c(2.0F).b(10.0F).a(k).c("stoneSlab"); + public static final BlockStepAbstract STEP = (BlockStepAbstract) (new BlockStep(44, false)).c(2.0F).b(10.0F).a(k).c("stoneSlab"); + public static final Block BRICK = (new Block(45, Material.STONE)).c(2.0F).b(10.0F).a(k).c("brick").a(CreativeModeTab.b).d("brick"); + public static final Block TNT = (new BlockTNT(46)).c(0.0F).a(j).c("tnt").d("tnt"); + public static final Block BOOKSHELF = (new BlockBookshelf(47)).c(1.5F).a(h).c("bookshelf").d("bookshelf"); + public static final Block MOSSY_COBBLESTONE = (new Block(48, Material.STONE)).c(2.0F).b(10.0F).a(k).c("stoneMoss").a(CreativeModeTab.b).d("cobblestone_mossy"); + public static final Block OBSIDIAN = (new BlockObsidian(49)).c(50.0F).b(2000.0F).a(k).c("obsidian").d("obsidian"); + public static final Block TORCH = (new BlockTorch(50)).c(0.0F).a(0.9375F).a(h).c("torch").d("torch_on"); + public static final BlockFire FIRE = (BlockFire) (new BlockFire(51)).c(0.0F).a(1.0F).a(h).c("fire").C().d("fire"); + public static final Block MOB_SPAWNER = (new BlockMobSpawner(52)).c(5.0F).a(l).c("mobSpawner").C().d("mob_spawner"); public static final Block WOOD_STAIRS = (new BlockStairs(53, WOOD, 0)).c("stairsWood"); - public static final BlockChest CHEST = (BlockChest) (new BlockChest(54, 0)).c(2.5F).a(g).c("chest"); - public static final BlockRedstoneWire REDSTONE_WIRE = (BlockRedstoneWire) (new BlockRedstoneWire(55)).c(0.0F).a(f).c("redstoneDust").D(); - public static final Block DIAMOND_ORE = (new BlockOre(56)).c(3.0F).b(5.0F).a(j).c("oreDiamond"); - public static final Block DIAMOND_BLOCK = (new BlockOreBlock(57)).c(5.0F).b(10.0F).a(k).c("blockDiamond"); - public static final Block WORKBENCH = (new BlockWorkbench(58)).c(2.5F).a(g).c("workbench"); - public static final Block CROPS = (new BlockCrops(59)).c("crops"); - public static final Block SOIL = (new BlockSoil(60)).c(0.6F).a(h).c("farmland"); - public static final Block FURNACE = (new BlockFurnace(61, false)).c(3.5F).a(j).c("furnace").a(CreativeModeTab.c); - public static final Block BURNING_FURNACE = (new BlockFurnace(62, true)).c(3.5F).a(j).a(0.875F).c("furnace"); - public static final Block SIGN_POST = (new BlockSign(63, TileEntitySign.class, true)).c(1.0F).a(g).c("sign").D(); - public static final Block WOODEN_DOOR = (new BlockDoor(64, Material.WOOD)).c(3.0F).a(g).c("doorWood").D(); - public static final Block LADDER = (new BlockLadder(65)).c(0.4F).a(p).c("ladder"); - public static final Block RAILS = (new BlockMinecartTrack(66)).c(0.7F).a(k).c("rail"); + public static final BlockChest CHEST = (BlockChest) (new BlockChest(54, 0)).c(2.5F).a(h).c("chest"); + public static final BlockRedstoneWire REDSTONE_WIRE = (BlockRedstoneWire) (new BlockRedstoneWire(55)).c(0.0F).a(g).c("redstoneDust").C().d("redstone_dust"); + public static final Block DIAMOND_ORE = (new BlockOre(56)).c(3.0F).b(5.0F).a(k).c("oreDiamond").d("diamond_ore"); + public static final Block DIAMOND_BLOCK = (new BlockOreBlock(57)).c(5.0F).b(10.0F).a(l).c("blockDiamond").d("diamond_block"); + public static final Block WORKBENCH = (new BlockWorkbench(58)).c(2.5F).a(h).c("workbench").d("crafting_table"); + public static final Block CROPS = (new BlockCrops(59)).c("crops").d("wheat"); + public static final Block SOIL = (new BlockSoil(60)).c(0.6F).a(i).c("farmland").d("farmland"); + public static final Block FURNACE = (new BlockFurnace(61, false)).c(3.5F).a(k).c("furnace").a(CreativeModeTab.c); + public static final Block BURNING_FURNACE = (new BlockFurnace(62, true)).c(3.5F).a(k).a(0.875F).c("furnace"); + public static final Block SIGN_POST = (new BlockSign(63, TileEntitySign.class, true)).c(1.0F).a(h).c("sign").C(); + public static final Block WOODEN_DOOR = (new BlockDoor(64, Material.WOOD)).c(3.0F).a(h).c("doorWood").C().d("door_wood"); + public static final Block LADDER = (new BlockLadder(65)).c(0.4F).a(q).c("ladder").d("ladder"); + public static final Block RAILS = (new BlockMinecartTrack(66)).c(0.7F).a(l).c("rail").d("rail_normal"); public static final Block COBBLESTONE_STAIRS = (new BlockStairs(67, COBBLESTONE, 0)).c("stairsStone"); - public static final Block WALL_SIGN = (new BlockSign(68, TileEntitySign.class, false)).c(1.0F).a(g).c("sign").D(); - public static final Block LEVER = (new BlockLever(69)).c(0.5F).a(g).c("lever"); - public static final Block STONE_PLATE = (new BlockPressurePlateBinary(70, "stone", Material.STONE, EnumMobType.MOBS)).c(0.5F).a(j).c("pressurePlate"); - public static final Block IRON_DOOR_BLOCK = (new BlockDoor(71, Material.ORE)).c(5.0F).a(k).c("doorIron").D(); - public static final Block WOOD_PLATE = (new BlockPressurePlateBinary(72, "wood", Material.WOOD, EnumMobType.EVERYTHING)).c(0.5F).a(g).c("pressurePlate"); - public static final Block REDSTONE_ORE = (new BlockRedstoneOre(73, false)).c(3.0F).b(5.0F).a(j).c("oreRedstone").a(CreativeModeTab.b); - public static final Block GLOWING_REDSTONE_ORE = (new BlockRedstoneOre(74, true)).a(0.625F).c(3.0F).b(5.0F).a(j).c("oreRedstone"); - public static final Block REDSTONE_TORCH_OFF = (new BlockRedstoneTorch(75, false)).c(0.0F).a(g).c("notGate"); - public static final Block REDSTONE_TORCH_ON = (new BlockRedstoneTorch(76, true)).c(0.0F).a(0.5F).a(g).c("notGate").a(CreativeModeTab.d); - public static final Block STONE_BUTTON = (new BlockStoneButton(77)).c(0.5F).a(j).c("button"); - public static final Block SNOW = (new BlockSnow(78)).c(0.1F).a(o).c("snow").k(0); - public static final Block ICE = (new BlockIce(79)).c(0.5F).k(3).a(l).c("ice"); - public static final Block SNOW_BLOCK = (new BlockSnowBlock(80)).c(0.2F).a(o).c("snow"); - public static final Block CACTUS = (new BlockCactus(81)).c(0.4F).a(m).c("cactus"); - public static final Block CLAY = (new BlockClay(82)).c(0.6F).a(h).c("clay"); - public static final Block SUGAR_CANE_BLOCK = (new BlockReed(83)).c(0.0F).a(i).c("reeds").D(); - public static final Block JUKEBOX = (new BlockJukeBox(84)).c(2.0F).b(10.0F).a(j).c("jukebox"); - public static final Block FENCE = (new BlockFence(85, "wood", Material.WOOD)).c(2.0F).b(5.0F).a(g).c("fence"); - public static final Block PUMPKIN = (new BlockPumpkin(86, false)).c(1.0F).a(g).c("pumpkin"); - public static final Block NETHERRACK = (new BlockBloodStone(87)).c(0.4F).a(j).c("hellrock"); - public static final Block SOUL_SAND = (new BlockSlowSand(88)).c(0.5F).a(n).c("hellsand"); - public static final Block GLOWSTONE = (new BlockLightStone(89, Material.SHATTERABLE)).c(0.3F).a(l).a(1.0F).c("lightgem"); - public static final BlockPortal PORTAL = (BlockPortal) (new BlockPortal(90)).c(-1.0F).a(l).a(0.75F).c("portal"); - public static final Block JACK_O_LANTERN = (new BlockPumpkin(91, true)).c(1.0F).a(g).a(1.0F).c("litpumpkin"); - public static final Block CAKE_BLOCK = (new BlockCake(92)).c(0.5F).a(m).c("cake").D(); - public static final BlockRepeater DIODE_OFF = (BlockRepeater) (new BlockRepeater(93, false)).c(0.0F).a(g).c("diode").D(); - public static final BlockRepeater DIODE_ON = (BlockRepeater) (new BlockRepeater(94, true)).c(0.0F).a(0.625F).a(g).c("diode").D(); - public static final Block LOCKED_CHEST = (new BlockLockedChest(95)).c(0.0F).a(1.0F).a(g).c("lockedchest").b(true); - public static final Block TRAP_DOOR = (new BlockTrapdoor(96, Material.WOOD)).c(3.0F).a(g).c("trapdoor").D(); + public static final Block WALL_SIGN = (new BlockSign(68, TileEntitySign.class, false)).c(1.0F).a(h).c("sign").C(); + public static final Block LEVER = (new BlockLever(69)).c(0.5F).a(h).c("lever").d("lever"); + public static final Block STONE_PLATE = (new BlockPressurePlateBinary(70, "stone", Material.STONE, EnumMobType.MOBS)).c(0.5F).a(k).c("pressurePlate"); + public static final Block IRON_DOOR_BLOCK = (new BlockDoor(71, Material.ORE)).c(5.0F).a(l).c("doorIron").C().d("door_iron"); + public static final Block WOOD_PLATE = (new BlockPressurePlateBinary(72, "planks_oak", Material.WOOD, EnumMobType.EVERYTHING)).c(0.5F).a(h).c("pressurePlate"); + public static final Block REDSTONE_ORE = (new BlockRedstoneOre(73, false)).c(3.0F).b(5.0F).a(k).c("oreRedstone").a(CreativeModeTab.b).d("redstone_ore"); + public static final Block GLOWING_REDSTONE_ORE = (new BlockRedstoneOre(74, true)).a(0.625F).c(3.0F).b(5.0F).a(k).c("oreRedstone").d("redstone_ore"); + public static final Block REDSTONE_TORCH_OFF = (new BlockRedstoneTorch(75, false)).c(0.0F).a(h).c("notGate").d("redstone_torch_off"); + public static final Block REDSTONE_TORCH_ON = (new BlockRedstoneTorch(76, true)).c(0.0F).a(0.5F).a(h).c("notGate").a(CreativeModeTab.d).d("redstone_torch_on"); + public static final Block STONE_BUTTON = (new BlockStoneButton(77)).c(0.5F).a(k).c("button"); + public static final Block SNOW = (new BlockSnow(78)).c(0.1F).a(p).c("snow").k(0).d("snow"); + public static final Block ICE = (new BlockIce(79)).c(0.5F).k(3).a(m).c("ice").d("ice"); + public static final Block SNOW_BLOCK = (new BlockSnowBlock(80)).c(0.2F).a(p).c("snow").d("snow"); + public static final Block CACTUS = (new BlockCactus(81)).c(0.4F).a(n).c("cactus").d("cactus"); + public static final Block CLAY = (new BlockClay(82)).c(0.6F).a(i).c("clay").d("clay"); + public static final Block SUGAR_CANE_BLOCK = (new BlockReed(83)).c(0.0F).a(j).c("reeds").C().d("reeds"); + public static final Block JUKEBOX = (new BlockJukeBox(84)).c(2.0F).b(10.0F).a(k).c("jukebox").d("jukebox"); + public static final Block FENCE = (new BlockFence(85, "planks_oak", Material.WOOD)).c(2.0F).b(5.0F).a(h).c("fence"); + public static final Block PUMPKIN = (new BlockPumpkin(86, false)).c(1.0F).a(h).c("pumpkin").d("pumpkin"); + public static final Block NETHERRACK = (new BlockBloodStone(87)).c(0.4F).a(k).c("hellrock").d("netherrack"); + public static final Block SOUL_SAND = (new BlockSlowSand(88)).c(0.5F).a(o).c("hellsand").d("soul_sand"); + public static final Block GLOWSTONE = (new BlockLightStone(89, Material.SHATTERABLE)).c(0.3F).a(m).a(1.0F).c("lightgem").d("glowstone"); + public static final BlockPortal PORTAL = (BlockPortal) (new BlockPortal(90)).c(-1.0F).a(m).a(0.75F).c("portal").d("portal"); + public static final Block JACK_O_LANTERN = (new BlockPumpkin(91, true)).c(1.0F).a(h).a(1.0F).c("litpumpkin").d("pumpkin"); + public static final Block CAKE_BLOCK = (new BlockCake(92)).c(0.5F).a(n).c("cake").C().d("cake"); + public static final BlockRepeater DIODE_OFF = (BlockRepeater) (new BlockRepeater(93, false)).c(0.0F).a(h).c("diode").C().d("repeater_off"); + public static final BlockRepeater DIODE_ON = (BlockRepeater) (new BlockRepeater(94, true)).c(0.0F).a(0.625F).a(h).c("diode").C().d("repeater_on"); + public static final Block LOCKED_CHEST = (new BlockLockedChest(95)).c(0.0F).a(1.0F).a(h).c("lockedchest").b(true); + public static final Block TRAP_DOOR = (new BlockTrapdoor(96, Material.WOOD)).c(3.0F).a(h).c("trapdoor").C().d("trapdoor"); public static final Block MONSTER_EGGS = (new BlockMonsterEggs(97)).c(0.75F).c("monsterStoneEgg"); - public static final Block SMOOTH_BRICK = (new BlockSmoothBrick(98)).c(1.5F).b(10.0F).a(j).c("stonebricksmooth"); - public static final Block BIG_MUSHROOM_1 = (new BlockHugeMushroom(99, Material.WOOD, 0)).c(0.2F).a(g).c("mushroom"); - public static final Block BIG_MUSHROOM_2 = (new BlockHugeMushroom(100, Material.WOOD, 1)).c(0.2F).a(g).c("mushroom"); - public static final Block IRON_FENCE = (new BlockThinFence(101, "fenceIron", "fenceIron", Material.ORE, true)).c(5.0F).b(10.0F).a(k).c("fenceIron"); - public static final Block THIN_GLASS = (new BlockThinFence(102, "glass", "thinglass_top", Material.SHATTERABLE, false)).c(0.3F).a(l).c("thinGlass"); - public static final Block MELON = (new BlockMelon(103)).c(1.0F).a(g).c("melon"); - public static final Block PUMPKIN_STEM = (new BlockStem(104, PUMPKIN)).c(0.0F).a(g).c("pumpkinStem"); - public static final Block MELON_STEM = (new BlockStem(105, MELON)).c(0.0F).a(g).c("pumpkinStem"); - public static final Block VINE = (new BlockVine(106)).c(0.2F).a(i).c("vine"); - public static final Block FENCE_GATE = (new BlockFenceGate(107)).c(2.0F).b(5.0F).a(g).c("fenceGate"); + public static final Block SMOOTH_BRICK = (new BlockSmoothBrick(98)).c(1.5F).b(10.0F).a(k).c("stonebricksmooth").d("stonebrick"); + public static final Block BIG_MUSHROOM_1 = (new BlockHugeMushroom(99, Material.WOOD, 0)).c(0.2F).a(h).c("mushroom").d("mushroom_block"); + public static final Block BIG_MUSHROOM_2 = (new BlockHugeMushroom(100, Material.WOOD, 1)).c(0.2F).a(h).c("mushroom").d("mushroom_block"); + public static final Block IRON_FENCE = (new BlockThinFence(101, "iron_bars", "iron_bars", Material.ORE, true)).c(5.0F).b(10.0F).a(l).c("fenceIron"); + public static final Block THIN_GLASS = (new BlockThinFence(102, "glass", "glass_pane_top", Material.SHATTERABLE, false)).c(0.3F).a(m).c("thinGlass"); + public static final Block MELON = (new BlockMelon(103)).c(1.0F).a(h).c("melon").d("melon"); + public static final Block PUMPKIN_STEM = (new BlockStem(104, PUMPKIN)).c(0.0F).a(h).c("pumpkinStem").d("pumpkin_stem"); + public static final Block MELON_STEM = (new BlockStem(105, MELON)).c(0.0F).a(h).c("pumpkinStem").d("melon_stem"); + public static final Block VINE = (new BlockVine(106)).c(0.2F).a(j).c("vine").d("vine"); + public static final Block FENCE_GATE = (new BlockFenceGate(107)).c(2.0F).b(5.0F).a(h).c("fenceGate"); public static final Block BRICK_STAIRS = (new BlockStairs(108, BRICK, 0)).c("stairsBrick"); public static final Block STONE_STAIRS = (new BlockStairs(109, SMOOTH_BRICK, 0)).c("stairsStoneBrickSmooth"); - public static final BlockMycel MYCEL = (BlockMycel) (new BlockMycel(110)).c(0.6F).a(i).c("mycel"); - public static final Block WATER_LILY = (new BlockWaterLily(111)).c(0.0F).a(i).c("waterlily"); - public static final Block NETHER_BRICK = (new Block(112, Material.STONE)).c(2.0F).b(10.0F).a(j).c("netherBrick").a(CreativeModeTab.b); - public static final Block NETHER_FENCE = (new BlockFence(113, "netherBrick", Material.STONE)).c(2.0F).b(10.0F).a(j).c("netherFence"); + public static final BlockMycel MYCEL = (BlockMycel) (new BlockMycel(110)).c(0.6F).a(j).c("mycel").d("mycelium"); + public static final Block WATER_LILY = (new BlockWaterLily(111)).c(0.0F).a(j).c("waterlily").d("waterlily"); + public static final Block NETHER_BRICK = (new Block(112, Material.STONE)).c(2.0F).b(10.0F).a(k).c("netherBrick").a(CreativeModeTab.b).d("nether_brick"); + public static final Block NETHER_FENCE = (new BlockFence(113, "nether_brick", Material.STONE)).c(2.0F).b(10.0F).a(k).c("netherFence"); public static final Block NETHER_BRICK_STAIRS = (new BlockStairs(114, NETHER_BRICK, 0)).c("stairsNetherBrick"); - public static final Block NETHER_WART = (new BlockNetherWart(115)).c("netherStalk"); - public static final Block ENCHANTMENT_TABLE = (new BlockEnchantmentTable(116)).c(5.0F).b(2000.0F).c("enchantmentTable"); - public static final Block BREWING_STAND = (new BlockBrewingStand(117)).c(0.5F).a(0.125F).c("brewingStand"); - public static final BlockCauldron CAULDRON = (BlockCauldron) (new BlockCauldron(118)).c(2.0F).c("cauldron"); + public static final Block NETHER_WART = (new BlockNetherWart(115)).c("netherStalk").d("nether_wart"); + public static final Block ENCHANTMENT_TABLE = (new BlockEnchantmentTable(116)).c(5.0F).b(2000.0F).c("enchantmentTable").d("enchanting_table"); + public static final Block BREWING_STAND = (new BlockBrewingStand(117)).c(0.5F).a(0.125F).c("brewingStand").d("brewing_stand"); + public static final BlockCauldron CAULDRON = (BlockCauldron) (new BlockCauldron(118)).c(2.0F).c("cauldron").d("cauldron"); public static final Block ENDER_PORTAL = (new BlockEnderPortal(119, Material.PORTAL)).c(-1.0F).b(6000000.0F); - public static final Block ENDER_PORTAL_FRAME = (new BlockEnderPortalFrame(120)).a(l).a(0.125F).c(-1.0F).c("endPortalFrame").b(6000000.0F).a(CreativeModeTab.c); - public static final Block WHITESTONE = (new Block(121, Material.STONE)).c(3.0F).b(15.0F).a(j).c("whiteStone").a(CreativeModeTab.b); - public static final Block DRAGON_EGG = (new BlockDragonEgg(122)).c(3.0F).b(15.0F).a(j).a(0.125F).c("dragonEgg"); - public static final Block REDSTONE_LAMP_OFF = (new BlockRedstoneLamp(123, false)).c(0.3F).a(l).c("redstoneLight").a(CreativeModeTab.d); - public static final Block REDSTONE_LAMP_ON = (new BlockRedstoneLamp(124, true)).c(0.3F).a(l).c("redstoneLight"); - public static final BlockStepAbstract WOOD_DOUBLE_STEP = (BlockStepAbstract) (new BlockWoodStep(125, true)).c(2.0F).b(5.0F).a(g).c("woodSlab"); - public static final BlockStepAbstract WOOD_STEP = (BlockStepAbstract) (new BlockWoodStep(126, false)).c(2.0F).b(5.0F).a(g).c("woodSlab"); - public static final Block COCOA = (new BlockCocoa(127)).c(0.2F).b(5.0F).a(g).c("cocoa"); + public static final Block ENDER_PORTAL_FRAME = (new BlockEnderPortalFrame(120)).a(m).a(0.125F).c(-1.0F).c("endPortalFrame").b(6000000.0F).a(CreativeModeTab.c).d("endframe"); + public static final Block WHITESTONE = (new Block(121, Material.STONE)).c(3.0F).b(15.0F).a(k).c("whiteStone").a(CreativeModeTab.b).d("end_stone"); + public static final Block DRAGON_EGG = (new BlockDragonEgg(122)).c(3.0F).b(15.0F).a(k).a(0.125F).c("dragonEgg").d("dragon_egg"); + public static final Block REDSTONE_LAMP_OFF = (new BlockRedstoneLamp(123, false)).c(0.3F).a(m).c("redstoneLight").a(CreativeModeTab.d).d("redstone_lamp_off"); + public static final Block REDSTONE_LAMP_ON = (new BlockRedstoneLamp(124, true)).c(0.3F).a(m).c("redstoneLight").d("redstone_lamp_on"); + public static final BlockStepAbstract WOOD_DOUBLE_STEP = (BlockStepAbstract) (new BlockWoodStep(125, true)).c(2.0F).b(5.0F).a(h).c("woodSlab"); + public static final BlockStepAbstract WOOD_STEP = (BlockStepAbstract) (new BlockWoodStep(126, false)).c(2.0F).b(5.0F).a(h).c("woodSlab"); + public static final Block COCOA = (new BlockCocoa(127)).c(0.2F).b(5.0F).a(h).c("cocoa").d("cocoa"); public static final Block SANDSTONE_STAIRS = (new BlockStairs(128, SANDSTONE, 0)).c("stairsSandStone"); - public static final Block EMERALD_ORE = (new BlockOre(129)).c(3.0F).b(5.0F).a(j).c("oreEmerald"); - public static final Block ENDER_CHEST = (new BlockEnderChest(130)).c(22.5F).b(1000.0F).a(j).c("enderChest").a(0.5F); - public static final BlockTripwireHook TRIPWIRE_SOURCE = (BlockTripwireHook) (new BlockTripwireHook(131)).c("tripWireSource"); - public static final Block TRIPWIRE = (new BlockTripwire(132)).c("tripWire"); - public static final Block EMERALD_BLOCK = (new BlockOreBlock(133)).c(5.0F).b(10.0F).a(k).c("blockEmerald"); + public static final Block EMERALD_ORE = (new BlockOre(129)).c(3.0F).b(5.0F).a(k).c("oreEmerald").d("emerald_ore"); + public static final Block ENDER_CHEST = (new BlockEnderChest(130)).c(22.5F).b(1000.0F).a(k).c("enderChest").a(0.5F); + public static final BlockTripwireHook TRIPWIRE_SOURCE = (BlockTripwireHook) (new BlockTripwireHook(131)).c("tripWireSource").d("trip_wire_source"); + public static final Block TRIPWIRE = (new BlockTripwire(132)).c("tripWire").d("trip_wire"); + public static final Block EMERALD_BLOCK = (new BlockOreBlock(133)).c(5.0F).b(10.0F).a(l).c("blockEmerald").d("emerald_block"); public static final Block SPRUCE_WOOD_STAIRS = (new BlockStairs(134, WOOD, 1)).c("stairsWoodSpruce"); public static final Block BIRCH_WOOD_STAIRS = (new BlockStairs(135, WOOD, 2)).c("stairsWoodBirch"); public static final Block JUNGLE_WOOD_STAIRS = (new BlockStairs(136, WOOD, 3)).c("stairsWoodJungle"); - public static final Block COMMAND = (new BlockCommand(137)).c("commandBlock"); - public static final BlockBeacon BEACON = (BlockBeacon) (new BlockBeacon(138)).c("beacon").a(1.0F); + public static final Block COMMAND = (new BlockCommand(137)).r().b(6000000.0F).c("commandBlock").d("command_block"); + public static final BlockBeacon BEACON = (BlockBeacon) (new BlockBeacon(138)).c("beacon").a(1.0F).d("beacon"); public static final Block COBBLE_WALL = (new BlockCobbleWall(139, COBBLESTONE)).c("cobbleWall"); - public static final Block FLOWER_POT = (new BlockFlowerPot(140)).c(0.0F).a(f).c("flowerPot"); - public static final Block CARROTS = (new BlockCarrots(141)).c("carrots"); - public static final Block POTATOES = (new BlockPotatoes(142)).c("potatoes"); - public static final Block WOOD_BUTTON = (new BlockWoodButton(143)).c(0.5F).a(g).c("button"); - public static final Block SKULL = (new BlockSkull(144)).c(1.0F).a(j).c("skull"); - public static final Block ANVIL = (new BlockAnvil(145)).c(5.0F).a(q).b(2000.0F).c("anvil"); - public static final Block TRAPPED_CHEST = (new BlockChest(146, 1)).c(2.5F).a(g).c("chestTrap"); - public static final Block GOLD_PLATE = (new BlockPressurePlateWeighted(147, "blockGold", Material.ORE, 64)).c(0.5F).a(g).c("weightedPlate_light"); - public static final Block IRON_PLATE = (new BlockPressurePlateWeighted(148, "blockIron", Material.ORE, 640)).c(0.5F).a(g).c("weightedPlate_heavy"); - public static final BlockRedstoneComparator REDSTONE_COMPARATOR_OFF = (BlockRedstoneComparator) (new BlockRedstoneComparator(149, false)).c(0.0F).a(g).c("comparator").D(); - public static final BlockRedstoneComparator REDSTONE_COMPARATOR_ON = (BlockRedstoneComparator) (new BlockRedstoneComparator(150, true)).c(0.0F).a(0.625F).a(g).c("comparator").D(); - public static final BlockDaylightDetector DAYLIGHT_DETECTOR = (BlockDaylightDetector) (new BlockDaylightDetector(151)).c(0.2F).a(g).c("daylightDetector"); - public static final Block REDSTONE_BLOCK = (new BlockRedstone(152)).c(5.0F).b(10.0F).a(k).c("blockRedstone"); - public static final Block QUARTZ_ORE = (new BlockOre(153)).c(3.0F).b(5.0F).a(j).c("netherquartz"); - public static final BlockHopper HOPPER = (BlockHopper) (new BlockHopper(154)).c(3.0F).b(8.0F).a(g).c("hopper"); - public static final Block QUARTZ_BLOCK = (new BlockQuartz(155)).a(j).c(0.8F).c("quartzBlock"); + public static final Block FLOWER_POT = (new BlockFlowerPot(140)).c(0.0F).a(g).c("flowerPot").d("flower_pot"); + public static final Block CARROTS = (new BlockCarrots(141)).c("carrots").d("carrots"); + public static final Block POTATOES = (new BlockPotatoes(142)).c("potatoes").d("potatoes"); + public static final Block WOOD_BUTTON = (new BlockWoodButton(143)).c(0.5F).a(h).c("button"); + public static final Block SKULL = (new BlockSkull(144)).c(1.0F).a(k).c("skull").d("skull"); + public static final Block ANVIL = (new BlockAnvil(145)).c(5.0F).a(r).b(2000.0F).c("anvil"); + public static final Block TRAPPED_CHEST = (new BlockChest(146, 1)).c(2.5F).a(h).c("chestTrap"); + public static final Block GOLD_PLATE = (new BlockPressurePlateWeighted(147, "gold_block", Material.ORE, 64)).c(0.5F).a(h).c("weightedPlate_light"); + public static final Block IRON_PLATE = (new BlockPressurePlateWeighted(148, "iron_block", Material.ORE, 640)).c(0.5F).a(h).c("weightedPlate_heavy"); + public static final BlockRedstoneComparator REDSTONE_COMPARATOR_OFF = (BlockRedstoneComparator) (new BlockRedstoneComparator(149, false)).c(0.0F).a(h).c("comparator").C().d("comparator_off"); + public static final BlockRedstoneComparator REDSTONE_COMPARATOR_ON = (BlockRedstoneComparator) (new BlockRedstoneComparator(150, true)).c(0.0F).a(0.625F).a(h).c("comparator").C().d("comparator_on"); + public static final BlockDaylightDetector DAYLIGHT_DETECTOR = (BlockDaylightDetector) (new BlockDaylightDetector(151)).c(0.2F).a(h).c("daylightDetector").d("daylight_detector"); + public static final Block REDSTONE_BLOCK = (new BlockRedstone(152)).c(5.0F).b(10.0F).a(l).c("blockRedstone").d("redstone_block"); + public static final Block QUARTZ_ORE = (new BlockOre(153)).c(3.0F).b(5.0F).a(k).c("netherquartz").d("quartz_ore"); + public static final BlockHopper HOPPER = (BlockHopper) (new BlockHopper(154)).c(3.0F).b(8.0F).a(h).c("hopper").d("hopper"); + public static final Block QUARTZ_BLOCK = (new BlockQuartz(155)).a(k).c(0.8F).c("quartzBlock").d("quartz_block"); public static final Block QUARTZ_STAIRS = (new BlockStairs(156, QUARTZ_BLOCK, 0)).c("stairsQuartz"); - public static final Block ACTIVATOR_RAIL = (new BlockPoweredRail(157)).c(0.7F).a(k).c("activatorRail"); - public static final Block DROPPER = (new BlockDropper(158)).c(3.5F).a(j).c("dropper"); + public static final Block ACTIVATOR_RAIL = (new BlockPoweredRail(157)).c(0.7F).a(l).c("activatorRail").d("rail_activator"); + public static final Block DROPPER = (new BlockDropper(158)).c(3.5F).a(k).c("dropper").d("dropper"); + public static final Block STAINED_HARDENED_CLAY = (new BlockCloth(159, Material.STONE)).c(1.25F).b(7.0F).a(k).c("clayHardenedStained").d("hardened_clay_stained"); + public static final Block HAY_BLOCK = (new BlockHay(170)).c(0.5F).a(j).c("hayBlock").a(CreativeModeTab.b).d("hay_block"); + public static final Block WOOL_CARPET = (new BlockCarpet(171)).c(0.1F).a(n).c("woolCarpet").k(0); + public static final Block HARDENED_CLAY = (new Block(172, Material.STONE)).c(1.25F).b(7.0F).a(k).c("clayHardened").a(CreativeModeTab.b).d("hardened_clay"); + public static final Block COAL_BLOCK = (new Block(173, Material.STONE)).c(5.0F).b(10.0F).a(k).c("blockCoal").a(CreativeModeTab.b).d("coal_block"); public final int id; protected float strength; protected float durability; - protected boolean cC = true; - protected boolean cD = true; - protected boolean cE; + protected boolean cI = true; + protected boolean cJ = true; + protected boolean cK; protected boolean isTileEntity; protected double minX; protected double minY; @@ -196,14 +202,14 @@ public class Block { protected double maxY; protected double maxZ; public StepSound stepSound; - public float cN; + public float cT; public final Material material; public float frictionFactor; private String name; protected Block(int i, Material material) { - this.stepSound = f; - this.cN = 1.0F; + this.stepSound = g; + this.cT = 1.0F; this.frictionFactor = 0.6F; if (byId[i] != null) { throw new IllegalArgumentException("Slot " + i + " is already occupied by " + byId[i] + " when adding " + this); @@ -212,9 +218,9 @@ public class Block { byId[i] = this; this.id = i; this.a(0.0F, 0.0F, 0.0F, 1.0F, 1.0F, 1.0F); - s[i] = this.c(); + t[i] = this.c(); lightBlock[i] = this.c() ? 255 : 0; - u[i] = !material.blocksLight(); + v[i] = !material.blocksLight(); } } @@ -277,12 +283,12 @@ public class Block { } protected Block b(boolean flag) { - this.cE = flag; + this.cK = flag; return this; } public boolean isTicking() { - return this.cE; + return this.cK; } public boolean t() { @@ -305,7 +311,7 @@ public class Block { public void a(World world, int i, int j, int k, AxisAlignedBB axisalignedbb, List list, Entity entity) { AxisAlignedBB axisalignedbb1 = this.b(world, i, j, k); - if (axisalignedbb1 != null && axisalignedbb.a(axisalignedbb1)) { + if (axisalignedbb1 != null && axisalignedbb.b(axisalignedbb1)) { list.add(axisalignedbb1); } } @@ -587,9 +593,9 @@ public class Block { public void a(World world, EntityHuman entityhuman, int i, int j, int k, int l) { entityhuman.a(StatisticList.C[this.id], 1); - entityhuman.j(0.025F); + entityhuman.a(0.025F); if (this.r_() && EnchantmentManager.hasSilkTouchEnchantment(entityhuman)) { - ItemStack itemstack = this.c_(l); + ItemStack itemstack = this.d_(l); if (itemstack != null) { this.b(world, i, j, k, itemstack); @@ -605,10 +611,10 @@ public class Block { return this.b() && !this.isTileEntity; } - protected ItemStack c_(int i) { + protected ItemStack d_(int i) { int j = 0; - if (this.id >= 0 && this.id < Item.byId.length && Item.byId[this.id].m()) { + if (this.id >= 0 && this.id < Item.byId.length && Item.byId[this.id].n()) { j = i; } @@ -644,12 +650,12 @@ public class Block { return false; } - public boolean C() { - return this.cD; + public boolean B() { + return this.cJ; } - protected Block D() { - this.cD = false; + protected Block C() { + this.cJ = false; return this; } @@ -698,9 +704,16 @@ public class Block { return 0; } + protected Block d(String s) { + this.f = s; + return this; + } + static { Item.byId[WOOL.id] = (new ItemCloth(WOOL.id - 256)).b("cloth"); - Item.byId[LOG.id] = (new ItemMultiTexture(LOG.id - 256, LOG, BlockLog.a)).b("log"); + Item.byId[STAINED_HARDENED_CLAY.id] = (new ItemCloth(STAINED_HARDENED_CLAY.id - 256)).b("clayHardenedStained"); + Item.byId[WOOL_CARPET.id] = (new ItemCloth(WOOL_CARPET.id - 256)).b("woolCarpet"); + Item.byId[LOG.id] = (new ItemMultiTexture(LOG.id - 256, LOG, BlockLog.b)).b("log"); Item.byId[WOOD.id] = (new ItemMultiTexture(WOOD.id - 256, WOOD, BlockWood.a)).b("wood"); Item.byId[MONSTER_EGGS.id] = (new ItemMultiTexture(MONSTER_EGGS.id - 256, MONSTER_EGGS, BlockMonsterEggs.a)).b("monsterStoneEgg"); Item.byId[SMOOTH_BRICK.id] = (new ItemMultiTexture(SMOOTH_BRICK.id - 256, SMOOTH_BRICK, BlockSmoothBrick.a)).b("stonebricksmooth"); @@ -747,7 +760,7 @@ public class Block { flag = true; } - if (u[i]) { + if (v[i]) { flag = true; } @@ -755,11 +768,11 @@ public class Block { flag = true; } - w[i] = flag; + x[i] = flag; } } - u[0] = true; + v[0] = true; StatisticList.b(); } diff --git a/src/main/java/net/minecraft/server/BlockCactus.java b/src/main/java/net/minecraft/server/BlockCactus.java index 83cc09da..03eece78 100644 --- a/src/main/java/net/minecraft/server/BlockCactus.java +++ b/src/main/java/net/minecraft/server/BlockCactus.java @@ -84,17 +84,17 @@ public class BlockCactus extends Block { org.bukkit.block.Block damager = world.getWorld().getBlockAt(i, j, k); org.bukkit.entity.Entity damagee = (entity == null) ? null : entity.getBukkitEntity(); - EntityDamageByBlockEvent event = new EntityDamageByBlockEvent(damager, damagee, org.bukkit.event.entity.EntityDamageEvent.DamageCause.CONTACT, 1); + EntityDamageByBlockEvent event = new EntityDamageByBlockEvent(damager, damagee, org.bukkit.event.entity.EntityDamageEvent.DamageCause.CONTACT, 1D); world.getServer().getPluginManager().callEvent(event); if (!event.isCancelled()) { damagee.setLastDamageCause(event); - entity.damageEntity(DamageSource.CACTUS, event.getDamage()); + entity.damageEntity(DamageSource.CACTUS, (float) event.getDamage()); } return; } // CraftBukkit end - entity.damageEntity(DamageSource.CACTUS, 1); + entity.damageEntity(DamageSource.CACTUS, 1.0F); } } diff --git a/src/main/java/net/minecraft/server/BlockCocoa.java b/src/main/java/net/minecraft/server/BlockCocoa.java index b7007d94..2ed2bdab 100644 --- a/src/main/java/net/minecraft/server/BlockCocoa.java +++ b/src/main/java/net/minecraft/server/BlockCocoa.java @@ -14,7 +14,7 @@ public class BlockCocoa extends BlockDirectional { public void a(World world, int i, int j, int k, Random random) { if (!this.f(world, i, j, k)) { this.c(world, i, j, k, world.getData(i, j, k), 0); - world.setAir(i, j, k); + world.setTypeIdAndData(i, j, k, 0, 0, 2); } else if (world.random.nextInt(5) == 0) { int l = world.getData(i, j, k); int i1 = c(l); @@ -33,7 +33,7 @@ public class BlockCocoa extends BlockDirectional { k += Direction.b[l]; int i1 = world.getTypeId(i, j, k); - return i1 == Block.LOG.id && BlockLog.d(world.getData(i, j, k)) == 3; + return i1 == Block.LOG.id && BlockLog.f(world.getData(i, j, k)) == 3; } public int d() { @@ -96,7 +96,7 @@ public class BlockCocoa extends BlockDirectional { public void doPhysics(World world, int i, int j, int k, int l) { if (!this.f(world, i, j, k)) { this.c(world, i, j, k, world.getData(i, j, k), 0); - world.setAir(i, j, k); + world.setTypeIdAndData(i, j, k, 0, 0, 2); } } diff --git a/src/main/java/net/minecraft/server/BlockCommand.java b/src/main/java/net/minecraft/server/BlockCommand.java index c464beb9..d5b2df7e 100644 --- a/src/main/java/net/minecraft/server/BlockCommand.java +++ b/src/main/java/net/minecraft/server/BlockCommand.java @@ -70,14 +70,18 @@ public class BlockCommand extends BlockContainer { public int b_(World world, int i, int j, int k, int l) { TileEntity tileentity = world.getTileEntity(i, j, k); - return tileentity != null && tileentity instanceof TileEntityCommand ? ((TileEntityCommand) tileentity).d() : 0; + return tileentity != null && tileentity instanceof TileEntityCommand ? ((TileEntityCommand) tileentity).f() : 0; } public void postPlace(World world, int i, int j, int k, EntityLiving entityliving, ItemStack itemstack) { TileEntityCommand tileentitycommand = (TileEntityCommand) world.getTileEntity(i, j, k); if (itemstack.hasName()) { - tileentitycommand.c(itemstack.getName()); + tileentitycommand.b(itemstack.getName()); } } + + public int a(Random random) { + return 0; + } } diff --git a/src/main/java/net/minecraft/server/BlockCrops.java b/src/main/java/net/minecraft/server/BlockCrops.java index 14a1c3bd..e157fbef 100644 --- a/src/main/java/net/minecraft/server/BlockCrops.java +++ b/src/main/java/net/minecraft/server/BlockCrops.java @@ -12,11 +12,11 @@ public class BlockCrops extends BlockFlower { this.a(0.5F - f, 0.0F, 0.5F - f, 0.5F + f, 0.25F, 0.5F + f); this.a((CreativeModeTab) null); this.c(0.0F); - this.a(Block.i); // CraftBukkit - i -> Block.i, decompile error - this.D(); + this.a(j); + this.C(); } - protected boolean f_(int i) { + protected boolean g_(int i) { return i == Block.SOIL.id; } diff --git a/src/main/java/net/minecraft/server/BlockDaylightDetector.java b/src/main/java/net/minecraft/server/BlockDaylightDetector.java index fc31262e..9a62eb7e 100644 --- a/src/main/java/net/minecraft/server/BlockDaylightDetector.java +++ b/src/main/java/net/minecraft/server/BlockDaylightDetector.java @@ -27,7 +27,7 @@ public class BlockDaylightDetector extends BlockContainer { public void onPlace(World world, int i, int j, int k) {} public void i_(World world, int i, int j, int k) { - if (!world.worldProvider.f) { + if (!world.worldProvider.g) { int l = world.getData(i, j, k); int i1 = world.b(EnumSkyBlock.SKY, i, j, k) - world.j; float f = world.d(1.0F); diff --git a/src/main/java/net/minecraft/server/BlockDiodeAbstract.java b/src/main/java/net/minecraft/server/BlockDiodeAbstract.java index 1ef8144d..6d205d91 100644 --- a/src/main/java/net/minecraft/server/BlockDiodeAbstract.java +++ b/src/main/java/net/minecraft/server/BlockDiodeAbstract.java @@ -109,7 +109,7 @@ public abstract class BlockDiodeAbstract extends BlockDirectional { b0 = -2; } - world.a(i, j, k, this.id, this.i_(i1), b0); + world.a(i, j, k, this.id, this.k_(i1), b0); } } } @@ -246,10 +246,10 @@ public abstract class BlockDiodeAbstract extends BlockDirectional { } protected int h(int i) { - return this.i_(i); + return this.k_(i); } - protected abstract int i_(int i); + protected abstract int k_(int i); protected abstract BlockDiodeAbstract i(); diff --git a/src/main/java/net/minecraft/server/BlockDispenser.java b/src/main/java/net/minecraft/server/BlockDispenser.java index e9c9ec59..9bf82b8f 100644 --- a/src/main/java/net/minecraft/server/BlockDispenser.java +++ b/src/main/java/net/minecraft/server/BlockDispenser.java @@ -30,19 +30,19 @@ public class BlockDispenser extends BlockContainer { int k1 = world.getTypeId(i + 1, j, k); byte b0 = 3; - if (Block.s[l] && !Block.s[i1]) { + if (Block.t[l] && !Block.t[i1]) { b0 = 3; } - if (Block.s[i1] && !Block.s[l]) { + if (Block.t[i1] && !Block.t[l]) { b0 = 2; } - if (Block.s[j1] && !Block.s[k1]) { + if (Block.t[j1] && !Block.t[k1]) { b0 = 5; } - if (Block.s[k1] && !Block.s[j1]) { + if (Block.t[k1] && !Block.t[j1]) { b0 = 4; } @@ -167,7 +167,7 @@ public class BlockDispenser extends BlockContainer { } public static IPosition a(ISourceBlock isourceblock) { - EnumFacing enumfacing = j_(isourceblock.h()); + EnumFacing enumfacing = l_(isourceblock.h()); double d0 = isourceblock.getX() + 0.7D * (double) enumfacing.c(); double d1 = isourceblock.getY() + 0.7D * (double) enumfacing.d(); double d2 = isourceblock.getZ() + 0.7D * (double) enumfacing.e(); @@ -175,7 +175,7 @@ public class BlockDispenser extends BlockContainer { return new Position(d0, d1, d2); } - public static EnumFacing j_(int i) { + public static EnumFacing l_(int i) { return EnumFacing.a(i & 7); } diff --git a/src/main/java/net/minecraft/server/BlockDoor.java b/src/main/java/net/minecraft/server/BlockDoor.java index fd28fa02..dea76145 100644 --- a/src/main/java/net/minecraft/server/BlockDoor.java +++ b/src/main/java/net/minecraft/server/BlockDoor.java @@ -6,17 +6,8 @@ import org.bukkit.event.block.BlockRedstoneEvent; // CraftBukkit public class BlockDoor extends Block { - private static final String[] a = new String[] { "doorWood_lower", "doorWood_upper", "doorIron_lower", "doorIron_upper"}; - private final int b; - protected BlockDoor(int i, Material material) { super(i, material); - if (material == Material.ORE) { - this.b = 2; - } else { - this.b = 0; - } - float f = 0.5F; float f1 = 1.0F; diff --git a/src/main/java/net/minecraft/server/BlockDropper.java b/src/main/java/net/minecraft/server/BlockDropper.java index 9498a039..d3dc5635 100644 --- a/src/main/java/net/minecraft/server/BlockDropper.java +++ b/src/main/java/net/minecraft/server/BlockDropper.java @@ -7,14 +7,14 @@ import org.bukkit.event.inventory.InventoryMoveItemEvent; public class BlockDropper extends BlockDispenser { - private final IDispenseBehavior cR = new DispenseBehaviorItem(); + private final IDispenseBehavior cX = new DispenseBehaviorItem(); protected BlockDropper(int i) { super(i); } protected IDispenseBehavior a(ItemStack itemstack) { - return this.cR; + return this.cX; } public TileEntity b(World world) { @@ -64,7 +64,7 @@ public class BlockDropper extends BlockDispenser { itemstack1 = itemstack.cloneItemStack(); } } else { - itemstack1 = this.cR.a(sourceblock, itemstack); + itemstack1 = this.cX.a(sourceblock, itemstack); if (itemstack1 != null && itemstack1.count == 0) { itemstack1 = null; } diff --git a/src/main/java/net/minecraft/server/BlockEnderPortal.java b/src/main/java/net/minecraft/server/BlockEnderPortal.java index 2b400236..b0d2d1e3 100644 --- a/src/main/java/net/minecraft/server/BlockEnderPortal.java +++ b/src/main/java/net/minecraft/server/BlockEnderPortal.java @@ -7,7 +7,7 @@ import org.bukkit.event.entity.EntityPortalEnterEvent; // CraftBukkit public class BlockEnderPortal extends BlockContainer { - public static boolean a = false; + public static boolean a; protected BlockEnderPortal(int i, Material material) { super(i, material); @@ -44,7 +44,7 @@ public class BlockEnderPortal extends BlockContainer { EntityPortalEnterEvent event = new EntityPortalEnterEvent(entity.getBukkitEntity(), new org.bukkit.Location(world.getWorld(), i, j, k)); world.getServer().getPluginManager().callEvent(event); // CraftBukkit end - entity.c(1); + entity.b(1); } } diff --git a/src/main/java/net/minecraft/server/BlockFire.java b/src/main/java/net/minecraft/server/BlockFire.java index a93beef6..f52d7845 100644 --- a/src/main/java/net/minecraft/server/BlockFire.java +++ b/src/main/java/net/minecraft/server/BlockFire.java @@ -34,6 +34,8 @@ public class BlockFire extends Block { this.a(Block.LONG_GRASS.id, 60, 100); this.a(Block.WOOL.id, 30, 60); this.a(Block.VINE.id, 15, 100); + this.a(Block.COAL_BLOCK.id, 5, 5); + this.a(Block.HAY_BLOCK.id, 60, 20); } private void a(int i, int j, int k) { @@ -77,7 +79,7 @@ public class BlockFire extends Block { fireExtinguished(world, i, j, k); // CraftBukkit - invalid place location } - if (!flag && world.P() && (world.F(i, j, k) || world.F(i - 1, j, k) || world.F(i + 1, j, k) || world.F(i, j, k - 1) || world.F(i, j, k + 1))) { + if (!flag && world.Q() && (world.F(i, j, k) || world.F(i - 1, j, k) || world.F(i + 1, j, k) || world.F(i, j, k - 1) || world.F(i, j, k + 1))) { fireExtinguished(world, i, j, k); // CraftBukkit - extinguished by rain } else { int l = world.getData(i, j, k); @@ -127,7 +129,7 @@ public class BlockFire extends Block { j2 /= 2; } - if (j2 > 0 && random.nextInt(l1) <= j2 && (!world.P() || !world.F(i1, k1, j1)) && !world.F(i1 - 1, k1, k) && !world.F(i1 + 1, k1, j1) && !world.F(i1, k1, j1 - 1) && !world.F(i1, k1, j1 + 1)) { + if (j2 > 0 && random.nextInt(l1) <= j2 && (!world.Q() || !world.F(i1, k1, j1)) && !world.F(i1 - 1, k1, k) && !world.F(i1 + 1, k1, j1) && !world.F(i1, k1, j1 - 1) && !world.F(i1, k1, j1 + 1)) { int k2 = l + random.nextInt(5) / 4; if (k2 > 15) { @@ -250,7 +252,7 @@ public class BlockFire extends Block { } public void onPlace(World world, int i, int j, int k) { - if (world.worldProvider.dimension > 0 || world.getTypeId(i, j - 1, k) != Block.OBSIDIAN.id || !Block.PORTAL.n_(world, i, j, k)) { + if (world.worldProvider.dimension > 0 || world.getTypeId(i, j - 1, k) != Block.OBSIDIAN.id || !Block.PORTAL.o_(world, i, j, k)) { if (!world.w(i, j - 1, k) && !this.k(world, i, j, k)) { fireExtinguished(world, i, j, k); // CraftBukkit - fuel block broke } else { diff --git a/src/main/java/net/minecraft/server/BlockFlowing.java b/src/main/java/net/minecraft/server/BlockFlowing.java index c95e922d..a98dadad 100644 --- a/src/main/java/net/minecraft/server/BlockFlowing.java +++ b/src/main/java/net/minecraft/server/BlockFlowing.java @@ -9,7 +9,7 @@ import org.bukkit.event.block.BlockFromToEvent; public class BlockFlowing extends BlockFluids { - int a = 0; + int a; boolean[] b = new boolean[4]; int[] c = new int[4]; @@ -34,64 +34,64 @@ public class BlockFlowing extends BlockFluids { org.bukkit.block.Block source = bworld == null ? null : bworld.getBlockAt(i, j, k); // CraftBukkit end - int l = this.k_(world, i, j, k); + int l = this.l_(world, i, j, k); byte b0 = 1; - if (this.material == Material.LAVA && !world.worldProvider.e) { + if (this.material == Material.LAVA && !world.worldProvider.f) { b0 = 2; } boolean flag = true; - int i1; + int i1 = this.a(world); + int j1; if (l > 0) { byte b1 = -100; this.a = 0; - int j1 = this.d(world, i - 1, j, k, b1); - - j1 = this.d(world, i + 1, j, k, j1); - j1 = this.d(world, i, j, k - 1, j1); - j1 = this.d(world, i, j, k + 1, j1); - i1 = j1 + b0; - if (i1 >= 8 || j1 < 0) { - i1 = -1; + int k1 = this.d(world, i - 1, j, k, b1); + + k1 = this.d(world, i + 1, j, k, k1); + k1 = this.d(world, i, j, k - 1, k1); + k1 = this.d(world, i, j, k + 1, k1); + j1 = k1 + b0; + if (j1 >= 8 || k1 < 0) { + j1 = -1; } - if (this.k_(world, i, j + 1, k) >= 0) { - int k1 = this.k_(world, i, j + 1, k); + if (this.l_(world, i, j + 1, k) >= 0) { + int l1 = this.l_(world, i, j + 1, k); - if (k1 >= 8) { - i1 = k1; + if (l1 >= 8) { + j1 = l1; } else { - i1 = k1 + 8; + j1 = l1 + 8; } } if (this.a >= 2 && this.material == Material.WATER) { if (world.getMaterial(i, j - 1, k).isBuildable()) { - i1 = 0; + j1 = 0; } else if (world.getMaterial(i, j - 1, k) == this.material && world.getData(i, j - 1, k) == 0) { - i1 = 0; + j1 = 0; } } - if (this.material == Material.LAVA && l < 8 && i1 < 8 && i1 > l && random.nextInt(4) != 0) { - i1 = l; - flag = false; + if (this.material == Material.LAVA && l < 8 && j1 < 8 && j1 > l && random.nextInt(4) != 0) { + i1 *= 4; } - if (i1 == l) { + if (j1 == l) { if (flag) { this.k(world, i, j, k); } } else { - l = i1; - if (i1 < 0) { + l = j1; + if (j1 < 0) { world.setAir(i, j, k); } else { - world.setData(i, j, k, i1, 2); - world.a(i, j, k, this.id, this.a(world)); + world.setData(i, j, k, j1, 2); + world.a(i, j, k, this.id, i1); world.applyPhysics(i, j, k, this.id); } } @@ -123,12 +123,12 @@ public class BlockFlowing extends BlockFluids { } else if (l >= 0 && (l == 0 || this.n(world, i, j - 1, k))) { boolean[] aboolean = this.m(world, i, j, k); - i1 = l + b0; + j1 = l + b0; if (l >= 8) { - i1 = 1; + j1 = 1; } - if (i1 >= 8) { + if (j1 >= 8) { return; } @@ -145,7 +145,7 @@ public class BlockFlowing extends BlockFluids { } if (!event.isCancelled()) { - this.flow(world, i + currentFace.getModX(), j, k + currentFace.getModZ(), i1); + this.flow(world, i + currentFace.getModX(), j, k + currentFace.getModZ(), j1); } } index++; @@ -279,7 +279,7 @@ public class BlockFlowing extends BlockFluids { } protected int d(World world, int i, int j, int k, int l) { - int i1 = this.k_(world, i, j, k); + int i1 = this.l_(world, i, j, k); if (i1 < 0) { return l; @@ -310,6 +310,6 @@ public class BlockFlowing extends BlockFluids { } public boolean l() { - return false; + return true; } } diff --git a/src/main/java/net/minecraft/server/BlockIce.java b/src/main/java/net/minecraft/server/BlockIce.java index e2259706..29563056 100644 --- a/src/main/java/net/minecraft/server/BlockIce.java +++ b/src/main/java/net/minecraft/server/BlockIce.java @@ -13,15 +13,15 @@ public class BlockIce extends BlockHalfTransparant { public void a(World world, EntityHuman entityhuman, int i, int j, int k, int l) { entityhuman.a(StatisticList.C[this.id], 1); - entityhuman.j(0.025F); + entityhuman.a(0.025F); if (this.r_() && EnchantmentManager.hasSilkTouchEnchantment(entityhuman)) { - ItemStack itemstack = this.c_(l); + ItemStack itemstack = this.d_(l); if (itemstack != null) { this.b(world, i, j, k, itemstack); } } else { - if (world.worldProvider.e) { + if (world.worldProvider.f) { world.setAir(i, j, k); return; } @@ -49,7 +49,7 @@ public class BlockIce extends BlockHalfTransparant { } // CraftBukkit end - if (world.worldProvider.e) { + if (world.worldProvider.f) { world.setAir(i, j, k); return; } diff --git a/src/main/java/net/minecraft/server/BlockLeaves.java b/src/main/java/net/minecraft/server/BlockLeaves.java index 9e4a9200..e3a3242c 100644 --- a/src/main/java/net/minecraft/server/BlockLeaves.java +++ b/src/main/java/net/minecraft/server/BlockLeaves.java @@ -7,8 +7,8 @@ import org.bukkit.event.block.LeavesDecayEvent; // CraftBukkit public class BlockLeaves extends BlockTransparant { public static final String[] a = new String[] { "oak", "spruce", "birch", "jungle"}; - public static final String[][] b = new String[][] { { "leaves", "leaves_spruce", "leaves", "leaves_jungle"}, { "leaves_opaque", "leaves_spruce_opaque", "leaves_opaque", "leaves_jungle_opaque"}}; - private IIcon[][] cR = new IIcon[2][]; + public static final String[][] b = new String[][] { { "leaves_oak", "leaves_spruce", "leaves_birch", "leaves_jungle"}, { "leaves_oak_opaque", "leaves_spruce_opaque", "leaves_birch_opaque", "leaves_jungle_opaque"}}; + private IIcon[][] cX = new IIcon[2][]; int[] c; protected BlockLeaves(int i) { @@ -178,7 +178,7 @@ public class BlockLeaves extends BlockTransparant { } public void a(World world, EntityHuman entityhuman, int i, int j, int k, int l) { - if (!world.isStatic && entityhuman.cd() != null && entityhuman.cd().id == Item.SHEARS.id) { + if (!world.isStatic && entityhuman.bt() != null && entityhuman.bt().id == Item.SHEARS.id) { entityhuman.a(StatisticList.C[this.id], 1); this.b(world, i, j, k, new ItemStack(Block.LEAVES.id, 1, l & 3)); } else { @@ -194,7 +194,7 @@ public class BlockLeaves extends BlockTransparant { return !this.d; } - protected ItemStack c_(int i) { + protected ItemStack d_(int i) { return new ItemStack(this.id, 1, i & 3); } } diff --git a/src/main/java/net/minecraft/server/BlockMushroom.java b/src/main/java/net/minecraft/server/BlockMushroom.java index 872ad003..796527da 100644 --- a/src/main/java/net/minecraft/server/BlockMushroom.java +++ b/src/main/java/net/minecraft/server/BlockMushroom.java @@ -14,11 +14,8 @@ import org.bukkit.event.world.StructureGrowEvent; public class BlockMushroom extends BlockFlower { - private final String a; - - protected BlockMushroom(int i, String s) { + protected BlockMushroom(int i) { super(i); - this.a = s; float f = 0.2F; this.a(0.5F - f, 0.0F, 0.5F - f, 0.5F + f, f * 2.0F, 0.5F + f); @@ -68,7 +65,7 @@ public class BlockMushroom extends BlockFlower { // CraftBukkit start org.bukkit.World bworld = world.getWorld(); BlockState blockState = bworld.getBlockAt(i1, j1, k1).getState(); - blockState.setTypeId(this.id); + blockState.setTypeId(this.id); // nms: this.id, 0, 2 BlockSpreadEvent event = new BlockSpreadEvent(blockState.getBlock(), bworld.getBlockAt(sourceX, sourceY, sourceZ), blockState); world.getServer().getPluginManager().callEvent(event); @@ -85,15 +82,15 @@ public class BlockMushroom extends BlockFlower { return super.canPlace(world, i, j, k) && this.f(world, i, j, k); } - protected boolean f_(int i) { - return Block.s[i]; + protected boolean g_(int i) { + return Block.t[i]; } public boolean f(World world, int i, int j, int k) { if (j >= 0 && j < 256) { int l = world.getTypeId(i, j - 1, k); - return l == Block.MYCEL.id || world.m(i, j, k) < 13 && this.f_(l); + return l == Block.MYCEL.id || world.m(i, j, k) < 13 && this.g_(l); } else { return false; } diff --git a/src/main/java/net/minecraft/server/BlockNetherWart.java b/src/main/java/net/minecraft/server/BlockNetherWart.java index 1a87122e..e90a5881 100644 --- a/src/main/java/net/minecraft/server/BlockNetherWart.java +++ b/src/main/java/net/minecraft/server/BlockNetherWart.java @@ -4,8 +4,6 @@ import java.util.Random; public class BlockNetherWart extends BlockFlower { - private static final String[] a = new String[] { "netherStalk_0", "netherStalk_1", "netherStalk_2"}; - protected BlockNetherWart(int i) { super(i); this.b(true); @@ -15,12 +13,12 @@ public class BlockNetherWart extends BlockFlower { this.a((CreativeModeTab) null); } - protected boolean f_(int i) { + protected boolean g_(int i) { return i == Block.SOUL_SAND.id; } public boolean f(World world, int i, int j, int k) { - return this.f_(world.getTypeId(i, j - 1, k)); + return this.g_(world.getTypeId(i, j - 1, k)); } public void a(World world, int i, int j, int k, Random random) { diff --git a/src/main/java/net/minecraft/server/BlockPiston.java b/src/main/java/net/minecraft/server/BlockPiston.java index cbafd17c..2d9e7669 100644 --- a/src/main/java/net/minecraft/server/BlockPiston.java +++ b/src/main/java/net/minecraft/server/BlockPiston.java @@ -15,7 +15,7 @@ public class BlockPiston extends Block { public BlockPiston(int i, boolean flag) { super(i, Material.PISTON); this.a = flag; - this.a(j); + this.a(k); this.c(0.5F); this.a(CreativeModeTab.d); } @@ -173,6 +173,8 @@ public class BlockPiston extends Block { int l = iblockaccess.getData(i, j, k); if (e(l)) { + float f = 0.25F; + switch (d(l)) { case 0: this.a(0.0F, 0.25F, 0.0F, 1.0F, 1.0F, 1.0F); diff --git a/src/main/java/net/minecraft/server/BlockPistonExtension.java b/src/main/java/net/minecraft/server/BlockPistonExtension.java index b6475f72..5d3d9845 100644 --- a/src/main/java/net/minecraft/server/BlockPistonExtension.java +++ b/src/main/java/net/minecraft/server/BlockPistonExtension.java @@ -5,11 +5,9 @@ import java.util.Random; public class BlockPistonExtension extends Block { - private IIcon a = null; - public BlockPistonExtension(int i) { super(i, Material.PISTON); - this.a(j); + this.a(k); this.c(0.5F); } @@ -58,6 +56,11 @@ public class BlockPistonExtension extends Block { public void a(World world, int i, int j, int k, AxisAlignedBB axisalignedbb, List list, Entity entity) { int l = world.getData(i, j, k); + float f = 0.25F; + float f1 = 0.375F; + float f2 = 0.625F; + float f3 = 0.25F; + float f4 = 0.75F; switch (d(l)) { case 0: @@ -107,6 +110,7 @@ public class BlockPistonExtension extends Block { public void updateShape(IBlockAccess iblockaccess, int i, int j, int k) { int l = iblockaccess.getData(i, j, k); + float f = 0.25F; switch (d(l)) { case 0: diff --git a/src/main/java/net/minecraft/server/BlockPortal.java b/src/main/java/net/minecraft/server/BlockPortal.java index e1a91e74..1b0fd21f 100644 --- a/src/main/java/net/minecraft/server/BlockPortal.java +++ b/src/main/java/net/minecraft/server/BlockPortal.java @@ -60,7 +60,7 @@ public class BlockPortal extends BlockHalfTransparant { return false; } - public boolean n_(World world, int i, int j, int k) { + public boolean o_(World world, int i, int j, int k) { byte b0 = 0; byte b1 = 0; diff --git a/src/main/java/net/minecraft/server/BlockPressurePlateAbstract.java b/src/main/java/net/minecraft/server/BlockPressurePlateAbstract.java index 23fb1879..9c330f9c 100644 --- a/src/main/java/net/minecraft/server/BlockPressurePlateAbstract.java +++ b/src/main/java/net/minecraft/server/BlockPressurePlateAbstract.java @@ -13,14 +13,14 @@ public abstract class BlockPressurePlateAbstract extends Block { this.a = s; this.a(CreativeModeTab.d); this.b(true); - this.b_(this.d(15)); + this.c_(this.d(15)); } public void updateShape(IBlockAccess iblockaccess, int i, int j, int k) { - this.b_(iblockaccess.getData(i, j, k)); + this.c_(iblockaccess.getData(i, j, k)); } - protected void b_(int i) { + protected void c_(int i) { boolean flag = this.c(i) > 0; float f = 0.0625F; @@ -52,13 +52,13 @@ public abstract class BlockPressurePlateAbstract extends Block { } public boolean canPlace(World world, int i, int j, int k) { - return world.w(i, j - 1, k) || BlockFence.l_(world.getTypeId(i, j - 1, k)); + return world.w(i, j - 1, k) || BlockFence.n_(world.getTypeId(i, j - 1, k)); } public void doPhysics(World world, int i, int j, int k, int l) { boolean flag = false; - if (!world.w(i, j - 1, k) && !BlockFence.l_(world.getTypeId(i, j - 1, k))) { + if (!world.w(i, j - 1, k) && !BlockFence.n_(world.getTypeId(i, j - 1, k))) { flag = true; } diff --git a/src/main/java/net/minecraft/server/BlockPressurePlateBinary.java b/src/main/java/net/minecraft/server/BlockPressurePlateBinary.java index 428386c5..36642b95 100644 --- a/src/main/java/net/minecraft/server/BlockPressurePlateBinary.java +++ b/src/main/java/net/minecraft/server/BlockPressurePlateBinary.java @@ -37,7 +37,7 @@ public class BlockPressurePlateBinary extends BlockPressurePlateAbstract { list = world.a(EntityHuman.class, this.a(i, j, k)); } - if (!list.isEmpty()) { + if (list != null && !list.isEmpty()) { Iterator iterator = list.iterator(); while (iterator.hasNext()) { @@ -63,7 +63,7 @@ public class BlockPressurePlateBinary extends BlockPressurePlateAbstract { } // CraftBukkit end - if (!entity.at()) { + if (!entity.as()) { return 15; } } diff --git a/src/main/java/net/minecraft/server/BlockRedstoneOre.java b/src/main/java/net/minecraft/server/BlockRedstoneOre.java index 73eb990c..8e2a2bf0 100644 --- a/src/main/java/net/minecraft/server/BlockRedstoneOre.java +++ b/src/main/java/net/minecraft/server/BlockRedstoneOre.java @@ -135,7 +135,7 @@ public class BlockRedstoneOre extends Block { } } - protected ItemStack c_(int i) { + protected ItemStack d_(int i) { return new ItemStack(Block.REDSTONE_ORE); } } diff --git a/src/main/java/net/minecraft/server/BlockRedstoneTorch.java b/src/main/java/net/minecraft/server/BlockRedstoneTorch.java index 3a560e22..f176e666 100644 --- a/src/main/java/net/minecraft/server/BlockRedstoneTorch.java +++ b/src/main/java/net/minecraft/server/BlockRedstoneTorch.java @@ -10,7 +10,7 @@ import org.bukkit.event.block.BlockRedstoneEvent; // CraftBukkit public class BlockRedstoneTorch extends BlockTorch { - private boolean isOn = false; + private boolean isOn; private static Map b = new HashMap(); private boolean a(World world, int i, int j, int k, boolean flag) { diff --git a/src/main/java/net/minecraft/server/BlockSapling.java b/src/main/java/net/minecraft/server/BlockSapling.java index 3b00939f..706d6c9b 100644 --- a/src/main/java/net/minecraft/server/BlockSapling.java +++ b/src/main/java/net/minecraft/server/BlockSapling.java @@ -13,7 +13,6 @@ import org.bukkit.event.world.StructureGrowEvent; public class BlockSapling extends BlockFlower { public static final String[] a = new String[] { "oak", "spruce", "birch", "jungle"}; - private static final String[] b = new String[] { "sapling", "sapling_spruce", "sapling_birch", "sapling_jungle"}; protected BlockSapling(int i) { super(i); diff --git a/src/main/java/net/minecraft/server/BlockSkull.java b/src/main/java/net/minecraft/server/BlockSkull.java index 7d659efc..78449b13 100644 --- a/src/main/java/net/minecraft/server/BlockSkull.java +++ b/src/main/java/net/minecraft/server/BlockSkull.java @@ -154,8 +154,8 @@ public class BlockSkull extends BlockContainer { if (!world.isStatic) { entitywither = new EntityWither(world); entitywither.setPositionRotation((double) i + 0.5D, (double) j - 1.45D, (double) (k + i1) + 1.5D, 90.0F, 0.0F); - entitywither.ay = 90.0F; - entitywither.m(); + entitywither.aN = 90.0F; + entitywither.bP(); if (world.addEntity(entitywither, SpawnReason.BUILD_WITHER)) { blockList.updateList(); @@ -191,7 +191,7 @@ public class BlockSkull extends BlockContainer { if (!world.isStatic) { entitywither = new EntityWither(world); entitywither.setPositionRotation((double) (i + i1) + 1.5D, (double) j - 1.45D, (double) k + 0.5D, 0.0F, 0.0F); - entitywither.m(); + entitywither.bP(); if (world.addEntity(entitywither, SpawnReason.BUILD_WITHER)) { blockList.updateList(); diff --git a/src/main/java/net/minecraft/server/BlockStem.java b/src/main/java/net/minecraft/server/BlockStem.java index 8339a352..f2d4e578 100644 --- a/src/main/java/net/minecraft/server/BlockStem.java +++ b/src/main/java/net/minecraft/server/BlockStem.java @@ -18,7 +18,7 @@ public class BlockStem extends BlockFlower { this.a((CreativeModeTab) null); } - protected boolean f_(int i) { + protected boolean g_(int i) { return i == Block.SOIL.id; } diff --git a/src/main/java/net/minecraft/server/BlockTripwire.java b/src/main/java/net/minecraft/server/BlockTripwire.java index ac7522ef..8bdbbf81 100644 --- a/src/main/java/net/minecraft/server/BlockTripwire.java +++ b/src/main/java/net/minecraft/server/BlockTripwire.java @@ -76,7 +76,7 @@ public class BlockTripwire extends Block { public void a(World world, int i, int j, int k, int l, EntityHuman entityhuman) { if (!world.isStatic) { - if (entityhuman.cd() != null && entityhuman.cd().id == Item.SHEARS.id) { + if (entityhuman.bt() != null && entityhuman.bt().id == Item.SHEARS.id) { world.setData(i, j, k, l | 8, 4); } } @@ -140,7 +140,7 @@ public class BlockTripwire extends Block { while (iterator.hasNext()) { Entity entity = (Entity) iterator.next(); - if (!entity.at()) { + if (!entity.as()) { flag1 = true; break; } diff --git a/src/main/java/net/minecraft/server/BlockVine.java b/src/main/java/net/minecraft/server/BlockVine.java index 2b05ac50..66dcfbb6 100644 --- a/src/main/java/net/minecraft/server/BlockVine.java +++ b/src/main/java/net/minecraft/server/BlockVine.java @@ -29,65 +29,66 @@ public class BlockVine extends Block { } public void updateShape(IBlockAccess iblockaccess, int i, int j, int k) { + float f = 0.0625F; int l = iblockaccess.getData(i, j, k); - float f = 1.0F; float f1 = 1.0F; float f2 = 1.0F; - float f3 = 0.0F; + float f3 = 1.0F; float f4 = 0.0F; float f5 = 0.0F; + float f6 = 0.0F; boolean flag = l > 0; if ((l & 2) != 0) { - f3 = Math.max(f3, 0.0625F); - f = 0.0F; + f4 = Math.max(f4, 0.0625F); f1 = 0.0F; - f4 = 1.0F; f2 = 0.0F; f5 = 1.0F; + f3 = 0.0F; + f6 = 1.0F; flag = true; } if ((l & 8) != 0) { - f = Math.min(f, 0.9375F); - f3 = 1.0F; - f1 = 0.0F; + f1 = Math.min(f1, 0.9375F); f4 = 1.0F; f2 = 0.0F; f5 = 1.0F; + f3 = 0.0F; + f6 = 1.0F; flag = true; } if ((l & 4) != 0) { - f5 = Math.max(f5, 0.0625F); - f2 = 0.0F; - f = 0.0F; - f3 = 1.0F; + f6 = Math.max(f6, 0.0625F); + f3 = 0.0F; f1 = 0.0F; f4 = 1.0F; + f2 = 0.0F; + f5 = 1.0F; flag = true; } if ((l & 1) != 0) { - f2 = Math.min(f2, 0.9375F); - f5 = 1.0F; - f = 0.0F; - f3 = 1.0F; + f3 = Math.min(f3, 0.9375F); + f6 = 1.0F; f1 = 0.0F; f4 = 1.0F; + f2 = 0.0F; + f5 = 1.0F; flag = true; } if (!flag && this.d(iblockaccess.getTypeId(i, j + 1, k))) { - f1 = Math.min(f1, 0.9375F); - f4 = 1.0F; - f = 0.0F; - f3 = 1.0F; - f2 = 0.0F; + f2 = Math.min(f2, 0.9375F); f5 = 1.0F; + f1 = 0.0F; + f4 = 1.0F; + f3 = 0.0F; + f6 = 1.0F; } - this.a(f, f1, f2, f3, f4, f5); + this.a(f1, f2, f3, f4, f5, f6); } public AxisAlignedBB b(World world, int i, int j, int k) { @@ -300,7 +301,7 @@ public class BlockVine extends Block { } public void a(World world, EntityHuman entityhuman, int i, int j, int k, int l) { - if (!world.isStatic && entityhuman.cd() != null && entityhuman.cd().id == Item.SHEARS.id) { + if (!world.isStatic && entityhuman.bt() != null && entityhuman.bt().id == Item.SHEARS.id) { entityhuman.a(StatisticList.C[this.id], 1); this.b(world, i, j, k, new ItemStack(Block.VINE, 1, 0)); } else { diff --git a/src/main/java/net/minecraft/server/Chunk.java b/src/main/java/net/minecraft/server/Chunk.java index 7416edcf..61e56abb 100644 --- a/src/main/java/net/minecraft/server/Chunk.java +++ b/src/main/java/net/minecraft/server/Chunk.java @@ -31,24 +31,16 @@ public class Chunk { public long n; public boolean seenByPlayer; public int p; + public long q; private int u; - boolean q; public Chunk(World world, int i, int j) { this.sections = new ChunkSection[16]; this.s = new byte[256]; this.b = new int[256]; this.c = new boolean[256]; - this.t = false; this.tileEntities = new HashMap(); - this.done = false; - this.l = false; - this.m = false; - this.n = 0L; - this.seenByPlayer = false; - this.p = 0; this.u = 4096; - this.q = false; this.entitySlices = new List[16]; this.world = world; this.x = i; @@ -85,7 +77,7 @@ public class Chunk { int k1 = j1 >> 4; if (this.sections[k1] == null) { - this.sections[k1] = new ChunkSection(k1 << 4, !world.worldProvider.f); + this.sections[k1] = new ChunkSection(k1 << 4, !world.worldProvider.g); } this.sections[k1].setTypeId(l, j1 & 15, i1, b0); @@ -145,7 +137,7 @@ public class Chunk { } } - if (!this.world.worldProvider.f) { + if (!this.world.worldProvider.g) { l = 15; int i1 = i + 16 - 1; @@ -266,7 +258,7 @@ public class Chunk { int l1; int i2; - if (!this.world.worldProvider.f) { + if (!this.world.worldProvider.g) { ChunkSection chunksection; if (i1 < l) { @@ -322,7 +314,7 @@ public class Chunk { this.p = l1; } - if (!this.world.worldProvider.f) { + if (!this.world.worldProvider.g) { this.d(j1 - 1, k1, i2, j2); this.d(j1 + 1, k1, i2, j2); this.d(j1, k1 - 1, i2, j2); @@ -380,7 +372,7 @@ public class Chunk { return false; } - chunksection = this.sections[j >> 4] = new ChunkSection(j >> 4 << 4, !this.world.worldProvider.f); + chunksection = this.sections[j >> 4] = new ChunkSection(j >> 4 << 4, !this.world.worldProvider.g); flag = j >= k1; } @@ -488,20 +480,20 @@ public class Chunk { public int getBrightness(EnumSkyBlock enumskyblock, int i, int j, int k) { ChunkSection chunksection = this.sections[j >> 4]; - return chunksection == null ? (this.d(i, j, k) ? enumskyblock.c : 0) : (enumskyblock == EnumSkyBlock.SKY ? (this.world.worldProvider.f ? 0 : chunksection.getSkyLight(i, j & 15, k)) : (enumskyblock == EnumSkyBlock.BLOCK ? chunksection.getEmittedLight(i, j & 15, k) : enumskyblock.c)); + return chunksection == null ? (this.d(i, j, k) ? enumskyblock.c : 0) : (enumskyblock == EnumSkyBlock.SKY ? (this.world.worldProvider.g ? 0 : chunksection.getSkyLight(i, j & 15, k)) : (enumskyblock == EnumSkyBlock.BLOCK ? chunksection.getEmittedLight(i, j & 15, k) : enumskyblock.c)); } public void a(EnumSkyBlock enumskyblock, int i, int j, int k, int l) { ChunkSection chunksection = this.sections[j >> 4]; if (chunksection == null) { - chunksection = this.sections[j >> 4] = new ChunkSection(j >> 4 << 4, !this.world.worldProvider.f); + chunksection = this.sections[j >> 4] = new ChunkSection(j >> 4 << 4, !this.world.worldProvider.g); this.initLighting(); } this.l = true; if (enumskyblock == EnumSkyBlock.SKY) { - if (!this.world.worldProvider.f) { + if (!this.world.worldProvider.g) { chunksection.setSkyLight(i, j & 15, k, l); } } else if (enumskyblock == EnumSkyBlock.BLOCK) { @@ -513,9 +505,9 @@ public class Chunk { ChunkSection chunksection = this.sections[j >> 4]; if (chunksection == null) { - return !this.world.worldProvider.f && l < EnumSkyBlock.SKY.c ? EnumSkyBlock.SKY.c - l : 0; + return !this.world.worldProvider.g && l < EnumSkyBlock.SKY.c ? EnumSkyBlock.SKY.c - l : 0; } else { - int i1 = this.world.worldProvider.f ? 0 : chunksection.getSkyLight(i, j & 15, k); + int i1 = this.world.worldProvider.g ? 0 : chunksection.getSkyLight(i, j & 15, k); if (i1 > 0) { a = true; @@ -661,6 +653,14 @@ public class Chunk { this.world.a(this.tileEntities.values()); for (int i = 0; i < this.entitySlices.length; ++i) { + Iterator iterator = this.entitySlices[i].iterator(); + + while (iterator.hasNext()) { + Entity entity = (Entity) iterator.next(); + + entity.P(); + } + this.world.a(this.entitySlices[i]); } } @@ -717,14 +717,14 @@ public class Chunk { for (int l = 0; l < list1.size(); ++l) { Entity entity1 = (Entity) list1.get(l); - if (entity1 != entity && entity1.boundingBox.a(axisalignedbb) && (ientityselector == null || ientityselector.a(entity1))) { + if (entity1 != entity && entity1.boundingBox.b(axisalignedbb) && (ientityselector == null || ientityselector.a(entity1))) { list.add(entity1); - Entity[] aentity = entity1.an(); + Entity[] aentity = entity1.am(); if (aentity != null) { for (int i1 = 0; i1 < aentity.length; ++i1) { entity1 = aentity[i1]; - if (entity1 != entity && entity1.boundingBox.a(axisalignedbb) && (ientityselector == null || ientityselector.a(entity1))) { + if (entity1 != entity && entity1.boundingBox.b(axisalignedbb) && (ientityselector == null || ientityselector.a(entity1))) { list.add(entity1); } } @@ -756,7 +756,7 @@ public class Chunk { for (int l = 0; l < list1.size(); ++l) { Entity entity = (Entity) list1.get(l); - if (oclass.isAssignableFrom(entity.getClass()) && entity.boundingBox.a(axisalignedbb) && (ientityselector == null || ientityselector.a(entity))) { + if (oclass.isAssignableFrom(entity.getClass()) && entity.boundingBox.b(axisalignedbb) && (ientityselector == null || ientityselector.a(entity))) { list.add(entity); } } @@ -828,7 +828,7 @@ public class Chunk { } public void k() { - if (this.t && !this.world.worldProvider.f) { + if (this.t && !this.world.worldProvider.g) { this.q(); } } diff --git a/src/main/java/net/minecraft/server/ChunkRegionLoader.java b/src/main/java/net/minecraft/server/ChunkRegionLoader.java index bee715b7..8a21f359 100644 --- a/src/main/java/net/minecraft/server/ChunkRegionLoader.java +++ b/src/main/java/net/minecraft/server/ChunkRegionLoader.java @@ -126,7 +126,7 @@ public class ChunkRegionLoader implements IAsyncChunkSaver, IChunkLoader { public void a(World world, Chunk chunk) { // CraftBukkit start - "handle" exception try { - world.F(); + world.G(); } catch (ExceptionWorldConflict ex) { ex.printStackTrace(); } @@ -210,9 +210,10 @@ public class ChunkRegionLoader implements IAsyncChunkSaver, IChunkLoader { nbttagcompound.setLong("LastUpdate", world.getTime()); nbttagcompound.setIntArray("HeightMap", chunk.heightMap); nbttagcompound.setBoolean("TerrainPopulated", chunk.done); + nbttagcompound.setLong("InhabitedTime", chunk.q); ChunkSection[] achunksection = chunk.i(); NBTTagList nbttaglist = new NBTTagList("Sections"); - boolean flag = !world.worldProvider.f; + boolean flag = !world.worldProvider.g; ChunkSection[] achunksection1 = achunksection; int i = achunksection.length; @@ -307,10 +308,11 @@ public class ChunkRegionLoader implements IAsyncChunkSaver, IChunkLoader { chunk.heightMap = nbttagcompound.getIntArray("HeightMap"); chunk.done = nbttagcompound.getBoolean("TerrainPopulated"); + chunk.q = nbttagcompound.getLong("InhabitedTime"); NBTTagList nbttaglist = nbttagcompound.getList("Sections"); byte b0 = 16; ChunkSection[] achunksection = new ChunkSection[b0]; - boolean flag = !world.worldProvider.f; + boolean flag = !world.worldProvider.g; for (int k = 0; k < nbttaglist.size(); ++k) { NBTTagCompound nbttagcompound1 = (NBTTagCompound) nbttaglist.get(k); diff --git a/src/main/java/net/minecraft/server/Container.java b/src/main/java/net/minecraft/server/Container.java index bb4c41aa..8092047f 100644 --- a/src/main/java/net/minecraft/server/Container.java +++ b/src/main/java/net/minecraft/server/Container.java @@ -20,10 +20,9 @@ public abstract class Container { public List b = new ArrayList(); public List c = new ArrayList(); - public int windowId = 0; - private short a = 0; + public int windowId; private int f = -1; - public int g = 0; // CraftBukkit - private -> public + public int g; // CraftBukkit - private -> public private final Set h = new HashSet(); protected List listeners = new ArrayList(); private Set i = new HashSet(); @@ -151,7 +150,7 @@ public abstract class Container { if (slot1 != null && a(slot1, playerinventory.getCarried(), true) && slot1.isAllowed(playerinventory.getCarried()) && playerinventory.getCarried().count >= this.h.size() && this.b(slot1)) { ItemStack itemstack2 = itemstack1.cloneItemStack(); - int j1 = slot1.d() ? slot1.getItem().count : 0; + int j1 = slot1.e() ? slot1.getItem().count : 0; a(this.h, this.f, itemstack2, j1); if (itemstack2.count > itemstack2.getMaxStackSize()) { @@ -276,11 +275,9 @@ public abstract class Container { k1 = slot2.a(); } - // CraftBukkit start if (itemstack4.count >= k1) { slot2.set(itemstack4.a(k1)); } - // CraftBukkit end if (itemstack4.count == 0) { playerinventory.setCarried((ItemStack) null); @@ -331,7 +328,7 @@ public abstract class Container { } } - slot2.e(); + slot2.f(); } } } else if (k == 2 && j >= 0 && j < 9) { @@ -346,7 +343,7 @@ public abstract class Container { flag |= k1 > -1; } - if (slot2.d() && flag) { + if (slot2.e() && flag) { itemstack3 = slot2.getItem(); playerinventory.setItem(j, itemstack3.cloneItemStack()); if ((slot2.inventory != playerinventory || !slot2.isAllowed(itemstack1)) && itemstack1 != null) { @@ -361,21 +358,21 @@ public abstract class Container { slot2.set(itemstack1); slot2.a(entityhuman, itemstack3); } - } else if (!slot2.d() && itemstack1 != null && slot2.isAllowed(itemstack1)) { + } else if (!slot2.e() && itemstack1 != null && slot2.isAllowed(itemstack1)) { playerinventory.setItem(j, (ItemStack) null); slot2.set(itemstack1); } } } else if (k == 3 && entityhuman.abilities.canInstantlyBuild && playerinventory.getCarried() == null && i >= 0) { slot2 = (Slot) this.c.get(i); - if (slot2 != null && slot2.d()) { + if (slot2 != null && slot2.e()) { itemstack1 = slot2.getItem().cloneItemStack(); itemstack1.count = itemstack1.getMaxStackSize(); playerinventory.setCarried(itemstack1); } } else if (k == 4 && playerinventory.getCarried() == null && i >= 0) { slot2 = (Slot) this.c.get(i); - if (slot2 != null && slot2.d() && slot2.a(entityhuman)) { + if (slot2 != null && slot2.e() && slot2.a(entityhuman)) { itemstack1 = slot2.a(j == 0 ? 1 : slot2.getItem().count); slot2.a(entityhuman, itemstack1); entityhuman.drop(itemstack1); @@ -383,7 +380,7 @@ public abstract class Container { } else if (k == 6 && i >= 0) { slot2 = (Slot) this.c.get(i); itemstack1 = playerinventory.getCarried(); - if (itemstack1 != null && (slot2 == null || !slot2.d() || !slot2.a(entityhuman))) { + if (itemstack1 != null && (slot2 == null || !slot2.e() || !slot2.a(entityhuman))) { l = j == 0 ? 0 : this.c.size() - 1; k1 = j == 0 ? 1 : -1; @@ -391,7 +388,7 @@ public abstract class Container { for (int i2 = l; i2 >= 0 && i2 < this.c.size() && itemstack1.count < itemstack1.getMaxStackSize(); i2 += k1) { Slot slot3 = (Slot) this.c.get(i2); - if (slot3.d() && a(slot3, itemstack1, true) && slot3.a(entityhuman) && this.a(itemstack1, slot3) && (l1 != 0 || slot3.getItem().count != slot3.getItem().getMaxStackSize())) { + if (slot3.e() && a(slot3, itemstack1, true) && slot3.a(entityhuman) && this.a(itemstack1, slot3) && (l1 != 0 || slot3.getItem().count != slot3.getItem().getMaxStackSize())) { int j2 = Math.min(itemstack1.getMaxStackSize() - itemstack1.count, slot3.getItem().count); ItemStack itemstack5 = slot3.a(j2); @@ -473,12 +470,12 @@ public abstract class Container { if (l <= itemstack.getMaxStackSize()) { itemstack.count = 0; itemstack1.count = l; - slot.e(); + slot.f(); flag1 = true; } else if (itemstack1.count < itemstack.getMaxStackSize()) { itemstack.count -= itemstack.getMaxStackSize() - itemstack1.count; itemstack1.count = itemstack.getMaxStackSize(); - slot.e(); + slot.f(); flag1 = true; } } @@ -503,7 +500,7 @@ public abstract class Container { itemstack1 = slot.getItem(); if (itemstack1 == null) { slot.set(itemstack.cloneItemStack()); - slot.e(); + slot.f(); itemstack.count = 0; flag1 = true; break; @@ -538,9 +535,9 @@ public abstract class Container { } public static boolean a(Slot slot, ItemStack itemstack, boolean flag) { - boolean flag1 = slot == null || !slot.d(); + boolean flag1 = slot == null || !slot.e(); - if (slot != null && slot.d() && itemstack != null && itemstack.doMaterialsMatch(slot.getItem()) && ItemStack.equals(slot.getItem(), itemstack)) { + if (slot != null && slot.e() && itemstack != null && itemstack.doMaterialsMatch(slot.getItem()) && ItemStack.equals(slot.getItem(), itemstack)) { int i = flag ? 0 : itemstack.count; flag1 |= slot.getItem().count + i <= itemstack.getMaxStackSize(); diff --git a/src/main/java/net/minecraft/server/ContainerAnvil.java b/src/main/java/net/minecraft/server/ContainerAnvil.java index d7cee91d..9b73555c 100644 --- a/src/main/java/net/minecraft/server/ContainerAnvil.java +++ b/src/main/java/net/minecraft/server/ContainerAnvil.java @@ -3,6 +3,8 @@ package net.minecraft.server; import java.util.Iterator; import java.util.Map; +import org.apache.commons.lang3.StringUtils; + import org.bukkit.craftbukkit.inventory.CraftInventoryView; // CraftBukkit public class ContainerAnvil extends Container { @@ -13,8 +15,8 @@ public class ContainerAnvil extends Container { private int i; private int j; private int k; - public int a = 0; - private int l = 0; + public int a; + private int l; private String m; private final EntityHuman n; // CraftBukkit start @@ -202,7 +204,13 @@ public class ContainerAnvil extends Container { } } - if (this.m != null && this.m.length() > 0 && !this.m.equalsIgnoreCase(this.n.getLocale().c(itemstack.a())) && !this.m.equals(itemstack.getName())) { + if (StringUtils.isBlank(this.m)) { + if (itemstack.hasName()) { + j = itemstack.g() ? 7 : itemstack.count * 5; + i += j; + itemstack1.t(); + } + } else if (!this.m.equals(itemstack.getName())) { j = itemstack.g() ? 7 : itemstack.count * 5; i += j; if (itemstack.hasName()) { @@ -260,7 +268,6 @@ public class ContainerAnvil extends Container { } if (j == i && j > 0 && this.a >= 40) { - // this.h.getLogger().info("Naming an item only, cost too high; giving discount to cap cost to 39 levels"); // CraftBukkit - remove debug this.a = 39; } @@ -319,7 +326,7 @@ public class ContainerAnvil extends Container { ItemStack itemstack = null; Slot slot = (Slot) this.c.get(i); - if (slot != null && slot.d()) { + if (slot != null && slot.e()) { ItemStack itemstack1 = slot.getItem(); itemstack = itemstack1.cloneItemStack(); @@ -340,7 +347,7 @@ public class ContainerAnvil extends Container { if (itemstack1.count == 0) { slot.set((ItemStack) null); } else { - slot.e(); + slot.f(); } if (itemstack1.count == itemstack.count) { @@ -355,8 +362,14 @@ public class ContainerAnvil extends Container { public void a(String s) { this.m = s; - if (this.getSlot(2).d()) { - this.getSlot(2).getItem().c(this.m); + if (this.getSlot(2).e()) { + ItemStack itemstack = this.getSlot(2).getItem(); + + if (StringUtils.isBlank(s)) { + itemstack.t(); + } else { + itemstack.c(this.m); + } } this.e(); diff --git a/src/main/java/net/minecraft/server/ContainerBeacon.java b/src/main/java/net/minecraft/server/ContainerBeacon.java index 04ccfc1d..278b3b76 100644 --- a/src/main/java/net/minecraft/server/ContainerBeacon.java +++ b/src/main/java/net/minecraft/server/ContainerBeacon.java @@ -45,10 +45,6 @@ public class ContainerBeacon extends Container { icrafting.setContainerData(this, 2, this.i); } - public void b() { - super.b(); - } - public TileEntityBeacon e() { return this.a; } @@ -62,7 +58,7 @@ public class ContainerBeacon extends Container { ItemStack itemstack = null; Slot slot = (Slot) this.c.get(i); - if (slot != null && slot.d()) { + if (slot != null && slot.e()) { ItemStack itemstack1 = slot.getItem(); itemstack = itemstack1.cloneItemStack(); @@ -72,7 +68,7 @@ public class ContainerBeacon extends Container { } slot.a(itemstack1, itemstack); - } else if (!this.f.d() && this.f.isAllowed(itemstack1) && itemstack1.count == 1) { + } else if (!this.f.e() && this.f.isAllowed(itemstack1) && itemstack1.count == 1) { if (!this.a(itemstack1, 0, 1, false)) { return null; } @@ -91,7 +87,7 @@ public class ContainerBeacon extends Container { if (itemstack1.count == 0) { slot.set((ItemStack) null); } else { - slot.e(); + slot.f(); } if (itemstack1.count == itemstack.count) { diff --git a/src/main/java/net/minecraft/server/ContainerBrewingStand.java b/src/main/java/net/minecraft/server/ContainerBrewingStand.java index b796ffdb..e4c2dce7 100644 --- a/src/main/java/net/minecraft/server/ContainerBrewingStand.java +++ b/src/main/java/net/minecraft/server/ContainerBrewingStand.java @@ -9,7 +9,7 @@ public class ContainerBrewingStand extends Container { private TileEntityBrewingStand brewingStand; private final Slot f; - private int g = 0; + private int g; // CraftBukkit start private CraftInventoryView bukkitEntity = null; private PlayerInventory player; @@ -64,16 +64,16 @@ public class ContainerBrewingStand extends Container { ItemStack itemstack = null; Slot slot = (Slot) this.c.get(i); - if (slot != null && slot.d()) { + if (slot != null && slot.e()) { ItemStack itemstack1 = slot.getItem(); itemstack = itemstack1.cloneItemStack(); if ((i < 0 || i > 2) && i != 3) { - if (!this.f.d() && this.f.isAllowed(itemstack1)) { + if (!this.f.e() && this.f.isAllowed(itemstack1)) { if (!this.a(itemstack1, 3, 4, false)) { return null; } - } else if (SlotPotionBottle.a_(itemstack)) { + } else if (SlotPotionBottle.b_(itemstack)) { if (!this.a(itemstack1, 0, 3, false)) { return null; } @@ -99,7 +99,7 @@ public class ContainerBrewingStand extends Container { if (itemstack1.count == 0) { slot.set((ItemStack) null); } else { - slot.e(); + slot.f(); } if (itemstack1.count == itemstack.count) { diff --git a/src/main/java/net/minecraft/server/ContainerChest.java b/src/main/java/net/minecraft/server/ContainerChest.java index d58d955e..273e9e84 100644 --- a/src/main/java/net/minecraft/server/ContainerChest.java +++ b/src/main/java/net/minecraft/server/ContainerChest.java @@ -71,7 +71,7 @@ public class ContainerChest extends Container { ItemStack itemstack = null; Slot slot = (Slot) this.c.get(i); - if (slot != null && slot.d()) { + if (slot != null && slot.e()) { ItemStack itemstack1 = slot.getItem(); itemstack = itemstack1.cloneItemStack(); @@ -86,7 +86,7 @@ public class ContainerChest extends Container { if (itemstack1.count == 0) { slot.set((ItemStack) null); } else { - slot.e(); + slot.f(); } } diff --git a/src/main/java/net/minecraft/server/ContainerDispenser.java b/src/main/java/net/minecraft/server/ContainerDispenser.java index 6a8cfd81..9cafc14e 100644 --- a/src/main/java/net/minecraft/server/ContainerDispenser.java +++ b/src/main/java/net/minecraft/server/ContainerDispenser.java @@ -49,7 +49,7 @@ public class ContainerDispenser extends Container { ItemStack itemstack = null; Slot slot = (Slot) this.c.get(i); - if (slot != null && slot.d()) { + if (slot != null && slot.e()) { ItemStack itemstack1 = slot.getItem(); itemstack = itemstack1.cloneItemStack(); @@ -64,7 +64,7 @@ public class ContainerDispenser extends Container { if (itemstack1.count == 0) { slot.set((ItemStack) null); } else { - slot.e(); + slot.f(); } if (itemstack1.count == itemstack.count) { diff --git a/src/main/java/net/minecraft/server/ContainerEnchantTable.java b/src/main/java/net/minecraft/server/ContainerEnchantTable.java index 92b654ad..e231b3c6 100644 --- a/src/main/java/net/minecraft/server/ContainerEnchantTable.java +++ b/src/main/java/net/minecraft/server/ContainerEnchantTable.java @@ -125,7 +125,7 @@ public class ContainerEnchantTable extends Container { // CraftBukkit start CraftItemStack item = CraftItemStack.asCraftMirror(itemstack); PrepareItemEnchantEvent event = new PrepareItemEnchantEvent(player, this.getBukkitView(), this.world.getWorld().getBlockAt(this.x, this.y, this.z), item, this.costs, i); - event.setCancelled(!itemstack.w()); + event.setCancelled(!itemstack.x()); this.world.getServer().getPluginManager().callEvent(event); if (event.isCancelled()) { @@ -229,7 +229,7 @@ public class ContainerEnchantTable extends Container { ItemStack itemstack = null; Slot slot = (Slot) this.c.get(i); - if (slot != null && slot.d()) { + if (slot != null && slot.e()) { ItemStack itemstack1 = slot.getItem(); itemstack = itemstack1.cloneItemStack(); @@ -238,7 +238,7 @@ public class ContainerEnchantTable extends Container { return null; } } else { - if (((Slot) this.c.get(0)).d() || !((Slot) this.c.get(0)).isAllowed(itemstack1)) { + if (((Slot) this.c.get(0)).e() || !((Slot) this.c.get(0)).isAllowed(itemstack1)) { return null; } @@ -254,7 +254,7 @@ public class ContainerEnchantTable extends Container { if (itemstack1.count == 0) { slot.set((ItemStack) null); } else { - slot.e(); + slot.f(); } if (itemstack1.count == itemstack.count) { diff --git a/src/main/java/net/minecraft/server/ContainerFurnace.java b/src/main/java/net/minecraft/server/ContainerFurnace.java index 5b744d9a..d9764da2 100644 --- a/src/main/java/net/minecraft/server/ContainerFurnace.java +++ b/src/main/java/net/minecraft/server/ContainerFurnace.java @@ -8,9 +8,9 @@ import org.bukkit.craftbukkit.inventory.CraftInventoryView; public class ContainerFurnace extends Container { private TileEntityFurnace furnace; - private int f = 0; - private int g = 0; - private int h = 0; + private int f; + private int g; + private int h; // CraftBukkit start private CraftInventoryView bukkitEntity = null; @@ -87,7 +87,7 @@ public class ContainerFurnace extends Container { ItemStack itemstack = null; Slot slot = (Slot) this.c.get(i); - if (slot != null && slot.d()) { + if (slot != null && slot.e()) { ItemStack itemstack1 = slot.getItem(); itemstack = itemstack1.cloneItemStack(); @@ -120,7 +120,7 @@ public class ContainerFurnace extends Container { if (itemstack1.count == 0) { slot.set((ItemStack) null); } else { - slot.e(); + slot.f(); } if (itemstack1.count == itemstack.count) { diff --git a/src/main/java/net/minecraft/server/ContainerHopper.java b/src/main/java/net/minecraft/server/ContainerHopper.java index 68c3d68a..a46a3d3d 100644 --- a/src/main/java/net/minecraft/server/ContainerHopper.java +++ b/src/main/java/net/minecraft/server/ContainerHopper.java @@ -56,7 +56,7 @@ public class ContainerHopper extends Container { ItemStack itemstack = null; Slot slot = (Slot) this.c.get(i); - if (slot != null && slot.d()) { + if (slot != null && slot.e()) { ItemStack itemstack1 = slot.getItem(); itemstack = itemstack1.cloneItemStack(); @@ -71,7 +71,7 @@ public class ContainerHopper extends Container { if (itemstack1.count == 0) { slot.set((ItemStack) null); } else { - slot.e(); + slot.f(); } } diff --git a/src/main/java/net/minecraft/server/ContainerHorse.java b/src/main/java/net/minecraft/server/ContainerHorse.java new file mode 100644 index 00000000..2c2ae9a9 --- /dev/null +++ b/src/main/java/net/minecraft/server/ContainerHorse.java @@ -0,0 +1,104 @@ +package net.minecraft.server; + +// CraftBukkit start +import org.bukkit.craftbukkit.inventory.CraftInventory; +import org.bukkit.craftbukkit.inventory.CraftInventoryView; +import org.bukkit.inventory.InventoryView; +// CraftBukkit end + +public class ContainerHorse extends Container { + + private IInventory a; + private EntityHorse f; + + // CraftBukkit start + org.bukkit.craftbukkit.inventory.CraftInventoryView bukkitEntity; + PlayerInventory player; + + @Override + public InventoryView getBukkitView() { + if (bukkitEntity != null) { + return bukkitEntity; + } + + CraftInventory inventory = new org.bukkit.craftbukkit.inventory.CraftInventoryHorse(this.a); + return bukkitEntity = new CraftInventoryView(player.player.getBukkitEntity(), inventory, this); + } + + public ContainerHorse(IInventory iinventory, IInventory iinventory1, EntityHorse entityhorse) { + player = (PlayerInventory) iinventory; + // CraftBukkit end + this.a = iinventory1; + this.f = entityhorse; + byte b0 = 3; + + iinventory1.startOpen(); + int i = (b0 - 4) * 18; + + this.a(new SlotHorseSaddle(this, iinventory1, 0, 8, 18)); + this.a(new SlotHorseArmor(this, iinventory1, 1, 8, 36, entityhorse)); + int j; + int k; + + if (entityhorse.ca()) { + for (j = 0; j < b0; ++j) { + for (k = 0; k < 5; ++k) { + this.a(new Slot(iinventory1, 2 + k + j * 5, 80 + k * 18, 18 + j * 18)); + } + } + } + + for (j = 0; j < 3; ++j) { + for (k = 0; k < 9; ++k) { + this.a(new Slot(iinventory, k + j * 9 + 9, 8 + k * 18, 102 + j * 18 + i)); + } + } + + for (j = 0; j < 9; ++j) { + this.a(new Slot(iinventory, j, 8 + j * 18, 160 + i)); + } + } + + public boolean a(EntityHuman entityhuman) { + return this.a.a(entityhuman) && this.f.d(entityhuman) < 8.0F; + } + + public ItemStack b(EntityHuman entityhuman, int i) { + ItemStack itemstack = null; + Slot slot = (Slot) this.c.get(i); + + if (slot != null && slot.e()) { + ItemStack itemstack1 = slot.getItem(); + + itemstack = itemstack1.cloneItemStack(); + if (i < this.a.getSize()) { + if (!this.a(itemstack1, this.a.getSize(), this.c.size(), true)) { + return null; + } + } else if (this.getSlot(1).isAllowed(itemstack1)) { + if (!this.a(itemstack1, 1, 2, false)) { + return null; + } + } else if (this.getSlot(0).isAllowed(itemstack1)) { + if (!this.a(itemstack1, 0, 1, false)) { + return null; + } + } else if (this.a.getSize() <= 2 || !this.a(itemstack1, 2, this.a.getSize(), false)) { + return null; + } + + if (itemstack1.count == 0) { + slot.set((ItemStack) null); + } else { + slot.f(); + } + } + + return itemstack; + } + + public void b(EntityHuman entityhuman) { + super.b(entityhuman); + this.a.g(); + } +} diff --git a/src/main/java/net/minecraft/server/ContainerMerchant.java b/src/main/java/net/minecraft/server/ContainerMerchant.java index 2f256780..7424452d 100644 --- a/src/main/java/net/minecraft/server/ContainerMerchant.java +++ b/src/main/java/net/minecraft/server/ContainerMerchant.java @@ -72,7 +72,7 @@ public class ContainerMerchant extends Container { ItemStack itemstack = null; Slot slot = (Slot) this.c.get(i); - if (slot != null && slot.d()) { + if (slot != null && slot.e()) { ItemStack itemstack1 = slot.getItem(); itemstack = itemstack1.cloneItemStack(); @@ -97,7 +97,7 @@ public class ContainerMerchant extends Container { if (itemstack1.count == 0) { slot.set((ItemStack) null); } else { - slot.e(); + slot.f(); } if (itemstack1.count == itemstack.count) { @@ -112,7 +112,7 @@ public class ContainerMerchant extends Container { public void b(EntityHuman entityhuman) { super.b(entityhuman); - this.merchant.a((EntityHuman) null); + this.merchant.a_((EntityHuman) null); super.b(entityhuman); if (!this.g.isStatic) { ItemStack itemstack = this.f.splitWithoutUpdate(0); diff --git a/src/main/java/net/minecraft/server/ContainerPlayer.java b/src/main/java/net/minecraft/server/ContainerPlayer.java index d230ce76..48b6d90a 100644 --- a/src/main/java/net/minecraft/server/ContainerPlayer.java +++ b/src/main/java/net/minecraft/server/ContainerPlayer.java @@ -9,7 +9,7 @@ public class ContainerPlayer extends Container { public InventoryCrafting craftInventory = new InventoryCrafting(this, 2, 2); public IInventory resultInventory = new InventoryCraftResult(); - public boolean g = false; + public boolean g; private final EntityHuman h; // CraftBukkit start private CraftInventoryView bukkitEntity = null; @@ -87,7 +87,7 @@ public class ContainerPlayer extends Container { ItemStack itemstack = null; Slot slot = (Slot) this.c.get(i); - if (slot != null && slot.d()) { + if (slot != null && slot.e()) { ItemStack itemstack1 = slot.getItem(); itemstack = itemstack1.cloneItemStack(); @@ -105,7 +105,7 @@ public class ContainerPlayer extends Container { if (!this.a(itemstack1, 9, 45, false)) { return null; } - } else if (itemstack.getItem() instanceof ItemArmor && !((Slot) this.c.get(5 + ((ItemArmor) itemstack.getItem()).b)).d()) { + } else if (itemstack.getItem() instanceof ItemArmor && !((Slot) this.c.get(5 + ((ItemArmor) itemstack.getItem()).b)).e()) { int j = 5 + ((ItemArmor) itemstack.getItem()).b; if (!this.a(itemstack1, j, j + 1, false)) { @@ -126,7 +126,7 @@ public class ContainerPlayer extends Container { if (itemstack1.count == 0) { slot.set((ItemStack) null); } else { - slot.e(); + slot.f(); } if (itemstack1.count == itemstack.count) { diff --git a/src/main/java/net/minecraft/server/ContainerWorkbench.java b/src/main/java/net/minecraft/server/ContainerWorkbench.java index a1d4c921..025cc625 100644 --- a/src/main/java/net/minecraft/server/ContainerWorkbench.java +++ b/src/main/java/net/minecraft/server/ContainerWorkbench.java @@ -89,7 +89,7 @@ public class ContainerWorkbench extends Container { ItemStack itemstack = null; Slot slot = (Slot) this.c.get(i); - if (slot != null && slot.d()) { + if (slot != null && slot.e()) { ItemStack itemstack1 = slot.getItem(); itemstack = itemstack1.cloneItemStack(); @@ -114,7 +114,7 @@ public class ContainerWorkbench extends Container { if (itemstack1.count == 0) { slot.set((ItemStack) null); } else { - slot.e(); + slot.f(); } if (itemstack1.count == itemstack.count) { diff --git a/src/main/java/net/minecraft/server/ControllerLook.java b/src/main/java/net/minecraft/server/ControllerLook.java index bd297b38..a4b4ba7e 100644 --- a/src/main/java/net/minecraft/server/ControllerLook.java +++ b/src/main/java/net/minecraft/server/ControllerLook.java @@ -4,16 +4,16 @@ import org.bukkit.craftbukkit.TrigMath; // CraftBukkit public class ControllerLook { - private EntityLiving a; + private EntityInsentient a; private float b; private float c; - private boolean d = false; + private boolean d; private double e; private double f; private double g; - public ControllerLook(EntityLiving entityliving) { - this.a = entityliving; + public ControllerLook(EntityInsentient entityinsentient) { + this.a = entityinsentient; } public void a(Entity entity, float f, float f1) { @@ -53,20 +53,20 @@ public class ControllerLook { // CraftBukkit end this.a.pitch = this.a(this.a.pitch, f1, this.c); - this.a.aA = this.a(this.a.aA, f, this.b); + this.a.aP = this.a(this.a.aP, f, this.b); } else { - this.a.aA = this.a(this.a.aA, this.a.ax, 10.0F); + this.a.aP = this.a(this.a.aP, this.a.aN, 10.0F); } - float f2 = MathHelper.g(this.a.aA - this.a.ay); + float f2 = MathHelper.g(this.a.aP - this.a.aN); - if (!this.a.getNavigation().f()) { + if (!this.a.getNavigation().g()) { if (f2 < -75.0F) { - this.a.aA = this.a.ay - 75.0F; + this.a.aP = this.a.aN - 75.0F; } if (f2 > 75.0F) { - this.a.aA = this.a.ay + 75.0F; + this.a.aP = this.a.aN + 75.0F; } } } diff --git a/src/main/java/net/minecraft/server/ControllerMove.java b/src/main/java/net/minecraft/server/ControllerMove.java index 1b66c970..246c6a36 100644 --- a/src/main/java/net/minecraft/server/ControllerMove.java +++ b/src/main/java/net/minecraft/server/ControllerMove.java @@ -2,38 +2,38 @@ package net.minecraft.server; public class ControllerMove { - private EntityLiving a; + private EntityInsentient a; private double b; private double c; private double d; - private float e; - private boolean f = false; + private double e; + private boolean f; - public ControllerMove(EntityLiving entityliving) { - this.a = entityliving; - this.b = entityliving.locX; - this.c = entityliving.locY; - this.d = entityliving.locZ; + public ControllerMove(EntityInsentient entityinsentient) { + this.a = entityinsentient; + this.b = entityinsentient.locX; + this.c = entityinsentient.locY; + this.d = entityinsentient.locZ; } public boolean a() { return this.f; } - public float b() { + public double b() { return this.e; } - public void a(double d0, double d1, double d2, float f) { + public void a(double d0, double d1, double d2, double d3) { this.b = d0; this.c = d1; this.d = d2; - this.e = f; + this.e = d3; this.f = true; } public void c() { - this.a.f(0.0F); + this.a.n(0.0F); if (this.f) { this.f = false; int i = MathHelper.floor(this.a.boundingBox.b + 0.5D); @@ -47,7 +47,7 @@ public class ControllerMove { float f = (float) (org.bukkit.craftbukkit.TrigMath.atan2(d1, d0) * 180.0D / 3.1415927410125732D) - 90.0F; this.a.yaw = this.a(this.a.yaw, f, 30.0F); - this.a.e(this.e * this.a.bE()); + this.a.i((float) (this.e * this.a.a(GenericAttributes.d).e())); if (d2 > 0.0D && d0 * d0 + d1 * d1 < 1.0D) { this.a.getControllerJump().a(); } diff --git a/src/main/java/net/minecraft/server/CraftingManager.java b/src/main/java/net/minecraft/server/CraftingManager.java index b6dc7900..146521e4 100644 --- a/src/main/java/net/minecraft/server/CraftingManager.java +++ b/src/main/java/net/minecraft/server/CraftingManager.java @@ -42,6 +42,8 @@ public class CraftingManager { this.registerShapedRecipe(new ItemStack(Block.NETHER_FENCE, 6), new Object[] { "###", "###", Character.valueOf('#'), Block.NETHER_BRICK}); this.registerShapedRecipe(new ItemStack(Block.FENCE_GATE, 1), new Object[] { "#W#", "#W#", Character.valueOf('#'), Item.STICK, Character.valueOf('W'), Block.WOOD}); this.registerShapedRecipe(new ItemStack(Block.JUKEBOX, 1), new Object[] { "###", "#X#", "###", Character.valueOf('#'), Block.WOOD, Character.valueOf('X'), Item.DIAMOND}); + this.registerShapedRecipe(new ItemStack(Item.LEASH, 2), new Object[] { "~~ ", "~O ", " ~", Character.valueOf('~'), Item.STRING, Character.valueOf('O'), Item.SLIME_BALL}); + this.registerShapedRecipe(new ItemStack(Block.HAY_BLOCK, 1), new Object[] { "###", "###", "###", Character.valueOf('#'), Item.WHEAT}); this.registerShapedRecipe(new ItemStack(Block.NOTE_BLOCK, 1), new Object[] { "###", "#X#", "###", Character.valueOf('#'), Block.WOOD, Character.valueOf('X'), Item.REDSTONE}); this.registerShapedRecipe(new ItemStack(Block.BOOKSHELF, 1), new Object[] { "###", "XXX", "###", Character.valueOf('#'), Block.WOOD, Character.valueOf('X'), Item.BOOK}); this.registerShapedRecipe(new ItemStack(Block.SNOW_BLOCK, 1), new Object[] { "##", "##", Character.valueOf('#'), Item.SNOW_BALL}); @@ -110,9 +112,10 @@ public class CraftingManager { this.registerShapedRecipe(new ItemStack(Block.QUARTZ_STAIRS, 4), new Object[] { "# ", "## ", "###", Character.valueOf('#'), Block.QUARTZ_BLOCK}); this.registerShapedRecipe(new ItemStack(Item.PAINTING, 1), new Object[] { "###", "#X#", "###", Character.valueOf('#'), Item.STICK, Character.valueOf('X'), Block.WOOL}); this.registerShapedRecipe(new ItemStack(Item.ITEM_FRAME, 1), new Object[] { "###", "#X#", "###", Character.valueOf('#'), Item.STICK, Character.valueOf('X'), Item.LEATHER}); - this.registerShapedRecipe(new ItemStack(Item.GOLDEN_APPLE, 1, 0), new Object[] { "###", "#X#", "###", Character.valueOf('#'), Item.GOLD_NUGGET, Character.valueOf('X'), Item.APPLE}); + this.registerShapedRecipe(new ItemStack(Item.GOLDEN_APPLE, 1, 0), new Object[] { "###", "#X#", "###", Character.valueOf('#'), Item.GOLD_INGOT, Character.valueOf('X'), Item.APPLE}); this.registerShapedRecipe(new ItemStack(Item.GOLDEN_APPLE, 1, 1), new Object[] { "###", "#X#", "###", Character.valueOf('#'), Block.GOLD_BLOCK, Character.valueOf('X'), Item.APPLE}); this.registerShapedRecipe(new ItemStack(Item.CARROT_GOLDEN, 1, 0), new Object[] { "###", "#X#", "###", Character.valueOf('#'), Item.GOLD_NUGGET, Character.valueOf('X'), Item.CARROT}); + this.registerShapedRecipe(new ItemStack(Item.SPECKLED_MELON, 1), new Object[] { "###", "#X#", "###", Character.valueOf('#'), Item.GOLD_NUGGET, Character.valueOf('X'), Item.MELON}); this.registerShapedRecipe(new ItemStack(Block.LEVER, 1), new Object[] { "X", "#", Character.valueOf('#'), Block.COBBLESTONE, Character.valueOf('X'), Item.STICK}); this.registerShapedRecipe(new ItemStack(Block.TRIPWIRE_SOURCE, 2), new Object[] { "I", "S", "#", Character.valueOf('#'), Block.WOOD, Character.valueOf('S'), Item.STICK, Character.valueOf('I'), Item.IRON_INGOT}); this.registerShapedRecipe(new ItemStack(Block.REDSTONE_TORCH_ON, 1), new Object[] { "X", "#", Character.valueOf('#'), Item.STICK, Character.valueOf('X'), Item.REDSTONE}); @@ -141,7 +144,6 @@ public class CraftingManager { this.registerShapedRecipe(new ItemStack(Block.HOPPER), new Object[] { "I I", "ICI", " I ", Character.valueOf('I'), Item.IRON_INGOT, Character.valueOf('C'), Block.CHEST}); // Collections.sort(this.recipes, new RecipeSorter(this)); // CraftBukkit - moved below this.sort(); // CraftBukkit - call new sort method - System.out.println(this.recipes.size() + " recipes"); } // CraftBukkit start diff --git a/src/main/java/net/minecraft/server/CrashReport.java b/src/main/java/net/minecraft/server/CrashReport.java index 211b7420..9f96e461 100644 --- a/src/main/java/net/minecraft/server/CrashReport.java +++ b/src/main/java/net/minecraft/server/CrashReport.java @@ -18,7 +18,7 @@ public class CrashReport { private final Throwable b; private final CrashReportSystemDetails c = new CrashReportSystemDetails(this, "System Details"); private final List d = new ArrayList(); - private File e = null; + private File e; private boolean f = true; private StackTraceElement[] g = new StackTraceElement[0]; @@ -130,7 +130,7 @@ public class CrashReport { return stringbuilder.toString(); } - public boolean a(File file1, IConsoleLogManager iconsolelogmanager) { + public boolean a(File file1, IConsoleLogManager iconsolelogmanager) { if (this.e != null) { return false; } else { diff --git a/src/main/java/net/minecraft/server/DedicatedServer.java b/src/main/java/net/minecraft/server/DedicatedServer.java index 7261dc92..0ce6c49a 100644 --- a/src/main/java/net/minecraft/server/DedicatedServer.java +++ b/src/main/java/net/minecraft/server/DedicatedServer.java @@ -19,21 +19,21 @@ import org.bukkit.event.server.ServerCommandEvent; public class DedicatedServer extends MinecraftServer implements IMinecraftServer { - private final List k = Collections.synchronizedList(new ArrayList()); - private final IConsoleLogManager l; - private RemoteStatusListener m; - private RemoteControlListener n; + private final List l = Collections.synchronizedList(new ArrayList()); + private final IConsoleLogManager m; + private RemoteStatusListener n; + private RemoteControlListener o; public PropertyManager propertyManager; // CraftBukkit - private -> public private boolean generateStructures; - private EnumGamemode q; - private ServerConnection r; - private boolean s = false; + private EnumGamemode r; + private ServerConnection s; + private boolean t; // CraftBukkit start - Signature changed public DedicatedServer(joptsimple.OptionSet options) { super(options); // CraftBukkit end - this.l = new ConsoleLogManager("Minecraft-Server", (String) null, (String) null); // CraftBukkit - null last argument + this.m = new ConsoleLogManager("Minecraft-Server", (String) null, (String) null); // CraftBukkit - null last argument new ThreadSleepForever(this); } @@ -48,18 +48,18 @@ public class DedicatedServer extends MinecraftServer implements IMinecraftServer System.setErr(new PrintStream(new LoggerOutputStream(this.getLogger().getLogger(), Level.SEVERE), true)); // CraftBukkit end - this.getLogger().info("Starting minecraft server version 1.5.2"); + this.getLogger().info("Starting minecraft server version 1.6.1"); if (Runtime.getRuntime().maxMemory() / 1024L / 1024L < 512L) { this.getLogger().warning("To start the server with more ram, launch it as \"java -Xmx1024M -Xms1024M -jar minecraft_server.jar\""); } this.getLogger().info("Loading properties"); this.propertyManager = new PropertyManager(this.options, this.getLogger()); // CraftBukkit - CLI argument support - if (this.I()) { - this.d("127.0.0.1"); + if (this.K()) { + this.c("127.0.0.1"); } else { this.setOnlineMode(this.propertyManager.getBoolean("online-mode", true)); - this.d(this.propertyManager.getString("server-ip", "")); + this.c(this.propertyManager.getString("server-ip", "")); } this.setSpawnAnimals(this.propertyManager.getBoolean("spawn-animals", true)); @@ -78,24 +78,24 @@ public class DedicatedServer extends MinecraftServer implements IMinecraftServer this.generateStructures = this.propertyManager.getBoolean("generate-structures", true); int i = this.propertyManager.getInt("gamemode", EnumGamemode.SURVIVAL.a()); - this.q = WorldSettings.a(i); - this.getLogger().info("Default game type: " + this.q); + this.r = WorldSettings.a(i); + this.getLogger().info("Default game type: " + this.r); InetAddress inetaddress = null; if (this.getServerIp().length() > 0) { inetaddress = InetAddress.getByName(this.getServerIp()); } - if (this.G() < 0) { + if (this.I() < 0) { this.setPort(this.propertyManager.getInt("server-port", 25565)); } this.getLogger().info("Generating keypair"); this.a(MinecraftEncryption.b()); - this.getLogger().info("Starting Minecraft server on " + (this.getServerIp().length() == 0 ? "*" : this.getServerIp()) + ":" + this.G()); + this.getLogger().info("Starting Minecraft server on " + (this.getServerIp().length() == 0 ? "*" : this.getServerIp()) + ":" + this.I()); try { - this.r = new DedicatedServerConnection(this, inetaddress, this.G()); + this.s = new DedicatedServerConnection(this, inetaddress, this.I()); } catch (Throwable ioexception) { // CraftBukkit - IOException -> Throwable this.getLogger().warning("**** FAILED TO BIND TO PORT!"); this.getLogger().warning("The exception was: {0}", new Object[] { ioexception.toString()}); @@ -116,8 +116,8 @@ public class DedicatedServer extends MinecraftServer implements IMinecraftServer this.convertable = new WorldLoaderServer(server.getWorldContainer()); // CraftBukkit - moved from MinecraftServer constructor long j = System.nanoTime(); - if (this.J() == null) { - this.l(this.propertyManager.getString("level-name", "world")); + if (this.L() == null) { + this.k(this.propertyManager.getString("level-name", "world")); } String s = this.propertyManager.getString("level-seed", ""); @@ -147,22 +147,22 @@ public class DedicatedServer extends MinecraftServer implements IMinecraftServer this.d((this.getMaxBuildHeight() + 8) / 16 * 16); this.d(MathHelper.a(this.getMaxBuildHeight(), 64, 256)); this.propertyManager.a("max-build-height", Integer.valueOf(this.getMaxBuildHeight())); - this.getLogger().info("Preparing level \"" + this.J() + "\""); - this.a(this.J(), this.J(), k, worldtype, s2); + this.getLogger().info("Preparing level \"" + this.L() + "\""); + this.a(this.L(), this.L(), k, worldtype, s2); long i1 = System.nanoTime() - j; String s3 = String.format("%.3fs", new Object[] { Double.valueOf((double) i1 / 1.0E9D)}); this.getLogger().info("Done (" + s3 + ")! For help, type \"help\" or \"?\""); if (this.propertyManager.getBoolean("enable-query", false)) { this.getLogger().info("Starting GS4 status listener"); - this.m = new RemoteStatusListener(this); - this.m.a(); + this.n = new RemoteStatusListener(this); + this.n.a(); } if (this.propertyManager.getBoolean("enable-rcon", false)) { this.getLogger().info("Starting remote control listener"); - this.n = new RemoteControlListener(this); - this.n.a(); + this.o = new RemoteControlListener(this); + this.o.a(); this.remoteConsole = new org.bukkit.craftbukkit.command.CraftRemoteConsoleCommandSender(); // CraftBukkit } @@ -188,7 +188,7 @@ public class DedicatedServer extends MinecraftServer implements IMinecraftServer } public EnumGamemode getGamemode() { - return this.q; + return this.r; } public int getDifficulty() { @@ -201,7 +201,7 @@ public class DedicatedServer extends MinecraftServer implements IMinecraftServer protected void a(CrashReport crashreport) { while (this.isRunning()) { - this.an(); + this.ar(); try { Thread.sleep(10L); @@ -218,13 +218,13 @@ public class DedicatedServer extends MinecraftServer implements IMinecraftServer return crashreport; } - protected void p() { + protected void r() { System.exit(0); } - public void r() { // CraftBukkit - protected -> public - super.r(); - this.an(); + public void t() { // CraftBukkit - protected -> public + super.t(); + this.ar(); } public boolean getAllowNether() { @@ -236,8 +236,8 @@ public class DedicatedServer extends MinecraftServer implements IMinecraftServer } public void a(MojangStatisticsGenerator mojangstatisticsgenerator) { - mojangstatisticsgenerator.a("whitelist_enabled", Boolean.valueOf(this.ao().getHasWhitelist())); - mojangstatisticsgenerator.a("whitelist_count", Integer.valueOf(this.ao().getWhitelisted().size())); + mojangstatisticsgenerator.a("whitelist_enabled", Boolean.valueOf(this.as().getHasWhitelist())); + mojangstatisticsgenerator.a("whitelist_count", Integer.valueOf(this.as().getWhitelisted().size())); super.a(mojangstatisticsgenerator); } @@ -246,12 +246,12 @@ public class DedicatedServer extends MinecraftServer implements IMinecraftServer } public void issueCommand(String s, ICommandListener icommandlistener) { - this.k.add(new ServerCommand(s, icommandlistener)); + this.l.add(new ServerCommand(s, icommandlistener)); } - public void an() { - while (!this.k.isEmpty()) { - ServerCommand servercommand = (ServerCommand) this.k.remove(0); + public void ar() { + while (!this.l.isEmpty()) { + ServerCommand servercommand = (ServerCommand) this.l.remove(0); // CraftBukkit start - ServerCommand for preprocessing ServerCommandEvent event = new ServerCommandEvent(this.console, servercommand.command); @@ -264,16 +264,16 @@ public class DedicatedServer extends MinecraftServer implements IMinecraftServer } } - public boolean T() { + public boolean V() { return true; } - public DedicatedPlayerList ao() { + public DedicatedPlayerList as() { return (DedicatedPlayerList) super.getPlayerList(); } - public ServerConnection ae() { - return this.r; + public ServerConnection ag() { + return this.s; } public int a(String s, int i) { @@ -302,13 +302,13 @@ public class DedicatedServer extends MinecraftServer implements IMinecraftServer return file1 != null ? file1.getAbsolutePath() : "No settings file"; } - public void ap() { + public void at() { ServerGUI.a(this); - this.s = true; + this.t = true; } - public boolean ag() { - return this.s; + public boolean ai() { + return this.t; } public String a(EnumGamemode enumgamemode, boolean flag) { @@ -326,9 +326,9 @@ public class DedicatedServer extends MinecraftServer implements IMinecraftServer public boolean a(World world, int i, int j, int k, EntityHuman entityhuman) { if (world.worldProvider.dimension != 0) { return false; - } else if (this.ao().getOPs().isEmpty()) { + } else if (this.as().getOPs().isEmpty()) { return false; - } else if (this.ao().isOp(entityhuman.name)) { + } else if (this.as().isOp(entityhuman.getName())) { return false; } else if (this.getSpawnProtection() <= 0) { return false; @@ -343,10 +343,14 @@ public class DedicatedServer extends MinecraftServer implements IMinecraftServer } public IConsoleLogManager getLogger() { - return this.l; + return this.m; + } + + public int k() { + return this.propertyManager.getInt("op-permission-level", 4); } public PlayerList getPlayerList() { - return this.ao(); + return this.as(); } } diff --git a/src/main/java/net/minecraft/server/DedicatedServerConnectionThread.java b/src/main/java/net/minecraft/server/DedicatedServerConnectionThread.java index ef7e10d2..25265c0a 100644 --- a/src/main/java/net/minecraft/server/DedicatedServerConnectionThread.java +++ b/src/main/java/net/minecraft/server/DedicatedServerConnectionThread.java @@ -13,7 +13,7 @@ public class DedicatedServerConnectionThread extends Thread { private final List a = Collections.synchronizedList(new ArrayList()); private final HashMap b = new HashMap(); - private int c = 0; + private int c; private final ServerSocket d; private ServerConnection e; private final InetAddress f; diff --git a/src/main/java/net/minecraft/server/DispenseBehaviorArmor.java b/src/main/java/net/minecraft/server/DispenseBehaviorArmor.java index 1c50ad4f..f324d4d9 100644 --- a/src/main/java/net/minecraft/server/DispenseBehaviorArmor.java +++ b/src/main/java/net/minecraft/server/DispenseBehaviorArmor.java @@ -12,7 +12,7 @@ final class DispenseBehaviorArmor extends DispenseBehaviorItem { DispenseBehaviorArmor() {} protected ItemStack b(ISourceBlock isourceblock, ItemStack itemstack) { - EnumFacing enumfacing = BlockDispenser.j_(isourceblock.h()); + EnumFacing enumfacing = BlockDispenser.l_(isourceblock.h()); int i = isourceblock.getBlockX() + enumfacing.c(); int j = isourceblock.getBlockY() + enumfacing.d(); int k = isourceblock.getBlockZ() + enumfacing.e(); @@ -22,7 +22,7 @@ final class DispenseBehaviorArmor extends DispenseBehaviorItem { if (list.size() > 0) { EntityLiving entityliving = (EntityLiving) list.get(0); int l = entityliving instanceof EntityHuman ? 1 : 0; - int i1 = EntityLiving.b(itemstack); + int i1 = EntityInsentient.b(itemstack); // CraftBukkit start ItemStack itemstack1 = itemstack.a(1); @@ -54,7 +54,10 @@ final class DispenseBehaviorArmor extends DispenseBehaviorItem { itemstack1.count = 1; entityliving.setEquipment(i1 - l, itemstack1); - entityliving.a(i1, 2.0F); + if (entityliving instanceof EntityInsentient) { + ((EntityInsentient) entityliving).a(i1, 2.0F); + } + // --itemstack.count; // CraftBukkit - handled above return itemstack; } else { diff --git a/src/main/java/net/minecraft/server/DispenseBehaviorBoat.java b/src/main/java/net/minecraft/server/DispenseBehaviorBoat.java index 8e3a8615..708cf60d 100644 --- a/src/main/java/net/minecraft/server/DispenseBehaviorBoat.java +++ b/src/main/java/net/minecraft/server/DispenseBehaviorBoat.java @@ -12,7 +12,7 @@ final class DispenseBehaviorBoat extends DispenseBehaviorItem { DispenseBehaviorBoat() {} public ItemStack b(ISourceBlock isourceblock, ItemStack itemstack) { - EnumFacing enumfacing = BlockDispenser.j_(isourceblock.h()); + EnumFacing enumfacing = BlockDispenser.l_(isourceblock.h()); World world = isourceblock.k(); double d0 = isourceblock.getX() + (double) ((float) enumfacing.c() * 1.125F); double d1 = isourceblock.getY() + (double) ((float) enumfacing.d() * 1.125F); diff --git a/src/main/java/net/minecraft/server/DispenseBehaviorBonemeal.java b/src/main/java/net/minecraft/server/DispenseBehaviorBonemeal.java index 54c590b6..1a58814d 100644 --- a/src/main/java/net/minecraft/server/DispenseBehaviorBonemeal.java +++ b/src/main/java/net/minecraft/server/DispenseBehaviorBonemeal.java @@ -13,7 +13,7 @@ final class DispenseBehaviorBonemeal extends DispenseBehaviorItem { protected ItemStack b(ISourceBlock isourceblock, ItemStack itemstack) { if (itemstack.getData() == 15) { - EnumFacing enumfacing = BlockDispenser.j_(isourceblock.h()); + EnumFacing enumfacing = BlockDispenser.l_(isourceblock.h()); World world = isourceblock.k(); int i = isourceblock.getBlockX() + enumfacing.c(); int j = isourceblock.getBlockY() + enumfacing.d(); diff --git a/src/main/java/net/minecraft/server/DispenseBehaviorEmptyBucket.java b/src/main/java/net/minecraft/server/DispenseBehaviorEmptyBucket.java index 1ed656ab..1e6d8529 100644 --- a/src/main/java/net/minecraft/server/DispenseBehaviorEmptyBucket.java +++ b/src/main/java/net/minecraft/server/DispenseBehaviorEmptyBucket.java @@ -12,7 +12,7 @@ final class DispenseBehaviorEmptyBucket extends DispenseBehaviorItem { DispenseBehaviorEmptyBucket() {} public ItemStack b(ISourceBlock isourceblock, ItemStack itemstack) { - EnumFacing enumfacing = BlockDispenser.j_(isourceblock.h()); + EnumFacing enumfacing = BlockDispenser.l_(isourceblock.h()); World world = isourceblock.k(); int i = isourceblock.getBlockX() + enumfacing.c(); int j = isourceblock.getBlockY() + enumfacing.d(); diff --git a/src/main/java/net/minecraft/server/DispenseBehaviorFilledBucket.java b/src/main/java/net/minecraft/server/DispenseBehaviorFilledBucket.java index 24395c3a..b8a2a78f 100644 --- a/src/main/java/net/minecraft/server/DispenseBehaviorFilledBucket.java +++ b/src/main/java/net/minecraft/server/DispenseBehaviorFilledBucket.java @@ -16,7 +16,7 @@ final class DispenseBehaviorFilledBucket extends DispenseBehaviorItem { int i = isourceblock.getBlockX(); int j = isourceblock.getBlockY(); int k = isourceblock.getBlockZ(); - EnumFacing enumfacing = BlockDispenser.j_(isourceblock.h()); + EnumFacing enumfacing = BlockDispenser.l_(isourceblock.h()); // CraftBukkit start World world = isourceblock.k(); @@ -50,7 +50,7 @@ final class DispenseBehaviorFilledBucket extends DispenseBehaviorItem { } // CraftBukkit end - if (itembucket.a(isourceblock.k(), (double) i, (double) j, (double) k, i + enumfacing.c(), j + enumfacing.d(), k + enumfacing.e())) { + if (itembucket.a(isourceblock.k(), i + enumfacing.c(), j + enumfacing.d(), k + enumfacing.e())) { // CraftBukkit start - Handle stacked buckets Item item = Item.BUCKET; if (--itemstack.count == 0) { diff --git a/src/main/java/net/minecraft/server/DispenseBehaviorFireball.java b/src/main/java/net/minecraft/server/DispenseBehaviorFireball.java index 1cb73aac..6d428c8f 100644 --- a/src/main/java/net/minecraft/server/DispenseBehaviorFireball.java +++ b/src/main/java/net/minecraft/server/DispenseBehaviorFireball.java @@ -12,7 +12,7 @@ final class DispenseBehaviorFireball extends DispenseBehaviorItem { DispenseBehaviorFireball() {} public ItemStack b(ISourceBlock isourceblock, ItemStack itemstack) { - EnumFacing enumfacing = BlockDispenser.j_(isourceblock.h()); + EnumFacing enumfacing = BlockDispenser.l_(isourceblock.h()); IPosition iposition = BlockDispenser.a(isourceblock); double d0 = iposition.getX() + (double) ((float) enumfacing.c() * 0.3F); double d1 = iposition.getY() + (double) ((float) enumfacing.c() * 0.3F); diff --git a/src/main/java/net/minecraft/server/DispenseBehaviorFireworks.java b/src/main/java/net/minecraft/server/DispenseBehaviorFireworks.java index 6141b441..6abc928a 100644 --- a/src/main/java/net/minecraft/server/DispenseBehaviorFireworks.java +++ b/src/main/java/net/minecraft/server/DispenseBehaviorFireworks.java @@ -10,7 +10,7 @@ final class DispenseBehaviorFireworks extends DispenseBehaviorItem { DispenseBehaviorFireworks() {} public ItemStack b(ISourceBlock isourceblock, ItemStack itemstack) { - EnumFacing enumfacing = BlockDispenser.j_(isourceblock.h()); + EnumFacing enumfacing = BlockDispenser.l_(isourceblock.h()); double d0 = isourceblock.getX() + (double) enumfacing.c(); double d1 = (double) ((float) isourceblock.getBlockY() + 0.2F); double d2 = isourceblock.getZ() + (double) enumfacing.e(); diff --git a/src/main/java/net/minecraft/server/DispenseBehaviorFlintAndSteel.java b/src/main/java/net/minecraft/server/DispenseBehaviorFlintAndSteel.java index 6fc910b7..d7f44fe1 100644 --- a/src/main/java/net/minecraft/server/DispenseBehaviorFlintAndSteel.java +++ b/src/main/java/net/minecraft/server/DispenseBehaviorFlintAndSteel.java @@ -12,7 +12,7 @@ final class DispenseBehaviorFlintAndSteel extends DispenseBehaviorItem { DispenseBehaviorFlintAndSteel() {} protected ItemStack b(ISourceBlock isourceblock, ItemStack itemstack) { - EnumFacing enumfacing = BlockDispenser.j_(isourceblock.h()); + EnumFacing enumfacing = BlockDispenser.l_(isourceblock.h()); World world = isourceblock.k(); int i = isourceblock.getBlockX() + enumfacing.c(); int j = isourceblock.getBlockY() + enumfacing.d(); diff --git a/src/main/java/net/minecraft/server/DispenseBehaviorItem.java b/src/main/java/net/minecraft/server/DispenseBehaviorItem.java index c3a9f36d..290b5837 100644 --- a/src/main/java/net/minecraft/server/DispenseBehaviorItem.java +++ b/src/main/java/net/minecraft/server/DispenseBehaviorItem.java @@ -13,12 +13,12 @@ public class DispenseBehaviorItem implements IDispenseBehavior { ItemStack itemstack1 = this.b(isourceblock, itemstack); this.a(isourceblock); - this.a(isourceblock, BlockDispenser.j_(isourceblock.h())); + this.a(isourceblock, BlockDispenser.l_(isourceblock.h())); return itemstack1; } protected ItemStack b(ISourceBlock isourceblock, ItemStack itemstack) { - EnumFacing enumfacing = BlockDispenser.j_(isourceblock.h()); + EnumFacing enumfacing = BlockDispenser.l_(isourceblock.h()); IPosition iposition = BlockDispenser.a(isourceblock); ItemStack itemstack1 = itemstack.a(1); diff --git a/src/main/java/net/minecraft/server/DispenseBehaviorMinecart.java b/src/main/java/net/minecraft/server/DispenseBehaviorMinecart.java index 2a7b4ad3..0682194b 100644 --- a/src/main/java/net/minecraft/server/DispenseBehaviorMinecart.java +++ b/src/main/java/net/minecraft/server/DispenseBehaviorMinecart.java @@ -12,7 +12,7 @@ final class DispenseBehaviorMinecart extends DispenseBehaviorItem { DispenseBehaviorMinecart() {} public ItemStack b(ISourceBlock isourceblock, ItemStack itemstack) { - EnumFacing enumfacing = BlockDispenser.j_(isourceblock.h()); + EnumFacing enumfacing = BlockDispenser.l_(isourceblock.h()); World world = isourceblock.k(); double d0 = isourceblock.getX() + (double) ((float) enumfacing.c() * 1.125F); double d1 = isourceblock.getY() + (double) ((float) enumfacing.d() * 1.125F); @@ -23,10 +23,10 @@ final class DispenseBehaviorMinecart extends DispenseBehaviorItem { int l = world.getTypeId(i, j, k); double d3; - if (BlockMinecartTrackAbstract.d_(l)) { + if (BlockMinecartTrackAbstract.e_(l)) { d3 = 0.0D; } else { - if (l != 0 || !BlockMinecartTrackAbstract.d_(world.getTypeId(i, j - 1, k))) { + if (l != 0 || !BlockMinecartTrackAbstract.e_(world.getTypeId(i, j - 1, k))) { return this.b.a(isourceblock, itemstack); } @@ -63,6 +63,10 @@ final class DispenseBehaviorMinecart extends DispenseBehaviorItem { EntityMinecartAbstract entityminecartabstract = EntityMinecartAbstract.a(world, event.getVelocity().getX(), event.getVelocity().getY(), event.getVelocity().getZ(), ((ItemMinecart) itemstack1.getItem()).a); // CraftBukkit end + if (itemstack.hasName()) { + entityminecartabstract.a(itemstack.getName()); + } + world.addEntity(entityminecartabstract); // itemstack.a(1); // CraftBukkit - handled during event processing return itemstack; diff --git a/src/main/java/net/minecraft/server/DispenseBehaviorMonsterEgg.java b/src/main/java/net/minecraft/server/DispenseBehaviorMonsterEgg.java index a29b550e..b3d01287 100644 --- a/src/main/java/net/minecraft/server/DispenseBehaviorMonsterEgg.java +++ b/src/main/java/net/minecraft/server/DispenseBehaviorMonsterEgg.java @@ -10,7 +10,7 @@ final class DispenseBehaviorMonsterEgg extends DispenseBehaviorItem { DispenseBehaviorMonsterEgg() {} public ItemStack b(ISourceBlock isourceblock, ItemStack itemstack) { - EnumFacing enumfacing = BlockDispenser.j_(isourceblock.h()); + EnumFacing enumfacing = BlockDispenser.l_(isourceblock.h()); double d0 = isourceblock.getX() + (double) enumfacing.c(); double d1 = (double) ((float) isourceblock.getBlockY() + 0.2F); double d2 = isourceblock.getZ() + (double) enumfacing.e(); @@ -47,7 +47,7 @@ final class DispenseBehaviorMonsterEgg extends DispenseBehaviorItem { Entity entity = ItemMonsterEgg.a(isourceblock.k(), itemstack.getData(), event.getVelocity().getX(), event.getVelocity().getY(), event.getVelocity().getZ()); if (entity instanceof EntityLiving && itemstack.hasName()) { - ((EntityLiving) entity).setCustomName(itemstack.getName()); + ((EntityInsentient) entity).setCustomName(itemstack.getName()); } // itemstack.a(1); // Handled during event processing diff --git a/src/main/java/net/minecraft/server/DispenseBehaviorProjectile.java b/src/main/java/net/minecraft/server/DispenseBehaviorProjectile.java index 916ce148..21948081 100644 --- a/src/main/java/net/minecraft/server/DispenseBehaviorProjectile.java +++ b/src/main/java/net/minecraft/server/DispenseBehaviorProjectile.java @@ -12,7 +12,7 @@ public abstract class DispenseBehaviorProjectile extends DispenseBehaviorItem { public ItemStack b(ISourceBlock isourceblock, ItemStack itemstack) { World world = isourceblock.k(); IPosition iposition = BlockDispenser.a(isourceblock); - EnumFacing enumfacing = BlockDispenser.j_(isourceblock.h()); + EnumFacing enumfacing = BlockDispenser.l_(isourceblock.h()); IProjectile iprojectile = this.a(world, iposition); // CraftBukkit start diff --git a/src/main/java/net/minecraft/server/DispenseBehaviorTNT.java b/src/main/java/net/minecraft/server/DispenseBehaviorTNT.java index 950d9e9d..affe3ec7 100644 --- a/src/main/java/net/minecraft/server/DispenseBehaviorTNT.java +++ b/src/main/java/net/minecraft/server/DispenseBehaviorTNT.java @@ -10,7 +10,7 @@ final class DispenseBehaviorTNT extends DispenseBehaviorItem { DispenseBehaviorTNT() {} protected ItemStack b(ISourceBlock isourceblock, ItemStack itemstack) { - EnumFacing enumfacing = BlockDispenser.j_(isourceblock.h()); + EnumFacing enumfacing = BlockDispenser.l_(isourceblock.h()); World world = isourceblock.k(); int i = isourceblock.getBlockX() + enumfacing.c(); int j = isourceblock.getBlockY() + enumfacing.d(); diff --git a/src/main/java/net/minecraft/server/Enchantment.java b/src/main/java/net/minecraft/server/Enchantment.java index fec45c46..54071dba 100644 --- a/src/main/java/net/minecraft/server/Enchantment.java +++ b/src/main/java/net/minecraft/server/Enchantment.java @@ -71,8 +71,8 @@ public abstract class Enchantment { return 0; } - public int a(int i, EntityLiving entityliving) { - return 0; + public float a(int i, EntityLiving entityliving) { + return 0.0F; } public boolean a(Enchantment enchantment) { @@ -106,7 +106,6 @@ public abstract class Enchantment { for (int j = 0; j < i; ++j) { Enchantment enchantment = aenchantment[j]; - if (enchantment != null) { arraylist.add(enchantment); } diff --git a/src/main/java/net/minecraft/server/Entity.java b/src/main/java/net/minecraft/server/Entity.java index 0f7be97a..3953bc49 100644 --- a/src/main/java/net/minecraft/server/Entity.java +++ b/src/main/java/net/minecraft/server/Entity.java @@ -38,7 +38,7 @@ public abstract class Entity { } // CraftBukkit end - private static int entityCount = 0; + private static int entityCount; public int id; public double l; public boolean m; @@ -108,42 +108,20 @@ public abstract class Entity { private boolean invulnerable; public UUID uniqueID; // CraftBukkit - private -> public public EnumEntitySize at; - public boolean valid = false; // CraftBukkit + public boolean valid; // CraftBukkit public Entity(World world) { this.id = entityCount++; this.l = 1.0D; - this.m = false; this.boundingBox = AxisAlignedBB.a(0.0D, 0.0D, 0.0D, 0.0D, 0.0D, 0.0D); - this.onGround = false; - this.I = false; - this.velocityChanged = false; this.L = true; - this.dead = false; - this.height = 0.0F; this.width = 0.6F; this.length = 1.8F; - this.Q = 0.0F; - this.R = 0.0F; - this.S = 0.0F; - this.fallDistance = 0.0F; this.c = 1; - this.X = 0.0F; - this.Y = 0.0F; - this.Z = false; - this.aa = 0.0F; this.random = new Random(); - this.ticksLived = 0; this.maxFireTicks = 1; - this.fireTicks = 0; - this.inWater = false; - this.noDamageTicks = 0; this.justCreated = true; - this.fireProof = false; this.datawatcher = new DataWatcher(); - this.ai = false; - this.as = 0; - this.invulnerable = false; this.uniqueID = UUID.randomUUID(); this.at = EnumEntitySize.SIZE_2; this.world = world; @@ -279,7 +257,7 @@ public abstract class Entity { b0 = -1; } - this.c(b0); + this.b(b0); } this.ap = false; @@ -324,7 +302,7 @@ public abstract class Entity { } } else { if (this.fireTicks % 20 == 0) { - this.damageEntity(DamageSource.BURN, 1); + this.damageEntity(DamageSource.BURN, 1.0F); } --this.fireTicks; @@ -342,7 +320,6 @@ public abstract class Entity { if (!this.world.isStatic) { this.a(0, this.fireTicks > 0); - this.a(2, this.vehicle != null); } this.justCreated = false; @@ -363,12 +340,12 @@ public abstract class Entity { org.bukkit.block.Block damager = null; // ((WorldServer) this.l).getWorld().getBlockAt(i, j, k); org.bukkit.entity.Entity damagee = this.getBukkitEntity(); - EntityDamageByBlockEvent event = new EntityDamageByBlockEvent(damager, damagee, EntityDamageEvent.DamageCause.LAVA, 4); + EntityDamageByBlockEvent event = new EntityDamageByBlockEvent(damager, damagee, EntityDamageEvent.DamageCause.LAVA, 4D); server.getPluginManager().callEvent(event); if (!event.isCancelled()) { damagee.setLastDamageCause(event); - this.damageEntity(DamageSource.LAVA, event.getDamage()); + this.damageEntity(DamageSource.LAVA, (float) event.getDamage()); } if (this.fireTicks <= 0) { @@ -549,7 +526,7 @@ public abstract class Entity { d2 = d8; AxisAlignedBB axisalignedbb1 = this.boundingBox.clone(); - this.boundingBox.c(axisalignedbb); + this.boundingBox.d(axisalignedbb); list = this.world.getCubes(this, this.boundingBox.a(d6, d1, d8)); for (k = 0; k < list.size(); ++k) { @@ -603,7 +580,7 @@ public abstract class Entity { d0 = d10; d1 = d11; d2 = d12; - this.boundingBox.c(axisalignedbb1); + this.boundingBox.d(axisalignedbb1); } } @@ -653,7 +630,7 @@ public abstract class Entity { } // CraftBukkit end - if (this.f_() && !flag && this.vehicle == null) { + if (this.e_() && !flag && this.vehicle == null) { int l = MathHelper.floor(this.locX); k = MathHelper.floor(this.locY - 0.20000000298023224D - (double) this.height); @@ -691,7 +668,16 @@ public abstract class Entity { } } - this.C(); + try { + this.C(); + } catch (Throwable throwable) { + CrashReport crashreport = CrashReport.a(throwable, "Checking entity tile collision"); + CrashReportSystemDetails crashreportsystemdetails = crashreport.a("Entity being checked for collision"); + + this.a(crashreportsystemdetails); + throw new ReportedException(crashreport); + } + boolean flag2 = this.F(); if (this.world.e(this.boundingBox.shrink(0.001D, 0.001D, 0.001D))) { @@ -739,7 +725,15 @@ public abstract class Entity { int j2 = this.world.getTypeId(k1, l1, i2); if (j2 > 0) { - Block.byId[j2].a(this.world, k1, l1, i2, this); + try { + Block.byId[j2].a(this.world, k1, l1, i2, this); + } catch (Throwable throwable) { + CrashReport crashreport = CrashReport.a(throwable, "Colliding entity with tile"); + CrashReportSystemDetails crashreportsystemdetails = crashreport.a("Tile being collided with"); + + CrashReportSystemDetails.a(crashreportsystemdetails, k1, l1, i2, j2, this.world.getData(k1, l1, i2)); + throw new ReportedException(crashreport); + } } } } @@ -762,14 +756,14 @@ public abstract class Entity { this.world.makeSound(this, s, f, f1); } - protected boolean f_() { + protected boolean e_() { return true; } protected void a(double d0, boolean flag) { if (flag) { if (this.fallDistance > 0.0F) { - this.a(this.fallDistance); + this.b(this.fallDistance); this.fallDistance = 0.0F; } } else if (d0 < 0.0D) { @@ -781,9 +775,9 @@ public abstract class Entity { return null; } - protected void burn(int i) { + protected void burn(float i) { // CraftBukkit - int -> float if (!this.fireProof) { - this.damageEntity(DamageSource.FIRE, i); + this.damageEntity(DamageSource.FIRE, (float) i); } } @@ -791,9 +785,9 @@ public abstract class Entity { return this.fireProof; } - protected void a(float f) { + protected void b(float f) { if (this.passenger != null) { - this.passenger.a(f); + this.passenger.b(f); } } @@ -889,7 +883,7 @@ public abstract class Entity { } } - public float c(float f) { + public float d(float f) { int i = MathHelper.floor(this.locX); int j = MathHelper.floor(this.locZ); @@ -1018,7 +1012,7 @@ public abstract class Entity { this.velocityChanged = true; } - public boolean damageEntity(DamageSource damagesource, int i) { + public boolean damageEntity(DamageSource damagesource, float f) { if (this.isInvulnerable()) { return false; } else { @@ -1035,10 +1029,10 @@ public abstract class Entity { return false; } - public void c(Entity entity, int i) {} + public void b(Entity entity, int i) {} public boolean c(NBTTagCompound nbttagcompound) { - String s = this.P(); + String s = this.O(); if (!this.dead && s != null) { nbttagcompound.setString("id", s); @@ -1050,7 +1044,7 @@ public abstract class Entity { } public boolean d(NBTTagCompound nbttagcompound) { - String s = this.P(); + String s = this.O(); if (!this.dead && s != null && this.passenger == null) { nbttagcompound.setString("id", s); @@ -1162,7 +1156,8 @@ public abstract class Entity { // Reset the persistence for tamed animals if (entity instanceof EntityTameableAnimal && !isLevelAtLeast(nbttagcompound, 2) && !nbttagcompound.getBoolean("PersistenceRequired")) { - entity.persistent = !entity.isTypeNotPersistent(); + EntityInsentient entityinsentient = (EntityInsentient) entity; + entityinsentient.persistent = !entityinsentient.isTypeNotPersistent(); } } // CraftBukkit end @@ -1215,7 +1210,7 @@ public abstract class Entity { } } - protected final String P() { + protected final String O() { return EntityTypes.b(this); } @@ -1223,6 +1218,8 @@ public abstract class Entity { protected abstract void b(NBTTagCompound nbttagcompound); + public void P() {} + protected NBTTagList a(double... adouble) { NBTTagList nbttaglist = new NBTTagList(); double[] adouble1 = adouble; @@ -1260,11 +1257,15 @@ public abstract class Entity { } public EntityItem a(ItemStack itemstack, float f) { - EntityItem entityitem = new EntityItem(this.world, this.locX, this.locY + (double) f, this.locZ, itemstack); + if (itemstack.count == 0) { + return null; + } else { + EntityItem entityitem = new EntityItem(this.world, this.locX, this.locY + (double) f, this.locZ, itemstack); - entityitem.pickupDelay = 10; - this.world.addEntity(entityitem); - return entityitem; + entityitem.pickupDelay = 10; + this.world.addEntity(entityitem); + return entityitem; + } } public boolean isAlive() { @@ -1288,7 +1289,7 @@ public abstract class Entity { return false; } - public boolean a_(EntityHuman entityhuman) { + public boolean c(EntityHuman entityhuman) { return false; } @@ -1354,12 +1355,6 @@ public abstract class Entity { public void U() { if (this.passenger != null) { - if (!(this.passenger instanceof EntityHuman) || !((EntityHuman) this.passenger).cg()) { - this.passenger.U = this.U; - this.passenger.V = this.V + this.W() + this.passenger.V(); - this.passenger.W = this.W; - } - this.passenger.setPosition(this.locX, this.locY + this.W() + this.passenger.V(), this.locZ); } } @@ -1430,43 +1425,6 @@ public abstract class Entity { } } - public void h(Entity entity) { - double d0 = this.locX; - double d1 = this.locY; - double d2 = this.locZ; - - if (entity != null) { - d0 = entity.locX; - d1 = entity.boundingBox.b + (double) entity.length; - d2 = entity.locZ; - } - - for (double d3 = -1.5D; d3 < 2.0D; ++d3) { - for (double d4 = -1.5D; d4 < 2.0D; ++d4) { - if (d3 != 0.0D || d4 != 0.0D) { - int i = (int) (this.locX + d3); - int j = (int) (this.locZ + d4); - AxisAlignedBB axisalignedbb = this.boundingBox.c(d3, 1.0D, d4); - - if (this.world.a(axisalignedbb).isEmpty()) { - if (this.world.w(i, (int) this.locY, j)) { - this.setPositionRotation(this.locX + d3, this.locY + 1.0D, this.locZ + d4, this.yaw, this.pitch); - return; - } - - if (this.world.w(i, (int) this.locY - 1, j) || this.world.getMaterial(i, (int) this.locY - 1, j) == Material.WATER) { - d0 = this.locX + d3; - d1 = this.locY + 1.0D; - d2 = this.locZ + d4; - } - } - } - } - } - - this.setPositionRotation(d0, d1, d2, this.yaw, this.pitch); - } - public float X() { return 0.1F; } @@ -1501,11 +1459,11 @@ public abstract class Entity { public void setEquipment(int i, ItemStack itemstack) {} public boolean isBurning() { - return this.fireTicks > 0 || this.f(0); + return !this.fireProof && (this.fireTicks > 0 || this.f(0)); } - public boolean af() { - return this.vehicle != null || this.f(2); + public boolean ae() { + return this.vehicle != null; } public boolean isSneaking() { @@ -1573,12 +1531,12 @@ public abstract class Entity { } } - EntityDamageEvent event = org.bukkit.craftbukkit.event.CraftEventFactory.callEntityDamageEvent(entitylightning, this, EntityDamageEvent.DamageCause.LIGHTNING, 5); + EntityDamageEvent event = org.bukkit.craftbukkit.event.CraftEventFactory.callEntityDamageEvent(entitylightning, this, EntityDamageEvent.DamageCause.LIGHTNING, 5D); if (event.isCancelled()) { return; } - this.burn(event.getDamage()); + this.burn((float) event.getDamage()); // CraftBukkit end ++this.fireTicks; @@ -1671,7 +1629,7 @@ public abstract class Entity { } } - public void al() { + public void ak() { this.K = true; this.fallDistance = 0.0F; } @@ -1686,11 +1644,11 @@ public abstract class Entity { return LocaleI18n.get("entity." + s + ".name"); } - public Entity[] an() { + public Entity[] am() { return null; } - public boolean i(Entity entity) { + public boolean h(Entity entity) { return this == entity; } @@ -1698,11 +1656,11 @@ public abstract class Entity { return 0.0F; } - public boolean ap() { + public boolean ao() { return true; } - public boolean j(Entity entity) { + public boolean i(Entity entity) { return false; } @@ -1714,7 +1672,7 @@ public abstract class Entity { return this.invulnerable; } - public void k(Entity entity) { + public void j(Entity entity) { this.setPositionRotation(entity.locX, entity.locY, entity.locZ, entity.yaw, entity.pitch); } @@ -1727,7 +1685,7 @@ public abstract class Entity { this.as = entity.as; } - public void c(int i) { + public void b(int i) { if (!this.world.isStatic && !this.dead) { this.world.methodProfiler.a("changeDimension"); MinecraftServer minecraftserver = MinecraftServer.getServer(); @@ -1767,6 +1725,13 @@ public abstract class Entity { // CraftBukkit end this.dimension = i; + /* CraftBukkit start - TODO: Check if we need this + if (j == 1 && i == 1) { + worldserver1 = minecraftserver.getWorldServer(0); + this.dimension = 0; + } + // CraftBukkit end */ + this.world.kill(this); this.dead = false; this.world.methodProfiler.a("reposition"); @@ -1782,6 +1747,14 @@ public abstract class Entity { if (entity != null) { entity.a(this, true); + /* CraftBukkit start - We need to do this... + if (j == 1 && i == 1) { + ChunkCoordinates chunkcoordinates = worldserver1.getSpawn(); + + chunkcoordinates.y = this.world.i(chunkcoordinates.x, chunkcoordinates.z); + entity.setPositionRotation((double) chunkcoordinates.x, (double) chunkcoordinates.y, (double) chunkcoordinates.z, entity.yaw, entity.pitch); + } + // CraftBukkit end */ worldserver1.addEntity(entity); // CraftBukkit start - Forward the CraftEntity to the new entity this.getBukkitEntity().setHandle(entity); @@ -1805,15 +1778,15 @@ public abstract class Entity { return true; } - public int ar() { + public int aq() { return 3; } - public int as() { + public int ar() { return this.as; } - public boolean at() { + public boolean as() { return false; } @@ -1826,7 +1799,11 @@ public abstract class Entity { crashreportsystemdetails.a("Entity\'s Momentum", String.format("%.2f, %.2f, %.2f", new Object[] { Double.valueOf(this.motX), Double.valueOf(this.motY), Double.valueOf(this.motZ)})); } - public boolean aw() { + public UUID getUniqueID() { + return this.uniqueID; + } + + public boolean av() { return true; } diff --git a/src/main/java/net/minecraft/server/EntityAgeable.java b/src/main/java/net/minecraft/server/EntityAgeable.java index fdc9167a..5ba19f3c 100644 --- a/src/main/java/net/minecraft/server/EntityAgeable.java +++ b/src/main/java/net/minecraft/server/EntityAgeable.java @@ -2,8 +2,8 @@ package net.minecraft.server; public abstract class EntityAgeable extends EntityCreature { - private float d = -1.0F; - private float e; + private float bp = -1.0F; + private float bq; public boolean ageLocked = false; // CraftBukkit public EntityAgeable(World world) { @@ -12,34 +12,38 @@ public abstract class EntityAgeable extends EntityCreature { public abstract EntityAgeable createChild(EntityAgeable entityageable); - public boolean a_(EntityHuman entityhuman) { + public boolean a(EntityHuman entityhuman) { ItemStack itemstack = entityhuman.inventory.getItemInHand(); - if (itemstack != null && itemstack.id == Item.MONSTER_EGG.id && !this.world.isStatic) { - Class oclass = EntityTypes.a(itemstack.getData()); + if (itemstack != null && itemstack.id == Item.MONSTER_EGG.id) { + if (!this.world.isStatic) { + Class oclass = EntityTypes.a(itemstack.getData()); - if (oclass != null && oclass.isAssignableFrom(this.getClass())) { - EntityAgeable entityageable = this.createChild(this); + if (oclass != null && oclass.isAssignableFrom(this.getClass())) { + EntityAgeable entityageable = this.createChild(this); - if (entityageable != null) { - entityageable.setAge(-24000); - entityageable.setPositionRotation(this.locX, this.locY, this.locZ, 0.0F, 0.0F); - this.world.addEntity(entityageable, org.bukkit.event.entity.CreatureSpawnEvent.SpawnReason.SPAWNER_EGG); // CraftBukkit - if (itemstack.hasName()) { - entityageable.setCustomName(itemstack.getName()); - } + if (entityageable != null) { + entityageable.setAge(-24000); + entityageable.setPositionRotation(this.locX, this.locY, this.locZ, 0.0F, 0.0F); + this.world.addEntity(entityageable, org.bukkit.event.entity.CreatureSpawnEvent.SpawnReason.SPAWNER_EGG); // CraftBukkit + if (itemstack.hasName()) { + entityageable.setCustomName(itemstack.getName()); + } - if (!entityhuman.abilities.canInstantlyBuild) { - --itemstack.count; - if (itemstack.count == 0) { // CraftBukkit - allow less than 0 stacks as "infinite" - entityhuman.inventory.setItem(entityhuman.inventory.itemInHandIndex, (ItemStack) null); + if (!entityhuman.abilities.canInstantlyBuild) { + --itemstack.count; + if (itemstack.count == 0) { // CraftBukkit - allow less than 0 stacks as "infinite" + entityhuman.inventory.setItem(entityhuman.inventory.itemInHandIndex, (ItemStack) null); + } } } } } - } - return super.a_(entityhuman); + return true; + } else { + return false; + } } protected void a() { @@ -51,6 +55,17 @@ public abstract class EntityAgeable extends EntityCreature { return this.datawatcher.getInt(12); } + public void a(int i) { + int j = this.getAge(); + + j += i * 20; + if (j > 0) { + j = 0; + } + + this.setAge(j); + } + public void setAge(int i) { this.datawatcher.watch(12, Integer.valueOf(i)); this.a(this.isBaby()); @@ -90,20 +105,20 @@ public abstract class EntityAgeable extends EntityCreature { } public void a(boolean flag) { - this.j(flag ? 0.5F : 1.0F); + this.a(flag ? 0.5F : 1.0F); } protected final void a(float f, float f1) { - boolean flag = this.d > 0.0F; + boolean flag = this.bp > 0.0F; - this.d = f; - this.e = f1; + this.bp = f; + this.bq = f1; if (!flag) { - this.j(1.0F); + this.a(1.0F); } } - private void j(float f) { - super.a(this.d * f, this.e * f); + protected final void a(float f) { + super.a(this.bp * f, this.bq * f); } } diff --git a/src/main/java/net/minecraft/server/EntityArrow.java b/src/main/java/net/minecraft/server/EntityArrow.java index f46c9209..affeca6e 100644 --- a/src/main/java/net/minecraft/server/EntityArrow.java +++ b/src/main/java/net/minecraft/server/EntityArrow.java @@ -12,14 +12,14 @@ public class EntityArrow extends Entity implements IProjectile { private int d = -1; private int e = -1; private int f = -1; - private int g = 0; - private int h = 0; - private boolean inGround = false; - public int fromPlayer = 0; - public int shake = 0; + private int g; + private int h; + private boolean inGround; + public int fromPlayer; + public int shake; public Entity shooter; private int j; - private int au = 0; + private int au; private double damage = 2.0D; private int aw; @@ -237,12 +237,12 @@ public class EntityArrow extends Entity implements IProjectile { // CraftBukkit end } - // if (movingobjectposition.entity.damageEntity(damagesource, i1)) { // CraftBukkit - moved up + // if (movingobjectposition.entity.damageEntity(damagesource, (float) i1)) { // CraftBukkit - moved up if (movingobjectposition.entity instanceof EntityLiving) { EntityLiving entityliving = (EntityLiving) movingobjectposition.entity; if (!this.world.isStatic) { - entityliving.r(entityliving.bM() + 1); + entityliving.m(entityliving.aQ() + 1); } if (this.aw > 0) { @@ -386,7 +386,7 @@ public class EntityArrow extends Entity implements IProjectile { EntityItem item = new EntityItem(this.world, this.locX, this.locY, this.locZ, itemstack); PlayerPickupItemEvent event = new PlayerPickupItemEvent((org.bukkit.entity.Player) entityhuman.getBukkitEntity(), new org.bukkit.craftbukkit.entity.CraftItem(this.world.getServer(), this, item), 0); - event.setCancelled(!entityhuman.canPickUpLoot); + // event.setCancelled(!entityhuman.canPickUpLoot); TODO this.world.getServer().getPluginManager().callEvent(event); if (event.isCancelled()) { @@ -409,7 +409,7 @@ public class EntityArrow extends Entity implements IProjectile { } } - protected boolean f_() { + protected boolean e_() { return false; } @@ -425,7 +425,7 @@ public class EntityArrow extends Entity implements IProjectile { this.aw = i; } - public boolean ap() { + public boolean ao() { return false; } diff --git a/src/main/java/net/minecraft/server/EntityBlaze.java b/src/main/java/net/minecraft/server/EntityBlaze.java index 8c72066f..f9c0430c 100644 --- a/src/main/java/net/minecraft/server/EntityBlaze.java +++ b/src/main/java/net/minecraft/server/EntityBlaze.java @@ -2,19 +2,19 @@ package net.minecraft.server; public class EntityBlaze extends EntityMonster { - private float d = 0.5F; - private int e; - private int f; + private float bp = 0.5F; + private int bq; + private int br; public EntityBlaze(World world) { super(world); - this.texture = "/mob/fire.png"; this.fireProof = true; - this.be = 10; + this.b = 10; } - public int getMaxHealth() { - return 20; + protected void ax() { + super.ax(); + this.a(GenericAttributes.e).a(6.0D); } protected void a() { @@ -22,35 +22,35 @@ public class EntityBlaze extends EntityMonster { this.datawatcher.a(16, new Byte((byte) 0)); } - protected String bb() { + protected String r() { return "mob.blaze.breathe"; } - protected String bc() { + protected String aK() { return "mob.blaze.hit"; } - protected String bd() { + protected String aL() { return "mob.blaze.death"; } - public float c(float f) { + public float d(float f) { return 1.0F; } public void c() { if (!this.world.isStatic) { if (this.F()) { - this.damageEntity(DamageSource.DROWN, 1); + this.damageEntity(DamageSource.DROWN, 1.0F); } - --this.e; - if (this.e <= 0) { - this.e = 100; - this.d = 0.5F + (float) this.random.nextGaussian() * 3.0F; + --this.bq; + if (this.bq <= 0) { + this.bq = 100; + this.bp = 0.5F + (float) this.random.nextGaussian() * 3.0F; } - if (this.l() != null && this.l().locY + (double) this.l().getHeadHeight() > this.locY + (double) this.getHeadHeight() + (double) this.d) { + if (this.bJ() != null && this.bJ().locY + (double) this.bJ().getHeadHeight() > this.locY + (double) this.getHeadHeight() + (double) this.bp) { this.motY += (0.30000001192092896D - this.motY) * 0.30000001192092896D; } } @@ -80,19 +80,19 @@ public class EntityBlaze extends EntityMonster { double d2 = entity.locZ - this.locZ; if (this.attackTicks == 0) { - ++this.f; - if (this.f == 1) { + ++this.br; + if (this.br == 1) { this.attackTicks = 60; this.a(true); - } else if (this.f <= 4) { + } else if (this.br <= 4) { this.attackTicks = 6; } else { this.attackTicks = 100; - this.f = 0; + this.br = 0; this.a(false); } - if (this.f > 1) { + if (this.br > 1) { float f1 = MathHelper.c(f) * 0.5F; this.world.a((EntityHuman) null, 1009, (int) this.locX, (int) this.locY, (int) this.locZ, 0); @@ -107,18 +107,18 @@ public class EntityBlaze extends EntityMonster { } this.yaw = (float) (Math.atan2(d2, d0) * 180.0D / 3.1415927410125732D) - 90.0F; - this.b = true; + this.bn = true; } } - protected void a(float f) {} + protected void b(float f) {} protected int getLootId() { return Item.BLAZE_ROD.id; } public boolean isBurning() { - return this.m(); + return this.bP(); } protected void dropDeathLoot(boolean flag, int i) { @@ -136,7 +136,7 @@ public class EntityBlaze extends EntityMonster { } } - public boolean m() { + public boolean bP() { return (this.datawatcher.getByte(16) & 1) != 0; } @@ -155,8 +155,4 @@ public class EntityBlaze extends EntityMonster { protected boolean i_() { return true; } - - public int c(Entity entity) { - return 6; - } } diff --git a/src/main/java/net/minecraft/server/EntityBoat.java b/src/main/java/net/minecraft/server/EntityBoat.java index acafa6cb..7c9b2733 100644 --- a/src/main/java/net/minecraft/server/EntityBoat.java +++ b/src/main/java/net/minecraft/server/EntityBoat.java @@ -53,14 +53,14 @@ public class EntityBoat extends Entity { this.height = this.length / 2.0F; } - protected boolean f_() { + protected boolean e_() { return false; } protected void a() { this.datawatcher.a(17, new Integer(0)); this.datawatcher.a(18, new Integer(1)); - this.datawatcher.a(19, new Integer(0)); + this.datawatcher.a(19, new Float(0.0F)); } public AxisAlignedBB g(Entity entity) { @@ -92,7 +92,7 @@ public class EntityBoat extends Entity { return (double) this.length * 0.0D - 0.30000001192092896D; } - public boolean damageEntity(DamageSource damagesource, int i) { + public boolean damageEntity(DamageSource damagesource, float f) { if (this.isInvulnerable()) { return false; } else if (!this.world.isStatic && !this.dead) { @@ -100,7 +100,7 @@ public class EntityBoat extends Entity { Vehicle vehicle = (Vehicle) this.getBukkitEntity(); org.bukkit.entity.Entity attacker = (damagesource.getEntity() == null) ? null : damagesource.getEntity().getBukkitEntity(); - VehicleDamageEvent event = new VehicleDamageEvent(vehicle, attacker, i); + VehicleDamageEvent event = new VehicleDamageEvent(vehicle, attacker, (double) f); this.world.getServer().getPluginManager().callEvent(event); if (event.isCancelled()) { @@ -109,19 +109,19 @@ public class EntityBoat extends Entity { // i = event.getDamage(); // TODO Why don't we do this? // CraftBukkit end - this.h(-this.h()); - this.b(10); - this.setDamage(this.getDamage() + i * 10); + this.c(-this.h()); + this.a(10); + this.setDamage(this.getDamage() + f * 10.0F); this.J(); boolean flag = damagesource.getEntity() instanceof EntityHuman && ((EntityHuman) damagesource.getEntity()).abilities.canInstantlyBuild; - if (flag || this.getDamage() > 40) { + if (flag || this.getDamage() > 40.0F) { // CraftBukkit start VehicleDestroyEvent destroyEvent = new VehicleDestroyEvent(vehicle, attacker); this.world.getServer().getPluginManager().callEvent(destroyEvent); if (destroyEvent.isCancelled()) { - this.setDamage(40); // Maximize damage so this doesn't get triggered again right away + this.setDamage(40F); // Maximize damage so this doesn't get triggered again right away return true; } // CraftBukkit end @@ -157,12 +157,12 @@ public class EntityBoat extends Entity { // CraftBukkit end super.l_(); - if (this.g() > 0) { - this.b(this.g() - 1); + if (this.e() > 0) { + this.a(this.e() - 1); } - if (this.getDamage() > 0) { - this.setDamage(this.getDamage() - 1); + if (this.getDamage() > 0.0F) { + this.setDamage(this.getDamage() - 1.0F); } this.lastX = this.locX; @@ -248,9 +248,14 @@ public class EntityBoat extends Entity { this.motY += 0.007000000216066837D; } - if (this.passenger != null) { - this.motX += this.passenger.motX * this.b; - this.motZ += this.passenger.motZ * this.b; + if (this.passenger != null && this.passenger instanceof EntityLiving) { + d4 = (double) ((EntityLiving) this.passenger).bf; + if (d4 > 0.0D) { + d5 = -Math.sin((double) (this.passenger.yaw * 3.1415927F / 180.0F)); + d10 = Math.cos((double) (this.passenger.yaw * 3.1415927F / 180.0F)); + this.motX += d5 * this.b * 0.05000000074505806D; + this.motZ += d10 * this.b * 0.05000000074505806D; + } } // CraftBukkit start - Support unoccupied deceleration else if (unoccupiedDeceleration >= 0) { @@ -420,7 +425,7 @@ public class EntityBoat extends Entity { protected void a(NBTTagCompound nbttagcompound) {} - public boolean a_(EntityHuman entityhuman) { + public boolean c(EntityHuman entityhuman) { if (this.passenger != null && this.passenger instanceof EntityHuman && this.passenger != entityhuman) { return true; } else { @@ -432,23 +437,23 @@ public class EntityBoat extends Entity { } } - public void setDamage(int i) { - this.datawatcher.watch(19, Integer.valueOf(i)); + public void setDamage(float f) { + this.datawatcher.watch(19, Float.valueOf(f)); } - public int getDamage() { - return this.datawatcher.getInt(19); + public float getDamage() { + return this.datawatcher.getFloat(19); } - public void b(int i) { + public void a(int i) { this.datawatcher.watch(17, Integer.valueOf(i)); } - public int g() { + public int e() { return this.datawatcher.getInt(17); } - public void h(int i) { + public void c(int i) { this.datawatcher.watch(18, Integer.valueOf(i)); } diff --git a/src/main/java/net/minecraft/server/EntityChicken.java b/src/main/java/net/minecraft/server/EntityChicken.java index 7d06ded2..b03f1ddb 100644 --- a/src/main/java/net/minecraft/server/EntityChicken.java +++ b/src/main/java/net/minecraft/server/EntityChicken.java @@ -2,80 +2,78 @@ package net.minecraft.server; public class EntityChicken extends EntityAnimal { - public boolean d = false; - public float e = 0.0F; - public float f = 0.0F; - public float g; - public float h; - public float i = 1.0F; - public int j; + public float bp; + public float bq; + public float br; + public float bs; + public float bt = 1.0F; + public int bu; public EntityChicken(World world) { super(world); - this.texture = "/mob/chicken.png"; this.a(0.3F, 0.7F); - this.j = this.random.nextInt(6000) + 6000; - float f = 0.25F; - + this.bu = this.random.nextInt(6000) + 6000; this.goalSelector.a(0, new PathfinderGoalFloat(this)); - this.goalSelector.a(1, new PathfinderGoalPanic(this, 0.38F)); - this.goalSelector.a(2, new PathfinderGoalBreed(this, f)); - this.goalSelector.a(3, new PathfinderGoalTempt(this, 0.25F, Item.SEEDS.id, false)); - this.goalSelector.a(4, new PathfinderGoalFollowParent(this, 0.28F)); - this.goalSelector.a(5, new PathfinderGoalRandomStroll(this, f)); + this.goalSelector.a(1, new PathfinderGoalPanic(this, 1.4D)); + this.goalSelector.a(2, new PathfinderGoalBreed(this, 1.0D)); + this.goalSelector.a(3, new PathfinderGoalTempt(this, 1.0D, Item.SEEDS.id, false)); + this.goalSelector.a(4, new PathfinderGoalFollowParent(this, 1.1D)); + this.goalSelector.a(5, new PathfinderGoalRandomStroll(this, 1.0D)); this.goalSelector.a(6, new PathfinderGoalLookAtPlayer(this, EntityHuman.class, 6.0F)); this.goalSelector.a(7, new PathfinderGoalRandomLookaround(this)); } - public boolean bh() { + public boolean bb() { return true; } - public int getMaxHealth() { - return 4; + protected void ax() { + super.ax(); + this.a(GenericAttributes.a).a(4.0D); + this.a(GenericAttributes.d).a(0.25D); } public void c() { super.c(); - this.h = this.e; - this.g = this.f; - this.f = (float) ((double) this.f + (double) (this.onGround ? -1 : 4) * 0.3D); - if (this.f < 0.0F) { - this.f = 0.0F; + this.bs = this.bp; + this.br = this.bq; + this.bq = (float) ((double) this.bq + (double) (this.onGround ? -1 : 4) * 0.3D); + if (this.bq < 0.0F) { + this.bq = 0.0F; } - if (this.f > 1.0F) { - this.f = 1.0F; + if (this.bq > 1.0F) { + this.bq = 1.0F; } - if (!this.onGround && this.i < 1.0F) { - this.i = 1.0F; + if (!this.onGround && this.bt < 1.0F) { + this.bt = 1.0F; } - this.i = (float) ((double) this.i * 0.9D); + this.bt = (float) ((double) this.bt * 0.9D); if (!this.onGround && this.motY < 0.0D) { this.motY *= 0.6D; } - this.e += this.i * 2.0F; - if (!this.isBaby() && !this.world.isStatic && --this.j <= 0) { + this.bp += this.bt * 2.0F; + if (!this.isBaby() && !this.world.isStatic && --this.bu <= 0) { this.makeSound("mob.chicken.plop", 1.0F, (this.random.nextFloat() - this.random.nextFloat()) * 0.2F + 1.0F); this.b(Item.EGG.id, 1); - this.j = this.random.nextInt(6000) + 6000; + this.bu = this.random.nextInt(6000) + 6000; } } - protected void a(float f) {} + protected void b(float f) {} - protected String bb() { + protected String r() { return "mob.chicken.say"; } - protected String bc() { + protected String aK() { return "mob.chicken.hurt"; } - protected String bd() { + protected String aL() { return "mob.chicken.hurt"; } diff --git a/src/main/java/net/minecraft/server/EntityCow.java b/src/main/java/net/minecraft/server/EntityCow.java index 748f7abf..9173a0a1 100644 --- a/src/main/java/net/minecraft/server/EntityCow.java +++ b/src/main/java/net/minecraft/server/EntityCow.java @@ -9,36 +9,37 @@ public class EntityCow extends EntityAnimal { public EntityCow(World world) { super(world); - this.texture = "/mob/cow.png"; this.a(0.9F, 1.3F); this.getNavigation().a(true); this.goalSelector.a(0, new PathfinderGoalFloat(this)); - this.goalSelector.a(1, new PathfinderGoalPanic(this, 0.38F)); - this.goalSelector.a(2, new PathfinderGoalBreed(this, 0.2F)); - this.goalSelector.a(3, new PathfinderGoalTempt(this, 0.25F, Item.WHEAT.id, false)); - this.goalSelector.a(4, new PathfinderGoalFollowParent(this, 0.25F)); - this.goalSelector.a(5, new PathfinderGoalRandomStroll(this, 0.2F)); + this.goalSelector.a(1, new PathfinderGoalPanic(this, 2.0D)); + this.goalSelector.a(2, new PathfinderGoalBreed(this, 1.0D)); + this.goalSelector.a(3, new PathfinderGoalTempt(this, 1.25D, Item.WHEAT.id, false)); + this.goalSelector.a(4, new PathfinderGoalFollowParent(this, 1.25D)); + this.goalSelector.a(5, new PathfinderGoalRandomStroll(this, 1.0D)); this.goalSelector.a(6, new PathfinderGoalLookAtPlayer(this, EntityHuman.class, 6.0F)); this.goalSelector.a(7, new PathfinderGoalRandomLookaround(this)); } - public boolean bh() { + public boolean bb() { return true; } - public int getMaxHealth() { - return 10; + protected void ax() { + super.ax(); + this.a(GenericAttributes.a).a(10.0D); + this.a(GenericAttributes.d).a(0.20000000298023224D); } - protected String bb() { + protected String r() { return "mob.cow.say"; } - protected String bc() { + protected String aK() { return "mob.cow.hurt"; } - protected String bd() { + protected String aL() { return "mob.cow.hurt"; } @@ -46,7 +47,7 @@ public class EntityCow extends EntityAnimal { this.makeSound("mob.cow.step", 0.15F, 1.0F); } - protected float ba() { + protected float aW() { return 0.4F; } @@ -75,10 +76,10 @@ public class EntityCow extends EntityAnimal { // CraftBukkit end } - public boolean a_(EntityHuman entityhuman) { + public boolean a(EntityHuman entityhuman) { ItemStack itemstack = entityhuman.inventory.getItemInHand(); - if (itemstack != null && itemstack.id == Item.BUCKET.id) { + if (itemstack != null && itemstack.id == Item.BUCKET.id && !entityhuman.abilities.canInstantlyBuild) { // CraftBukkit start - Got milk? org.bukkit.Location loc = this.getBukkitEntity().getLocation(); org.bukkit.event.player.PlayerBucketFillEvent event = CraftEventFactory.callPlayerBucketFillEvent(entityhuman, loc.getBlockX(), loc.getBlockY(), loc.getBlockZ(), -1, itemstack, Item.MILK_BUCKET); @@ -96,7 +97,7 @@ public class EntityCow extends EntityAnimal { return true; } else { - return super.a_(entityhuman); + return super.a(entityhuman); } } diff --git a/src/main/java/net/minecraft/server/EntityCreature.java b/src/main/java/net/minecraft/server/EntityCreature.java index 4d91a461..052f2338 100644 --- a/src/main/java/net/minecraft/server/EntityCreature.java +++ b/src/main/java/net/minecraft/server/EntityCreature.java @@ -1,33 +1,43 @@ package net.minecraft.server; +import java.util.UUID; + // CraftBukkit start import org.bukkit.craftbukkit.entity.CraftEntity; import org.bukkit.event.entity.EntityTargetEvent; // CraftBukkit end -public abstract class EntityCreature extends EntityLiving { +public abstract class EntityCreature extends EntityInsentient { + public static final UUID h = UUID.fromString("E199AD21-BA8A-4C53-8D13-6182D5C69D3A"); + public static final AttributeModifier i = (new AttributeModifier(h, "Fleeing speed bonus", 2.0D, 2)).a(false); public PathEntity pathEntity; // CraftBukkit - private -> public public Entity target; // CraftBukkit - protected -> public - protected boolean b = false; - protected int c = 0; + protected boolean bn; + protected int bo; + private ChunkCoordinates bq = new ChunkCoordinates(0, 0, 0); + private float br = -1.0F; + private PathfinderGoal bs = new PathfinderGoalMoveTowardsRestriction(this, 1.0D); + private boolean bt; public EntityCreature(World world) { super(world); } - protected boolean h() { + protected boolean bF() { return false; } - protected void bq() { + protected void bh() { this.world.methodProfiler.a("ai"); - if (this.c > 0) { - --this.c; + if (this.bo > 0 && --this.bo == 0) { + AttributeInstance attributeinstance = this.a(GenericAttributes.d); + + attributeinstance.b(i); } - this.b = this.h(); - float f = 16.0F; + this.bn = this.bF(); + float f11 = 16.0F; if (this.target == null) { // CraftBukkit start @@ -47,12 +57,12 @@ public abstract class EntityCreature extends EntityLiving { // CraftBukkit end if (this.target != null) { - this.pathEntity = this.world.findPath(this, this.target, f, true, false, false, true); + this.pathEntity = this.world.findPath(this, this.target, f11, true, false, false, true); } } else if (this.target.isAlive()) { float f1 = this.target.d((Entity) this); - if (this.n(this.target)) { + if (this.o(this.target)) { this.a(this.target, f1); } } else { @@ -71,10 +81,10 @@ public abstract class EntityCreature extends EntityLiving { } this.world.methodProfiler.b(); - if (!this.b && this.target != null && (this.pathEntity == null || this.random.nextInt(20) == 0)) { - this.pathEntity = this.world.findPath(this, this.target, f, true, false, false, true); - } else if (!this.b && (this.pathEntity == null && this.random.nextInt(180) == 0 || this.random.nextInt(120) == 0 || this.c > 0) && this.bC < 100) { - this.i(); + if (!this.bn && this.target != null && (this.pathEntity == null || this.random.nextInt(20) == 0)) { + this.pathEntity = this.world.findPath(this, this.target, f11, true, false, false, true); + } else if (!this.bn && (this.pathEntity == null && this.random.nextInt(180) == 0 || this.random.nextInt(120) == 0 || this.bo > 0) && this.aV < 100) { + this.bG(); } int i = MathHelper.floor(this.boundingBox.b + 0.5D); @@ -97,7 +107,7 @@ public abstract class EntityCreature extends EntityLiving { } } - this.bG = false; + this.bd = false; if (vec3d != null) { double d1 = vec3d.c - this.locX; double d2 = vec3d.e - this.locZ; @@ -106,7 +116,7 @@ public abstract class EntityCreature extends EntityLiving { float f2 = (float) (org.bukkit.craftbukkit.TrigMath.atan2(d2, d1) * 180.0D / 3.1415927410125732D) - 90.0F; float f3 = MathHelper.g(f2 - this.yaw); - this.bE = this.bI; + this.bf = (float) this.a(GenericAttributes.d).e(); if (f3 > 30.0F) { f3 = 30.0F; } @@ -116,19 +126,19 @@ public abstract class EntityCreature extends EntityLiving { } this.yaw += f3; - if (this.b && this.target != null) { + if (this.bn && this.target != null) { double d4 = this.target.locX - this.locX; double d5 = this.target.locZ - this.locZ; float f4 = this.yaw; this.yaw = (float) (Math.atan2(d5, d4) * 180.0D / 3.1415927410125732D) - 90.0F; f3 = (f4 - this.yaw + 90.0F) * 3.1415927F / 180.0F; - this.bD = -MathHelper.sin(f3) * this.bE * 1.0F; - this.bE = MathHelper.cos(f3) * this.bE * 1.0F; + this.be = -MathHelper.sin(f3) * this.bf * 1.0F; + this.bf = MathHelper.cos(f3) * this.bf * 1.0F; } if (d3 > 0.0D) { - this.bG = true; + this.bd = true; } } @@ -136,22 +146,22 @@ public abstract class EntityCreature extends EntityLiving { this.a(this.target, 30.0F, 30.0F); } - if (this.positionChanged && !this.k()) { - this.bG = true; + if (this.positionChanged && !this.bI()) { + this.bd = true; } if (this.random.nextFloat() < 0.8F && (flag || flag1)) { - this.bG = true; + this.bd = true; } this.world.methodProfiler.b(); } else { - super.bq(); + super.bh(); this.pathEntity = null; } } - protected void i() { + protected void bG() { this.world.methodProfiler.a("stroll"); boolean flag = false; int i = -1; @@ -199,7 +209,7 @@ public abstract class EntityCreature extends EntityLiving { return super.canSpawn() && this.a(i, j, k) >= 0.0F; } - public boolean k() { + public boolean bI() { return this.pathEntity != null; } @@ -207,7 +217,7 @@ public abstract class EntityCreature extends EntityLiving { this.pathEntity = pathentity; } - public Entity l() { + public Entity bJ() { return this.target; } @@ -215,13 +225,79 @@ public abstract class EntityCreature extends EntityLiving { this.target = entity; } - public float bE() { - float f = super.bE(); + public boolean bK() { + return this.b(MathHelper.floor(this.locX), MathHelper.floor(this.locY), MathHelper.floor(this.locZ)); + } - if (this.c > 0 && !this.bh()) { - f *= 2.0F; - } + public boolean b(int i, int j, int k) { + return this.br == -1.0F ? true : this.bq.e(i, j, k) < this.br * this.br; + } + + public void b(int i, int j, int k, int l) { + this.bq.b(i, j, k); + this.br = (float) l; + } + + public ChunkCoordinates bL() { + return this.bq; + } + + public float bM() { + return this.br; + } + + public void bN() { + this.br = -1.0F; + } + + public boolean bO() { + return this.br != -1.0F; + } - return f; + protected void bB() { + super.bB(); + if (this.bD() && this.bE() != null && this.bE().world == this.world) { + Entity entity = this.bE(); + + this.b((int) entity.locX, (int) entity.locY, (int) entity.locZ, 5); + float f = this.d(entity); + + if (this instanceof EntityTameableAnimal && ((EntityTameableAnimal) this).isSitting()) { + if (f > 10.0F) { + this.i(true); + } + + return; + } + + if (!this.bt) { + this.goalSelector.a(2, this.bs); + this.getNavigation().a(false); + this.bt = true; + } + + if (f > 4.0F) { + this.getNavigation().a(entity, 1.0D); + } + + if (f > 6.0F) { + double d0 = (entity.locX - this.locX) / (double) f; + double d1 = (entity.locY - this.locY) / (double) f; + double d2 = (entity.locZ - this.locZ) / (double) f; + + this.motX += d0 * Math.abs(d0) * 0.4D; + this.motY += d1 * Math.abs(d1) * 0.4D; + this.motZ += d2 * Math.abs(d2) * 0.4D; + } + + if (f > 10.0F) { + this.i(true); + } + } else if (!this.bD() && this.bt) { + this.bt = false; + this.goalSelector.a(this.bs); + this.getNavigation().a(true); + this.bN(); + } } } diff --git a/src/main/java/net/minecraft/server/EntityCreeper.java b/src/main/java/net/minecraft/server/EntityCreeper.java index 5752e267..bd02091b 100644 --- a/src/main/java/net/minecraft/server/EntityCreeper.java +++ b/src/main/java/net/minecraft/server/EntityCreeper.java @@ -7,7 +7,7 @@ import org.bukkit.event.entity.ExplosionPrimeEvent; public class EntityCreeper extends EntityMonster { - private int d; + private int bp; private int fuseTicks; private int maxFuseTicks = 30; private int explosionRadius = 3; @@ -15,38 +15,38 @@ public class EntityCreeper extends EntityMonster { public EntityCreeper(World world) { super(world); - this.texture = "/mob/creeper.png"; this.goalSelector.a(1, new PathfinderGoalFloat(this)); this.goalSelector.a(2, new PathfinderGoalSwell(this)); - this.goalSelector.a(3, new PathfinderGoalAvoidPlayer(this, EntityOcelot.class, 6.0F, 0.25F, 0.3F)); - this.goalSelector.a(4, new PathfinderGoalMeleeAttack(this, 0.25F, false)); - this.goalSelector.a(5, new PathfinderGoalRandomStroll(this, 0.2F)); + this.goalSelector.a(3, new PathfinderGoalAvoidPlayer(this, EntityOcelot.class, 6.0F, 1.0D, 1.2D)); + this.goalSelector.a(4, new PathfinderGoalMeleeAttack(this, 1.0D, false)); + this.goalSelector.a(5, new PathfinderGoalRandomStroll(this, 0.8D)); this.goalSelector.a(6, new PathfinderGoalLookAtPlayer(this, EntityHuman.class, 8.0F)); this.goalSelector.a(6, new PathfinderGoalRandomLookaround(this)); - this.targetSelector.a(1, new PathfinderGoalNearestAttackableTarget(this, EntityHuman.class, 16.0F, 0, true)); + this.targetSelector.a(1, new PathfinderGoalNearestAttackableTarget(this, EntityHuman.class, 0, true)); this.targetSelector.a(2, new PathfinderGoalHurtByTarget(this, false)); } - public boolean bh() { + protected void ax() { + super.ax(); + this.a(GenericAttributes.d).a(0.25D); + } + + public boolean bb() { return true; } - public int ar() { - return this.getGoalTarget() == null ? 3 : 3 + (this.health - 1); + public int aq() { + return this.getGoalTarget() == null ? 3 : 3 + (int) (this.getHealth() - 1.0F); } - protected void a(float f) { - super.a(f); + protected void b(float f) { + super.b(f); this.fuseTicks = (int) ((float) this.fuseTicks + f * 1.5F); if (this.fuseTicks > this.maxFuseTicks - 5) { this.fuseTicks = this.maxFuseTicks - 5; } } - public int getMaxHealth() { - return 20; - } - protected void a() { super.a(); this.datawatcher.a(16, Byte.valueOf((byte) -1)); @@ -77,8 +77,8 @@ public class EntityCreeper extends EntityMonster { public void l_() { if (this.isAlive()) { - this.d = this.fuseTicks; - int i = this.o(); + this.bp = this.fuseTicks; + int i = this.bR(); if (i > 0 && this.fuseTicks == 0) { this.makeSound("random.fuse", 1.0F, 0.5F); @@ -112,11 +112,11 @@ public class EntityCreeper extends EntityMonster { super.l_(); } - protected String bc() { + protected String aK() { return "mob.creeper.say"; } - protected String bd() { + protected String aL() { return "mob.creeper.death"; } @@ -173,7 +173,7 @@ public class EntityCreeper extends EntityMonster { return Item.SULPHUR.id; } - public int o() { + public int bR() { return this.datawatcher.getByte(16); } diff --git a/src/main/java/net/minecraft/server/EntityDamageSourceIndirect.java b/src/main/java/net/minecraft/server/EntityDamageSourceIndirect.java index 19121530..73838198 100644 --- a/src/main/java/net/minecraft/server/EntityDamageSourceIndirect.java +++ b/src/main/java/net/minecraft/server/EntityDamageSourceIndirect.java @@ -17,13 +17,13 @@ public class EntityDamageSourceIndirect extends EntityDamageSource { return this.owner; } - public String getLocalizedDeathMessage(EntityLiving entityliving) { + public ChatMessage getLocalizedDeathMessage(EntityLiving entityliving) { String s = this.owner == null ? this.p.getScoreboardDisplayName() : this.owner.getScoreboardDisplayName(); - ItemStack itemstack = this.owner instanceof EntityLiving ? ((EntityLiving) this.owner).bG() : null; + ItemStack itemstack = this.owner instanceof EntityLiving ? ((EntityLiving) this.owner).aV() : null; String s1 = "death.attack." + this.translationIndex; String s2 = s1 + ".item"; - return itemstack != null && itemstack.hasName() && LocaleI18n.b(s2) ? LocaleI18n.get(s2, new Object[] { entityliving.getScoreboardDisplayName(), s, itemstack.getName()}) : LocaleI18n.get(s1, new Object[] { entityliving.getScoreboardDisplayName(), s}); + return itemstack != null && itemstack.hasName() && LocaleI18n.b(s2) ? ChatMessage.b(s2, new Object[] { entityliving.getScoreboardDisplayName(), s, itemstack.getName()}) : ChatMessage.b(s1, new Object[] { entityliving.getScoreboardDisplayName(), s}); } // CraftBukkit start diff --git a/src/main/java/net/minecraft/server/EntityEgg.java b/src/main/java/net/minecraft/server/EntityEgg.java index ed8f271f..16d8328b 100644 --- a/src/main/java/net/minecraft/server/EntityEgg.java +++ b/src/main/java/net/minecraft/server/EntityEgg.java @@ -23,7 +23,7 @@ public class EntityEgg extends EntityProjectile { protected void a(MovingObjectPosition movingobjectposition) { if (movingobjectposition.entity != null) { - movingobjectposition.entity.damageEntity(DamageSource.projectile(this, this.getShooter()), 0); + movingobjectposition.entity.damageEntity(DamageSource.projectile(this, this.getShooter()), 0.0F); } // CraftBukkit start diff --git a/src/main/java/net/minecraft/server/EntityEnderCrystal.java b/src/main/java/net/minecraft/server/EntityEnderCrystal.java index 582ecac3..ebf76a0b 100644 --- a/src/main/java/net/minecraft/server/EntityEnderCrystal.java +++ b/src/main/java/net/minecraft/server/EntityEnderCrystal.java @@ -4,7 +4,7 @@ import org.bukkit.craftbukkit.event.CraftEventFactory; // CraftBukkit public class EntityEnderCrystal extends Entity { - public int a = 0; + public int a; public int b; public EntityEnderCrystal(World world) { @@ -16,7 +16,7 @@ public class EntityEnderCrystal extends Entity { this.a = this.random.nextInt(100000); } - protected boolean f_() { + protected boolean e_() { return false; } @@ -51,13 +51,13 @@ public class EntityEnderCrystal extends Entity { return true; } - public boolean damageEntity(DamageSource damagesource, int i) { + public boolean damageEntity(DamageSource damagesource, float f) { if (this.isInvulnerable()) { return false; } else { if (!this.dead && !this.world.isStatic) { // CraftBukkit start - All non-living entities need this - if (CraftEventFactory.handleNonLivingEntityDamageEvent(this, damagesource, i)) { + if (CraftEventFactory.handleNonLivingEntityDamageEvent(this, damagesource, f)) { return false; } // CraftBukkit end diff --git a/src/main/java/net/minecraft/server/EntityEnderDragon.java b/src/main/java/net/minecraft/server/EntityEnderDragon.java index e020e7f5..f776aeb3 100644 --- a/src/main/java/net/minecraft/server/EntityEnderDragon.java +++ b/src/main/java/net/minecraft/server/EntityEnderDragon.java @@ -12,68 +12,67 @@ import org.bukkit.event.entity.EntityRegainHealthEvent; import org.bukkit.Bukkit; // CraftBukkit end -public class EntityEnderDragon extends EntityLiving implements IComplex { +public class EntityEnderDragon extends EntityInsentient implements IComplex, IMonster { - public double a; - public double b; - public double c; - public double[][] d = new double[64][3]; - public int e = -1; + public double h; + public double i; + public double j; + public double[][] bn = new double[64][3]; + public int bo = -1; public EntityComplexPart[] children; - public EntityComplexPart g; - public EntityComplexPart h; - public EntityComplexPart i; - public EntityComplexPart j; - public EntityComplexPart bK; - public EntityComplexPart bL; - public EntityComplexPart bM; - public float bN = 0.0F; - public float bO = 0.0F; - public boolean bP = false; - public boolean bQ = false; - private Entity bT; - public int bR = 0; - public EntityEnderCrystal bS = null; + public EntityComplexPart bq; + public EntityComplexPart br; + public EntityComplexPart bs; + public EntityComplexPart bt; + public EntityComplexPart bu; + public EntityComplexPart bv; + public EntityComplexPart bw; + public float bx; + public float by; + public boolean bz; + public boolean bA; + private Entity bD; + public int bB; + public EntityEnderCrystal bC; private Explosion explosionSource = new Explosion(null, this, Double.NaN, Double.NaN, Double.NaN, Float.NaN); // CraftBukkit - reusable source for CraftTNTPrimed.getSource() public EntityEnderDragon(World world) { super(world); - this.children = new EntityComplexPart[] { this.g = new EntityComplexPart(this, "head", 6.0F, 6.0F), this.h = new EntityComplexPart(this, "body", 8.0F, 8.0F), this.i = new EntityComplexPart(this, "tail", 4.0F, 4.0F), this.j = new EntityComplexPart(this, "tail", 4.0F, 4.0F), this.bK = new EntityComplexPart(this, "tail", 4.0F, 4.0F), this.bL = new EntityComplexPart(this, "wing", 4.0F, 4.0F), this.bM = new EntityComplexPart(this, "wing", 4.0F, 4.0F)}; + this.children = new EntityComplexPart[] { this.bq = new EntityComplexPart(this, "head", 6.0F, 6.0F), this.br = new EntityComplexPart(this, "body", 8.0F, 8.0F), this.bs = new EntityComplexPart(this, "tail", 4.0F, 4.0F), this.bt = new EntityComplexPart(this, "tail", 4.0F, 4.0F), this.bu = new EntityComplexPart(this, "tail", 4.0F, 4.0F), this.bv = new EntityComplexPart(this, "wing", 4.0F, 4.0F), this.bw = new EntityComplexPart(this, "wing", 4.0F, 4.0F)}; this.setHealth(this.getMaxHealth()); - this.texture = "/mob/enderdragon/ender.png"; this.a(16.0F, 8.0F); this.Z = true; this.fireProof = true; - this.b = 100.0D; + this.i = 100.0D; this.am = true; } - public int getMaxHealth() { - return 200; + protected void ax() { + super.ax(); + this.a(GenericAttributes.a).a(200.0D); } protected void a() { super.a(); - this.datawatcher.a(16, new Integer(this.getMaxHealth())); } public double[] b(int i, float f) { - if (this.health <= 0) { + if (this.getHealth() <= 0.0F) { f = 0.0F; } f = 1.0F - f; - int j = this.e - i * 1 & 63; - int k = this.e - i * 1 - 1 & 63; + int j = this.bo - i * 1 & 63; + int k = this.bo - i * 1 - 1 & 63; double[] adouble = new double[3]; - double d0 = this.d[j][0]; - double d1 = MathHelper.g(this.d[k][0] - d0); + double d0 = this.bn[j][0]; + double d1 = MathHelper.g(this.bn[k][0] - d0); adouble[0] = d0 + d1 * (double) f; - d0 = this.d[j][1]; - d1 = this.d[k][1] - d0; + d0 = this.bn[j][1]; + d1 = this.bn[k][1] - d0; adouble[1] = d0 + d1 * (double) f; - adouble[2] = this.d[j][2] + (this.d[k][2] - this.d[j][2]) * (double) f; + adouble[2] = this.bn[j][2] + (this.bn[k][2] - this.bn[j][2]) * (double) f; return adouble; } @@ -81,48 +80,46 @@ public class EntityEnderDragon extends EntityLiving implements IComplex { float f; float f1; - if (!this.world.isStatic) { - this.datawatcher.watch(16, Integer.valueOf(this.getScaledHealth())); // CraftBukkit - this.health -> this.getScaledHealth() - } else { - f = MathHelper.cos(this.bO * 3.1415927F * 2.0F); - f1 = MathHelper.cos(this.bN * 3.1415927F * 2.0F); + if (this.world.isStatic) { + f = MathHelper.cos(this.by * 3.1415927F * 2.0F); + f1 = MathHelper.cos(this.bx * 3.1415927F * 2.0F); if (f1 <= -0.3F && f >= -0.3F) { this.world.a(this.locX, this.locY, this.locZ, "mob.enderdragon.wings", 5.0F, 0.8F + this.random.nextFloat() * 0.3F, false); } } - this.bN = this.bO; + this.bx = this.by; float f2; - if (this.health <= 0) { + if (this.getHealth() <= 0.0F) { f = (this.random.nextFloat() - 0.5F) * 8.0F; f1 = (this.random.nextFloat() - 0.5F) * 4.0F; f2 = (this.random.nextFloat() - 0.5F) * 8.0F; this.world.addParticle("largeexplode", this.locX + (double) f, this.locY + 2.0D + (double) f1, this.locZ + (double) f2, 0.0D, 0.0D, 0.0D); } else { - this.h(); + this.bF(); f = 0.2F / (MathHelper.sqrt(this.motX * this.motX + this.motZ * this.motZ) * 10.0F + 1.0F); f *= (float) Math.pow(2.0D, this.motY); - if (this.bQ) { - this.bO += f * 0.5F; + if (this.bA) { + this.by += f * 0.5F; } else { - this.bO += f; + this.by += f; } this.yaw = MathHelper.g(this.yaw); - if (this.e < 0) { - for (int d05 = 0; d05 < this.d.length; ++d05) { - this.d[d05][0] = (double) this.yaw; - this.d[d05][1] = this.locY; + if (this.bo < 0) { + for (int d05 = 0; d05 < this.bn.length; ++d05) { + this.bn[d05][0] = (double) this.yaw; + this.bn[d05][1] = this.locY; } } - if (++this.e == this.d.length) { - this.e = 0; + if (++this.bo == this.bn.length) { + this.bo = 0; } - this.d[this.e][0] = (double) this.yaw; - this.d[this.e][1] = this.locY; + this.bn[this.bo][0] = (double) this.yaw; + this.bn[this.bo][1] = this.locY; double d0; double d1; double d2; @@ -130,27 +127,27 @@ public class EntityEnderDragon extends EntityLiving implements IComplex { float f3; if (this.world.isStatic) { - if (this.bu > 0) { - d0 = this.locX + (this.bv - this.locX) / (double) this.bu; - d1 = this.locY + (this.bw - this.locY) / (double) this.bu; - d2 = this.locZ + (this.bx - this.locZ) / (double) this.bu; - d3 = MathHelper.g(this.by - (double) this.yaw); - this.yaw = (float) ((double) this.yaw + d3 / (double) this.bu); - this.pitch = (float) ((double) this.pitch + (this.bz - (double) this.pitch) / (double) this.bu); - --this.bu; + if (this.bh > 0) { + d0 = this.locX + (this.bi - this.locX) / (double) this.bh; + d1 = this.locY + (this.bj - this.locY) / (double) this.bh; + d2 = this.locZ + (this.bk - this.locZ) / (double) this.bh; + d3 = MathHelper.g(this.bl - (double) this.yaw); + this.yaw = (float) ((double) this.yaw + d3 / (double) this.bh); + this.pitch = (float) ((double) this.pitch + (this.bm - (double) this.pitch) / (double) this.bh); + --this.bh; this.setPosition(d0, d1, d2); this.b(this.yaw, this.pitch); } } else { - d0 = this.a - this.locX; - d1 = this.b - this.locY; - d2 = this.c - this.locZ; + d0 = this.h - this.locX; + d1 = this.i - this.locY; + d2 = this.j - this.locZ; d3 = d0 * d0 + d1 * d1 + d2 * d2; - if (this.bT != null) { - this.a = this.bT.locX; - this.c = this.bT.locZ; - double d4 = this.a - this.locX; - double d5 = this.c - this.locZ; + if (this.bD != null) { + this.h = this.bD.locX; + this.j = this.bD.locZ; + double d4 = this.h - this.locX; + double d5 = this.j - this.locZ; double d6 = Math.sqrt(d4 * d4 + d5 * d5); double d7 = 0.4000000059604645D + d6 / 80.0D - 1.0D; @@ -158,14 +155,14 @@ public class EntityEnderDragon extends EntityLiving implements IComplex { d7 = 10.0D; } - this.b = this.bT.boundingBox.b + d7; + this.i = this.bD.boundingBox.b + d7; } else { - this.a += this.random.nextGaussian() * 2.0D; - this.c += this.random.nextGaussian() * 2.0D; + this.h += this.random.nextGaussian() * 2.0D; + this.j += this.random.nextGaussian() * 2.0D; } - if (this.bP || d3 < 100.0D || d3 > 22500.0D || this.positionChanged || this.H) { - this.i(); + if (this.bz || d3 < 100.0D || d3 > 22500.0D || this.positionChanged || this.H) { + this.bG(); } d1 /= (double) MathHelper.sqrt(d0 * d0 + d2 * d2); @@ -191,7 +188,7 @@ public class EntityEnderDragon extends EntityLiving implements IComplex { d9 = -50.0D; } - Vec3D vec3d = this.world.getVec3DPool().create(this.a - this.locX, this.b - this.locY, this.c - this.locZ).a(); + Vec3D vec3d = this.world.getVec3DPool().create(this.h - this.locX, this.i - this.locY, this.j - this.locZ).a(); Vec3D vec3d1 = this.world.getVec3DPool().create((double) MathHelper.sin(this.yaw * 3.1415927F / 180.0F), this.motY, (double) (-MathHelper.cos(this.yaw * 3.1415927F / 180.0F))).a(); float f4 = (float) (vec3d1.b(vec3d) + 0.5D) / 1.5F; @@ -199,7 +196,7 @@ public class EntityEnderDragon extends EntityLiving implements IComplex { f4 = 0.0F; } - this.bF *= 0.8F; + this.bg *= 0.8F; float f5 = MathHelper.sqrt(this.motX * this.motX + this.motZ * this.motZ) * 1.0F + 1.0F; double d10 = Math.sqrt(this.motX * this.motX + this.motZ * this.motZ) * 1.0D + 1.0D; @@ -207,13 +204,13 @@ public class EntityEnderDragon extends EntityLiving implements IComplex { d10 = 40.0D; } - this.bF = (float) ((double) this.bF + d9 * (0.699999988079071D / d10 / (double) f5)); - this.yaw += this.bF * 0.1F; + this.bg = (float) ((double) this.bg + d9 * (0.699999988079071D / d10 / (double) f5)); + this.yaw += this.bg * 0.1F; float f6 = (float) (2.0D / (d10 + 1.0D)); float f7 = 0.06F; this.a(0.0F, -1.0F, f7 * (f4 * f6 + (1.0F - f6))); - if (this.bQ) { + if (this.bA) { this.move(this.motX * 0.800000011920929D, this.motY * 0.800000011920929D, this.motZ * 0.800000011920929D); } else { this.move(this.motX, this.motY, this.motZ); @@ -228,17 +225,17 @@ public class EntityEnderDragon extends EntityLiving implements IComplex { this.motY *= 0.9100000262260437D; } - this.ay = this.yaw; - this.g.width = this.g.length = 3.0F; - this.i.width = this.i.length = 2.0F; - this.j.width = this.j.length = 2.0F; - this.bK.width = this.bK.length = 2.0F; - this.h.length = 3.0F; - this.h.width = 5.0F; - this.bL.length = 2.0F; - this.bL.width = 4.0F; - this.bM.length = 3.0F; - this.bM.width = 4.0F; + this.aN = this.yaw; + this.bq.width = this.bq.length = 3.0F; + this.bs.width = this.bs.length = 2.0F; + this.bt.width = this.bt.length = 2.0F; + this.bu.width = this.bu.length = 2.0F; + this.br.length = 3.0F; + this.br.width = 5.0F; + this.bv.length = 2.0F; + this.bv.width = 4.0F; + this.bw.length = 3.0F; + this.bw.width = 4.0F; f1 = (float) (this.b(5, 1.0F)[1] - this.b(10, 1.0F)[1]) * 10.0F / 180.0F * 3.1415927F; f2 = MathHelper.cos(f1); float f9 = -MathHelper.sin(f1); @@ -246,40 +243,40 @@ public class EntityEnderDragon extends EntityLiving implements IComplex { float f11 = MathHelper.sin(f10); float f12 = MathHelper.cos(f10); - this.h.l_(); - this.h.setPositionRotation(this.locX + (double) (f11 * 0.5F), this.locY, this.locZ - (double) (f12 * 0.5F), 0.0F, 0.0F); - this.bL.l_(); - this.bL.setPositionRotation(this.locX + (double) (f12 * 4.5F), this.locY + 2.0D, this.locZ + (double) (f11 * 4.5F), 0.0F, 0.0F); - this.bM.l_(); - this.bM.setPositionRotation(this.locX - (double) (f12 * 4.5F), this.locY + 2.0D, this.locZ - (double) (f11 * 4.5F), 0.0F, 0.0F); + this.br.l_(); + this.br.setPositionRotation(this.locX + (double) (f11 * 0.5F), this.locY, this.locZ - (double) (f12 * 0.5F), 0.0F, 0.0F); + this.bv.l_(); + this.bv.setPositionRotation(this.locX + (double) (f12 * 4.5F), this.locY + 2.0D, this.locZ + (double) (f11 * 4.5F), 0.0F, 0.0F); + this.bw.l_(); + this.bw.setPositionRotation(this.locX - (double) (f12 * 4.5F), this.locY + 2.0D, this.locZ - (double) (f11 * 4.5F), 0.0F, 0.0F); if (!this.world.isStatic && this.hurtTicks == 0) { - this.a(this.world.getEntities(this, this.bL.boundingBox.grow(4.0D, 2.0D, 4.0D).d(0.0D, -2.0D, 0.0D))); - this.a(this.world.getEntities(this, this.bM.boundingBox.grow(4.0D, 2.0D, 4.0D).d(0.0D, -2.0D, 0.0D))); - this.b(this.world.getEntities(this, this.g.boundingBox.grow(1.0D, 1.0D, 1.0D))); + this.a(this.world.getEntities(this, this.bv.boundingBox.grow(4.0D, 2.0D, 4.0D).d(0.0D, -2.0D, 0.0D))); + this.a(this.world.getEntities(this, this.bw.boundingBox.grow(4.0D, 2.0D, 4.0D).d(0.0D, -2.0D, 0.0D))); + this.b(this.world.getEntities(this, this.bq.boundingBox.grow(1.0D, 1.0D, 1.0D))); } double[] adouble = this.b(5, 1.0F); double[] adouble1 = this.b(0, 1.0F); - f3 = MathHelper.sin(this.yaw * 3.1415927F / 180.0F - this.bF * 0.01F); - float f13 = MathHelper.cos(this.yaw * 3.1415927F / 180.0F - this.bF * 0.01F); + f3 = MathHelper.sin(this.yaw * 3.1415927F / 180.0F - this.bg * 0.01F); + float f13 = MathHelper.cos(this.yaw * 3.1415927F / 180.0F - this.bg * 0.01F); - this.g.l_(); - this.g.setPositionRotation(this.locX + (double) (f3 * 5.5F * f2), this.locY + (adouble1[1] - adouble[1]) * 1.0D + (double) (f9 * 5.5F), this.locZ - (double) (f13 * 5.5F * f2), 0.0F, 0.0F); + this.bq.l_(); + this.bq.setPositionRotation(this.locX + (double) (f3 * 5.5F * f2), this.locY + (adouble1[1] - adouble[1]) * 1.0D + (double) (f9 * 5.5F), this.locZ - (double) (f13 * 5.5F * f2), 0.0F, 0.0F); for (int j = 0; j < 3; ++j) { EntityComplexPart entitycomplexpart = null; if (j == 0) { - entitycomplexpart = this.i; + entitycomplexpart = this.bs; } if (j == 1) { - entitycomplexpart = this.j; + entitycomplexpart = this.bt; } if (j == 2) { - entitycomplexpart = this.bK; + entitycomplexpart = this.bu; } double[] adouble2 = this.b(12 + j * 2, 1.0F); @@ -294,26 +291,26 @@ public class EntityEnderDragon extends EntityLiving implements IComplex { } if (!this.world.isStatic) { - this.bQ = this.a(this.g.boundingBox) | this.a(this.h.boundingBox); + this.bA = this.a(this.bq.boundingBox) | this.a(this.br.boundingBox); } } } - private void h() { - if (this.bS != null) { - if (this.bS.dead) { + private void bF() { + if (this.bC != null) { + if (this.bC.dead) { if (!this.world.isStatic) { - this.a(this.g, DamageSource.explosion((Explosion) null), 10); + this.a(this.bq, DamageSource.explosion((Explosion) null), 10.0F); } - this.bS = null; - } else if (this.ticksLived % 10 == 0 && this.health < this.maxHealth) { // CraftBukkit - this.getMaxHealth() -> this.maxHealth + this.bC = null; + } else if (this.ticksLived % 10 == 0 && this.getHealth() < this.maxHealth) { // CraftBukkit - this.getMaxHealth() -> this.maxHealth // CraftBukkit start - EntityRegainHealthEvent event = new EntityRegainHealthEvent(this.getBukkitEntity(), 1, EntityRegainHealthEvent.RegainReason.ENDER_CRYSTAL); + EntityRegainHealthEvent event = new EntityRegainHealthEvent(this.getBukkitEntity(), 1.0D, EntityRegainHealthEvent.RegainReason.ENDER_CRYSTAL); this.world.getServer().getPluginManager().callEvent(event); if (!event.isCancelled()) { - this.setHealth(this.getHealth() + event.getAmount()); + this.setHealth((float) (this.getHealth() + event.getAmount())); } // CraftBukkit end } @@ -336,13 +333,13 @@ public class EntityEnderDragon extends EntityLiving implements IComplex { } } - this.bS = entityendercrystal; + this.bC = entityendercrystal; } } private void a(List list) { - double d0 = (this.h.boundingBox.a + this.h.boundingBox.d) / 2.0D; - double d1 = (this.h.boundingBox.c + this.h.boundingBox.f) / 2.0D; + double d0 = (this.br.boundingBox.a + this.br.boundingBox.d) / 2.0D; + double d1 = (this.br.boundingBox.c + this.br.boundingBox.f) / 2.0D; Iterator iterator = list.iterator(); while (iterator.hasNext()) { @@ -363,32 +360,32 @@ public class EntityEnderDragon extends EntityLiving implements IComplex { Entity entity = (Entity) list.get(i); if (entity instanceof EntityLiving) { - entity.damageEntity(DamageSource.mobAttack(this), 10); + entity.damageEntity(DamageSource.mobAttack(this), 10.0F); } } } - private void i() { - this.bP = false; + private void bG() { + this.bz = false; if (this.random.nextInt(2) == 0 && !this.world.players.isEmpty()) { - this.bT = (Entity) this.world.players.get(this.random.nextInt(this.world.players.size())); + this.bD = (Entity) this.world.players.get(this.random.nextInt(this.world.players.size())); } else { boolean flag = false; do { - this.a = 0.0D; - this.b = (double) (70.0F + this.random.nextFloat() * 50.0F); - this.c = 0.0D; - this.a += (double) (this.random.nextFloat() * 120.0F - 60.0F); - this.c += (double) (this.random.nextFloat() * 120.0F - 60.0F); - double d0 = this.locX - this.a; - double d1 = this.locY - this.b; - double d2 = this.locZ - this.c; + this.h = 0.0D; + this.i = (double) (70.0F + this.random.nextFloat() * 50.0F); + this.j = 0.0D; + this.h += (double) (this.random.nextFloat() * 120.0F - 60.0F); + this.j += (double) (this.random.nextFloat() * 120.0F - 60.0F); + double d0 = this.locX - this.h; + double d1 = this.locY - this.i; + double d2 = this.locZ - this.j; flag = d0 * d0 + d1 * d1 + d2 * d2 > 100.0D; } while (!flag); - this.bT = null; + this.bD = null; } } @@ -477,37 +474,37 @@ public class EntityEnderDragon extends EntityLiving implements IComplex { return flag; } - public boolean a(EntityComplexPart entitycomplexpart, DamageSource damagesource, int i) { - if (entitycomplexpart != this.g) { - i = i / 4 + 1; + public boolean a(EntityComplexPart entitycomplexpart, DamageSource damagesource, float f) { + if (entitycomplexpart != this.bq) { + f = f / 4.0F + 1.0F; } - float f = this.yaw * 3.1415927F / 180.0F; - float f1 = MathHelper.sin(f); - float f2 = MathHelper.cos(f); + float f1 = this.yaw * 3.1415927F / 180.0F; + float f2 = MathHelper.sin(f1); + float f3 = MathHelper.cos(f1); - this.a = this.locX + (double) (f1 * 5.0F) + (double) ((this.random.nextFloat() - 0.5F) * 2.0F); - this.b = this.locY + (double) (this.random.nextFloat() * 3.0F) + 1.0D; - this.c = this.locZ - (double) (f2 * 5.0F) + (double) ((this.random.nextFloat() - 0.5F) * 2.0F); - this.bT = null; + this.h = this.locX + (double) (f2 * 5.0F) + (double) ((this.random.nextFloat() - 0.5F) * 2.0F); + this.i = this.locY + (double) (this.random.nextFloat() * 3.0F) + 1.0D; + this.j = this.locZ - (double) (f3 * 5.0F) + (double) ((this.random.nextFloat() - 0.5F) * 2.0F); + this.bD = null; if (damagesource.getEntity() instanceof EntityHuman || damagesource.c()) { - this.dealDamage(damagesource, i); + this.dealDamage(damagesource, f); } return true; } - public boolean damageEntity(DamageSource damagesource, int i) { + public boolean damageEntity(DamageSource damagesource, float f) { return false; } - public boolean dealDamage(DamageSource damagesource, int i) { // CraftBukkit - protected -> public - return super.damageEntity(damagesource, i); + public boolean dealDamage(DamageSource damagesource, float f) { // CraftBukkit - protected -> public + return super.damageEntity(damagesource, f); } - protected void aS() { - ++this.bR; - if (this.bR >= 180 && this.bR <= 200) { + protected void az() { + ++this.bB; + if (this.bB >= 180 && this.bB <= 200) { float f = (this.random.nextFloat() - 0.5F) * 8.0F; float f1 = (this.random.nextFloat() - 0.5F) * 4.0F; float f2 = (this.random.nextFloat() - 0.5F) * 8.0F; @@ -519,7 +516,7 @@ public class EntityEnderDragon extends EntityLiving implements IComplex { int j; if (!this.world.isStatic) { - if (this.bR > 150 && this.bR % 5 == 0) { + if (this.bB > 150 && this.bB % 5 == 0) { i = expToDrop / 12; // CraftBukkit - drop experience as dragon falls from sky. use experience drop from death event. This is now set in getExpReward() while (i > 0) { @@ -529,14 +526,14 @@ public class EntityEnderDragon extends EntityLiving implements IComplex { } } - if (this.bR == 1) { + if (this.bB == 1) { this.world.d(1018, (int) this.locX, (int) this.locY, (int) this.locZ, 0); } } this.move(0.0D, 0.10000000149011612D, 0.0D); - this.ay = this.yaw += 20.0F; - if (this.bR == 200 && !this.world.isStatic) { + this.aN = this.yaw += 20.0F; + if (this.bB == 200 && !this.world.isStatic) { i = expToDrop - 10 * (expToDrop / 12); // CraftBukkit - drop the remaining experience while (i > 0) { @@ -616,9 +613,9 @@ public class EntityEnderDragon extends EntityLiving implements IComplex { BlockEnderPortal.a = false; } - protected void bn() {} + protected void bk() {} - public Entity[] an() { + public Entity[] am() { return this.children; } @@ -626,19 +623,19 @@ public class EntityEnderDragon extends EntityLiving implements IComplex { return false; } - public World d() { + public World b() { return this.world; } - protected String bb() { + protected String r() { return "mob.enderdragon.growl"; } - protected String bc() { + protected String aK() { return "mob.enderdragon.hit"; } - protected float ba() { + protected float aW() { return 5.0F; } diff --git a/src/main/java/net/minecraft/server/EntityEnderPearl.java b/src/main/java/net/minecraft/server/EntityEnderPearl.java index fa2ccc48..585154e4 100644 --- a/src/main/java/net/minecraft/server/EntityEnderPearl.java +++ b/src/main/java/net/minecraft/server/EntityEnderPearl.java @@ -43,13 +43,13 @@ public class EntityEnderPearl extends EntityProjectile { entityplayer.playerConnection.teleport(teleEvent.getTo()); this.getShooter().fallDistance = 0.0F; - EntityDamageByEntityEvent damageEvent = new EntityDamageByEntityEvent(this.getBukkitEntity(), player, EntityDamageByEntityEvent.DamageCause.FALL, 5); + EntityDamageByEntityEvent damageEvent = new EntityDamageByEntityEvent(this.getBukkitEntity(), player, EntityDamageByEntityEvent.DamageCause.FALL, 5.0D); Bukkit.getPluginManager().callEvent(damageEvent); if (!damageEvent.isCancelled() && !entityplayer.playerConnection.disconnected) { entityplayer.invulnerableTicks = -1; // Remove spawning invulnerability player.setLastDamageCause(damageEvent); - entityplayer.damageEntity(DamageSource.FALL, damageEvent.getDamage()); + entityplayer.damageEntity(DamageSource.FALL, (float) damageEvent.getDamage()); } } // CraftBukkit end diff --git a/src/main/java/net/minecraft/server/EntityEnderman.java b/src/main/java/net/minecraft/server/EntityEnderman.java index e1be9b0c..3692aeb5 100644 --- a/src/main/java/net/minecraft/server/EntityEnderman.java +++ b/src/main/java/net/minecraft/server/EntityEnderman.java @@ -1,5 +1,7 @@ package net.minecraft.server; +import java.util.UUID; + // CraftBukkit start import org.bukkit.Location; import org.bukkit.craftbukkit.event.CraftEventFactory; @@ -8,21 +10,25 @@ import org.bukkit.event.entity.EntityTeleportEvent; public class EntityEnderman extends EntityMonster { - private static boolean[] d = new boolean[256]; - private int e = 0; - private int f = 0; - private boolean g; + private static final UUID bp = UUID.fromString("020E0DFB-87AE-4653-9556-831010E291A0"); + private static final AttributeModifier bq = (new AttributeModifier(bp, "Attacking speed boost", 6.199999809265137D, 0)).a(false); + private static boolean[] br = new boolean[256]; + private int bs; + private int bt; + private Entity bu; + private boolean bv; public EntityEnderman(World world) { super(world); - this.texture = "/mob/enderman.png"; - this.bI = 0.2F; this.a(0.6F, 2.9F); this.Y = 1.0F; } - public int getMaxHealth() { - return 40; + protected void ax() { + super.ax(); + this.a(GenericAttributes.a).a(40.0D); + this.a(GenericAttributes.d).a(0.30000001192092896D); + this.a(GenericAttributes.e).a(7.0D); } protected void a() { @@ -48,48 +54,57 @@ public class EntityEnderman extends EntityMonster { EntityHuman entityhuman = this.world.findNearbyVulnerablePlayer(this, 64.0D); if (entityhuman != null) { - if (this.e(entityhuman)) { - this.g = true; - if (this.f == 0) { + if (this.f(entityhuman)) { + this.bv = true; + if (this.bt == 0) { this.world.makeSound(entityhuman, "mob.endermen.stare", 1.0F, 1.0F); } - if (this.f++ == 5) { - this.f = 0; + if (this.bt++ == 5) { + this.bt = 0; this.a(true); return entityhuman; } } else { - this.f = 0; + this.bt = 0; } } return null; } - private boolean e(EntityHuman entityhuman) { + private boolean f(EntityHuman entityhuman) { ItemStack itemstack = entityhuman.inventory.armor[3]; if (itemstack != null && itemstack.id == Block.PUMPKIN.id) { return false; } else { - Vec3D vec3d = entityhuman.i(1.0F).a(); + Vec3D vec3d = entityhuman.j(1.0F).a(); Vec3D vec3d1 = this.world.getVec3DPool().create(this.locX - entityhuman.locX, this.boundingBox.b + (double) (this.length / 2.0F) - (entityhuman.locY + (double) entityhuman.getHeadHeight()), this.locZ - entityhuman.locZ); double d0 = vec3d1.b(); vec3d1 = vec3d1.a(); double d1 = vec3d.b(vec3d1); - return d1 > 1.0D - 0.025D / d0 ? entityhuman.n(this) : false; + return d1 > 1.0D - 0.025D / d0 ? entityhuman.o(this) : false; } } public void c() { if (this.F()) { - this.damageEntity(DamageSource.DROWN, 1); + this.damageEntity(DamageSource.DROWN, 1.0F); + } + + if (this.bu != this.target) { + AttributeInstance attributeinstance = this.a(GenericAttributes.d); + + attributeinstance.b(bq); + if (this.target != null) { + attributeinstance.a(bq); + } } - this.bI = this.target != null ? 6.5F : 0.3F; + this.bu = this.target; int i; if (!this.world.isStatic && this.world.getGameRules().getBoolean("mobGriefing")) { @@ -103,7 +118,7 @@ public class EntityEnderman extends EntityMonster { j = MathHelper.floor(this.locY + this.random.nextDouble() * 3.0D); k = MathHelper.floor(this.locZ - 2.0D + this.random.nextDouble() * 4.0D); l = this.world.getTypeId(i, j, k); - if (d[l]) { + if (br[l]) { // CraftBukkit start - Pickup event if (!CraftEventFactory.callEntityChangeBlockEvent(this, this.world.getWorld().getBlockAt(i, j, k), org.bukkit.Material.AIR).isCancelled()) { this.setCarriedId(this.world.getTypeId(i, j, k)); @@ -136,55 +151,53 @@ public class EntityEnderman extends EntityMonster { } if (this.world.v() && !this.world.isStatic) { - float f = this.c(1.0F); + float f = this.d(1.0F); if (f > 0.5F && this.world.l(MathHelper.floor(this.locX), MathHelper.floor(this.locY), MathHelper.floor(this.locZ)) && this.random.nextFloat() * 30.0F < (f - 0.4F) * 2.0F) { this.target = null; this.a(false); - this.g = false; - this.m(); + this.bv = false; + this.bP(); } } if (this.F() || this.isBurning()) { this.target = null; this.a(false); - this.g = false; - this.m(); + this.bv = false; + this.bP(); } - if (this.q() && !this.g && this.random.nextInt(100) == 0) { + if (this.bT() && !this.bv && this.random.nextInt(100) == 0) { this.a(false); } - this.bG = false; + this.bd = false; if (this.target != null) { this.a(this.target, 100.0F, 100.0F); } if (!this.world.isStatic && this.isAlive()) { if (this.target != null) { - if (this.target instanceof EntityHuman && this.e((EntityHuman) this.target)) { - this.bD = this.bE = 0.0F; - this.bI = 0.0F; + if (this.target instanceof EntityHuman && this.f((EntityHuman) this.target)) { if (this.target.e((Entity) this) < 16.0D) { - this.m(); + this.bP(); } - this.e = 0; - } else if (this.target.e((Entity) this) > 256.0D && this.e++ >= 30 && this.p(this.target)) { - this.e = 0; + this.bs = 0; + } else if (this.target.e((Entity) this) > 256.0D && this.bs++ >= 30 && this.c(this.target)) { + this.bs = 0; } } else { this.a(false); - this.e = 0; + this.bs = 0; } } super.c(); } - protected boolean m() { + protected boolean bP() { double d0 = this.locX + (this.random.nextDouble() - 0.5D) * 64.0D; double d1 = this.locY + (double) (this.random.nextInt(64) - 32); double d2 = this.locZ + (this.random.nextDouble() - 0.5D) * 64.0D; @@ -192,7 +205,7 @@ public class EntityEnderman extends EntityMonster { return this.j(d0, d1, d2); } - protected boolean p(Entity entity) { + protected boolean c(Entity entity) { Vec3D vec3d = this.world.getVec3DPool().create(this.locX - entity.locX, this.boundingBox.b + (double) (this.length / 2.0F) - entity.locY + (double) entity.getHeadHeight(), this.locZ - entity.locZ); vec3d = vec3d.a(); @@ -273,15 +286,15 @@ public class EntityEnderman extends EntityMonster { } } - protected String bb() { - return this.q() ? "mob.endermen.scream" : "mob.endermen.idle"; + protected String r() { + return this.bT() ? "mob.endermen.scream" : "mob.endermen.idle"; } - protected String bc() { + protected String aK() { return "mob.endermen.hit"; } - protected String bd() { + protected String aL() { return "mob.endermen.death"; } @@ -322,32 +335,32 @@ public class EntityEnderman extends EntityMonster { return this.datawatcher.getByte(17); } - public boolean damageEntity(DamageSource damagesource, int i) { + public boolean damageEntity(DamageSource damagesource, float f) { if (this.isInvulnerable()) { return false; } else { this.a(true); if (damagesource instanceof EntityDamageSource && damagesource.getEntity() instanceof EntityHuman) { - this.g = true; + this.bv = true; } if (damagesource instanceof EntityDamageSourceIndirect) { - this.g = false; + this.bv = false; - for (int j = 0; j < 64; ++j) { - if (this.m()) { + for (int i = 0; i < 64; ++i) { + if (this.bP()) { return true; } } return false; } else { - return super.damageEntity(damagesource, i); + return super.damageEntity(damagesource, f); } } } - public boolean q() { + public boolean bT() { return this.datawatcher.getByte(18) > 0; } @@ -355,24 +368,20 @@ public class EntityEnderman extends EntityMonster { this.datawatcher.watch(18, Byte.valueOf((byte) (flag ? 1 : 0))); } - public int c(Entity entity) { - return 7; - } - static { - d[Block.GRASS.id] = true; - d[Block.DIRT.id] = true; - d[Block.SAND.id] = true; - d[Block.GRAVEL.id] = true; - d[Block.YELLOW_FLOWER.id] = true; - d[Block.RED_ROSE.id] = true; - d[Block.BROWN_MUSHROOM.id] = true; - d[Block.RED_MUSHROOM.id] = true; - d[Block.TNT.id] = true; - d[Block.CACTUS.id] = true; - d[Block.CLAY.id] = true; - d[Block.PUMPKIN.id] = true; - d[Block.MELON.id] = true; - d[Block.MYCEL.id] = true; + br[Block.GRASS.id] = true; + br[Block.DIRT.id] = true; + br[Block.SAND.id] = true; + br[Block.GRAVEL.id] = true; + br[Block.YELLOW_FLOWER.id] = true; + br[Block.RED_ROSE.id] = true; + br[Block.BROWN_MUSHROOM.id] = true; + br[Block.RED_MUSHROOM.id] = true; + br[Block.TNT.id] = true; + br[Block.CACTUS.id] = true; + br[Block.CLAY.id] = true; + br[Block.PUMPKIN.id] = true; + br[Block.MELON.id] = true; + br[Block.MYCEL.id] = true; } } diff --git a/src/main/java/net/minecraft/server/EntityExperienceOrb.java b/src/main/java/net/minecraft/server/EntityExperienceOrb.java index e76e0f94..9a1152d0 100644 --- a/src/main/java/net/minecraft/server/EntityExperienceOrb.java +++ b/src/main/java/net/minecraft/server/EntityExperienceOrb.java @@ -8,7 +8,7 @@ import org.bukkit.event.entity.EntityTargetEvent; public class EntityExperienceOrb extends Entity { public int a; - public int b = 0; + public int b; public int c; private int d = 5; public int value; // CraftBukkit - private -> public @@ -27,7 +27,7 @@ public class EntityExperienceOrb extends Entity { this.value = i; } - protected boolean f_() { + protected boolean e_() { return false; } @@ -119,15 +119,15 @@ public class EntityExperienceOrb extends Entity { } protected void burn(int i) { - this.damageEntity(DamageSource.FIRE, i); + this.damageEntity(DamageSource.FIRE, (float) i); } - public boolean damageEntity(DamageSource damagesource, int i) { + public boolean damageEntity(DamageSource damagesource, float f) { if (this.isInvulnerable()) { return false; } else { this.J(); - this.d -= i; + this.d = (int) ((float) this.d - f); if (this.d <= 0) { this.die(); } @@ -150,8 +150,8 @@ public class EntityExperienceOrb extends Entity { public void b_(EntityHuman entityhuman) { if (!this.world.isStatic) { - if (this.c == 0 && entityhuman.bT == 0) { - entityhuman.bT = 2; + if (this.c == 0 && entityhuman.bv == 0) { + entityhuman.bv = 2; this.makeSound("random.orb", 0.1F, 0.5F * ((this.random.nextFloat() - this.random.nextFloat()) * 0.7F + 1.8F)); entityhuman.receive(this, 1); entityhuman.giveExp(CraftEventFactory.callPlayerExpChangeEvent(entityhuman, this.value).getAmount()); // CraftBukkit - this.value to event.getAmount() @@ -187,7 +187,7 @@ public class EntityExperienceOrb extends Entity { return i >= 2477 ? 2477 : (i >= 1237 ? 1237 : (i >= 617 ? 617 : (i >= 307 ? 307 : (i >= 149 ? 149 : (i >= 73 ? 73 : (i >= 37 ? 37 : (i >= 17 ? 17 : (i >= 7 ? 7 : (i >= 3 ? 3 : 1))))))))); } - public boolean ap() { + public boolean ao() { return false; } } diff --git a/src/main/java/net/minecraft/server/EntityFallingBlock.java b/src/main/java/net/minecraft/server/EntityFallingBlock.java index 17d837dd..daa376c3 100644 --- a/src/main/java/net/minecraft/server/EntityFallingBlock.java +++ b/src/main/java/net/minecraft/server/EntityFallingBlock.java @@ -22,13 +22,9 @@ public class EntityFallingBlock extends Entity { public EntityFallingBlock(World world) { super(world); - this.c = 0; this.dropItem = true; - this.f = false; - this.hurtEntities = false; this.fallHurtMax = 40; this.fallHurtAmount = 2.0F; - this.tileEntityData = null; } public EntityFallingBlock(World world, double d0, double d1, double d2, int i) { @@ -37,13 +33,9 @@ public class EntityFallingBlock extends Entity { public EntityFallingBlock(World world, double d0, double d1, double d2, int i, int j) { super(world); - this.c = 0; this.dropItem = true; - this.f = false; - this.hurtEntities = false; this.fallHurtMax = 40; this.fallHurtAmount = 2.0F; - this.tileEntityData = null; this.id = i; this.data = j; this.m = true; @@ -58,7 +50,7 @@ public class EntityFallingBlock extends Entity { this.lastZ = d2; } - protected boolean f_() { + protected boolean e_() { return false; } @@ -150,7 +142,7 @@ public class EntityFallingBlock extends Entity { } } - protected void a(float f) { + protected void b(float f) { if (this.hurtEntities) { int i = MathHelper.f(f - 1.0F); @@ -163,14 +155,14 @@ public class EntityFallingBlock extends Entity { Entity entity = (Entity) iterator.next(); // CraftBukkit start - int damage = Math.min(MathHelper.d((float) i * this.fallHurtAmount), this.fallHurtMax); + float damage = (float) Math.min(MathHelper.d((float) i * this.fallHurtAmount), this.fallHurtMax); EntityDamageEvent event = CraftEventFactory.callEntityDamageEvent(this, entity, EntityDamageEvent.DamageCause.FALLING_BLOCK, damage); if (event.isCancelled()) { continue; } - entity.damageEntity(damagesource, event.getDamage()); + entity.damageEntity(damagesource, (float) event.getDamage()); // CraftBukkit end } diff --git a/src/main/java/net/minecraft/server/EntityFireball.java b/src/main/java/net/minecraft/server/EntityFireball.java index 194a58fc..a8237967 100644 --- a/src/main/java/net/minecraft/server/EntityFireball.java +++ b/src/main/java/net/minecraft/server/EntityFireball.java @@ -7,11 +7,11 @@ public abstract class EntityFireball extends Entity { private int e = -1; private int f = -1; private int g = -1; - private int h = 0; - private boolean i = false; + private int h; + private boolean i; public EntityLiving shooter; private int j; - private int au = 0; + private int au; public double dirX; public double dirY; public double dirZ; @@ -106,7 +106,7 @@ public abstract class EntityFireball extends Entity { for (int j = 0; j < list.size(); ++j) { Entity entity1 = (Entity) list.get(j); - if (entity1.K() && (!entity1.i(this.shooter) || this.au >= 25)) { + if (entity1.K() && (!entity1.h(this.shooter) || this.au >= 25)) { float f = 0.3F; AxisAlignedBB axisalignedbb = entity1.boundingBox.grow((double) f, (double) f, (double) f); MovingObjectPosition movingobjectposition1 = axisalignedbb.a(vec3d, vec3d1); @@ -227,7 +227,7 @@ public abstract class EntityFireball extends Entity { return 1.0F; } - public boolean damageEntity(DamageSource damagesource, int i) { + public boolean damageEntity(DamageSource damagesource, float f) { if (this.isInvulnerable()) { return false; } else { @@ -255,7 +255,7 @@ public abstract class EntityFireball extends Entity { } } - public float c(float f) { + public float d(float f) { return 1.0F; } } diff --git a/src/main/java/net/minecraft/server/EntityFireworks.java b/src/main/java/net/minecraft/server/EntityFireworks.java index 6856e5b5..35fb8d43 100644 --- a/src/main/java/net/minecraft/server/EntityFireworks.java +++ b/src/main/java/net/minecraft/server/EntityFireworks.java @@ -111,11 +111,11 @@ public class EntityFireworks extends Entity { } } - public float c(float f) { - return super.c(f); + public float d(float f) { + return super.d(f); } - public boolean ap() { + public boolean ao() { return false; } } diff --git a/src/main/java/net/minecraft/server/EntityFishingHook.java b/src/main/java/net/minecraft/server/EntityFishingHook.java index fbae2934..255ff381 100644 --- a/src/main/java/net/minecraft/server/EntityFishingHook.java +++ b/src/main/java/net/minecraft/server/EntityFishingHook.java @@ -13,14 +13,14 @@ public class EntityFishingHook extends Entity { private int d = -1; private int e = -1; private int f = -1; - private int g = 0; - private boolean h = false; - public int a = 0; + private int g; + private boolean h; + public int a; public EntityHuman owner; private int i; - private int j = 0; - private int au = 0; - public Entity hooked = null; + private int j; + private int au; + public Entity hooked; private int av; private double aw; private double ax; @@ -93,7 +93,7 @@ public class EntityFishingHook extends Entity { this.b(this.yaw, this.pitch); } else { if (!this.world.isStatic) { - ItemStack itemstack = this.owner.cd(); + ItemStack itemstack = this.owner.bt(); if (this.owner.dead || !this.owner.isAlive() || itemstack == null || itemstack.getItem() != Item.FISHING_ROD || this.e(this.owner) > 1024.0D) { this.die(); @@ -180,7 +180,7 @@ public class EntityFishingHook extends Entity { if (movingobjectposition != null) { org.bukkit.craftbukkit.event.CraftEventFactory.callProjectileHitEvent(this); // Craftbukkit - Call event if (movingobjectposition.entity != null) { - if (movingobjectposition.entity.damageEntity(DamageSource.projectile(this, this.owner), 0)) { + if (movingobjectposition.entity.damageEntity(DamageSource.projectile(this, this.owner), 0.0F)) { this.hooked = movingobjectposition.entity; } } else { diff --git a/src/main/java/net/minecraft/server/EntityGhast.java b/src/main/java/net/minecraft/server/EntityGhast.java index f18a9246..be3922a2 100644 --- a/src/main/java/net/minecraft/server/EntityGhast.java +++ b/src/main/java/net/minecraft/server/EntityGhast.java @@ -8,33 +8,32 @@ import org.bukkit.event.entity.EntityTargetEvent; public class EntityGhast extends EntityFlying implements IMonster { - public int b = 0; - public double c; - public double d; - public double e; - private Entity target = null; - private int i = 0; - public int f = 0; - public int g = 0; + public int h; + public double i; + public double j; + public double bn; + private Entity target; + private int br; + public int bo; + public int bp; private int explosionPower = 1; public EntityGhast(World world) { super(world); - this.texture = "/mob/ghast.png"; this.a(4.0F, 4.0F); this.fireProof = true; - this.be = 5; + this.b = 5; } - public boolean damageEntity(DamageSource damagesource, int i) { + public boolean damageEntity(DamageSource damagesource, float f) { if (this.isInvulnerable()) { return false; } else if ("fireball".equals(damagesource.n()) && damagesource.getEntity() instanceof EntityHuman) { - super.damageEntity(damagesource, 1000); + super.damageEntity(damagesource, 1000.0F); ((EntityHuman) damagesource.getEntity()).a((Statistic) AchievementList.y); return true; } else { - return super.damageEntity(damagesource, i); + return super.damageEntity(damagesource, f); } } @@ -43,46 +42,40 @@ public class EntityGhast extends EntityFlying implements IMonster { this.datawatcher.a(16, Byte.valueOf((byte) 0)); } - public int getMaxHealth() { - return 10; + protected void ax() { + super.ax(); + this.a(GenericAttributes.a).a(10.0D); } - public void l_() { - super.l_(); - byte b0 = this.datawatcher.getByte(16); - - this.texture = b0 == 1 ? "/mob/ghast_fire.png" : "/mob/ghast.png"; - } - - protected void bq() { + protected void bh() { if (!this.world.isStatic && this.world.difficulty == 0) { this.die(); } - this.bn(); - this.f = this.g; - double d0 = this.c - this.locX; - double d1 = this.d - this.locY; - double d2 = this.e - this.locZ; + this.bk(); + this.bo = this.bp; + double d0 = this.i - this.locX; + double d1 = this.j - this.locY; + double d2 = this.bn - this.locZ; double d3 = d0 * d0 + d1 * d1 + d2 * d2; if (d3 < 1.0D || d3 > 3600.0D) { - this.c = this.locX + (double) ((this.random.nextFloat() * 2.0F - 1.0F) * 16.0F); - this.d = this.locY + (double) ((this.random.nextFloat() * 2.0F - 1.0F) * 16.0F); - this.e = this.locZ + (double) ((this.random.nextFloat() * 2.0F - 1.0F) * 16.0F); + this.i = this.locX + (double) ((this.random.nextFloat() * 2.0F - 1.0F) * 16.0F); + this.j = this.locY + (double) ((this.random.nextFloat() * 2.0F - 1.0F) * 16.0F); + this.bn = this.locZ + (double) ((this.random.nextFloat() * 2.0F - 1.0F) * 16.0F); } - if (this.b-- <= 0) { - this.b += this.random.nextInt(5) + 2; + if (this.h-- <= 0) { + this.h += this.random.nextInt(5) + 2; d3 = (double) MathHelper.sqrt(d3); - if (this.a(this.c, this.d, this.e, d3)) { + if (this.a(this.i, this.j, this.bn, d3)) { this.motX += d0 / d3 * 0.1D; this.motY += d1 / d3 * 0.1D; this.motZ += d2 / d3 * 0.1D; } else { - this.c = this.locX; - this.d = this.locY; - this.e = this.locZ; + this.i = this.locX; + this.j = this.locY; + this.bn = this.locZ; } } @@ -101,7 +94,7 @@ public class EntityGhast extends EntityFlying implements IMonster { // CraftBukkit end } - if (this.target == null || this.i-- <= 0) { + if (this.target == null || this.br-- <= 0) { // CraftBukkit start Entity target = this.world.findNearbyVulnerablePlayer(this, 100.0D); if (target != null) { @@ -119,7 +112,7 @@ public class EntityGhast extends EntityFlying implements IMonster { // CraftBukkit end if (this.target != null) { - this.i = 20; + this.br = 20; } } @@ -130,41 +123,41 @@ public class EntityGhast extends EntityFlying implements IMonster { double d6 = this.target.boundingBox.b + (double) (this.target.length / 2.0F) - (this.locY + (double) (this.length / 2.0F)); double d7 = this.target.locZ - this.locZ; - this.ay = this.yaw = -((float) Math.atan2(d5, d7)) * 180.0F / 3.1415927F; - if (this.n(this.target)) { - if (this.g == 10) { + this.aN = this.yaw = -((float) Math.atan2(d5, d7)) * 180.0F / 3.1415927F; + if (this.o(this.target)) { + if (this.bp == 10) { this.world.a((EntityHuman) null, 1007, (int) this.locX, (int) this.locY, (int) this.locZ, 0); } - ++this.g; - if (this.g == 20) { + ++this.bp; + if (this.bp == 20) { this.world.a((EntityHuman) null, 1008, (int) this.locX, (int) this.locY, (int) this.locZ, 0); EntityLargeFireball entitylargefireball = new EntityLargeFireball(this.world, this, d5, d6, d7); // CraftBukkit - set yield when setting explosionpower entitylargefireball.yield = entitylargefireball.e = this.explosionPower; double d8 = 4.0D; - Vec3D vec3d = this.i(1.0F); + Vec3D vec3d = this.j(1.0F); entitylargefireball.locX = this.locX + vec3d.c * d8; entitylargefireball.locY = this.locY + (double) (this.length / 2.0F) + 0.5D; entitylargefireball.locZ = this.locZ + vec3d.e * d8; this.world.addEntity(entitylargefireball); - this.g = -40; + this.bp = -40; } - } else if (this.g > 0) { - --this.g; + } else if (this.bp > 0) { + --this.bp; } } else { - this.ay = this.yaw = -((float) Math.atan2(this.motX, this.motZ)) * 180.0F / 3.1415927F; - if (this.g > 0) { - --this.g; + this.aN = this.yaw = -((float) Math.atan2(this.motX, this.motZ)) * 180.0F / 3.1415927F; + if (this.bp > 0) { + --this.bp; } } if (!this.world.isStatic) { byte b0 = this.datawatcher.getByte(16); - byte b1 = (byte) (this.g > 10 ? 1 : 0); + byte b1 = (byte) (this.bp > 10 ? 1 : 0); if (b0 != b1) { this.datawatcher.watch(16, Byte.valueOf(b1)); @@ -173,9 +166,9 @@ public class EntityGhast extends EntityFlying implements IMonster { } private boolean a(double d0, double d1, double d2, double d3) { - double d4 = (this.c - this.locX) / d3; - double d5 = (this.d - this.locY) / d3; - double d6 = (this.e - this.locZ) / d3; + double d4 = (this.i - this.locX) / d3; + double d5 = (this.j - this.locY) / d3; + double d6 = (this.bn - this.locZ) / d3; AxisAlignedBB axisalignedbb = this.boundingBox.clone(); for (int i = 1; (double) i < d3; ++i) { @@ -188,15 +181,15 @@ public class EntityGhast extends EntityFlying implements IMonster { return true; } - protected String bb() { + protected String r() { return "mob.ghast.moan"; } - protected String bc() { + protected String aK() { return "mob.ghast.scream"; } - protected String bd() { + protected String aL() { return "mob.ghast.death"; } @@ -225,7 +218,7 @@ public class EntityGhast extends EntityFlying implements IMonster { // CraftBukkit end } - protected float ba() { + protected float aW() { return 10.0F; } @@ -233,7 +226,7 @@ public class EntityGhast extends EntityFlying implements IMonster { return this.random.nextInt(20) == 0 && super.canSpawn() && this.world.difficulty > 0; } - public int by() { + public int br() { return 1; } diff --git a/src/main/java/net/minecraft/server/EntityHanging.java b/src/main/java/net/minecraft/server/EntityHanging.java index f697d851..af64f750 100644 --- a/src/main/java/net/minecraft/server/EntityHanging.java +++ b/src/main/java/net/minecraft/server/EntityHanging.java @@ -20,8 +20,6 @@ public abstract class EntityHanging extends Entity { public EntityHanging(World world) { super(world); - this.e = 0; - this.direction = 0; this.height = 0.0F; this.a(0.5F, 0.5F); } @@ -39,7 +37,7 @@ public abstract class EntityHanging extends Entity { this.direction = i; this.lastYaw = this.yaw = (float) (i * 90); float f = (float) this.d(); - float f1 = (float) this.g(); + float f1 = (float) this.e(); float f2 = (float) this.d(); if (i != 2 && i != 0) { @@ -74,33 +72,36 @@ public abstract class EntityHanging extends Entity { } if (i == 2) { - f3 -= this.b(this.d()); + f3 -= this.c(this.d()); } if (i == 1) { - f5 += this.b(this.d()); + f5 += this.c(this.d()); } if (i == 0) { - f3 += this.b(this.d()); + f3 += this.c(this.d()); } if (i == 3) { - f5 -= this.b(this.d()); + f5 -= this.c(this.d()); } - f4 += this.b(this.g()); + f4 += this.c(this.e()); this.setPosition((double) f3, (double) f4, (double) f5); float f7 = -0.03125F; this.boundingBox.b((double) (f3 - f - f7), (double) (f4 - f1 - f7), (double) (f5 - f2 - f7), (double) (f3 + f + f7), (double) (f4 + f1 + f7), (double) (f5 + f2 + f7)); } - private float b(int i) { + private float c(int i) { return i == 32 ? 0.5F : (i == 64 ? 0.5F : 0.0F); } public void l_() { + this.lastX = this.locX; + this.lastY = this.locY; + this.lastZ = this.locZ; if (this.e++ == 100 && !this.world.isStatic) { this.e = 0; if (!this.dead && !this.survives()) { @@ -132,7 +133,7 @@ public abstract class EntityHanging extends Entity { // CraftBukkit end this.die(); - this.h(); + this.b((Entity) null); } } } @@ -142,7 +143,7 @@ public abstract class EntityHanging extends Entity { return false; } else { int i = Math.max(1, this.d() / 16); - int j = Math.max(1, this.g() / 16); + int j = Math.max(1, this.e() / 16); int k = this.x; int l = this.y; int i1 = this.z; @@ -163,7 +164,7 @@ public abstract class EntityHanging extends Entity { i1 = MathHelper.floor(this.locZ - (double) ((float) this.d() / 32.0F)); } - l = MathHelper.floor(this.locY - (double) ((float) this.g() / 32.0F)); + l = MathHelper.floor(this.locY - (double) ((float) this.e() / 32.0F)); for (int j1 = 0; j1 < i; ++j1) { for (int k1 = 0; k1 < j; ++k1) { @@ -202,11 +203,11 @@ public abstract class EntityHanging extends Entity { return true; } - public boolean j(Entity entity) { - return entity instanceof EntityHuman ? this.damageEntity(DamageSource.playerAttack((EntityHuman) entity), 0) : false; + public boolean i(Entity entity) { + return entity instanceof EntityHuman ? this.damageEntity(DamageSource.playerAttack((EntityHuman) entity), 0.0F) : false; } - public boolean damageEntity(DamageSource damagesource, int i) { + public boolean damageEntity(DamageSource damagesource, float f) { if (this.isInvulnerable()) { return false; } else { @@ -239,17 +240,7 @@ public abstract class EntityHanging extends Entity { this.die(); this.J(); - EntityHuman entityhuman = null; - - if (damagesource.getEntity() instanceof EntityHuman) { - entityhuman = (EntityHuman) damagesource.getEntity(); - } - - if (entityhuman != null && entityhuman.abilities.canInstantlyBuild) { - return true; - } - - this.h(); + this.b(damagesource.getEntity()); } return true; @@ -261,14 +252,14 @@ public abstract class EntityHanging extends Entity { if (dead) return; // CraftBukkit this.die(); - this.h(); + this.b((Entity) null); } } public void g(double d0, double d1, double d2) { if (false && !this.world.isStatic && !this.dead && d0 * d0 + d1 * d1 + d2 * d2 > 0.0D) { // CraftBukkit - not needed this.die(); - this.h(); + this.b((Entity) null); } } @@ -325,7 +316,7 @@ public abstract class EntityHanging extends Entity { public abstract int d(); - public abstract int g(); + public abstract int e(); - public abstract void h(); + public abstract void b(Entity entity); } diff --git a/src/main/java/net/minecraft/server/EntityHuman.java b/src/main/java/net/minecraft/server/EntityHuman.java index 6ea27779..96c1f8c0 100644 --- a/src/main/java/net/minecraft/server/EntityHuman.java +++ b/src/main/java/net/minecraft/server/EntityHuman.java @@ -23,18 +23,17 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen public Container defaultContainer; public Container activeContainer; protected FoodMetaData foodData = new FoodMetaData(); - protected int bO = 0; - public byte bP = 0; - public float bQ; - public float bR; - public String name; - public int bT = 0; - public double bU; - public double bV; - public double bW; - public double bX; - public double bY; - public double bZ; + protected int br; + public float bs; + public float bt; + protected final String name; + public int bv; + public double bw; + public double bx; + public double by; + public double bz; + public double bA; + public double bB; // CraftBukkit start public boolean sleeping; // protected -> public public boolean fauxSleeping; @@ -46,10 +45,10 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen } // CraftBukkit end - public ChunkCoordinates cb; + public ChunkCoordinates bD; public int sleepTicks; // CraftBukkit - private -> public - public float cc; - public float cd; + public float bE; + public float bF; private ChunkCoordinates c; private boolean d; private ChunkCoordinates e; @@ -60,49 +59,49 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen public float exp; private ItemStack f; private int g; - protected float ci = 0.1F; - protected float cj = 0.02F; - private int h = 0; - public EntityFishingHook hookedFish = null; + protected float bK = 0.1F; + protected float bL = 0.02F; + private int h; + public EntityFishingHook hookedFish; - public EntityHuman(World world) { + public EntityHuman(World world, String s) { super(world); + this.name = s; this.defaultContainer = new ContainerPlayer(this.inventory, !world.isStatic, this); this.activeContainer = this.defaultContainer; this.height = 1.62F; ChunkCoordinates chunkcoordinates = world.getSpawn(); this.setPositionRotation((double) chunkcoordinates.x + 0.5D, (double) (chunkcoordinates.y + 1), (double) chunkcoordinates.z + 0.5D, 0.0F, 0.0F); - this.aK = "humanoid"; - this.aJ = 180.0F; + this.ba = 180.0F; this.maxFireTicks = 20; - this.texture = "/mob/char.png"; } - public int getMaxHealth() { - return 20; + protected void ax() { + super.ax(); + this.aT().b(GenericAttributes.e).a(1.0D); } protected void a() { super.a(); this.datawatcher.a(16, Byte.valueOf((byte) 0)); - this.datawatcher.a(17, Byte.valueOf((byte) 0)); + this.datawatcher.a(17, Float.valueOf(0.0F)); this.datawatcher.a(18, Integer.valueOf(0)); } - public boolean bX() { + public boolean bm() { return this.f != null; } - public void bZ() { + public void bo() { if (this.f != null) { this.f.b(this.world, this, this.g); } - this.ca(); + this.bp(); } - public void ca() { + public void bp() { this.f = null; this.g = 0; if (!this.world.isStatic) { @@ -111,7 +110,7 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen } public boolean isBlocking() { - return this.bX() && Item.byId[this.f.id].b_(this.f) == EnumAnimation.BLOCK; + return this.bm() && Item.byId[this.f.id].c_(this.f) == EnumAnimation.BLOCK; } public void l_() { @@ -124,15 +123,15 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen } if (--this.g == 0 && !this.world.isStatic) { - this.m(); + this.n(); } } else { - this.ca(); + this.bp(); } } - if (this.bT > 0) { - --this.bT; + if (this.bv > 0) { + --this.bv; } if (this.isSleeping()) { @@ -142,7 +141,7 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen } if (!this.world.isStatic) { - if (!this.i()) { + if (!this.h()) { this.a(true, true, false); } else if (this.world.v()) { this.a(false, true, true); @@ -165,41 +164,41 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen this.extinguish(); } - this.bU = this.bX; - this.bV = this.bY; - this.bW = this.bZ; - double d0 = this.locX - this.bX; - double d1 = this.locY - this.bY; - double d2 = this.locZ - this.bZ; + this.bw = this.bz; + this.bx = this.bA; + this.by = this.bB; + double d0 = this.locX - this.bz; + double d1 = this.locY - this.bA; + double d2 = this.locZ - this.bB; double d3 = 10.0D; if (d0 > d3) { - this.bU = this.bX = this.locX; + this.bw = this.bz = this.locX; } if (d2 > d3) { - this.bW = this.bZ = this.locZ; + this.by = this.bB = this.locZ; } if (d1 > d3) { - this.bV = this.bY = this.locY; + this.bx = this.bA = this.locY; } if (d0 < -d3) { - this.bU = this.bX = this.locX; + this.bw = this.bz = this.locX; } if (d2 < -d3) { - this.bW = this.bZ = this.locZ; + this.by = this.bB = this.locZ; } if (d1 < -d3) { - this.bV = this.bY = this.locY; + this.bx = this.bA = this.locY; } - this.bX += d0 * 0.25D; - this.bZ += d2 * 0.25D; - this.bY += d1 * 0.25D; + this.bz += d0 * 0.25D; + this.bB += d2 * 0.25D; + this.bA += d1 * 0.25D; this.a(StatisticList.k, 1); if (this.vehicle == null) { this.e = null; @@ -245,7 +244,7 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen } } - protected void m() { + protected void n() { if (this.f != null) { this.c(this.f, 16); int i = this.f.count; @@ -284,12 +283,12 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen } } - this.ca(); + this.bp(); } } - protected boolean bj() { - return this.getHealth() <= 0 || this.isSleeping(); + protected boolean aY() { + return this.getHealth() <= 0.0F || this.isSleeping(); } // CraftBukkit - protected -> public @@ -304,8 +303,11 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen public void setPassengerOf(Entity entity) { // CraftBukkit end - if (this.vehicle == entity) { - this.h(entity); + if (this.vehicle != null && entity == null) { + if (!this.world.isStatic) { + this.l(this.vehicle); + } + if (this.vehicle != null) { this.vehicle.passenger = null; } @@ -317,48 +319,59 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen } public void T() { - double d0 = this.locX; - double d1 = this.locY; - double d2 = this.locZ; - float f = this.yaw; - float f1 = this.pitch; - - super.T(); - this.bQ = this.bR; - this.bR = 0.0F; - this.k(this.locX - d0, this.locY - d1, this.locZ - d2); - if (this.vehicle instanceof EntityPig) { - this.pitch = f1; - this.yaw = f; - this.ay = ((EntityPig) this.vehicle).ay; + if (!this.world.isStatic && this.isSneaking()) { + this.mount((Entity) null); + this.setSneaking(false); + } else { + double d0 = this.locX; + double d1 = this.locY; + double d2 = this.locZ; + float f = this.yaw; + float f1 = this.pitch; + + super.T(); + this.bs = this.bt; + this.bt = 0.0F; + this.k(this.locX - d0, this.locY - d1, this.locZ - d2); + if (this.vehicle instanceof EntityPig) { + this.pitch = f1; + this.yaw = f; + this.aN = ((EntityPig) this.vehicle).aN; + } } } - protected void bq() { - this.br(); + protected void bh() { + super.bh(); + this.aS(); } public void c() { - if (this.bO > 0) { - --this.bO; + if (this.br > 0) { + --this.br; } // CraftBukkit - this.getMaxHealth() -> this.maxHealth - if (this.world.difficulty == 0 && this.getHealth() < this.maxHealth && this.ticksLived % 20 * 12 == 0) { + if (this.world.difficulty == 0 && this.getHealth() < this.maxHealth && this.world.getGameRules().getBoolean("naturalRegeneration") && this.ticksLived % 20 * 12 == 0) { // CraftBukkit - added regain reason of "REGEN" for filtering purposes. - this.heal(1, org.bukkit.event.entity.EntityRegainHealthEvent.RegainReason.REGEN); + this.heal(1.0F, org.bukkit.event.entity.EntityRegainHealthEvent.RegainReason.REGEN); } this.inventory.k(); - this.bQ = this.bR; + this.bs = this.bt; super.c(); - this.aO = this.abilities.b(); - this.aP = this.cj; + AttributeInstance attributeinstance = this.a(GenericAttributes.d); + + if (!this.world.isStatic) { + attributeinstance.a((double) this.abilities.b()); + } + + this.aR = this.bL; if (this.isSprinting()) { - this.aO = (float) ((double) this.aO + (double) this.abilities.b() * 0.3D); - this.aP = (float) ((double) this.aP + (double) this.cj * 0.3D); + this.aR = (float) ((double) this.aR + (double) this.bL * 0.3D); } + this.i((float) attributeinstance.e()); float f = MathHelper.sqrt(this.motX * this.motX + this.motZ * this.motZ); // CraftBukkit - Math -> TrigMath float f1 = (float) org.bukkit.craftbukkit.TrigMath.atan(-this.motY * 0.20000000298023224D) * 15.0F; @@ -367,18 +380,26 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen f = 0.1F; } - if (!this.onGround || this.getHealth() <= 0) { + if (!this.onGround || this.getHealth() <= 0.0F) { f = 0.0F; } - if (this.onGround || this.getHealth() <= 0) { + if (this.onGround || this.getHealth() <= 0.0F) { f1 = 0.0F; } - this.bR += (f - this.bR) * 0.4F; - this.bc += (f1 - this.bc) * 0.8F; - if (this.getHealth() > 0) { - List list = this.world.getEntities(this, this.boundingBox.grow(1.0D, 0.5D, 1.0D)); + this.bt += (f - this.bt) * 0.4F; + this.aK += (f1 - this.aK) * 0.8F; + if (this.getHealth() > 0.0F) { + AxisAlignedBB axisalignedbb = null; + + if (this.vehicle != null && !this.vehicle.dead) { + axisalignedbb = this.boundingBox.a(this.vehicle.boundingBox).grow(1.0D, 0.0D, 1.0D); + } else { + axisalignedbb = this.boundingBox.grow(1.0D, 0.5D, 1.0D); + } + + List list = this.world.getEntities(this, axisalignedbb); if (list != null) { for (int i = 0; i < list.size(); ++i) { @@ -424,8 +445,8 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen } if (damagesource != null) { - this.motX = (double) (-MathHelper.cos((this.aY + this.yaw) * 3.1415927F / 180.0F) * 0.1F); - this.motZ = (double) (-MathHelper.sin((this.aY + this.yaw) * 3.1415927F / 180.0F) * 0.1F); + this.motX = (double) (-MathHelper.cos((this.aA + this.yaw) * 3.1415927F / 180.0F) * 0.1F); + this.motZ = (double) (-MathHelper.sin((this.aA + this.yaw) * 3.1415927F / 180.0F) * 0.1F); } else { this.motX = this.motZ = 0.0D; } @@ -434,7 +455,7 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen this.a(StatisticList.y, 1); } - public void c(Entity entity, int i) { + public void b(Entity entity, int i) { this.addScore(i); // CraftBukkit - Get our scores instead Collection<ScoreboardScore> collection = this.world.getServer().getScoreboardManager().getScoreboardScores(IScoreboardCriteria.e, this.getLocalizedName(), new java.util.ArrayList<ScoreboardScore>()); @@ -467,6 +488,8 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen public EntityItem a(ItemStack itemstack, boolean flag) { if (itemstack == null) { return null; + } else if (itemstack.count == 0) { + return null; } else { EntityItem entityitem = new EntityItem(this.world, this.locX, this.locY - 0.30000001192092896D + (double) this.getHeadHeight(), this.locZ, itemstack); @@ -571,7 +594,7 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen this.expTotal = nbttagcompound.getInt("XpTotal"); this.setScore(nbttagcompound.getInt("Score")); if (this.sleeping) { - this.cb = new ChunkCoordinates(MathHelper.floor(this.locX), MathHelper.floor(this.locY), MathHelper.floor(this.locZ)); + this.bD = new ChunkCoordinates(MathHelper.floor(this.locX), MathHelper.floor(this.locY), MathHelper.floor(this.locZ)); this.a(true, true, false); } @@ -625,6 +648,8 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen public void openMinecartHopper(EntityMinecartHopper entityminecarthopper) {} + public void openHorseInventory(EntityHorse entityhorse, IInventory iinventory) {} + public void startEnchanting(int i, int j, int k, String s) {} public void openAnvil(int i, int j, int k) {} @@ -635,18 +660,18 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen return 0.12F; } - protected void e_() { + protected void d_() { this.height = 1.62F; } - public boolean damageEntity(DamageSource damagesource, int i) { + public boolean damageEntity(DamageSource damagesource, float f) { if (this.isInvulnerable()) { return false; } else if (this.abilities.isInvulnerable && !damagesource.ignoresInvulnerability()) { return false; } else { - this.bC = 0; - if (this.getHealth() <= 0) { + this.aV = 0; + if (this.getHealth() <= 0.0F) { return false; } else { if (this.isSleeping() && !this.world.isStatic) { @@ -655,19 +680,19 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen if (damagesource.p()) { if (this.world.difficulty == 0) { - return false; // CraftBukkit - i = 0 -> return false + return false; // CraftBukkit - f = 0 -> return false } if (this.world.difficulty == 1) { - i = i / 2 + 1; + f = f / 2.0F + 1.0F; } if (this.world.difficulty == 3) { - i = i * 3 / 2; + f = f * 3.0F / 2.0F; } } - if (false && i == 0) { // CraftBukkit - Don't filter out 0 damage + if (false && f == 0.0F) { // CraftBukkit - Don't filter out 0 damage return false; } else { Entity entity = damagesource.getEntity(); @@ -680,8 +705,8 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen this.a((EntityLiving) entity, false); } - this.a(StatisticList.x, i); - return super.damageEntity(damagesource, i); + this.a(StatisticList.x, Math.round(f * 10.0F)); + return super.damageEntity(damagesource, f); } } } @@ -724,30 +749,32 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen } if (!(entityliving instanceof EntityHuman) || this.a((EntityHuman) entityliving)) { - List list = this.world.a(EntityWolf.class, AxisAlignedBB.a().a(this.locX, this.locY, this.locZ, this.locX + 1.0D, this.locY + 1.0D, this.locZ + 1.0D).grow(16.0D, 4.0D, 16.0D)); - Iterator iterator = list.iterator(); + if (!(entityliving instanceof EntityHorse) || !((EntityHorse) entityliving).bS()) { + List list = this.world.a(EntityWolf.class, AxisAlignedBB.a().a(this.locX, this.locY, this.locZ, this.locX + 1.0D, this.locY + 1.0D, this.locZ + 1.0D).grow(16.0D, 4.0D, 16.0D)); + Iterator iterator = list.iterator(); - while (iterator.hasNext()) { - EntityWolf entitywolf1 = (EntityWolf) iterator.next(); + while (iterator.hasNext()) { + EntityWolf entitywolf1 = (EntityWolf) iterator.next(); - if (entitywolf1.isTamed() && entitywolf1.l() == null && this.name.equals(entitywolf1.getOwnerName()) && (!flag || !entitywolf1.isSitting())) { - entitywolf1.setSitting(false); - entitywolf1.setTarget(entityliving); + if (entitywolf1.isTamed() && entitywolf1.bJ() == null && this.name.equals(entitywolf1.getOwnerName()) && (!flag || !entitywolf1.isSitting())) { + entitywolf1.setSitting(false); + entitywolf1.setTarget(entityliving); + } } } } } } - protected void k(int i) { - this.inventory.g(i); + protected void h(float f) { + this.inventory.a(f); } - public int aZ() { + public int aM() { return this.inventory.l(); } - public float cc() { + public float bs() { int i = 0; ItemStack[] aitemstack = this.inventory.armor; int j = aitemstack.length; @@ -763,19 +790,25 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen return (float) i / (float) this.inventory.armor.length; } - protected void d(DamageSource damagesource, int i) { + protected void d(DamageSource damagesource, float f) { if (!this.isInvulnerable()) { - if (!damagesource.ignoresArmor() && this.isBlocking()) { - i = 1 + i >> 1; + if (!damagesource.ignoresArmor() && this.isBlocking() && f > 0.0F) { + f = (1.0F + f) * 0.5F; } - i = this.b(damagesource, i); - i = this.c(damagesource, i); - this.j(damagesource.f()); - int j = this.getHealth(); + f = this.b(damagesource, f); + f = this.c(damagesource, f); + float f1 = f; + + f = Math.max(f - this.bj(), 0.0F); + this.m(this.bj() - (f1 - f)); + if (f != 0.0F) { + this.a(damagesource.f()); + float f2 = this.getHealth(); - this.setHealth(this.getHealth() - i); - this.bt.a(damagesource, j, i); + this.setHealth(this.getHealth() - f); + this.aN().a(damagesource, f2, f); + } } } @@ -791,23 +824,22 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen public void openTrade(IMerchant imerchant, String s) {} - public void d(ItemStack itemstack) {} + public void c(ItemStack itemstack) {} public boolean p(Entity entity) { - if (entity.a_(this)) { - return true; - } else { - ItemStack itemstack = this.cd(); + ItemStack itemstack = this.bt(); + ItemStack itemstack1 = itemstack != null ? itemstack.cloneItemStack() : null; + if (!entity.c(this)) { if (itemstack != null && entity instanceof EntityLiving) { if (this.abilities.canInstantlyBuild) { - itemstack = itemstack.cloneItemStack(); + itemstack = itemstack1; } - if (itemstack.a((EntityLiving) entity)) { + if (itemstack.a(this, (EntityLiving) entity)) { // CraftBukkit - bypass infinite items; <= 0 -> == 0 if (itemstack.count == 0 && !this.abilities.canInstantlyBuild) { - this.ce(); + this.bu(); } return true; @@ -815,14 +847,24 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen } return false; + } else { + if (itemstack != null && itemstack == this.bt()) { + if (itemstack.count <= 0 && !this.abilities.canInstantlyBuild) { + this.bu(); + } else if (itemstack.count < itemstack1.count && this.abilities.canInstantlyBuild) { + itemstack.count = itemstack1.count; + } + } + + return true; } } - public ItemStack cd() { + public ItemStack bt() { return this.inventory.getItemInHand(); } - public void ce() { + public void bu() { this.inventory.setItem(this.inventory.itemInHandIndex, (ItemStack) null); } @@ -831,47 +873,38 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen } public void attack(Entity entity) { - if (entity.ap()) { - if (!entity.j(this)) { - int i = this.inventory.a(entity); - - if (this.hasEffect(MobEffectList.INCREASE_DAMAGE)) { - i += 3 << this.getEffect(MobEffectList.INCREASE_DAMAGE).getAmplifier(); - } - - if (this.hasEffect(MobEffectList.WEAKNESS)) { - i -= 2 << this.getEffect(MobEffectList.WEAKNESS).getAmplifier(); - } - - int j = 0; - int k = 0; + if (entity.ao()) { + if (!entity.i(this)) { + float f = (float) this.a(GenericAttributes.e).e(); + int i = 0; + float f1 = 0.0F; if (entity instanceof EntityLiving) { - k = EnchantmentManager.a((EntityLiving) this, (EntityLiving) entity); - j += EnchantmentManager.getKnockbackEnchantmentLevel(this, (EntityLiving) entity); + f1 = EnchantmentManager.a((EntityLiving) this, (EntityLiving) entity); + i += EnchantmentManager.getKnockbackEnchantmentLevel(this, (EntityLiving) entity); } if (this.isSprinting()) { - ++j; + ++i; } - if (i > 0 || k > 0) { - boolean flag = this.fallDistance > 0.0F && !this.onGround && !this.g_() && !this.G() && !this.hasEffect(MobEffectList.BLINDNESS) && this.vehicle == null && entity instanceof EntityLiving; + if (f > 0.0F || f1 > 0.0F) { + boolean flag = this.fallDistance > 0.0F && !this.onGround && !this.e() && !this.G() && !this.hasEffect(MobEffectList.BLINDNESS) && this.vehicle == null && entity instanceof EntityLiving; - if (flag && i > 0) { - i += this.random.nextInt(i / 2 + 2); + if (flag && f > 0.0F) { + f *= 1.5F; } - i += k; + f += f1; boolean flag1 = false; - int l = EnchantmentManager.getFireAspectEnchantmentLevel(this); + int j = EnchantmentManager.getFireAspectEnchantmentLevel(this); - if (entity instanceof EntityLiving && l > 0 && !entity.isBurning()) { + if (entity instanceof EntityLiving && j > 0 && !entity.isBurning()) { flag1 = true; entity.setOnFire(1); } - boolean flag2 = entity.damageEntity(DamageSource.playerAttack(this), i); + boolean flag2 = entity.damageEntity(DamageSource.playerAttack(this), f); // CraftBukkit start - Return when the damage fails so that the item will not lose durability if (!flag2) { @@ -883,8 +916,8 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen // CraftBukkit end if (flag2) { - if (j > 0) { - entity.g((double) (-MathHelper.sin(this.yaw * 3.1415927F / 180.0F) * (float) j * 0.5F), 0.1D, (double) (MathHelper.cos(this.yaw * 3.1415927F / 180.0F) * (float) j * 0.5F)); + if (i > 0) { + entity.g((double) (-MathHelper.sin(this.yaw * 3.1415927F / 180.0F) * (float) i * 0.5F), 0.1D, (double) (MathHelper.cos(this.yaw * 3.1415927F / 180.0F) * (float) i * 0.5F)); this.motX *= 0.6D; this.motZ *= 0.6D; this.setSprinting(false); @@ -894,21 +927,21 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen this.b(entity); } - if (k > 0) { + if (f1 > 0.0F) { this.c(entity); } - if (i >= 18) { + if (f >= 18.0F) { this.a((Statistic) AchievementList.E); } - this.l(entity); + this.k(entity); if (entity instanceof EntityLiving) { EnchantmentThorns.a(this, (EntityLiving) entity, this.random); } } - ItemStack itemstack = this.cd(); + ItemStack itemstack = this.bt(); Object object = entity; if (entity instanceof EntityComplexPart) { @@ -923,7 +956,7 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen itemstack.a((EntityLiving) object, this); // CraftBukkit - bypass infinite items; <= 0 -> == 0 if (itemstack.count == 0) { - this.ce(); + this.bu(); } } @@ -932,10 +965,10 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen this.a((EntityLiving) entity, true); } - this.a(StatisticList.w, i); - if (l > 0 && flag2) { + this.a(StatisticList.w, Math.round(f * 10.0F)); + if (j > 0 && flag2) { // CraftBukkit start - Call a combust event when somebody hits with a fire enchanted item - EntityCombustByEntityEvent combustEvent = new EntityCombustByEntityEvent(this.getBukkitEntity(), entity.getBukkitEntity(), l * 4); + EntityCombustByEntityEvent combustEvent = new EntityCombustByEntityEvent(this.getBukkitEntity(), entity.getBukkitEntity(), j * 4); org.bukkit.Bukkit.getPluginManager().callEvent(combustEvent); if (!combustEvent.isCancelled()) { @@ -947,7 +980,7 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen } } - this.j(0.3F); + this.a(0.3F); } } } @@ -969,10 +1002,6 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen return !this.sleeping && super.inBlock(); } - public boolean cg() { - return false; - } - public EnumBedResult a(int i, int j, int k) { if (!this.world.isStatic) { if (this.isSleeping() || !this.isAlive()) { @@ -1000,6 +1029,10 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen } } + if (this.ae()) { + this.mount((Entity) null); + } + // CraftBukkit start if (this.getBukkitEntity() instanceof Player) { Player player = (Player) this.getBukkitEntity(); @@ -1039,7 +1072,7 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen f = 0.9F; } - this.x(i1); + this.t(i1); this.setPosition((double) ((float) i + f), (double) ((float) j + 0.9375F), (double) ((float) k + f1)); } else { this.setPosition((double) ((float) i + 0.5F), (double) ((float) j + 0.9375F), (double) ((float) k + 0.5F)); @@ -1047,7 +1080,7 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen this.sleeping = true; this.sleepTicks = 0; - this.cb = new ChunkCoordinates(i, j, k); + this.bD = new ChunkCoordinates(i, j, k); this.motX = this.motZ = this.motY = 0.0D; if (!this.world.isStatic) { this.world.everyoneSleeping(); @@ -1056,32 +1089,32 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen return EnumBedResult.OK; } - private void x(int i) { - this.cc = 0.0F; - this.cd = 0.0F; + private void t(int i) { + this.bE = 0.0F; + this.bF = 0.0F; switch (i) { case 0: - this.cd = -1.8F; + this.bF = -1.8F; break; case 1: - this.cc = 1.8F; + this.bE = 1.8F; break; case 2: - this.cd = 1.8F; + this.bF = 1.8F; break; case 3: - this.cc = -1.8F; + this.bE = -1.8F; } } public void a(boolean flag, boolean flag1, boolean flag2) { this.a(0.6F, 1.8F); - this.e_(); - ChunkCoordinates chunkcoordinates = this.cb; - ChunkCoordinates chunkcoordinates1 = this.cb; + this.d_(); + ChunkCoordinates chunkcoordinates = this.bD; + ChunkCoordinates chunkcoordinates1 = this.bD; if (chunkcoordinates != null && this.world.getTypeId(chunkcoordinates.x, chunkcoordinates.y, chunkcoordinates.z) == Block.BED.id) { BlockBed.a(this.world, chunkcoordinates.x, chunkcoordinates.y, chunkcoordinates.z, false); @@ -1121,16 +1154,16 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen } if (flag2) { - this.setRespawnPosition(this.cb, false); + this.setRespawnPosition(this.bD, false); } } - private boolean i() { - return this.world.getTypeId(this.cb.x, this.cb.y, this.cb.z) == Block.BED.id; + private boolean h() { + return this.world.getTypeId(this.bD.x, this.bD.y, this.bD.z) == Block.BED.id; } public static ChunkCoordinates getBed(World world, ChunkCoordinates chunkcoordinates, boolean flag) { - IChunkProvider ichunkprovider = world.K(); + IChunkProvider ichunkprovider = world.L(); ichunkprovider.getChunkAt(chunkcoordinates.x - 3 >> 4, chunkcoordinates.z - 3 >> 4); ichunkprovider.getChunkAt(chunkcoordinates.x + 3 >> 4, chunkcoordinates.z - 3 >> 4); @@ -1168,7 +1201,7 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen } } - public void b(String s) {} + public void a(String s) {} public ChunkCoordinates getBed() { return this.c; @@ -1196,13 +1229,13 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen public void a(Statistic statistic, int i) {} - protected void bl() { - super.bl(); + protected void ba() { + super.ba(); this.a(StatisticList.u, 1); if (this.isSprinting()) { - this.j(0.8F); + this.a(0.8F); } else { - this.j(0.2F); + this.a(0.2F); } } @@ -1213,12 +1246,12 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen if (this.abilities.isFlying && this.vehicle == null) { double d3 = this.motY; - float f2 = this.aP; + float f2 = this.aR; - this.aP = this.abilities.a(); + this.aR = this.abilities.a(); super.e(f, f1); this.motY = d3 * 0.6D; - this.aP = f2; + this.aR = f2; } else { super.e(f, f1); } @@ -1226,6 +1259,10 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen this.checkMovement(this.locX - d0, this.locY - d1, this.locZ - d2); } + public float bc() { + return (float) this.a(GenericAttributes.d).e(); + } + public void checkMovement(double d0, double d1, double d2) { if (this.vehicle == null) { int i; @@ -1234,15 +1271,15 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen i = Math.round(MathHelper.sqrt(d0 * d0 + d1 * d1 + d2 * d2) * 100.0F); if (i > 0) { this.a(StatisticList.q, i); - this.j(0.015F * (float) i * 0.01F); + this.a(0.015F * (float) i * 0.01F); } } else if (this.G()) { i = Math.round(MathHelper.sqrt(d0 * d0 + d2 * d2) * 100.0F); if (i > 0) { this.a(StatisticList.m, i); - this.j(0.015F * (float) i * 0.01F); + this.a(0.015F * (float) i * 0.01F); } - } else if (this.g_()) { + } else if (this.e()) { if (d1 > 0.0D) { this.a(StatisticList.o, (int) Math.round(d1 * 100.0D)); } @@ -1251,9 +1288,9 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen if (i > 0) { this.a(StatisticList.l, i); if (this.isSprinting()) { - this.j(0.099999994F * (float) i * 0.01F); + this.a(0.099999994F * (float) i * 0.01F); } else { - this.j(0.01F * (float) i * 0.01F); + this.a(0.01F * (float) i * 0.01F); } } } else { @@ -1286,13 +1323,13 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen } } - protected void a(float f) { + protected void b(float f) { if (!this.abilities.canFly) { if (f >= 2.0F) { this.a(StatisticList.n, (int) Math.round((double) f * 100.0D)); } - super.a(f); + super.b(f); } } @@ -1302,20 +1339,16 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen } } - public void al() { + public void ak() { if (!this.abilities.isFlying) { - super.al(); + super.ak(); } } - public ItemStack q(int i) { + public ItemStack o(int i) { return this.inventory.f(i); } - protected void bH() {} - - protected void bI() {} - public void giveExp(int i) { this.addScore(i); int j = Integer.MAX_VALUE - this.expTotal; @@ -1352,7 +1385,7 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen return this.expLevel >= 30 ? 62 + (this.expLevel - 30) * 7 : (this.expLevel >= 15 ? 17 + (this.expLevel - 15) * 3 : 17); } - public void j(float f) { + public void a(float f) { if (!this.abilities.isInvulnerable) { if (!this.world.isStatic) { this.foodData.a(f); @@ -1364,12 +1397,12 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen return this.foodData; } - public boolean i(boolean flag) { + public boolean g(boolean flag) { return (flag || this.foodData.c()) && !this.abilities.isInvulnerable; } - public boolean co() { - return this.getHealth() > 0 && this.getHealth() < this.maxHealth; // CraftBukkit - this.getMaxHealth() -> this.maxHealth + public boolean bE() { + return this.getHealth() > 0.0F && this.getHealth() < this.maxHealth; // CraftBukkit - this.getMaxHealth() -> this.maxHealth } public void a(ItemStack itemstack, int i) { @@ -1382,7 +1415,7 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen } } - public boolean e(int i, int j, int k) { + public boolean d(int i, int j, int k) { if (this.abilities.mayBuild) { return true; } else { @@ -1395,8 +1428,8 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen return true; } - if (this.cd() != null) { - ItemStack itemstack = this.cd(); + if (this.bt() != null) { + ItemStack itemstack = this.bt(); if (itemstack.b(block) || itemstack.a(block) > 1.0F) { return true; @@ -1409,7 +1442,7 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen } public boolean a(int i, int j, int k, int l, ItemStack itemstack) { - return this.abilities.mayBuild ? true : (itemstack != null ? itemstack.y() : false); + return this.abilities.mayBuild ? true : (itemstack != null ? itemstack.z() : false); } protected int getExpValue(EntityHuman entityhuman) { @@ -1430,20 +1463,10 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen return this.name; } - public boolean getCustomNameVisible() { - return super.getCustomNameVisible(); - } - - /* CraftBukkit start - We use canPickUpLoot on players, can't have this - public boolean bT() { - return false; - } - // CraftBukkit end */ - public void copyTo(EntityHuman entityhuman, boolean flag) { if (flag) { this.inventory.b(entityhuman.inventory); - this.health = entityhuman.health; + this.setHealth(entityhuman.getHealth()); this.foodData = entityhuman.foodData; this.expLevel = entityhuman.expLevel; this.expTotal = entityhuman.expTotal; @@ -1461,7 +1484,7 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen this.enderChest = entityhuman.enderChest; } - protected boolean f_() { + protected boolean e_() { return !this.abilities.isFlying; } @@ -1473,12 +1496,8 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen return this.name; } - public LocaleLanguage getLocale() { - return LocaleLanguage.a(); - } - - public String a(String s, Object... aobject) { - return this.getLocale().a(s, aobject); + public World f_() { + return this.world; } public InventoryEnderChest getEnderChest() { @@ -1489,7 +1508,7 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen return i == 0 ? this.inventory.getItemInHand() : this.inventory.armor[i - 1]; } - public ItemStack bG() { + public ItemStack aV() { return this.inventory.getItemInHand(); } @@ -1501,7 +1520,7 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen return this.inventory.armor; } - public boolean aw() { + public boolean av() { return !this.abilities.isFlying; } @@ -1514,7 +1533,19 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen } public String getScoreboardDisplayName() { - // TODO: fun + // CraftBukkit todo: fun return ScoreboardTeam.getPlayerDisplayName(this.getScoreboardTeam(), this.name); } + + public void m(float f) { + if (f < 0.0F) { + f = 0.0F; + } + + this.getDataWatcher().watch(17, Float.valueOf(f)); + } + + public float bj() { + return this.getDataWatcher().getFloat(17); + } } diff --git a/src/main/java/net/minecraft/server/EntityInsentient.java b/src/main/java/net/minecraft/server/EntityInsentient.java new file mode 100644 index 00000000..7d8f2b42 --- /dev/null +++ b/src/main/java/net/minecraft/server/EntityInsentient.java @@ -0,0 +1,884 @@ +package net.minecraft.server; + +import java.util.Iterator; +import java.util.List; +import java.util.UUID; + +//CraftBukkit start +import org.bukkit.craftbukkit.event.CraftEventFactory; +import org.bukkit.event.entity.EntityDamageByBlockEvent; +import org.bukkit.event.entity.EntityDamageEvent; +import org.bukkit.event.entity.EntityRegainHealthEvent; +//CraftBukkit end + +public abstract class EntityInsentient extends EntityLiving { + + public int a_; + protected int b; + private ControllerLook h; + private ControllerMove moveController; + private ControllerJump lookController; + private EntityAIBodyControl bn; + private Navigation navigation; + protected final PathfinderGoalSelector goalSelector; + protected final PathfinderGoalSelector targetSelector; + private EntityLiving goalTarget; + private EntitySenses bq; + private ItemStack[] equipment = new ItemStack[5]; + public float[] dropChances = new float[5]; // CraftBukkit - protected -> public + public boolean canPickUpLoot; // CraftBukkit - private -> public + public boolean persistent; // CraftBukkit - private -> public + protected float f; + private Entity bu; + protected int g; + private boolean bv; + private Entity bw; + private NBTTagCompound bx; + + public EntityInsentient(World world) { + super(world); + this.goalSelector = new PathfinderGoalSelector(world != null && world.methodProfiler != null ? world.methodProfiler : null); + this.targetSelector = new PathfinderGoalSelector(world != null && world.methodProfiler != null ? world.methodProfiler : null); + this.h = new ControllerLook(this); + this.moveController = new ControllerMove(this); + this.lookController = new ControllerJump(this); + this.bn = new EntityAIBodyControl(this); + this.navigation = new Navigation(this, world); + this.bq = new EntitySenses(this); + + for (int i = 0; i < this.dropChances.length; ++i) { + this.dropChances[i] = 0.085F; + } + } + + protected void ax() { + super.ax(); + this.aT().b(GenericAttributes.b).a(16.0D); + } + + public ControllerLook getControllerLook() { + return this.h; + } + + public ControllerMove getControllerMove() { + return this.moveController; + } + + public ControllerJump getControllerJump() { + return this.lookController; + } + + public Navigation getNavigation() { + return this.navigation; + } + + public EntitySenses getEntitySenses() { + return this.bq; + } + + public EntityLiving getGoalTarget() { + return this.goalTarget; + } + + public void setGoalTarget(EntityLiving entityliving) { + this.goalTarget = entityliving; + } + + public boolean a(Class oclass) { + return EntityCreeper.class != oclass && EntityGhast.class != oclass; + } + + public void n() {} + + protected void a() { + super.a(); + this.datawatcher.a(11, Byte.valueOf((byte) 0)); + this.datawatcher.a(10, ""); + } + + public int o() { + return 80; + } + + public void p() { + String s = this.r(); + + if (s != null) { + this.makeSound(s, this.aW(), this.aX()); + } + } + + public void x() { + super.x(); + this.world.methodProfiler.a("mobBaseTick"); + if (this.isAlive() && this.random.nextInt(1000) < this.a_++) { + this.a_ = -this.o(); + this.p(); + } + + this.world.methodProfiler.b(); + } + + protected int getExpValue(EntityHuman entityhuman) { + if (this.b > 0) { + int i = this.b; + ItemStack[] aitemstack = this.getEquipment(); + + for (int j = 0; j < aitemstack.length; ++j) { + if (aitemstack[j] != null && this.dropChances[j] <= 1.0F) { + i += 1 + this.random.nextInt(3); + } + } + + return i; + } else { + return this.b; + } + } + + public void q() { + for (int i = 0; i < 20; ++i) { + double d0 = this.random.nextGaussian() * 0.02D; + double d1 = this.random.nextGaussian() * 0.02D; + double d2 = this.random.nextGaussian() * 0.02D; + double d3 = 10.0D; + + this.world.addParticle("explode", this.locX + (double) (this.random.nextFloat() * this.width * 2.0F) - (double) this.width - d0 * d3, this.locY + (double) (this.random.nextFloat() * this.length) - d1 * d3, this.locZ + (double) (this.random.nextFloat() * this.width * 2.0F) - (double) this.width - d2 * d3, d0, d1, d2); + } + } + + public void l_() { + super.l_(); + if (!this.world.isStatic) { + this.bB(); + } + } + + protected float f(float f, float f1) { + if (this.bb()) { + this.bn.a(); + return f1; + } else { + return super.f(f, f1); + } + } + + protected String r() { + return null; + } + + protected int getLootId() { + return 0; + } + + protected void dropDeathLoot(boolean flag, int i) { + // CraftBukkit start - Whole method + List<org.bukkit.inventory.ItemStack> loot = new java.util.ArrayList<org.bukkit.inventory.ItemStack>(); + int j = this.getLootId(); + + if (j > 0) { + int k = this.random.nextInt(3); + + if (i > 0) { + k += this.random.nextInt(i + 1); + } + + if (k > 0) { + loot.add(new org.bukkit.inventory.ItemStack(j, k)); + } + } + + // Determine rare item drops and add them to the loot + if (this.lastDamageByPlayerTime > 0) { + int k = this.random.nextInt(200) - i; + + if (k < 5) { + ItemStack itemstack = this.l(k <= 0 ? 1 : 0); + if (itemstack != null) { + loot.add(org.bukkit.craftbukkit.inventory.CraftItemStack.asCraftMirror(itemstack)); + } + } + } + + CraftEventFactory.callEntityDeathEvent(this, loot); // raise event even for those times when the entity does not drop loot + // CraftBukkit end + } + + public void b(NBTTagCompound nbttagcompound) { + super.b(nbttagcompound); + nbttagcompound.setBoolean("CanPickUpLoot", this.bz()); + nbttagcompound.setBoolean("PersistenceRequired", this.persistent); + NBTTagList nbttaglist = new NBTTagList(); + + NBTTagCompound nbttagcompound1; + + for (int i = 0; i < this.equipment.length; ++i) { + nbttagcompound1 = new NBTTagCompound(); + if (this.equipment[i] != null) { + this.equipment[i].save(nbttagcompound1); + } + + nbttaglist.add(nbttagcompound1); + } + + nbttagcompound.set("Equipment", nbttaglist); + NBTTagList nbttaglist1 = new NBTTagList(); + + for (int j = 0; j < this.dropChances.length; ++j) { + nbttaglist1.add(new NBTTagFloat(j + "", this.dropChances[j])); + } + + nbttagcompound.set("DropChances", nbttaglist1); + nbttagcompound.setString("CustomName", this.getCustomName()); + nbttagcompound.setBoolean("CustomNameVisible", this.getCustomNameVisible()); + nbttagcompound.setBoolean("Leashed", this.bv); + if (this.bw != null) { + nbttagcompound1 = new NBTTagCompound("Leash"); + if (this.bw instanceof EntityLiving) { + nbttagcompound1.setLong("UUIDMost", this.bw.getUniqueID().getMostSignificantBits()); + nbttagcompound1.setLong("UUIDLeast", this.bw.getUniqueID().getLeastSignificantBits()); + } else if (this.bw instanceof EntityHanging) { + EntityHanging entityhanging = (EntityHanging) this.bw; + + nbttagcompound1.setInt("X", entityhanging.x); + nbttagcompound1.setInt("Y", entityhanging.y); + nbttagcompound1.setInt("Z", entityhanging.z); + } + + nbttagcompound.set("Leash", nbttagcompound1); + } + } + + public void a(NBTTagCompound nbttagcompound) { + super.a(nbttagcompound); + this.h(nbttagcompound.getBoolean("CanPickUpLoot")); + this.persistent = nbttagcompound.getBoolean("PersistenceRequired"); + + // CraftBukkit start - If looting or persistence is false only use it if it was set after we started using it + boolean data = nbttagcompound.getBoolean("CanPickUpLoot"); + if (isLevelAtLeast(nbttagcompound, 1) || data) { + this.canPickUpLoot = data; + } + + data = nbttagcompound.getBoolean("PersistenceRequired"); + if (isLevelAtLeast(nbttagcompound, 1) || data) { + this.persistent = data; + } + // CraftBukkit end + + if (nbttagcompound.hasKey("CustomName") && nbttagcompound.getString("CustomName").length() > 0) { + this.setCustomName(nbttagcompound.getString("CustomName")); + } + + this.setCustomNameVisible(nbttagcompound.getBoolean("CustomNameVisible")); + NBTTagList nbttaglist; + int i; + + if (nbttagcompound.hasKey("Equipment")) { + nbttaglist = nbttagcompound.getList("Equipment"); + + for (i = 0; i < this.equipment.length; ++i) { + this.equipment[i] = ItemStack.createStack((NBTTagCompound) nbttaglist.get(i)); + } + } + + if (nbttagcompound.hasKey("DropChances")) { + nbttaglist = nbttagcompound.getList("DropChances"); + + for (i = 0; i < nbttaglist.size(); ++i) { + this.dropChances[i] = ((NBTTagFloat) nbttaglist.get(i)).data; + } + } + + this.bv = nbttagcompound.getBoolean("Leashed"); + if (this.bv && nbttagcompound.hasKey("Leash")) { + this.bx = nbttagcompound.getCompound("Leash"); + } + } + + public void n(float f) { + this.bf = f; + } + + public void i(float f) { + super.i(f); + this.n(f); + } + + public void c() { + super.c(); + this.world.methodProfiler.a("looting"); + if (!this.world.isStatic && this.bz() && !this.aU && this.world.getGameRules().getBoolean("mobGriefing")) { + List list = this.world.a(EntityItem.class, this.boundingBox.grow(1.0D, 0.0D, 1.0D)); + Iterator iterator = list.iterator(); + + while (iterator.hasNext()) { + EntityItem entityitem = (EntityItem) iterator.next(); + + if (!entityitem.dead && entityitem.getItemStack() != null) { + ItemStack itemstack = entityitem.getItemStack(); + int i = b(itemstack); + + if (i > -1) { + boolean flag = true; + ItemStack itemstack1 = this.getEquipment(i); + + if (itemstack1 != null) { + if (i == 0) { + if (itemstack.getItem() instanceof ItemSword && !(itemstack1.getItem() instanceof ItemSword)) { + flag = true; + } else if (itemstack.getItem() instanceof ItemSword && itemstack1.getItem() instanceof ItemSword) { + ItemSword itemsword = (ItemSword) itemstack.getItem(); + ItemSword itemsword1 = (ItemSword) itemstack1.getItem(); + + if (itemsword.g() == itemsword1.g()) { + flag = itemstack.getData() > itemstack1.getData() || itemstack.hasTag() && !itemstack1.hasTag(); + } else { + flag = itemsword.g() > itemsword1.g(); + } + } else { + flag = false; + } + } else if (itemstack.getItem() instanceof ItemArmor && !(itemstack1.getItem() instanceof ItemArmor)) { + flag = true; + } else if (itemstack.getItem() instanceof ItemArmor && itemstack1.getItem() instanceof ItemArmor) { + ItemArmor itemarmor = (ItemArmor) itemstack.getItem(); + ItemArmor itemarmor1 = (ItemArmor) itemstack1.getItem(); + + if (itemarmor.c == itemarmor1.c) { + flag = itemstack.getData() > itemstack1.getData() || itemstack.hasTag() && !itemstack1.hasTag(); + } else { + flag = itemarmor.c > itemarmor1.c; + } + } else { + flag = false; + } + } + + if (flag) { + if (itemstack1 != null && this.random.nextFloat() - 0.1F < this.dropChances[i]) { + this.a(itemstack1, 0.0F); + } + + this.setEquipment(i, itemstack); + this.dropChances[i] = 2.0F; + this.persistent = true; + this.receive(entityitem, 1); + entityitem.die(); + } + } + } + } + } + + this.world.methodProfiler.b(); + } + + protected boolean bb() { + return false; + } + + protected boolean isTypeNotPersistent() { + return true; + } + + protected void bk() { + if (this.persistent) { + this.aV = 0; + } else { + EntityHuman entityhuman = this.world.findNearbyPlayer(this, -1.0D); + + if (entityhuman != null) { + double d0 = entityhuman.locX - this.locX; + double d1 = entityhuman.locY - this.locY; + double d2 = entityhuman.locZ - this.locZ; + double d3 = d0 * d0 + d1 * d1 + d2 * d2; + + if (d3 > 16384.0D) { // CraftBukkit - remove isTypeNotPersistent() check + this.die(); + } + + if (this.aV > 600 && this.random.nextInt(800) == 0 && d3 > 1024.0D) { // CraftBukkit - remove isTypeNotPersistent() check + this.die(); + } else if (d3 < 1024.0D) { + this.aV = 0; + } + } + } + } + + protected void be() { + ++this.aV; + this.world.methodProfiler.a("checkDespawn"); + this.bk(); + this.world.methodProfiler.b(); + this.world.methodProfiler.a("sensing"); + this.bq.a(); + this.world.methodProfiler.b(); + this.world.methodProfiler.a("targetSelector"); + this.targetSelector.a(); + this.world.methodProfiler.b(); + this.world.methodProfiler.a("goalSelector"); + this.goalSelector.a(); + this.world.methodProfiler.b(); + this.world.methodProfiler.a("navigation"); + this.navigation.f(); + this.world.methodProfiler.b(); + this.world.methodProfiler.a("mob tick"); + this.bg(); + this.world.methodProfiler.b(); + this.world.methodProfiler.a("controls"); + this.world.methodProfiler.a("move"); + this.moveController.c(); + this.world.methodProfiler.c("look"); + this.h.a(); + this.world.methodProfiler.c("jump"); + this.lookController.b(); + this.world.methodProfiler.b(); + this.world.methodProfiler.b(); + } + + protected void bh() { + super.bh(); + this.be = 0.0F; + this.bf = 0.0F; + this.bk(); + float f = 8.0F; + + if (this.random.nextFloat() < 0.02F) { + EntityHuman entityhuman = this.world.findNearbyPlayer(this, (double) f); + + if (entityhuman != null) { + this.bu = entityhuman; + this.g = 10 + this.random.nextInt(20); + } else { + this.bg = (this.random.nextFloat() - 0.5F) * 20.0F; + } + } + + if (this.bu != null) { + this.a(this.bu, 10.0F, (float) this.bl()); + if (this.g-- <= 0 || this.bu.dead || this.bu.e((Entity) this) > (double) (f * f)) { + this.bu = null; + } + } else { + if (this.random.nextFloat() < 0.05F) { + this.bg = (this.random.nextFloat() - 0.5F) * 20.0F; + } + + this.yaw += this.bg; + this.pitch = this.f; + } + + boolean flag = this.G(); + boolean flag1 = this.I(); + + if (flag || flag1) { + this.bd = this.random.nextFloat() < 0.8F; + } + } + + public int bl() { + return 40; + } + + public void a(Entity entity, float f, float f1) { + double d0 = entity.locX - this.locX; + double d1 = entity.locZ - this.locZ; + double d2; + + if (entity instanceof EntityLiving) { + EntityLiving entityliving = (EntityLiving) entity; + + d2 = entityliving.locY + (double) entityliving.getHeadHeight() - (this.locY + (double) this.getHeadHeight()); + } else { + d2 = (entity.boundingBox.b + entity.boundingBox.e) / 2.0D - (this.locY + (double) this.getHeadHeight()); + } + + double d3 = (double) MathHelper.sqrt(d0 * d0 + d1 * d1); + float f2 = (float) (Math.atan2(d1, d0) * 180.0D / 3.1415927410125732D) - 90.0F; + float f3 = (float) (-(Math.atan2(d2, d3) * 180.0D / 3.1415927410125732D)); + + this.pitch = this.b(this.pitch, f3, f1); + this.yaw = this.b(this.yaw, f2, f); + } + + private float b(float f, float f1, float f2) { + float f3 = MathHelper.g(f1 - f); + + if (f3 > f2) { + f3 = f2; + } + + if (f3 < -f2) { + f3 = -f2; + } + + return f + f3; + } + + public boolean canSpawn() { + return this.world.b(this.boundingBox) && this.world.getCubes(this, this.boundingBox).isEmpty() && !this.world.containsLiquid(this.boundingBox); + } + + public int br() { + return 4; + } + + public int aq() { + if (this.getGoalTarget() == null) { + return 3; + } else { + int i = (int) (this.getHealth() - this.maxHealth * 0.33F); // CraftBukkit - this.getMaxHealth() -> this.maxHealth + + i -= (3 - this.world.difficulty) * 4; + if (i < 0) { + i = 0; + } + + return i + 3; + } + } + + public ItemStack aV() { + return this.equipment[0]; + } + + public ItemStack getEquipment(int i) { + return this.equipment[i]; + } + + public ItemStack o(int i) { + return this.equipment[i + 1]; + } + + public void setEquipment(int i, ItemStack itemstack) { + this.equipment[i] = itemstack; + } + + public ItemStack[] getEquipment() { + return this.equipment; + } + + protected void dropEquipment(boolean flag, int i) { + for (int j = 0; j < this.getEquipment().length; ++j) { + ItemStack itemstack = this.getEquipment(j); + boolean flag1 = this.dropChances[j] > 1.0F; + + if (itemstack != null && (flag || flag1) && this.random.nextFloat() - (float) i * 0.01F < this.dropChances[j]) { + if (!flag1 && itemstack.g()) { + int k = Math.max(itemstack.l() - 25, 1); + int l = itemstack.l() - this.random.nextInt(this.random.nextInt(k) + 1); + + if (l > k) { + l = k; + } + + if (l < 1) { + l = 1; + } + + itemstack.setData(l); + } + + this.a(itemstack, 0.0F); + } + } + } + + protected void bs() { + if (this.random.nextFloat() < 0.15F * this.world.b(this.locX, this.locY, this.locZ)) { + int i = this.random.nextInt(2); + float f = this.world.difficulty == 3 ? 0.1F : 0.25F; + + if (this.random.nextFloat() < 0.095F) { + ++i; + } + + if (this.random.nextFloat() < 0.095F) { + ++i; + } + + if (this.random.nextFloat() < 0.095F) { + ++i; + } + + for (int j = 3; j >= 0; --j) { + ItemStack itemstack = this.o(j); + + if (j < 3 && this.random.nextFloat() < f) { + break; + } + + if (itemstack == null) { + Item item = a(j + 1, i); + + if (item != null) { + this.setEquipment(j + 1, new ItemStack(item)); + } + } + } + } + } + + public static int b(ItemStack itemstack) { + if (itemstack.id != Block.PUMPKIN.id && itemstack.id != Item.SKULL.id) { + if (itemstack.getItem() instanceof ItemArmor) { + switch (((ItemArmor) itemstack.getItem()).b) { + case 0: + return 4; + + case 1: + return 3; + + case 2: + return 2; + + case 3: + return 1; + } + } + + return 0; + } else { + return 4; + } + } + + public static Item a(int i, int j) { + switch (i) { + case 4: + if (j == 0) { + return Item.LEATHER_HELMET; + } else if (j == 1) { + return Item.GOLD_HELMET; + } else if (j == 2) { + return Item.CHAINMAIL_HELMET; + } else if (j == 3) { + return Item.IRON_HELMET; + } else if (j == 4) { + return Item.DIAMOND_HELMET; + } + + case 3: + if (j == 0) { + return Item.LEATHER_CHESTPLATE; + } else if (j == 1) { + return Item.GOLD_CHESTPLATE; + } else if (j == 2) { + return Item.CHAINMAIL_CHESTPLATE; + } else if (j == 3) { + return Item.IRON_CHESTPLATE; + } else if (j == 4) { + return Item.DIAMOND_CHESTPLATE; + } + + case 2: + if (j == 0) { + return Item.LEATHER_LEGGINGS; + } else if (j == 1) { + return Item.GOLD_LEGGINGS; + } else if (j == 2) { + return Item.CHAINMAIL_LEGGINGS; + } else if (j == 3) { + return Item.IRON_LEGGINGS; + } else if (j == 4) { + return Item.DIAMOND_LEGGINGS; + } + + case 1: + if (j == 0) { + return Item.LEATHER_BOOTS; + } else if (j == 1) { + return Item.GOLD_BOOTS; + } else if (j == 2) { + return Item.CHAINMAIL_BOOTS; + } else if (j == 3) { + return Item.IRON_BOOTS; + } else if (j == 4) { + return Item.DIAMOND_BOOTS; + } + + default: + return null; + } + } + + protected void bt() { + float f = this.world.b(this.locX, this.locY, this.locZ); + + if (this.aV() != null && this.random.nextFloat() < 0.25F * f) { + EnchantmentManager.a(this.random, this.aV(), (int) (5.0F + f * (float) this.random.nextInt(18))); + } + + for (int i = 0; i < 4; ++i) { + ItemStack itemstack = this.o(i); + + if (itemstack != null && this.random.nextFloat() < 0.5F * f) { + EnchantmentManager.a(this.random, itemstack, (int) (5.0F + f * (float) this.random.nextInt(18))); + } + } + } + + public GroupDataEntity a(GroupDataEntity groupdataentity) { + this.a(GenericAttributes.b).a(new AttributeModifier("Random spawn bonus", this.random.nextGaussian() * 0.05D, 1)); + return groupdataentity; + } + + public boolean bu() { + return false; + } + + public String getLocalizedName() { + return this.hasCustomName() ? this.getCustomName() : super.getLocalizedName(); + } + + public void bv() { + this.persistent = true; + } + + public void setCustomName(String s) { + this.datawatcher.watch(10, s); + } + + public String getCustomName() { + return this.datawatcher.getString(10); + } + + public boolean hasCustomName() { + return this.datawatcher.getString(10).length() > 0; + } + + public void setCustomNameVisible(boolean flag) { + this.datawatcher.watch(11, Byte.valueOf((byte) (flag ? 1 : 0))); + } + + public boolean getCustomNameVisible() { + return this.datawatcher.getByte(11) == 1; + } + + public void a(int i, float f) { + this.dropChances[i] = f; + } + + public boolean bz() { + return this.canPickUpLoot; + } + + public void h(boolean flag) { + this.canPickUpLoot = flag; + } + + public boolean bA() { + return this.persistent; + } + + public final boolean c(EntityHuman entityhuman) { + if (this.bD() && this.bE() == entityhuman) { + this.i(true); + return true; + } else { + ItemStack itemstack = entityhuman.inventory.getItemInHand(); + + if (itemstack != null && itemstack.id == Item.LEASH.id && this.bC()) { + if (!(this instanceof EntityTameableAnimal) || !((EntityTameableAnimal) this).isTamed()) { + this.b(entityhuman, true); + --itemstack.count; + return true; + } + + if (entityhuman.getName().equalsIgnoreCase(((EntityTameableAnimal) this).getOwnerName())) { + this.b(entityhuman, true); + --itemstack.count; + return true; + } + } + + return this.a(entityhuman) ? true : super.c(entityhuman); + } + } + + protected boolean a(EntityHuman entityhuman) { + return false; + } + + protected void bB() { + if (this.bx != null) { + this.bF(); + } + + if (this.bv) { + if (this.bw == null || this.bw.dead) { + this.i(true); + } + } + } + + public void i(boolean flag) { + if (this.bv) { + this.bv = false; + this.bw = null; + if (!this.world.isStatic) { + this.b(Item.LEASH.id, 1); + } + + if (!this.world.isStatic && flag && this.world instanceof WorldServer) { + ((WorldServer) this.world).getTracker().a((Entity) this, (Packet) (new Packet39AttachEntity(1, this, (Entity) null))); + } + } + } + + public boolean bC() { + return !this.bD() && !(this instanceof IMonster); + } + + public boolean bD() { + return this.bv; + } + + public Entity bE() { + return this.bw; + } + + public void b(Entity entity, boolean flag) { + this.bv = true; + this.bw = entity; + if (!this.world.isStatic && flag && this.world instanceof WorldServer) { + ((WorldServer) this.world).getTracker().a((Entity) this, (Packet) (new Packet39AttachEntity(1, this, this.bw))); + } + } + + private void bF() { + if (this.bv && this.bx != null) { + if (this.bx.hasKey("UUIDMost") && this.bx.hasKey("UUIDLeast")) { + UUID uuid = new UUID(this.bx.getLong("UUIDMost"), this.bx.getLong("UUIDLeast")); + List list = this.world.a(EntityLiving.class, this.boundingBox.grow(10.0D, 10.0D, 10.0D)); + Iterator iterator = list.iterator(); + + while (iterator.hasNext()) { + EntityLiving entityliving = (EntityLiving) iterator.next(); + + if (entityliving.getUniqueID().equals(uuid)) { + this.bw = entityliving; + break; + } + } + } else if (this.bx.hasKey("X") && this.bx.hasKey("Y") && this.bx.hasKey("Z")) { + int i = this.bx.getInt("X"); + int j = this.bx.getInt("Y"); + int k = this.bx.getInt("Z"); + EntityLeash entityleash = EntityLeash.b(this.world, i, j, k); + + if (entityleash == null) { + entityleash = EntityLeash.a(this.world, i, j, k); + } + + this.bw = entityleash; + } else { + this.i(false); + } + } + + this.bx = null; + } +} diff --git a/src/main/java/net/minecraft/server/EntityIronGolem.java b/src/main/java/net/minecraft/server/EntityIronGolem.java index d2c5857e..35826769 100644 --- a/src/main/java/net/minecraft/server/EntityIronGolem.java +++ b/src/main/java/net/minecraft/server/EntityIronGolem.java @@ -4,27 +4,26 @@ import org.bukkit.craftbukkit.inventory.CraftItemStack; // CraftBukkit public class EntityIronGolem extends EntityGolem { - private int e = 0; - Village d = null; - private int f; - private int g; + private int bq; + Village bp; + private int br; + private int bs; public EntityIronGolem(World world) { super(world); - this.texture = "/mob/villager_golem.png"; this.a(1.4F, 2.9F); this.getNavigation().a(true); - this.goalSelector.a(1, new PathfinderGoalMeleeAttack(this, 0.25F, true)); - this.goalSelector.a(2, new PathfinderGoalMoveTowardsTarget(this, 0.22F, 32.0F)); - this.goalSelector.a(3, new PathfinderGoalMoveThroughVillage(this, 0.16F, true)); - this.goalSelector.a(4, new PathfinderGoalMoveTowardsRestriction(this, 0.16F)); + this.goalSelector.a(1, new PathfinderGoalMeleeAttack(this, 1.0D, true)); + this.goalSelector.a(2, new PathfinderGoalMoveTowardsTarget(this, 0.9D, 32.0F)); + this.goalSelector.a(3, new PathfinderGoalMoveThroughVillage(this, 0.6D, true)); + this.goalSelector.a(4, new PathfinderGoalMoveTowardsRestriction(this, 1.0D)); this.goalSelector.a(5, new PathfinderGoalOfferFlower(this)); - this.goalSelector.a(6, new PathfinderGoalRandomStroll(this, 0.16F)); + this.goalSelector.a(6, new PathfinderGoalRandomStroll(this, 0.6D)); this.goalSelector.a(7, new PathfinderGoalLookAtPlayer(this, EntityHuman.class, 6.0F)); this.goalSelector.a(8, new PathfinderGoalRandomLookaround(this)); this.targetSelector.a(1, new PathfinderGoalDefendVillage(this)); this.targetSelector.a(2, new PathfinderGoalHurtByTarget(this, false)); - this.targetSelector.a(3, new PathfinderGoalNearestAttackableTarget(this, EntityLiving.class, 16.0F, 0, false, true, IMonster.a)); + this.targetSelector.a(3, new PathfinderGoalNearestAttackableTarget(this, EntityInsentient.class, 0, false, true, IMonster.a)); } protected void a() { @@ -32,50 +31,52 @@ public class EntityIronGolem extends EntityGolem { this.datawatcher.a(16, Byte.valueOf((byte) 0)); } - public boolean bh() { + public boolean bb() { return true; } - protected void bp() { - if (--this.e <= 0) { - this.e = 70 + this.random.nextInt(50); - this.d = this.world.villages.getClosestVillage(MathHelper.floor(this.locX), MathHelper.floor(this.locY), MathHelper.floor(this.locZ), 32); - if (this.d == null) { - this.aO(); + protected void bg() { + if (--this.bq <= 0) { + this.bq = 70 + this.random.nextInt(50); + this.bp = this.world.villages.getClosestVillage(MathHelper.floor(this.locX), MathHelper.floor(this.locY), MathHelper.floor(this.locZ), 32); + if (this.bp == null) { + this.bN(); } else { - ChunkCoordinates chunkcoordinates = this.d.getCenter(); + ChunkCoordinates chunkcoordinates = this.bp.getCenter(); - this.b(chunkcoordinates.x, chunkcoordinates.y, chunkcoordinates.z, (int) ((float) this.d.getSize() * 0.6F)); + this.b(chunkcoordinates.x, chunkcoordinates.y, chunkcoordinates.z, (int) ((float) this.bp.getSize() * 0.6F)); } } - super.bp(); + super.bg(); } - public int getMaxHealth() { - return 100; + protected void ax() { + super.ax(); + this.a(GenericAttributes.a).a(100.0D); + this.a(GenericAttributes.d).a(0.25D); } protected int h(int i) { return i; } - protected void o(Entity entity) { - if (entity instanceof IMonster && this.aE().nextInt(20) == 0) { + protected void n(Entity entity) { + if (entity instanceof IMonster && this.aB().nextInt(20) == 0) { this.setGoalTarget((EntityLiving) entity); } - super.o(entity); + super.n(entity); } public void c() { super.c(); - if (this.f > 0) { - --this.f; + if (this.br > 0) { + --this.br; } - if (this.g > 0) { - --this.g; + if (this.bs > 0) { + --this.bs; } if (this.motX * this.motX + this.motZ * this.motZ > 2.500000277905201E-7D && this.random.nextInt(5) == 0) { @@ -91,12 +92,12 @@ public class EntityIronGolem extends EntityGolem { } public boolean a(Class oclass) { - return this.p() && EntityHuman.class.isAssignableFrom(oclass) ? false : super.a(oclass); + return this.bS() && EntityHuman.class.isAssignableFrom(oclass) ? false : super.a(oclass); } public void b(NBTTagCompound nbttagcompound) { super.b(nbttagcompound); - nbttagcompound.setBoolean("PlayerCreated", this.p()); + nbttagcompound.setBoolean("PlayerCreated", this.bS()); } public void a(NBTTagCompound nbttagcompound) { @@ -105,9 +106,9 @@ public class EntityIronGolem extends EntityGolem { } public boolean m(Entity entity) { - this.f = 10; + this.br = 10; this.world.broadcastEntityEffect(this, (byte) 4); - boolean flag = entity.damageEntity(DamageSource.mobAttack(this), 7 + this.random.nextInt(15)); + boolean flag = entity.damageEntity(DamageSource.mobAttack(this), (float) (7 + this.random.nextInt(15))); if (flag) { entity.motY += 0.4000000059604645D; @@ -117,24 +118,24 @@ public class EntityIronGolem extends EntityGolem { return flag; } - public Village m() { - return this.d; + public Village bP() { + return this.bp; } public void a(boolean flag) { - this.g = flag ? 400 : 0; + this.bs = flag ? 400 : 0; this.world.broadcastEntityEffect(this, (byte) 11); } - protected String bb() { + protected String r() { return "none"; } - protected String bc() { + protected String aK() { return "mob.irongolem.hit"; } - protected String bd() { + protected String aL() { return "mob.irongolem.death"; } @@ -163,11 +164,11 @@ public class EntityIronGolem extends EntityGolem { // CraftBukkit end } - public int o() { - return this.g; + public int bR() { + return this.bs; } - public boolean p() { + public boolean bS() { return (this.datawatcher.getByte(16) & 1) != 0; } @@ -182,8 +183,8 @@ public class EntityIronGolem extends EntityGolem { } public void die(DamageSource damagesource) { - if (!this.p() && this.killer != null && this.d != null) { - this.d.a(this.killer.getName(), -5); + if (!this.bS() && this.killer != null && this.bp != null) { + this.bp.a(this.killer.getName(), -5); } super.die(damagesource); diff --git a/src/main/java/net/minecraft/server/EntityItem.java b/src/main/java/net/minecraft/server/EntityItem.java index 0225f535..cb2b1143 100644 --- a/src/main/java/net/minecraft/server/EntityItem.java +++ b/src/main/java/net/minecraft/server/EntityItem.java @@ -14,7 +14,6 @@ public class EntityItem extends Entity { public EntityItem(World world, double d0, double d1, double d2) { super(world); - this.age = 0; this.d = 5; this.c = (float) (Math.random() * 3.141592653589793D * 2.0D); this.a(0.25F, 0.25F); @@ -36,13 +35,12 @@ public class EntityItem extends Entity { this.setItemStack(itemstack); } - protected boolean f_() { + protected boolean e_() { return false; } public EntityItem(World world) { super(world); - this.age = 0; this.d = 5; this.c = (float) (Math.random() * 3.141592653589793D * 2.0D); this.a(0.25F, 0.25F); @@ -79,7 +77,7 @@ public class EntityItem extends Entity { } if (!this.world.isStatic) { - this.g(); + this.e(); } } @@ -113,7 +111,7 @@ public class EntityItem extends Entity { } } - private void g() { + private void e() { Iterator iterator = this.world.a(EntityItem.class, this.boundingBox.grow(0.5D, 0.0D, 0.5D)).iterator(); while (iterator.hasNext()) { @@ -136,7 +134,7 @@ public class EntityItem extends Entity { return false; } else if (itemstack1.hasTag() && !itemstack1.getTag().equals(itemstack.getTag())) { return false; - } else if (itemstack1.getItem().m() && itemstack1.getData() != itemstack.getData()) { + } else if (itemstack1.getItem().n() && itemstack1.getData() != itemstack.getData()) { return false; } else if (itemstack1.count < itemstack.count) { return entityitem.a(this); @@ -164,17 +162,17 @@ public class EntityItem extends Entity { } protected void burn(int i) { - this.damageEntity(DamageSource.FIRE, i); + this.damageEntity(DamageSource.FIRE, (float) i); } - public boolean damageEntity(DamageSource damagesource, int i) { + public boolean damageEntity(DamageSource damagesource, float f) { if (this.isInvulnerable()) { return false; } else if (this.getItemStack() != null && this.getItemStack().id == Item.NETHER_STAR.id && damagesource.c()) { return false; } else { this.J(); - this.d -= i; + this.d = (int) ((float) this.d - f); if (this.d <= 0) { this.die(); } @@ -225,7 +223,7 @@ public class EntityItem extends Entity { if (this.pickupDelay <= 0 && canHold > 0) { itemstack.count = canHold; PlayerPickupItemEvent event = new PlayerPickupItemEvent((org.bukkit.entity.Player) entityhuman.getBukkitEntity(), (org.bukkit.entity.Item) this.getBukkitEntity(), remaining); - event.setCancelled(!entityhuman.canPickUpLoot); + // event.setCancelled(!entityhuman.canPickUpLoot); TODO this.world.getServer().getPluginManager().callEvent(event); itemstack.count = canHold + remaining; @@ -268,14 +266,14 @@ public class EntityItem extends Entity { return LocaleI18n.get("item." + this.getItemStack().a()); } - public boolean ap() { + public boolean ao() { return false; } - public void c(int i) { - super.c(i); + public void b(int i) { + super.b(i); if (!this.world.isStatic) { - this.g(); + this.e(); } } diff --git a/src/main/java/net/minecraft/server/EntityLargeFireball.java b/src/main/java/net/minecraft/server/EntityLargeFireball.java index 0aebd902..748acd81 100644 --- a/src/main/java/net/minecraft/server/EntityLargeFireball.java +++ b/src/main/java/net/minecraft/server/EntityLargeFireball.java @@ -17,7 +17,7 @@ public class EntityLargeFireball extends EntityFireball { protected void a(MovingObjectPosition movingobjectposition) { if (!this.world.isStatic) { if (movingobjectposition.entity != null) { - movingobjectposition.entity.damageEntity(DamageSource.fireball(this, this.shooter), 6); + movingobjectposition.entity.damageEntity(DamageSource.fireball(this, this.shooter), 6.0F); } // CraftBukkit start diff --git a/src/main/java/net/minecraft/server/EntityLightning.java b/src/main/java/net/minecraft/server/EntityLightning.java index 83c45101..a438d674 100644 --- a/src/main/java/net/minecraft/server/EntityLightning.java +++ b/src/main/java/net/minecraft/server/EntityLightning.java @@ -7,7 +7,7 @@ import org.bukkit.craftbukkit.event.CraftEventFactory; // CraftBukkit public class EntityLightning extends EntityWeather { private int lifeTicks; - public long a = 0L; + public long a; private int c; // CraftBukkit start @@ -32,7 +32,7 @@ public class EntityLightning extends EntityWeather { this.c = this.random.nextInt(3) + 1; // CraftBukkit - if (!isEffect && !world.isStatic && world.difficulty >= 2 && world.areChunksLoaded(MathHelper.floor(d0), MathHelper.floor(d1), MathHelper.floor(d2), 10)) { + if (!isEffect && !world.isStatic && world.getGameRules().getBoolean("doFireTick") && world.difficulty >= 2 && world.areChunksLoaded(MathHelper.floor(d0), MathHelper.floor(d1), MathHelper.floor(d2), 10)) { int i = MathHelper.floor(d0); int j = MathHelper.floor(d1); int k = MathHelper.floor(d2); @@ -77,7 +77,7 @@ public class EntityLightning extends EntityWeather { this.lifeTicks = 1; this.a = this.random.nextLong(); // CraftBukkit - if (!this.isEffect && !this.world.isStatic && this.world.areChunksLoaded(MathHelper.floor(this.locX), MathHelper.floor(this.locY), MathHelper.floor(this.locZ), 10)) { + if (!isEffect && !this.world.isStatic && this.world.getGameRules().getBoolean("doFireTick") && this.world.areChunksLoaded(MathHelper.floor(this.locX), MathHelper.floor(this.locY), MathHelper.floor(this.locZ), 10)) { int i = MathHelper.floor(this.locX); int j = MathHelper.floor(this.locY); int k = MathHelper.floor(this.locZ); diff --git a/src/main/java/net/minecraft/server/EntityLiving.java b/src/main/java/net/minecraft/server/EntityLiving.java index 965e6ce4..0d9ba820 100644 --- a/src/main/java/net/minecraft/server/EntityLiving.java +++ b/src/main/java/net/minecraft/server/EntityLiving.java @@ -5,7 +5,7 @@ import java.util.HashMap; import java.util.Iterator; import java.util.List; import java.util.Random; -import java.util.concurrent.Callable; +import java.util.UUID; // CraftBukkit start import org.bukkit.craftbukkit.event.CraftEventFactory; @@ -16,206 +16,100 @@ import org.bukkit.event.entity.EntityRegainHealthEvent; public abstract class EntityLiving extends Entity { - private static final float[] b = new float[] { 0.0F, 0.0F, 0.1F, 0.2F}; - private static final float[] c = new float[] { 0.0F, 0.0F, 0.25F, 0.5F}; - private static final float[] d = new float[] { 0.0F, 0.0F, 0.05F, 0.07F}; - public static final float[] au = new float[] { 0.0F, 0.1F, 0.15F, 0.45F}; - public int maxNoDamageTicks = 20; - public float aw; + private static final UUID b = UUID.fromString("662A6B8D-DA3E-4C1C-8813-96EA6097278D"); + private static final AttributeModifier c = (new AttributeModifier(b, "Sprinting speed boost", 0.30000001192092896D, 2)).a(false); + private AttributeMapBase d; + public CombatTracker combatTracker = new CombatTracker(this); // CraftBukkit - private -> public, remove final + public final HashMap effects = new HashMap(); // CraftBukkit - protected -> public + private final ItemStack[] g = new ItemStack[5]; + public boolean au; + public int av; + public int aw; public float ax; - public float ay = 0.0F; - public float az = 0.0F; - public float aA = 0.0F; - public float aB = 0.0F; - protected float aC; - protected float aD; - protected float aE; - protected float aF; - protected boolean aG = true; - protected String texture = "/mob/char.png"; - protected boolean aI = true; - protected float aJ = 0.0F; - protected String aK = null; - protected float aL = 1.0F; - protected int aM = 0; - protected float aN = 0.0F; - public float aO = 0.1F; - public float aP = 0.02F; - public float aQ; - public float aR; - protected int health = this.getMaxHealth(); - public int aT; - protected int aU; - public int aV; public int hurtTicks; - public int aX; - public float aY = 0.0F; - public int deathTicks = 0; - public int attackTicks = 0; - public float bb; - public float bc; - protected boolean bd = false; - protected int be; - public int bf = -1; - public float bg = (float) (Math.random() * 0.8999999761581421D + 0.10000000149011612D); - public float bh; - public float bi; - public float bj; - public EntityHuman killer = null; // CraftBukkit - protected -> public - protected int lastDamageByPlayerTime = 0; - public EntityLiving lastDamager = null; // CraftBukkit - private -> public - private int f = 0; - private EntityLiving g = null; - public int bm = 0; - public HashMap effects = new HashMap(); // CraftBukkit - protected -> public + public int az; + public float aA; + public int deathTicks; + public int attackTicks; + public float aD; + public float aE; + public float aF; + public float aG; + public float aH; + public int maxNoDamageTicks = 20; + public float aJ; + public float aK; + public float aL; + public float aM; + public float aN; + public float aO; + public float aP; + public float aQ; + public float aR = 0.02F; + public EntityHuman killer; // CraftBukkit - protected -> public + protected int lastDamageByPlayerTime; + protected boolean aU; + protected int aV; + protected float aW; + protected float aX; + protected float aY; + protected float aZ; + protected float ba; + protected int bb; + public float lastDamage; // CraftBukkit - protected -> public + protected boolean bd; + public float be; + public float bf; + protected float bg; + protected int bh; + protected double bi; + protected double bj; + protected double bk; + protected double bl; + protected double bm; public boolean updateEffects = true; // CraftBukkit - private -> public - private int i; - private ControllerLook lookController; - private ControllerMove moveController; - private ControllerJump jumpController; - private EntityAIBodyControl senses; - private Navigation navigation; - protected final PathfinderGoalSelector goalSelector; - protected final PathfinderGoalSelector targetSelector; - private EntityLiving goalTarget; - private EntitySenses bP; - private float bQ; - private ChunkCoordinates bR = new ChunkCoordinates(0, 0, 0); - private float bS = -1.0F; - private ItemStack[] equipment = new ItemStack[5]; - public float[] dropChances = new float[5]; // CraftBukkit - protected -> public - private ItemStack[] bU = new ItemStack[5]; - public boolean br = false; - public int bs = 0; - public boolean canPickUpLoot = false; // CraftBukkit - protected -> public - public boolean persistent = !this.isTypeNotPersistent(); // CraftBukkit - private -> public, change value - protected CombatTracker bt = new CombatTracker(this); // CraftBukkit - remove final - protected int bu; - protected double bv; - protected double bw; - protected double bx; - protected double by; - protected double bz; - float bA = 0.0F; - public int lastDamage = 0; // CraftBukkit - protected -> public - protected int bC = 0; - protected float bD; - protected float bE; - protected float bF; - protected boolean bG = false; - protected float bH = 0.0F; - protected float bI = 0.7F; - private int bX = 0; - private Entity bY; - protected int bJ = 0; + public EntityLiving lastDamager; // CraftBukkit - private -> public + private int j; + private EntityLiving bn; + private float bo; + private int bp; + private float bq; // CraftBukkit start - public int expToDrop = 0; + public int expToDrop; public int maxAirTicks = 300; - public int maxHealth = this.getMaxHealth(); + public float maxHealth; // CraftBukkit end public EntityLiving(World world) { super(world); + this.ax(); + this.setHealth(this.getMaxHealth()); this.m = true; - this.goalSelector = new PathfinderGoalSelector(world != null && world.methodProfiler != null ? world.methodProfiler : null); - this.targetSelector = new PathfinderGoalSelector(world != null && world.methodProfiler != null ? world.methodProfiler : null); - this.lookController = new ControllerLook(this); - this.moveController = new ControllerMove(this); - this.jumpController = new ControllerJump(this); - this.senses = new EntityAIBodyControl(this); - this.navigation = new Navigation(this, world, (float) this.ay()); - this.bP = new EntitySenses(this); - this.ax = (float) (Math.random() + 1.0D) * 0.01F; + this.aM = (float) (Math.random() + 1.0D) * 0.01F; this.setPosition(this.locX, this.locY, this.locZ); - this.aw = (float) Math.random() * 12398.0F; + this.aL = (float) Math.random() * 12398.0F; this.yaw = (float) (Math.random() * 3.1415927410125732D * 2.0D); - this.aA = this.yaw; - - for (int i = 0; i < this.dropChances.length; ++i) { - this.dropChances[i] = 0.085F; - } - + this.aP = this.yaw; this.Y = 0.5F; + maxHealth = this.getMaxHealth(); // CraftBukkit - We can't initialize maxHealth until this.ax() has been invoked. } - protected int ay() { - return 16; - } - - public ControllerLook getControllerLook() { - return this.lookController; - } - - public ControllerMove getControllerMove() { - return this.moveController; - } - - public ControllerJump getControllerJump() { - return this.jumpController; - } - - public Navigation getNavigation() { - return this.navigation; - } - - public EntitySenses getEntitySenses() { - return this.bP; - } - - public Random aE() { - return this.random; - } - - public EntityLiving aF() { - return this.lastDamager; - } - - public EntityLiving aG() { - return this.g; + protected void a() { + this.datawatcher.a(7, Integer.valueOf(0)); + this.datawatcher.a(8, Byte.valueOf((byte) 0)); + this.datawatcher.a(9, Byte.valueOf((byte) 0)); + this.datawatcher.a(6, Float.valueOf(1.0F)); } - public void l(Entity entity) { - if (entity instanceof EntityLiving) { - this.g = (EntityLiving) entity; + protected void ax() { + this.aT().b(GenericAttributes.a); + this.aT().b(GenericAttributes.c); + this.aT().b(GenericAttributes.d); + if (!this.bb()) { + this.a(GenericAttributes.d).a(0.10000000149011612D); } } - public int aH() { - return this.bC; - } - - public float getHeadRotation() { - return this.aA; - } - - public float aI() { - return this.bQ; - } - - public void e(float f) { - this.bQ = f; - this.f(f); - } - - public boolean m(Entity entity) { - this.l(entity); - return false; - } - - public EntityLiving getGoalTarget() { - return this.goalTarget; - } - - public void setGoalTarget(EntityLiving entityliving) { - this.goalTarget = entityliving; - } - - public boolean a(Class oclass) { - return EntityCreeper.class != oclass && EntityGhast.class != oclass; - } - - public void aK() {} - protected void a(double d0, boolean flag) { if (!this.G()) { this.H(); @@ -243,87 +137,16 @@ public abstract class EntityLiving extends Entity { super.a(d0, flag); } - public boolean aL() { - return this.d(MathHelper.floor(this.locX), MathHelper.floor(this.locY), MathHelper.floor(this.locZ)); - } - - public boolean d(int i, int j, int k) { - return this.bS == -1.0F ? true : this.bR.e(i, j, k) < this.bS * this.bS; - } - - public void b(int i, int j, int k, int l) { - this.bR.b(i, j, k); - this.bS = (float) l; - } - - public ChunkCoordinates aM() { - return this.bR; - } - - public float aN() { - return this.bS; - } - - public void aO() { - this.bS = -1.0F; - } - - public boolean aP() { - return this.bS != -1.0F; - } - - public void c(EntityLiving entityliving) { - this.lastDamager = entityliving; - this.f = this.lastDamager != null ? 100 : 0; - } - - protected void a() { - this.datawatcher.a(8, Integer.valueOf(this.i)); - this.datawatcher.a(9, Byte.valueOf((byte) 0)); - this.datawatcher.a(10, Byte.valueOf((byte) 0)); - this.datawatcher.a(6, Byte.valueOf((byte) 0)); - this.datawatcher.a(5, ""); - } - - public boolean n(Entity entity) { - return this.world.a(this.world.getVec3DPool().create(this.locX, this.locY + (double) this.getHeadHeight(), this.locZ), this.world.getVec3DPool().create(entity.locX, entity.locY + (double) entity.getHeadHeight(), entity.locZ)) == null; - } - - public boolean K() { - return !this.dead; - } - - public boolean L() { - return !this.dead; - } - - public float getHeadHeight() { - return this.length * 0.85F; - } - - public int aQ() { - return 80; - } - - public void aR() { - String s = this.bb(); - - if (s != null) { - this.makeSound(s, this.ba(), this.aY()); - } + public boolean ay() { + return false; } public void x() { - this.aQ = this.aR; + this.aD = this.aE; super.x(); - this.world.methodProfiler.a("mobBaseTick"); - if (this.isAlive() && this.random.nextInt(1000) < this.aV++) { - this.aV = -this.aQ(); - this.aR(); - } - + this.world.methodProfiler.a("livingEntityBaseTick"); if (this.isAlive() && this.inBlock()) { - this.damageEntity(DamageSource.STUCK, 1); + this.damageEntity(DamageSource.STUCK, 1.0F); } if (this.isFireproof() || this.world.isStatic) { @@ -332,23 +155,28 @@ public abstract class EntityLiving extends Entity { boolean flag = this instanceof EntityHuman && ((EntityHuman) this).abilities.isInvulnerable; - if (this.isAlive() && this.a(Material.WATER) && !this.bf() && !this.effects.containsKey(Integer.valueOf(MobEffectList.WATER_BREATHING.id)) && !flag) { - this.setAirTicks(this.h(this.getAirTicks())); - if (this.getAirTicks() == -20) { - this.setAirTicks(0); + if (this.isAlive() && this.a(Material.WATER)) { + if (!this.ay() && !this.hasEffect(MobEffectList.WATER_BREATHING.id) && !flag) { + this.setAirTicks(this.h(this.getAirTicks())); + if (this.getAirTicks() == -20) { + this.setAirTicks(0); - for (int i = 0; i < 8; ++i) { - float f = this.random.nextFloat() - this.random.nextFloat(); - float f1 = this.random.nextFloat() - this.random.nextFloat(); - float f2 = this.random.nextFloat() - this.random.nextFloat(); + for (int i = 0; i < 8; ++i) { + float f = this.random.nextFloat() - this.random.nextFloat(); + float f1 = this.random.nextFloat() - this.random.nextFloat(); + float f2 = this.random.nextFloat() - this.random.nextFloat(); - this.world.addParticle("bubble", this.locX + (double) f, this.locY + (double) f1, this.locZ + (double) f2, this.motX, this.motY, this.motZ); - } + this.world.addParticle("bubble", this.locX + (double) f, this.locY + (double) f1, this.locZ + (double) f2, this.motX, this.motY, this.motZ); + } - this.damageEntity(DamageSource.DROWN, 2); + this.damageEntity(DamageSource.DROWN, 2.0F); + } } this.extinguish(); + if (!this.world.isStatic && this.ae() && this.vehicle instanceof EntityLiving) { + this.mount((Entity) null); + } } else { // CraftBukkit start - Only set if needed to work around a DataWatcher inefficiency if (this.getAirTicks() != 300) { @@ -357,7 +185,7 @@ public abstract class EntityLiving extends Entity { // CraftBukkit end } - this.bb = this.bc; + this.aJ = this.aK; if (this.attackTicks > 0) { --this.attackTicks; } @@ -370,8 +198,8 @@ public abstract class EntityLiving extends Entity { --this.noDamageTicks; } - if (this.health <= 0) { - this.aS(); + if (this.getHealth() <= 0.0F) { + this.az(); } if (this.lastDamageByPlayerTime > 0) { @@ -380,24 +208,24 @@ public abstract class EntityLiving extends Entity { this.killer = null; } - if (this.g != null && !this.g.isAlive()) { - this.g = null; + if (this.bn != null && !this.bn.isAlive()) { + this.bn = null; } if (this.lastDamager != null) { if (!this.lastDamager.isAlive()) { - this.c((EntityLiving) null); - } else if (this.f > 0) { - --this.f; + this.b((EntityLiving) null); + } else if (this.j > 0) { + --this.j; } else { - this.c((EntityLiving) null); + this.b((EntityLiving) null); } } - this.bA(); - this.aF = this.aE; - this.az = this.ay; - this.aB = this.aA; + this.aF(); + this.aZ = this.aY; + this.aO = this.aN; + this.aQ = this.aP; this.lastYaw = this.yaw; this.lastPitch = this.pitch; this.world.methodProfiler.b(); @@ -414,7 +242,7 @@ public abstract class EntityLiving extends Entity { } } - public int getScaledHealth() { + public float getScaledHealth() { if (this.maxHealth != this.getMaxHealth() && this.getHealth() > 0) { return this.getHealth() * this.getMaxHealth() / this.maxHealth + 1; } else { @@ -423,7 +251,11 @@ public abstract class EntityLiving extends Entity { } // CraftBukkit end - protected void aS() { + public boolean isBaby() { + return false; + } + + protected void az() { ++this.deathTicks; if (this.deathTicks >= 20 && !this.dead) { // CraftBukkit - (this.deathTicks == 20) -> (this.deathTicks >= 20 && !this.dead) int i; @@ -458,253 +290,372 @@ public abstract class EntityLiving extends Entity { } protected int getExpValue(EntityHuman entityhuman) { - if (this.be > 0) { - int i = this.be; - ItemStack[] aitemstack = this.getEquipment(); - - for (int j = 0; j < aitemstack.length; ++j) { - if (aitemstack[j] != null && this.dropChances[j] <= 1.0F) { - i += 1 + this.random.nextInt(3); - } - } - - return i; - } else { - return this.be; - } + return 0; } protected boolean alwaysGivesExp() { return false; } - public void aU() { - for (int i = 0; i < 20; ++i) { - double d0 = this.random.nextGaussian() * 0.02D; - double d1 = this.random.nextGaussian() * 0.02D; - double d2 = this.random.nextGaussian() * 0.02D; - double d3 = 10.0D; + public Random aB() { + return this.random; + } + + public EntityLiving getLastDamager() { + return this.lastDamager; + } + + public void b(EntityLiving entityliving) { + this.lastDamager = entityliving; + this.j = this.lastDamager != null ? 100 : 0; + } + + public EntityLiving aD() { + return this.bn; + } - this.world.addParticle("explode", this.locX + (double) (this.random.nextFloat() * this.width * 2.0F) - (double) this.width - d0 * d3, this.locY + (double) (this.random.nextFloat() * this.length) - d1 * d3, this.locZ + (double) (this.random.nextFloat() * this.width * 2.0F) - (double) this.width - d2 * d3, d0, d1, d2); + public void k(Entity entity) { + if (entity instanceof EntityLiving) { + this.bn = (EntityLiving) entity; } } - public void T() { - super.T(); - this.aC = this.aD; - this.aD = 0.0F; - this.fallDistance = 0.0F; + public int aE() { + return this.aV; } - public void l_() { - super.l_(); - if (!this.world.isStatic) { - int i; + public void b(NBTTagCompound nbttagcompound) { + nbttagcompound.setFloat("HealF", this.getHealth()); + nbttagcompound.setShort("Health", (short) ((int) Math.ceil((double) this.getHealth()))); + nbttagcompound.setFloat("Bukkit.MaxHealth", this.maxHealth); // CraftBukkit + nbttagcompound.setShort("HurtTime", (short) this.hurtTicks); + nbttagcompound.setShort("DeathTime", (short) this.deathTicks); + nbttagcompound.setShort("AttackTime", (short) this.attackTicks); + nbttagcompound.setFloat("AbsorptionAmount", this.bj()); + ItemStack[] aitemstack = this.getEquipment(); + int i = aitemstack.length; - for (i = 0; i < 5; ++i) { - ItemStack itemstack = this.getEquipment(i); + int j; + ItemStack itemstack; - if (!ItemStack.matches(itemstack, this.bU[i])) { - ((WorldServer) this.world).getTracker().a((Entity) this, (Packet) (new Packet5EntityEquipment(this.id, i, itemstack))); - this.bU[i] = itemstack == null ? null : itemstack.cloneItemStack(); - } + for (j = 0; j < i; ++j) { + itemstack = aitemstack[j]; + if (itemstack != null) { + this.d.a(itemstack.D()); } + } - i = this.bM(); - if (i > 0) { - if (this.bm <= 0) { - this.bm = 20 * (30 - i); - } + nbttagcompound.set("Attributes", GenericAttributes.a(this.aT())); + aitemstack = this.getEquipment(); + i = aitemstack.length; - --this.bm; - if (this.bm <= 0) { - this.r(i - 1); - } + for (j = 0; j < i; ++j) { + itemstack = aitemstack[j]; + if (itemstack != null) { + this.d.b(itemstack.D()); } } - this.c(); - double d0 = this.locX - this.lastX; - double d1 = this.locZ - this.lastZ; - float f = (float) (d0 * d0 + d1 * d1); - float f1 = this.ay; - float f2 = 0.0F; + if (!this.effects.isEmpty()) { + NBTTagList nbttaglist = new NBTTagList(); + Iterator iterator = this.effects.values().iterator(); - this.aC = this.aD; - float f3 = 0.0F; + while (iterator.hasNext()) { + MobEffect mobeffect = (MobEffect) iterator.next(); - if (f > 0.0025000002F) { - f3 = 1.0F; - f2 = (float) Math.sqrt((double) f) * 3.0F; - // CraftBukkit - Math -> TrigMath - f1 = (float) org.bukkit.craftbukkit.TrigMath.atan2(d1, d0) * 180.0F / 3.1415927F - 90.0F; + nbttaglist.add(mobeffect.a(new NBTTagCompound())); + } + + nbttagcompound.set("ActiveEffects", nbttaglist); } + } - if (this.aR > 0.0F) { - f1 = this.yaw; + public void a(NBTTagCompound nbttagcompound) { + this.m(nbttagcompound.getFloat("AbsorptionAmount")); + if (nbttagcompound.hasKey("Attributes") && this.world != null && !this.world.isStatic) { + GenericAttributes.a(this.aT(), nbttagcompound.getList("Attributes"), this.world == null ? null : this.world.getLogger()); } - if (!this.onGround) { - f3 = 0.0F; + if (nbttagcompound.hasKey("ActiveEffects")) { + NBTTagList nbttaglist = nbttagcompound.getList("ActiveEffects"); + + for (int i = 0; i < nbttaglist.size(); ++i) { + NBTTagCompound nbttagcompound1 = (NBTTagCompound) nbttaglist.get(i); + MobEffect mobeffect = MobEffect.b(nbttagcompound1); + + this.effects.put(Integer.valueOf(mobeffect.getEffectId()), mobeffect); + } } - this.aD += (f3 - this.aD) * 0.3F; - this.world.methodProfiler.a("headTurn"); - if (this.bh()) { - this.senses.a(); + // CraftBukkit start + if (nbttagcompound.hasKey("Bukkit.MaxHealth")) { + NBTBase nbtbase = nbttagcompound.get("Bukkit.MaxHealth"); + if (nbtbase.getTypeId() == 5) { + this.maxHealth = ((NBTTagFloat) nbtbase).data; + } else if (nbtbase.getTypeId() == 3) { + this.maxHealth = (float) ((NBTTagInt) nbtbase).data; + } + } + // CraftBukkit end + + if (nbttagcompound.hasKey("HealF")) { + this.setHealth(nbttagcompound.getFloat("HealF")); } else { - float f4 = MathHelper.g(f1 - this.ay); + NBTBase nbtbase = nbttagcompound.get("Health"); + + if (nbtbase == null) { + this.setHealth(this.maxHealth); // CraftBukkit - this.getMaxHealth() -> this.maxHealth + } else if (nbtbase.getTypeId() == 5) { + this.setHealth(((NBTTagFloat) nbtbase).data); + } else if (nbtbase.getTypeId() == 2) { + this.setHealth((float) ((NBTTagShort) nbtbase).data); + } + } + + this.hurtTicks = nbttagcompound.getShort("HurtTime"); + this.deathTicks = nbttagcompound.getShort("DeathTime"); + this.attackTicks = nbttagcompound.getShort("AttackTime"); + } + + protected void aF() { + Iterator iterator = this.effects.keySet().iterator(); - this.ay += f4 * 0.3F; - float f5 = MathHelper.g(this.yaw - this.ay); - boolean flag = f5 < -90.0F || f5 >= 90.0F; + while (iterator.hasNext()) { + Integer integer = (Integer) iterator.next(); + MobEffect mobeffect = (MobEffect) this.effects.get(integer); - if (f5 < -75.0F) { - f5 = -75.0F; + if (!mobeffect.tick(this)) { + if (!this.world.isStatic) { + iterator.remove(); + this.c(mobeffect); + } + } else if (mobeffect.getDuration() % 600 == 0) { + this.b(mobeffect); } + } + + int i; - if (f5 >= 75.0F) { - f5 = 75.0F; + if (this.updateEffects) { + if (!this.world.isStatic) { + if (this.effects.isEmpty()) { + this.datawatcher.watch(8, Byte.valueOf((byte) 0)); + this.datawatcher.watch(7, Integer.valueOf(0)); + this.setInvisible(false); + } else { + i = PotionBrewer.a(this.effects.values()); + this.datawatcher.watch(8, Byte.valueOf((byte) (PotionBrewer.b(this.effects.values()) ? 1 : 0))); + this.datawatcher.watch(7, Integer.valueOf(i)); + this.setInvisible(this.hasEffect(MobEffectList.INVISIBILITY.id)); + } } - this.ay = this.yaw - f5; - if (f5 * f5 > 2500.0F) { - this.ay += f5 * 0.2F; + this.updateEffects = false; + } + + i = this.datawatcher.getInt(7); + boolean flag = this.datawatcher.getByte(8) > 0; + + if (i > 0) { + boolean flag1 = false; + + if (!this.isInvisible()) { + flag1 = this.random.nextBoolean(); + } else { + flag1 = this.random.nextInt(15) == 0; } if (flag) { - f2 *= -1.0F; + flag1 &= this.random.nextInt(5) == 0; } - } - this.world.methodProfiler.b(); - this.world.methodProfiler.a("rangeChecks"); + if (flag1 && i > 0) { + double d0 = (double) (i >> 16 & 255) / 255.0D; + double d1 = (double) (i >> 8 & 255) / 255.0D; + double d2 = (double) (i >> 0 & 255) / 255.0D; - while (this.yaw - this.lastYaw < -180.0F) { - this.lastYaw -= 360.0F; + this.world.addParticle(flag ? "mobSpellAmbient" : "mobSpell", this.locX + (this.random.nextDouble() - 0.5D) * (double) this.width, this.locY + this.random.nextDouble() * (double) this.length - (double) this.height, this.locZ + (this.random.nextDouble() - 0.5D) * (double) this.width, d0, d1, d2); + } } + } - while (this.yaw - this.lastYaw >= 180.0F) { - this.lastYaw += 360.0F; + public void aG() { + Iterator iterator = this.effects.keySet().iterator(); + + while (iterator.hasNext()) { + Integer integer = (Integer) iterator.next(); + MobEffect mobeffect = (MobEffect) this.effects.get(integer); + + if (!this.world.isStatic) { + iterator.remove(); + this.c(mobeffect); + } } + } + + public Collection getEffects() { + return this.effects.values(); + } + + public boolean hasEffect(int i) { + // CraftBukkit - Add size check for efficiency + return this.effects.size() != 0 && this.effects.containsKey(Integer.valueOf(i)); + } + + public boolean hasEffect(MobEffectList mobeffectlist) { + // CraftBukkit - Add size check for efficiency + return this.effects.size() != 0 && this.effects.containsKey(Integer.valueOf(mobeffectlist.id)); + } + + public MobEffect getEffect(MobEffectList mobeffectlist) { + return (MobEffect) this.effects.get(Integer.valueOf(mobeffectlist.id)); + } - while (this.ay - this.az < -180.0F) { - this.az -= 360.0F; + public void addEffect(MobEffect mobeffect) { + if (this.e(mobeffect)) { + if (this.effects.containsKey(Integer.valueOf(mobeffect.getEffectId()))) { + ((MobEffect) this.effects.get(Integer.valueOf(mobeffect.getEffectId()))).a(mobeffect); + this.b((MobEffect) this.effects.get(Integer.valueOf(mobeffect.getEffectId()))); + } else { + this.effects.put(Integer.valueOf(mobeffect.getEffectId()), mobeffect); + this.a(mobeffect); + } } + } + + public boolean e(MobEffect mobeffect) { + if (this.getMonsterType() == EnumMonsterType.UNDEAD) { + int i = mobeffect.getEffectId(); - while (this.ay - this.az >= 180.0F) { - this.az += 360.0F; + if (i == MobEffectList.REGENERATION.id || i == MobEffectList.POISON.id) { + return false; + } } - while (this.pitch - this.lastPitch < -180.0F) { - this.lastPitch -= 360.0F; + return true; + } + + public boolean aI() { + return this.getMonsterType() == EnumMonsterType.UNDEAD; + } + + public void k(int i) { + MobEffect mobeffect = (MobEffect) this.effects.remove(Integer.valueOf(i)); + + if (mobeffect != null) { + this.c(mobeffect); } + } - while (this.pitch - this.lastPitch >= 180.0F) { - this.lastPitch += 360.0F; + protected void a(MobEffect mobeffect) { + this.updateEffects = true; + if (!this.world.isStatic) { + MobEffectList.byId[mobeffect.getEffectId()].b(this, this.aT(), mobeffect.getAmplifier()); } + } - while (this.aA - this.aB < -180.0F) { - this.aB -= 360.0F; + protected void b(MobEffect mobeffect) { + this.updateEffects = true; + if (!this.world.isStatic) { + MobEffectList.byId[mobeffect.getEffectId()].a(this, this.aT(), mobeffect.getAmplifier()); } - while (this.aA - this.aB >= 180.0F) { - this.aB += 360.0F; + if (!this.world.isStatic) { + MobEffectList.byId[mobeffect.getEffectId()].b(this, this.aT(), mobeffect.getAmplifier()); } + } - this.world.methodProfiler.b(); - this.aE += f2; + protected void c(MobEffect mobeffect) { + this.updateEffects = true; + if (!this.world.isStatic) { + MobEffectList.byId[mobeffect.getEffectId()].a(this, this.aT(), mobeffect.getAmplifier()); + } } // CraftBukkit start - Delegate so we can handle providing a reason for health being regained - public void heal(int i) { - heal(i, EntityRegainHealthEvent.RegainReason.CUSTOM); + public void heal(float f) { + heal(f, EntityRegainHealthEvent.RegainReason.CUSTOM); } - public void heal(int i, EntityRegainHealthEvent.RegainReason regainReason) { - if (this.health > 0) { - EntityRegainHealthEvent event = new EntityRegainHealthEvent(this.getBukkitEntity(), i, regainReason); + public void heal(float f, EntityRegainHealthEvent.RegainReason regainReason) { + float f1 = this.getHealth(); + + if (f1 > 0.0F) { + EntityRegainHealthEvent event = new EntityRegainHealthEvent(this.getBukkitEntity(), f, regainReason); this.world.getServer().getPluginManager().callEvent(event); if (!event.isCancelled()) { - this.setHealth(this.getHealth() + event.getAmount()); + this.setHealth((float) (this.getHealth() + event.getAmount())); } - // this.getMaxHealth() -> this.maxHealth - if (this.health > this.maxHealth) { + // TODO should we be doing this anymore + if (this.getHealth() > this.maxHealth) { this.setHealth(this.maxHealth); - // CraftBukkit end } - - this.noDamageTicks = this.maxNoDamageTicks / 2; + // CraftBukkit end } } - public abstract int getMaxHealth(); - - public int getHealth() { - return this.health; + public final float getHealth() { + return this.datawatcher.getFloat(6); } - public void setHealth(int i) { - this.health = i; - if (i > this.getMaxHealth()) { - i = this.getMaxHealth(); - } + public void setHealth(float f) { + this.datawatcher.watch(6, Float.valueOf(MathHelper.a(f, 0.0F, this.getMaxHealth()))); } - public boolean damageEntity(DamageSource damagesource, int i) { + public boolean damageEntity(DamageSource damagesource, float f) { if (this.isInvulnerable()) { return false; } else if (this.world.isStatic) { return false; } else { - this.bC = 0; - if (this.health <= 0) { + this.aV = 0; + if (this.getHealth() <= 0.0F) { return false; } else if (damagesource.m() && this.hasEffect(MobEffectList.FIRE_RESISTANCE)) { return false; } else { if ((damagesource == DamageSource.ANVIL || damagesource == DamageSource.FALLING_BLOCK) && this.getEquipment(4) != null) { - this.getEquipment(4).damage(i * 4 + this.random.nextInt(i * 2), this); - i = (int) ((float) i * 0.75F); + this.getEquipment(4).damage((int) (f * 4.0F + this.random.nextFloat() * f * 2.0F), this); + f *= 0.75F; } - this.bi = 1.5F; + this.aG = 1.5F; boolean flag = true; // CraftBukkit start - EntityDamageEvent event = CraftEventFactory.handleEntityDamageEvent(this, damagesource, i); + EntityDamageEvent event = CraftEventFactory.handleEntityDamageEvent(this, damagesource, f); if (event != null) { if (event.isCancelled()) { return false; } - i = event.getDamage(); + f = (float) event.getDamage(); } // CraftBukkit end if ((float) this.noDamageTicks > (float) this.maxNoDamageTicks / 2.0F) { - if (i <= this.lastDamage) { + if (f <= this.lastDamage) { return false; } - this.d(damagesource, i - this.lastDamage); - this.lastDamage = i; + this.d(damagesource, f - this.lastDamage); + this.lastDamage = f; flag = false; } else { - this.lastDamage = i; - this.aT = this.health; + this.lastDamage = f; + this.ax = this.getHealth(); this.noDamageTicks = this.maxNoDamageTicks; - this.d(damagesource, i); - this.hurtTicks = this.aX = 10; + this.d(damagesource, f); + this.hurtTicks = this.az = 10; } - this.aY = 0.0F; + this.aA = 0.0F; Entity entity = damagesource.getEntity(); if (entity != null) { if (entity instanceof EntityLiving) { - this.c((EntityLiving) entity); + this.b((EntityLiving) entity); } if (entity instanceof EntityHuman) { @@ -735,21 +686,21 @@ public abstract class EntityLiving extends Entity { d0 = (Math.random() - Math.random()) * 0.01D; } - this.aY = (float) (Math.atan2(d1, d0) * 180.0D / 3.1415927410125732D) - this.yaw; - this.a(entity, i, d0, d1); + this.aA = (float) (Math.atan2(d1, d0) * 180.0D / 3.1415927410125732D) - this.yaw; + this.a(entity, f, d0, d1); } else { - this.aY = (float) ((int) (Math.random() * 2.0D) * 180); + this.aA = (float) ((int) (Math.random() * 2.0D) * 180); } } - if (this.health <= 0) { + if (this.getHealth() <= 0.0F) { if (flag) { - this.makeSound(this.bd(), this.ba(), this.aY()); + this.makeSound(this.aL(), this.aW(), this.aX()); } this.die(damagesource); } else if (flag) { - this.makeSound(this.bc(), this.ba(), this.aY()); + this.makeSound(this.aK(), this.aW(), this.aX()); } return true; @@ -757,11 +708,149 @@ public abstract class EntityLiving extends Entity { } } - protected float aY() { - return this.isBaby() ? (this.random.nextFloat() - this.random.nextFloat()) * 0.2F + 1.5F : (this.random.nextFloat() - this.random.nextFloat()) * 0.2F + 1.0F; + public void a(ItemStack itemstack) { + this.makeSound("random.break", 0.8F, 0.8F + this.world.random.nextFloat() * 0.4F); + + for (int i = 0; i < 5; ++i) { + Vec3D vec3d = this.world.getVec3DPool().create(((double) this.random.nextFloat() - 0.5D) * 0.1D, Math.random() * 0.1D + 0.1D, 0.0D); + + vec3d.a(-this.pitch * 3.1415927F / 180.0F); + vec3d.b(-this.yaw * 3.1415927F / 180.0F); + Vec3D vec3d1 = this.world.getVec3DPool().create(((double) this.random.nextFloat() - 0.5D) * 0.3D, (double) (-this.random.nextFloat()) * 0.6D - 0.3D, 0.6D); + + vec3d1.a(-this.pitch * 3.1415927F / 180.0F); + vec3d1.b(-this.yaw * 3.1415927F / 180.0F); + vec3d1 = vec3d1.add(this.locX, this.locY + (double) this.getHeadHeight(), this.locZ); + this.world.addParticle("iconcrack_" + itemstack.getItem().id, vec3d1.c, vec3d1.d, vec3d1.e, vec3d.c, vec3d.d + 0.05D, vec3d.e); + } + } + + public void die(DamageSource damagesource) { + Entity entity = damagesource.getEntity(); + EntityLiving entityliving = this.aO(); + + if (this.bb >= 0 && entityliving != null) { + entityliving.b(this, this.bb); + } + + if (entity != null) { + entity.a(this); + } + + this.aU = true; + if (!this.world.isStatic) { + int i = 0; + + if (entity instanceof EntityHuman) { + i = EnchantmentManager.getBonusMonsterLootEnchantmentLevel((EntityLiving) entity); + } + + if (!this.isBaby() && this.world.getGameRules().getBoolean("doMobLoot")) { + this.dropDeathLoot(this.lastDamageByPlayerTime > 0, i); + this.dropEquipment(this.lastDamageByPlayerTime > 0, i); + if (false && this.lastDamageByPlayerTime > 0) { // CraftBukkit - move rare item drop call to dropDeathLoot + int j = this.random.nextInt(200) - i; + + if (j < 5) { + this.l(j <= 0 ? 1 : 0); + } + } + } else { // CraftBukkit + CraftEventFactory.callEntityDeathEvent(this); // CraftBukkit + } + } + + this.world.broadcastEntityEffect(this, (byte) 3); + } + + protected void dropEquipment(boolean flag, int i) {} + + public void a(Entity entity, float f, double d0, double d1) { + if (this.random.nextDouble() >= this.a(GenericAttributes.c).e()) { + this.an = true; + float f1 = MathHelper.sqrt(d0 * d0 + d1 * d1); + float f2 = 0.4F; + + this.motX /= 2.0D; + this.motY /= 2.0D; + this.motZ /= 2.0D; + this.motX -= d0 / (double) f1 * (double) f2; + this.motY += (double) f2; + this.motZ -= d1 / (double) f1 * (double) f2; + if (this.motY > 0.4000000059604645D) { + this.motY = 0.4000000059604645D; + } + } + } + + protected String aK() { + return "damage.hit"; + } + + protected String aL() { + return "damage.hit"; + } + + // CraftBukkit start - Change return type to ItemStack + protected ItemStack l(int i) { + return null; + } + // CraftBukkit end + + protected void dropDeathLoot(boolean flag, int i) {} + + public boolean e() { + int i = MathHelper.floor(this.locX); + int j = MathHelper.floor(this.boundingBox.b); + int k = MathHelper.floor(this.locZ); + int l = this.world.getTypeId(i, j, k); + + return l == Block.LADDER.id || l == Block.VINE.id; + } + + public boolean isAlive() { + return !this.dead && this.getHealth() > 0.0F; + } + + protected void b(float f) { + super.b(f); + MobEffect mobeffect = this.getEffect(MobEffectList.JUMP); + float f1 = mobeffect != null ? (float) (mobeffect.getAmplifier() + 1) : 0.0F; + // CraftBukkit start + float i = MathHelper.f(f - 3.0F - f1); + + if (i > 0) { + EntityDamageEvent event = CraftEventFactory.callEntityDamageEvent(null, this, EntityDamageEvent.DamageCause.FALL, i); + if (event.isCancelled()) { + return; + } + + i = (float) event.getDamage(); + if (i > 0) { + this.getBukkitEntity().setLastDamageCause(event); + } + } + // CraftBukkit end + + if (i > 0) { + if (i > 4) { + this.makeSound("damage.fallbig", 1.0F, 1.0F); + } else { + this.makeSound("damage.fallsmall", 1.0F, 1.0F); + } + + this.damageEntity(DamageSource.FALL, (float) i); + int j = this.world.getTypeId(MathHelper.floor(this.locX), MathHelper.floor(this.locY - 0.20000000298023224D - (double) this.height), MathHelper.floor(this.locZ)); + + if (j > 0) { + StepSound stepsound = Block.byId[j].stepSound; + + this.makeSound(stepsound.getStepSound(), stepsound.getVolume1() * 0.5F, stepsound.getVolume2() * 0.75F); + } + } } - public int aZ() { + public int aM() { int i = 0; ItemStack[] aitemstack = this.getEquipment(); int j = aitemstack.length; @@ -779,211 +868,227 @@ public abstract class EntityLiving extends Entity { return i; } - protected void k(int i) {} + protected void h(float f) {} - protected int b(DamageSource damagesource, int i) { + protected float b(DamageSource damagesource, float f) { if (!damagesource.ignoresArmor()) { - int j = 25 - this.aZ(); - int k = i * j + this.aU; + int i = 25 - this.aM(); + float f1 = f * (float) i; - this.k(i); - i = k / 25; - this.aU = k % 25; + this.h(f); + f = f1 / 25.0F; } - return i; + return f; } - protected int c(DamageSource damagesource, int i) { + protected float c(DamageSource damagesource, float f) { + if (this instanceof EntityZombie) { + f = f; + } + + int i; int j; - int k; - int l; + float f1; - if (this.hasEffect(MobEffectList.RESISTANCE)) { - j = (this.getEffect(MobEffectList.RESISTANCE).getAmplifier() + 1) * 5; - k = 25 - j; - l = i * k + this.aU; - i = l / 25; - this.aU = l % 25; + if (this.hasEffect(MobEffectList.RESISTANCE) && damagesource != DamageSource.OUT_OF_WORLD) { + i = (this.getEffect(MobEffectList.RESISTANCE).getAmplifier() + 1) * 5; + j = 25 - i; + f1 = f * (float) j; + f = f1 / 25.0F; } - if (i <= 0) { - return 0; + if (f <= 0.0F) { + return 0.0F; } else { - j = EnchantmentManager.a(this.getEquipment(), damagesource); - if (j > 20) { - j = 20; + i = EnchantmentManager.a(this.getEquipment(), damagesource); + if (i > 20) { + i = 20; } - if (j > 0 && j <= 20) { - k = 25 - j; - l = i * k + this.aU; - i = l / 25; - this.aU = l % 25; + if (i > 0 && i <= 20) { + j = 25 - i; + f1 = f * (float) j; + f = f1 / 25.0F; } - return i; + return f; } } - protected void d(DamageSource damagesource, int i) { + protected void d(DamageSource damagesource, float f) { if (!this.isInvulnerable()) { - i = this.b(damagesource, i); - i = this.c(damagesource, i); - int j = this.getHealth(); + f = this.b(damagesource, f); + f = this.c(damagesource, f); + float f1 = f; + + f = Math.max(f - this.bj(), 0.0F); + this.m(this.bj() - (f1 - f)); + if (f != 0.0F) { + float f2 = this.getHealth(); - this.health -= i; - this.bt.a(damagesource, j, i); + this.setHealth(f2 - f); + this.aN().a(damagesource, f2, f); + this.m(this.bj() - f); + } } } - protected float ba() { - return 1.0F; + public CombatTracker aN() { + return this.combatTracker; } - protected String bb() { - return null; + public EntityLiving aO() { + return (EntityLiving) (this.combatTracker.c() != null ? this.combatTracker.c() : (this.killer != null ? this.killer : (this.lastDamager != null ? this.lastDamager : null))); } - protected String bc() { - return "damage.hit"; + public final float getMaxHealth() { + return (float) this.a(GenericAttributes.a).e(); } - protected String bd() { - return "damage.hit"; + public final int aQ() { + return this.datawatcher.getByte(9); } - public void a(Entity entity, int i, double d0, double d1) { - this.an = true; - float f = MathHelper.sqrt(d0 * d0 + d1 * d1); - float f1 = 0.4F; - - this.motX /= 2.0D; - this.motY /= 2.0D; - this.motZ /= 2.0D; - this.motX -= d0 / (double) f * (double) f1; - this.motY += (double) f1; - this.motZ -= d1 / (double) f * (double) f1; - if (this.motY > 0.4000000059604645D) { - this.motY = 0.4000000059604645D; - } + public final void m(int i) { + this.datawatcher.watch(9, Byte.valueOf((byte) i)); } - public void die(DamageSource damagesource) { - Entity entity = damagesource.getEntity(); - EntityLiving entityliving = this.bN(); + private int h() { + return this.hasEffect(MobEffectList.FASTER_DIG) ? 6 - (1 + this.getEffect(MobEffectList.FASTER_DIG).getAmplifier()) * 1 : (this.hasEffect(MobEffectList.SLOWER_DIG) ? 6 + (1 + this.getEffect(MobEffectList.SLOWER_DIG).getAmplifier()) * 2 : 6); + } - if (this.aM >= 0 && entityliving != null) { - entityliving.c(this, this.aM); + public void aR() { + if (!this.au || this.av >= this.h() / 2 || this.av < 0) { + this.av = -1; + this.au = true; + if (this.world instanceof WorldServer) { + ((WorldServer) this.world).getTracker().a((Entity) this, (Packet) (new Packet18ArmAnimation(this, 1))); + } } + } - if (entity != null) { - entity.a(this); - } + protected void B() { + this.damageEntity(DamageSource.OUT_OF_WORLD, 4.0F); + } - this.bd = true; - if (!this.world.isStatic) { - int i = 0; + protected void aS() { + int i = this.h(); - if (entity instanceof EntityHuman) { - i = EnchantmentManager.getBonusMonsterLootEnchantmentLevel((EntityLiving) entity); + if (this.au) { + ++this.av; + if (this.av >= i) { + this.av = 0; + this.au = false; } + } else { + this.av = 0; + } - if (!this.isBaby() && this.world.getGameRules().getBoolean("doMobLoot")) { - this.dropDeathLoot(this.lastDamageByPlayerTime > 0, i); - this.dropEquipment(this.lastDamageByPlayerTime > 0, i); - if (false && this.lastDamageByPlayerTime > 0) { // CraftBukkit - move rare item drop call to dropDeathLoot - int j = this.random.nextInt(200) - i; + this.aE = (float) this.av / (float) i; + } - if (j < 5) { - this.l(j <= 0 ? 1 : 0); - } - } - } else { // CraftBukkit - CraftEventFactory.callEntityDeathEvent(this); // CraftBukkit + public AttributeInstance a(IAttribute iattribute) { + return this.aT().a(iattribute); + } + + public AttributeMapBase aT() { + if (this.d == null) { + if (this.world != null && !this.world.isStatic) { + this.d = new AttributeMapServer(); + } else { + this.d = new AttributeMapClient(); } } - this.world.broadcastEntityEffect(this, (byte) 3); + return this.d; } - // CraftBukkit start - Change return type to ItemStack - protected ItemStack l(int i) { - return null; + public EnumMonsterType getMonsterType() { + return EnumMonsterType.UNDEFINED; } - // CraftBukkit end - protected void dropDeathLoot(boolean flag, int i) { - // CraftBukkit start - Whole method - List<org.bukkit.inventory.ItemStack> loot = new java.util.ArrayList<org.bukkit.inventory.ItemStack>(); - int j = this.getLootId(); + public abstract ItemStack aV(); - if (j > 0) { - int k = this.random.nextInt(3); + public abstract ItemStack getEquipment(int i); - if (i > 0) { - k += this.random.nextInt(i + 1); - } + public abstract void setEquipment(int i, ItemStack itemstack); + + public void setSprinting(boolean flag) { + super.setSprinting(flag); + if (!this.world.isStatic) { + AttributeInstance attributeinstance = this.a(GenericAttributes.d); - if (k > 0) { - loot.add(new org.bukkit.inventory.ItemStack(j, k)); + attributeinstance.b(c); + if (flag) { + attributeinstance.a(c); } } + } - // Determine rare item drops and add them to the loot - if (this.lastDamageByPlayerTime > 0) { - int k = this.random.nextInt(200) - i; + public abstract ItemStack[] getEquipment(); - if (k < 5) { - ItemStack itemstack = this.l(k <= 0 ? 1 : 0); - if (itemstack != null) { - loot.add(org.bukkit.craftbukkit.inventory.CraftItemStack.asCraftMirror(itemstack)); - } - } - } + protected float aW() { + return 1.0F; + } - CraftEventFactory.callEntityDeathEvent(this, loot); // raise event even for those times when the entity does not drop loot - // CraftBukkit end + protected float aX() { + return this.isBaby() ? (this.random.nextFloat() - this.random.nextFloat()) * 0.2F + 1.5F : (this.random.nextFloat() - this.random.nextFloat()) * 0.2F + 1.0F; } - protected int getLootId() { - return 0; + protected boolean aY() { + return this.getHealth() <= 0.0F; } - protected void a(float f) { - super.a(f); - int i = MathHelper.f(f - 3.0F); + public void enderTeleportTo(double d0, double d1, double d2) { + this.setPositionRotation(d0, d1, d2, this.yaw, this.pitch); + } - // CraftBukkit start - if (i > 0) { - EntityDamageEvent event = CraftEventFactory.callEntityDamageEvent(null, this, EntityDamageEvent.DamageCause.FALL, i); - if (event.isCancelled()) { - return; - } + public void l(Entity entity) { + double d0 = entity.locX; + double d1 = entity.boundingBox.b + (double) entity.length; + double d2 = entity.locZ; + + for (double d3 = -1.5D; d3 < 2.0D; ++d3) { + for (double d4 = -1.5D; d4 < 2.0D; ++d4) { + if (d3 != 0.0D || d4 != 0.0D) { + int i = (int) (this.locX + d3); + int j = (int) (this.locZ + d4); + AxisAlignedBB axisalignedbb = this.boundingBox.c(d3, 1.0D, d4); + + if (this.world.a(axisalignedbb).isEmpty()) { + if (this.world.w(i, (int) this.locY, j)) { + this.enderTeleportTo(this.locX + d3, this.locY + 1.0D, this.locZ + d4); + return; + } - i = event.getDamage(); - if (i > 0) { - this.getBukkitEntity().setLastDamageCause(event); + if (this.world.w(i, (int) this.locY - 1, j) || this.world.getMaterial(i, (int) this.locY - 1, j) == Material.WATER) { + d0 = this.locX + d3; + d1 = this.locY + 1.0D; + d2 = this.locZ + d4; + } + } + } } } - // CraftBukkit end - if (i > 0) { - if (i > 4) { - this.makeSound("damage.fallbig", 1.0F, 1.0F); - } else { - this.makeSound("damage.fallsmall", 1.0F, 1.0F); - } + this.enderTeleportTo(d0, d1, d2); + } - this.damageEntity(DamageSource.FALL, i); - int j = this.world.getTypeId(MathHelper.floor(this.locX), MathHelper.floor(this.locY - 0.20000000298023224D - (double) this.height), MathHelper.floor(this.locZ)); + protected void ba() { + this.motY = 0.41999998688697815D; + if (this.hasEffect(MobEffectList.JUMP)) { + this.motY += (double) ((float) (this.getEffect(MobEffectList.JUMP).getAmplifier() + 1) * 0.1F); + } - if (j > 0) { - StepSound stepsound = Block.byId[j].stepSound; + if (this.isSprinting()) { + float f = this.yaw * 0.017453292F; - this.makeSound(stepsound.getStepSound(), stepsound.getVolume1() * 0.5F, stepsound.getVolume2() * 0.75F); - } + this.motX -= (double) (MathHelper.sin(f) * 0.2F); + this.motZ += (double) (MathHelper.cos(f) * 0.2F); } + + this.an = true; } public void e(float f, float f1) { @@ -991,7 +1096,7 @@ public abstract class EntityLiving extends Entity { if (this.G() && (!(this instanceof EntityHuman) || !((EntityHuman) this).abilities.isFlying)) { d0 = this.locY; - this.a(f, f1, this.bh() ? 0.04F : 0.02F); + this.a(f, f1, this.bb() ? 0.04F : 0.02F); this.move(this.motX, this.motY, this.motZ); this.motX *= 0.800000011920929D; this.motY *= 0.800000011920929D; @@ -1027,15 +1132,9 @@ public abstract class EntityLiving extends Entity { float f4; if (this.onGround) { - if (this.bh()) { - f4 = this.aI(); - } else { - f4 = this.aO; - } - - f4 *= f3; + f4 = this.bc() * f3; } else { - f4 = this.aP; + f4 = this.aR; } this.a(f, f1, f4); @@ -1049,7 +1148,7 @@ public abstract class EntityLiving extends Entity { } } - if (this.g_()) { + if (this.e()) { float f5 = 0.15F; if (this.motX < (double) (-f5)) { @@ -1081,7 +1180,7 @@ public abstract class EntityLiving extends Entity { } this.move(this.motX, this.motY, this.motZ); - if (this.positionChanged && this.g_()) { + if (this.positionChanged && this.e()) { this.motY = 0.2D; } @@ -1100,7 +1199,7 @@ public abstract class EntityLiving extends Entity { this.motZ *= (double) f2; } - this.bh = this.bi; + this.aF = this.aG; d0 = this.locX - this.lastX; double d1 = this.locZ - this.lastZ; float f6 = MathHelper.sqrt(d0 * d0 + d1 * d1) * 4.0F; @@ -1109,164 +1208,174 @@ public abstract class EntityLiving extends Entity { f6 = 1.0F; } - this.bi += (f6 - this.bi) * 0.4F; - this.bj += this.bi; + this.aG += (f6 - this.aG) * 0.4F; + this.aH += this.aG; } - public boolean g_() { - int i = MathHelper.floor(this.locX); - int j = MathHelper.floor(this.boundingBox.b); - int k = MathHelper.floor(this.locZ); - int l = this.world.getTypeId(i, j, k); + protected boolean bb() { + return false; + } - return l == Block.LADDER.id || l == Block.VINE.id; + public float bc() { + return this.bb() ? this.bo : 0.1F; } - public void b(NBTTagCompound nbttagcompound) { - if (this.health < -32768) { - this.health = -32768; - } + public void i(float f) { + this.bo = f; + } - nbttagcompound.setShort("Health", (short) this.health); - nbttagcompound.setShort("HurtTime", (short) this.hurtTicks); - nbttagcompound.setShort("DeathTime", (short) this.deathTicks); - nbttagcompound.setShort("AttackTime", (short) this.attackTicks); - nbttagcompound.setBoolean("CanPickUpLoot", this.bT()); - nbttagcompound.setBoolean("PersistenceRequired", this.persistent); - NBTTagList nbttaglist = new NBTTagList(); + public boolean m(Entity entity) { + this.k(entity); + return false; + } - for (int i = 0; i < this.equipment.length; ++i) { - NBTTagCompound nbttagcompound1 = new NBTTagCompound(); + public boolean isSleeping() { + return false; + } - if (this.equipment[i] != null) { - this.equipment[i].save(nbttagcompound1); - } + public void l_() { + super.l_(); + if (!this.world.isStatic) { + int i = this.aQ(); - nbttaglist.add(nbttagcompound1); - } + if (i > 0) { + if (this.aw <= 0) { + this.aw = 20 * (30 - i); + } - nbttagcompound.set("Equipment", nbttaglist); - NBTTagList nbttaglist1; + --this.aw; + if (this.aw <= 0) { + this.m(i - 1); + } + } - if (!this.effects.isEmpty()) { - nbttaglist1 = new NBTTagList(); - Iterator iterator = this.effects.values().iterator(); + for (int j = 0; j < 5; ++j) { + ItemStack itemstack = this.g[j]; + ItemStack itemstack1 = this.getEquipment(j); - while (iterator.hasNext()) { - MobEffect mobeffect = (MobEffect) iterator.next(); + if (!ItemStack.matches(itemstack1, itemstack)) { + ((WorldServer) this.world).getTracker().a((Entity) this, (Packet) (new Packet5EntityEquipment(this.id, j, itemstack1))); + if (itemstack != null) { + this.d.a(itemstack.D()); + } - nbttaglist1.add(mobeffect.a(new NBTTagCompound())); - } + if (itemstack1 != null) { + this.d.b(itemstack1.D()); + } - nbttagcompound.set("ActiveEffects", nbttaglist1); + this.g[j] = itemstack1 == null ? null : itemstack1.cloneItemStack(); + } + } } - nbttaglist1 = new NBTTagList(); + this.c(); + double d0 = this.locX - this.lastX; + double d1 = this.locZ - this.lastZ; + float f = (float) (d0 * d0 + d1 * d1); + float f1 = this.aN; + float f2 = 0.0F; - for (int j = 0; j < this.dropChances.length; ++j) { - nbttaglist1.add(new NBTTagFloat(j + "", this.dropChances[j])); - } + this.aW = this.aX; + float f3 = 0.0F; - nbttagcompound.set("DropChances", nbttaglist1); - nbttagcompound.setString("CustomName", this.getCustomName()); - nbttagcompound.setBoolean("CustomNameVisible", this.getCustomNameVisible()); - nbttagcompound.setInt("Bukkit.MaxHealth", this.maxHealth); // CraftBukkit - } + if (f > 0.0025000002F) { + f3 = 1.0F; + f2 = (float) Math.sqrt((double) f) * 3.0F; + // CraftBukkit - Math -> TrigMath + f1 = (float) org.bukkit.craftbukkit.TrigMath.atan2(d1, d0) * 180.0F / 3.1415927F - 90.0F; + } - public void a(NBTTagCompound nbttagcompound) { - this.health = nbttagcompound.getShort("Health"); - // CraftBukkit start - if (nbttagcompound.hasKey("Bukkit.MaxHealth")) { - this.maxHealth = nbttagcompound.getInt("Bukkit.MaxHealth"); + if (this.aE > 0.0F) { + f1 = this.yaw; } - // CraftBukkit end - if (!nbttagcompound.hasKey("Health")) { - this.health = this.maxHealth; // CraftBukkit - this.getMaxHealth() -> this.maxHealth + if (!this.onGround) { + f3 = 0.0F; } - this.hurtTicks = nbttagcompound.getShort("HurtTime"); - this.deathTicks = nbttagcompound.getShort("DeathTime"); - this.attackTicks = nbttagcompound.getShort("AttackTime"); + this.aX += (f3 - this.aX) * 0.3F; + this.world.methodProfiler.a("headTurn"); + f2 = this.f(f1, f2); + this.world.methodProfiler.b(); + this.world.methodProfiler.a("rangeChecks"); - // CraftBukkit start - If looting or persistence is false only use it if it was set after we started using it - boolean data = nbttagcompound.getBoolean("CanPickUpLoot"); - if (isLevelAtLeast(nbttagcompound, 1) || data) { - this.canPickUpLoot = data; + while (this.yaw - this.lastYaw < -180.0F) { + this.lastYaw -= 360.0F; } - data = nbttagcompound.getBoolean("PersistenceRequired"); - if (isLevelAtLeast(nbttagcompound, 1) || data) { - this.persistent = data; + while (this.yaw - this.lastYaw >= 180.0F) { + this.lastYaw += 360.0F; } - // CraftBukkit end - if (nbttagcompound.hasKey("CustomName") && nbttagcompound.getString("CustomName").length() > 0) { - this.setCustomName(nbttagcompound.getString("CustomName")); + while (this.aN - this.aO < -180.0F) { + this.aO -= 360.0F; } - this.setCustomNameVisible(nbttagcompound.getBoolean("CustomNameVisible")); - NBTTagList nbttaglist; - int i; - - if (nbttagcompound.hasKey("Equipment")) { - nbttaglist = nbttagcompound.getList("Equipment"); + while (this.aN - this.aO >= 180.0F) { + this.aO += 360.0F; + } - for (i = 0; i < this.equipment.length; ++i) { - this.equipment[i] = ItemStack.createStack((NBTTagCompound) nbttaglist.get(i)); - } + while (this.pitch - this.lastPitch < -180.0F) { + this.lastPitch -= 360.0F; } - if (nbttagcompound.hasKey("ActiveEffects")) { - nbttaglist = nbttagcompound.getList("ActiveEffects"); + while (this.pitch - this.lastPitch >= 180.0F) { + this.lastPitch += 360.0F; + } - for (i = 0; i < nbttaglist.size(); ++i) { - NBTTagCompound nbttagcompound1 = (NBTTagCompound) nbttaglist.get(i); - MobEffect mobeffect = MobEffect.b(nbttagcompound1); + while (this.aP - this.aQ < -180.0F) { + this.aQ -= 360.0F; + } - this.effects.put(Integer.valueOf(mobeffect.getEffectId()), mobeffect); - } + while (this.aP - this.aQ >= 180.0F) { + this.aQ += 360.0F; } - if (nbttagcompound.hasKey("DropChances")) { - nbttaglist = nbttagcompound.getList("DropChances"); + this.world.methodProfiler.b(); + this.aY += f2; + } - for (i = 0; i < nbttaglist.size(); ++i) { - this.dropChances[i] = ((NBTTagFloat) nbttaglist.get(i)).data; - } + protected float f(float f, float f1) { + float f2 = MathHelper.g(f - this.aN); + + this.aN += f2 * 0.3F; + float f3 = MathHelper.g(this.yaw - this.aN); + boolean flag = f3 < -90.0F || f3 >= 90.0F; + + if (f3 < -75.0F) { + f3 = -75.0F; } - } - public boolean isAlive() { - return !this.dead && this.health > 0; - } + if (f3 >= 75.0F) { + f3 = 75.0F; + } - public boolean bf() { - return false; - } + this.aN = this.yaw - f3; + if (f3 * f3 > 2500.0F) { + this.aN += f3 * 0.2F; + } - public void f(float f) { - this.bE = f; - } + if (flag) { + f1 *= -1.0F; + } - public void f(boolean flag) { - this.bG = flag; + return f1; } public void c() { - if (this.bX > 0) { - --this.bX; + if (this.bp > 0) { + --this.bp; } - if (this.bu > 0) { - double d0 = this.locX + (this.bv - this.locX) / (double) this.bu; - double d1 = this.locY + (this.bw - this.locY) / (double) this.bu; - double d2 = this.locZ + (this.bx - this.locZ) / (double) this.bu; - double d3 = MathHelper.g(this.by - (double) this.yaw); + if (this.bh > 0) { + double d0 = this.locX + (this.bi - this.locX) / (double) this.bh; + double d1 = this.locY + (this.bj - this.locY) / (double) this.bh; + double d2 = this.locZ + (this.bk - this.locZ) / (double) this.bh; + double d3 = MathHelper.g(this.bl - (double) this.yaw); - this.yaw = (float) ((double) this.yaw + d3 / (double) this.bu); - this.pitch = (float) ((double) this.pitch + (this.bz - (double) this.pitch) / (double) this.bu); - --this.bu; + this.yaw = (float) ((double) this.yaw + d3 / (double) this.bh); + this.pitch = (float) ((double) this.pitch + (this.bm - (double) this.pitch) / (double) this.bh); + --this.bh; this.setPosition(d0, d1, d2); this.b(this.yaw, this.pitch); } else if (!this.bi()) { @@ -1288,131 +1397,64 @@ public abstract class EntityLiving extends Entity { } this.world.methodProfiler.a("ai"); - if (this.bj()) { - this.bG = false; - this.bD = 0.0F; - this.bE = 0.0F; - this.bF = 0.0F; + if (this.aY()) { + this.bd = false; + this.be = 0.0F; + this.bf = 0.0F; + this.bg = 0.0F; } else if (this.bi()) { - if (this.bh()) { + if (this.bb()) { this.world.methodProfiler.a("newAi"); - this.bo(); + this.be(); this.world.methodProfiler.b(); } else { this.world.methodProfiler.a("oldAi"); - this.bq(); + this.bh(); this.world.methodProfiler.b(); - this.aA = this.yaw; + this.aP = this.yaw; } } this.world.methodProfiler.b(); this.world.methodProfiler.a("jump"); - if (this.bG) { + if (this.bd) { if (!this.G() && !this.I()) { - if (this.onGround && this.bX == 0) { - this.bl(); - this.bX = 10; + if (this.onGround && this.bp == 0) { + this.ba(); + this.bp = 10; } } else { this.motY += 0.03999999910593033D; } } else { - this.bX = 0; + this.bp = 0; } this.world.methodProfiler.b(); this.world.methodProfiler.a("travel"); - this.bD *= 0.98F; - this.bE *= 0.98F; - this.bF *= 0.9F; - float f = this.aO; - - this.aO *= this.bE(); - this.e(this.bD, this.bE); - this.aO = f; + this.be *= 0.98F; + this.bf *= 0.98F; + this.bg *= 0.9F; + this.e(this.be, this.bf); this.world.methodProfiler.b(); this.world.methodProfiler.a("push"); if (!this.world.isStatic) { - this.bg(); - } - - this.world.methodProfiler.b(); - this.world.methodProfiler.a("looting"); - // CraftBukkit - Don't run mob pickup code on players - if (!this.world.isStatic && !(this instanceof EntityPlayer) && this.bT() && !this.bd && this.world.getGameRules().getBoolean("mobGriefing")) { - List list = this.world.a(EntityItem.class, this.boundingBox.grow(1.0D, 0.0D, 1.0D)); - Iterator iterator = list.iterator(); - - while (iterator.hasNext()) { - EntityItem entityitem = (EntityItem) iterator.next(); - - if (!entityitem.dead && entityitem.getItemStack() != null) { - ItemStack itemstack = entityitem.getItemStack(); - int i = b(itemstack); - - if (i > -1) { - boolean flag = true; - ItemStack itemstack1 = this.getEquipment(i); - - if (itemstack1 != null) { - if (i == 0) { - if (itemstack.getItem() instanceof ItemSword && !(itemstack1.getItem() instanceof ItemSword)) { - flag = true; - } else if (itemstack.getItem() instanceof ItemSword && itemstack1.getItem() instanceof ItemSword) { - ItemSword itemsword = (ItemSword) itemstack.getItem(); - ItemSword itemsword1 = (ItemSword) itemstack1.getItem(); - - if (itemsword.g() == itemsword1.g()) { - flag = itemstack.getData() > itemstack1.getData() || itemstack.hasTag() && !itemstack1.hasTag(); - } else { - flag = itemsword.g() > itemsword1.g(); - } - } else { - flag = false; - } - } else if (itemstack.getItem() instanceof ItemArmor && !(itemstack1.getItem() instanceof ItemArmor)) { - flag = true; - } else if (itemstack.getItem() instanceof ItemArmor && itemstack1.getItem() instanceof ItemArmor) { - ItemArmor itemarmor = (ItemArmor) itemstack.getItem(); - ItemArmor itemarmor1 = (ItemArmor) itemstack1.getItem(); - - if (itemarmor.c == itemarmor1.c) { - flag = itemstack.getData() > itemstack1.getData() || itemstack.hasTag() && !itemstack1.hasTag(); - } else { - flag = itemarmor.c > itemarmor1.c; - } - } else { - flag = false; - } - } - - if (flag) { - if (itemstack1 != null && this.random.nextFloat() - 0.1F < this.dropChances[i]) { - this.a(itemstack1, 0.0F); - } - - this.setEquipment(i, itemstack); - this.dropChances[i] = 2.0F; - this.persistent = true; - this.receive(entityitem, 1); - entityitem.die(); - } - } - } - } + this.bf(); } this.world.methodProfiler.b(); } - protected void bg() { + protected void be() {} + + protected void bf() { List list = this.world.getEntities(this, this.boundingBox.grow(0.20000000298023224D, 0.0D, 0.20000000298023224D)); if (list != null && !list.isEmpty()) { for (int i = 0; i < list.size(); ++i) { Entity entity = (Entity) list.get(i); + // TODO better check now? // CraftBukkit start - Only handle mob (non-player) collisions every other tick if (entity instanceof EntityLiving && !(this instanceof EntityPlayer) && this.ticksLived % 2 == 0) { continue; @@ -1420,220 +1462,60 @@ public abstract class EntityLiving extends Entity { // CraftBukkit end if (entity.L()) { - this.o(entity); + this.n(entity); } } } } - protected void o(Entity entity) { + protected void n(Entity entity) { entity.collide(this); } - protected boolean bh() { - return false; - } - - protected boolean bi() { - return !this.world.isStatic; + public void T() { + super.T(); + this.aW = this.aX; + this.aX = 0.0F; + this.fallDistance = 0.0F; } - protected boolean bj() { - return this.health <= 0; - } + protected void bg() {} - public boolean isBlocking() { - return false; + protected void bh() { + ++this.aV; } - protected void bl() { - this.motY = 0.41999998688697815D; - if (this.hasEffect(MobEffectList.JUMP)) { - this.motY += (double) ((float) (this.getEffect(MobEffectList.JUMP).getAmplifier() + 1) * 0.1F); - } - - if (this.isSprinting()) { - float f = this.yaw * 0.017453292F; - - this.motX -= (double) (MathHelper.sin(f) * 0.2F); - this.motZ += (double) (MathHelper.cos(f) * 0.2F); - } - - this.an = true; - } - - protected boolean isTypeNotPersistent() { - return true; - } - - protected void bn() { - if (!this.persistent) { - EntityHuman entityhuman = this.world.findNearbyPlayer(this, -1.0D); - - if (entityhuman != null) { - double d0 = entityhuman.locX - this.locX; - double d1 = entityhuman.locY - this.locY; - double d2 = entityhuman.locZ - this.locZ; - double d3 = d0 * d0 + d1 * d1 + d2 * d2; - - if (d3 > 16384.0D) { // CraftBukkit - remove isTypeNotPersistent() check - this.die(); - } - - if (this.bC > 600 && this.random.nextInt(800) == 0 && d3 > 1024.0D) { // CraftBukkit - remove isTypeNotPersistent() check - this.die(); - } else if (d3 < 1024.0D) { - this.bC = 0; - } - } - // CraftBukkit start - } else { - this.bC = 0; - } - // CraftBukkit end - } - - protected void bo() { - ++this.bC; - this.world.methodProfiler.a("checkDespawn"); - this.bn(); - this.world.methodProfiler.b(); - this.world.methodProfiler.a("sensing"); - this.bP.a(); - this.world.methodProfiler.b(); - this.world.methodProfiler.a("targetSelector"); - this.targetSelector.a(); - this.world.methodProfiler.b(); - this.world.methodProfiler.a("goalSelector"); - this.goalSelector.a(); - this.world.methodProfiler.b(); - this.world.methodProfiler.a("navigation"); - this.navigation.e(); - this.world.methodProfiler.b(); - this.world.methodProfiler.a("mob tick"); - this.bp(); - this.world.methodProfiler.b(); - this.world.methodProfiler.a("controls"); - this.world.methodProfiler.a("move"); - this.moveController.c(); - this.world.methodProfiler.c("look"); - this.lookController.a(); - this.world.methodProfiler.c("jump"); - this.jumpController.b(); - this.world.methodProfiler.b(); - this.world.methodProfiler.b(); + public void f(boolean flag) { + this.bd = flag; } - protected void bp() {} - - protected void bq() { - ++this.bC; - this.bn(); - this.bD = 0.0F; - this.bE = 0.0F; - float f = 8.0F; - - if (this.random.nextFloat() < 0.02F) { - EntityHuman entityhuman = this.world.findNearbyPlayer(this, (double) f); + public void receive(Entity entity, int i) { + if (!entity.dead && !this.world.isStatic) { + EntityTracker entitytracker = ((WorldServer) this.world).getTracker(); - if (entityhuman != null) { - this.bY = entityhuman; - this.bJ = 10 + this.random.nextInt(20); - } else { - this.bF = (this.random.nextFloat() - 0.5F) * 20.0F; + if (entity instanceof EntityItem) { + entitytracker.a(entity, (Packet) (new Packet22Collect(entity.id, this.id))); } - } - if (this.bY != null) { - this.a(this.bY, 10.0F, (float) this.bs()); - if (this.bJ-- <= 0 || this.bY.dead || this.bY.e((Entity) this) > (double) (f * f)) { - this.bY = null; - } - } else { - if (this.random.nextFloat() < 0.05F) { - this.bF = (this.random.nextFloat() - 0.5F) * 20.0F; + if (entity instanceof EntityArrow) { + entitytracker.a(entity, (Packet) (new Packet22Collect(entity.id, this.id))); } - this.yaw += this.bF; - this.pitch = this.bH; - } - - boolean flag = this.G(); - boolean flag1 = this.I(); - - if (flag || flag1) { - this.bG = this.random.nextFloat() < 0.8F; - } - } - - protected void br() { - int i = this.h(); - - if (this.br) { - ++this.bs; - if (this.bs >= i) { - this.bs = 0; - this.br = false; + if (entity instanceof EntityExperienceOrb) { + entitytracker.a(entity, (Packet) (new Packet22Collect(entity.id, this.id))); } - } else { - this.bs = 0; - } - - this.aR = (float) this.bs / (float) i; - } - - public int bs() { - return 40; - } - - public void a(Entity entity, float f, float f1) { - double d0 = entity.locX - this.locX; - double d1 = entity.locZ - this.locZ; - double d2; - - if (entity instanceof EntityLiving) { - EntityLiving entityliving = (EntityLiving) entity; - - d2 = entityliving.locY + (double) entityliving.getHeadHeight() - (this.locY + (double) this.getHeadHeight()); - } else { - d2 = (entity.boundingBox.b + entity.boundingBox.e) / 2.0D - (this.locY + (double) this.getHeadHeight()); - } - - double d3 = (double) MathHelper.sqrt(d0 * d0 + d1 * d1); - float f2 = (float) (Math.atan2(d1, d0) * 180.0D / 3.1415927410125732D) - 90.0F; - float f3 = (float) (-(Math.atan2(d2, d3) * 180.0D / 3.1415927410125732D)); - - this.pitch = this.b(this.pitch, f3, f1); - this.yaw = this.b(this.yaw, f2, f); - } - - private float b(float f, float f1, float f2) { - float f3 = MathHelper.g(f1 - f); - - if (f3 > f2) { - f3 = f2; - } - - if (f3 < -f2) { - f3 = -f2; } - - return f + f3; - } - - public boolean canSpawn() { - return this.world.b(this.boundingBox) && this.world.getCubes(this, this.boundingBox).isEmpty() && !this.world.containsLiquid(this.boundingBox); } - protected void B() { - this.damageEntity(DamageSource.OUT_OF_WORLD, 4); + public boolean o(Entity entity) { + return this.world.a(this.world.getVec3DPool().create(this.locX, this.locY + (double) this.getHeadHeight(), this.locZ), this.world.getVec3DPool().create(entity.locX, entity.locY + (double) entity.getHeadHeight(), entity.locZ)) == null; } public Vec3D Y() { - return this.i(1.0F); + return this.j(1.0F); } - public Vec3D i(float f) { + public Vec3D j(float f) { float f1; float f2; float f3; @@ -1657,496 +1539,39 @@ public abstract class EntityLiving extends Entity { } } - public int by() { - return 4; - } - - public boolean isSleeping() { - return false; - } - - protected void bA() { - Iterator iterator = this.effects.keySet().iterator(); - - while (iterator.hasNext()) { - Integer integer = (Integer) iterator.next(); - MobEffect mobeffect = (MobEffect) this.effects.get(integer); - - try { - if (!mobeffect.tick(this)) { - if (!this.world.isStatic) { - iterator.remove(); - this.c(mobeffect); - } - } else if (mobeffect.getDuration() % 600 == 0) { - this.b(mobeffect); - } - } catch (Throwable throwable) { - CrashReport crashreport = CrashReport.a(throwable, "Ticking mob effect instance"); - CrashReportSystemDetails crashreportsystemdetails = crashreport.a("Mob effect being ticked"); - - crashreportsystemdetails.a("Effect Name", (Callable) (new CrashReportEffectName(this, mobeffect))); - crashreportsystemdetails.a("Effect ID", (Callable) (new CrashReportEffectID(this, mobeffect))); - crashreportsystemdetails.a("Effect Duration", (Callable) (new CrashReportEffectDuration(this, mobeffect))); - crashreportsystemdetails.a("Effect Amplifier", (Callable) (new CrashReportEffectAmplifier(this, mobeffect))); - crashreportsystemdetails.a("Effect is Splash", (Callable) (new CrashReportEffectSplash(this, mobeffect))); - crashreportsystemdetails.a("Effect is Ambient", (Callable) (new CrashReportEffectAmbient(this, mobeffect))); - throw new ReportedException(crashreport); - } - } - - int i; - - if (this.updateEffects) { - if (!this.world.isStatic) { - if (this.effects.isEmpty()) { - this.datawatcher.watch(9, Byte.valueOf((byte) 0)); - this.datawatcher.watch(8, Integer.valueOf(0)); - this.setInvisible(false); - } else { - i = PotionBrewer.a(this.effects.values()); - this.datawatcher.watch(9, Byte.valueOf((byte) (PotionBrewer.b(this.effects.values()) ? 1 : 0))); - this.datawatcher.watch(8, Integer.valueOf(i)); - this.setInvisible(this.hasEffect(MobEffectList.INVISIBILITY.id)); - } - } - - this.updateEffects = false; - } - - i = this.datawatcher.getInt(8); - boolean flag = this.datawatcher.getByte(9) > 0; - - if (i > 0) { - boolean flag1 = false; - - if (!this.isInvisible()) { - flag1 = this.random.nextBoolean(); - } else { - flag1 = this.random.nextInt(15) == 0; - } - - if (flag) { - flag1 &= this.random.nextInt(5) == 0; - } - - if (flag1 && i > 0) { - double d0 = (double) (i >> 16 & 255) / 255.0D; - double d1 = (double) (i >> 8 & 255) / 255.0D; - double d2 = (double) (i >> 0 & 255) / 255.0D; - - this.world.addParticle(flag ? "mobSpellAmbient" : "mobSpell", this.locX + (this.random.nextDouble() - 0.5D) * (double) this.width, this.locY + this.random.nextDouble() * (double) this.length - (double) this.height, this.locZ + (this.random.nextDouble() - 0.5D) * (double) this.width, d0, d1, d2); - } - } - } - - public void bB() { - Iterator iterator = this.effects.keySet().iterator(); - - while (iterator.hasNext()) { - Integer integer = (Integer) iterator.next(); - MobEffect mobeffect = (MobEffect) this.effects.get(integer); - - if (!this.world.isStatic) { - iterator.remove(); - this.c(mobeffect); - } - } - } - - public Collection getEffects() { - return this.effects.values(); - } - - public boolean hasEffect(int i) { - // CraftBukkit - Add size check for efficiency - return this.effects.size() != 0 && this.effects.containsKey(Integer.valueOf(i)); - } - - public boolean hasEffect(MobEffectList mobeffectlist) { - // CraftBukkit - Add size check for efficiency - return this.effects.size() != 0 && this.effects.containsKey(Integer.valueOf(mobeffectlist.id)); - } - - public MobEffect getEffect(MobEffectList mobeffectlist) { - return (MobEffect) this.effects.get(Integer.valueOf(mobeffectlist.id)); - } - - public void addEffect(MobEffect mobeffect) { - if (this.e(mobeffect)) { - if (this.effects.containsKey(Integer.valueOf(mobeffect.getEffectId()))) { - ((MobEffect) this.effects.get(Integer.valueOf(mobeffect.getEffectId()))).a(mobeffect); - this.b((MobEffect) this.effects.get(Integer.valueOf(mobeffect.getEffectId()))); - } else { - this.effects.put(Integer.valueOf(mobeffect.getEffectId()), mobeffect); - this.a(mobeffect); - } - } + public boolean bi() { + return !this.world.isStatic; } - public boolean e(MobEffect mobeffect) { - if (this.getMonsterType() == EnumMonsterType.UNDEAD) { - int i = mobeffect.getEffectId(); - - if (i == MobEffectList.REGENERATION.id || i == MobEffectList.POISON.id) { - return false; - } - } - - return true; + public boolean K() { + return !this.dead; } - public boolean bD() { - return this.getMonsterType() == EnumMonsterType.UNDEAD; + public boolean L() { + return !this.dead; } - public void o(int i) { - MobEffect mobeffect = (MobEffect) this.effects.remove(Integer.valueOf(i)); - - if (mobeffect != null) { - this.c(mobeffect); - } + public float getHeadHeight() { + return this.length * 0.85F; } - protected void a(MobEffect mobeffect) { - this.updateEffects = true; + protected void J() { + this.velocityChanged = this.random.nextDouble() >= this.a(GenericAttributes.c).e(); } - protected void b(MobEffect mobeffect) { - this.updateEffects = true; + public float getHeadRotation() { + return this.aP; } - protected void c(MobEffect mobeffect) { - this.updateEffects = true; + public float bj() { + return this.bq; } - public float bE() { - float f = 1.0F; - - if (this.hasEffect(MobEffectList.FASTER_MOVEMENT)) { - f *= 1.0F + 0.2F * (float) (this.getEffect(MobEffectList.FASTER_MOVEMENT).getAmplifier() + 1); - } - - if (this.hasEffect(MobEffectList.SLOWER_MOVEMENT)) { - f *= 1.0F - 0.15F * (float) (this.getEffect(MobEffectList.SLOWER_MOVEMENT).getAmplifier() + 1); - } - + public void m(float f) { if (f < 0.0F) { f = 0.0F; } - return f; - } - - public void enderTeleportTo(double d0, double d1, double d2) { - this.setPositionRotation(d0, d1, d2, this.yaw, this.pitch); - } - - public boolean isBaby() { - return false; - } - - public EnumMonsterType getMonsterType() { - return EnumMonsterType.UNDEFINED; - } - - public void a(ItemStack itemstack) { - this.makeSound("random.break", 0.8F, 0.8F + this.world.random.nextFloat() * 0.4F); - - for (int i = 0; i < 5; ++i) { - Vec3D vec3d = this.world.getVec3DPool().create(((double) this.random.nextFloat() - 0.5D) * 0.1D, Math.random() * 0.1D + 0.1D, 0.0D); - - vec3d.a(-this.pitch * 3.1415927F / 180.0F); - vec3d.b(-this.yaw * 3.1415927F / 180.0F); - Vec3D vec3d1 = this.world.getVec3DPool().create(((double) this.random.nextFloat() - 0.5D) * 0.3D, (double) (-this.random.nextFloat()) * 0.6D - 0.3D, 0.6D); - - vec3d1.a(-this.pitch * 3.1415927F / 180.0F); - vec3d1.b(-this.yaw * 3.1415927F / 180.0F); - vec3d1 = vec3d1.add(this.locX, this.locY + (double) this.getHeadHeight(), this.locZ); - this.world.addParticle("iconcrack_" + itemstack.getItem().id, vec3d1.c, vec3d1.d, vec3d1.e, vec3d.c, vec3d.d + 0.05D, vec3d.e); - } - } - - public int ar() { - if (this.getGoalTarget() == null) { - return 3; - } else { - int i = (int) ((float) this.health - (float) this.maxHealth * 0.33F); // CraftBukkit - this.getMaxHealth() -> this.maxHealth - - i -= (3 - this.world.difficulty) * 4; - if (i < 0) { - i = 0; - } - - return i + 3; - } - } - - public ItemStack bG() { - return this.equipment[0]; - } - - public ItemStack getEquipment(int i) { - return this.equipment[i]; - } - - public ItemStack q(int i) { - return this.equipment[i + 1]; - } - - public void setEquipment(int i, ItemStack itemstack) { - this.equipment[i] = itemstack; - } - - public ItemStack[] getEquipment() { - return this.equipment; - } - - protected void dropEquipment(boolean flag, int i) { - for (int j = 0; j < this.getEquipment().length; ++j) { - ItemStack itemstack = this.getEquipment(j); - boolean flag1 = this.dropChances[j] > 1.0F; - - if (itemstack != null && (flag || flag1) && this.random.nextFloat() - (float) i * 0.01F < this.dropChances[j]) { - if (!flag1 && itemstack.g()) { - int k = Math.max(itemstack.l() - 25, 1); - int l = itemstack.l() - this.random.nextInt(this.random.nextInt(k) + 1); - - if (l > k) { - l = k; - } - - if (l < 1) { - l = 1; - } - - itemstack.setData(l); - } - - this.a(itemstack, 0.0F); - } - } - } - - protected void bH() { - if (this.random.nextFloat() < d[this.world.difficulty]) { - int i = this.random.nextInt(2); - float f = this.world.difficulty == 3 ? 0.1F : 0.25F; - - if (this.random.nextFloat() < 0.095F) { - ++i; - } - - if (this.random.nextFloat() < 0.095F) { - ++i; - } - - if (this.random.nextFloat() < 0.095F) { - ++i; - } - - for (int j = 3; j >= 0; --j) { - ItemStack itemstack = this.q(j); - - if (j < 3 && this.random.nextFloat() < f) { - break; - } - - if (itemstack == null) { - Item item = a(j + 1, i); - - if (item != null) { - this.setEquipment(j + 1, new ItemStack(item)); - } - } - } - } - } - - public void receive(Entity entity, int i) { - if (!entity.dead && !this.world.isStatic) { - EntityTracker entitytracker = ((WorldServer) this.world).getTracker(); - - if (entity instanceof EntityItem) { - entitytracker.a(entity, (Packet) (new Packet22Collect(entity.id, this.id))); - } - - if (entity instanceof EntityArrow) { - entitytracker.a(entity, (Packet) (new Packet22Collect(entity.id, this.id))); - } - - if (entity instanceof EntityExperienceOrb) { - entitytracker.a(entity, (Packet) (new Packet22Collect(entity.id, this.id))); - } - } - } - - public static int b(ItemStack itemstack) { - if (itemstack.id != Block.PUMPKIN.id && itemstack.id != Item.SKULL.id) { - if (itemstack.getItem() instanceof ItemArmor) { - switch (((ItemArmor) itemstack.getItem()).b) { - case 0: - return 4; - - case 1: - return 3; - - case 2: - return 2; - - case 3: - return 1; - } - } - - return 0; - } else { - return 4; - } - } - - public static Item a(int i, int j) { - switch (i) { - case 4: - if (j == 0) { - return Item.LEATHER_HELMET; - } else if (j == 1) { - return Item.GOLD_HELMET; - } else if (j == 2) { - return Item.CHAINMAIL_HELMET; - } else if (j == 3) { - return Item.IRON_HELMET; - } else if (j == 4) { - return Item.DIAMOND_HELMET; - } - - case 3: - if (j == 0) { - return Item.LEATHER_CHESTPLATE; - } else if (j == 1) { - return Item.GOLD_CHESTPLATE; - } else if (j == 2) { - return Item.CHAINMAIL_CHESTPLATE; - } else if (j == 3) { - return Item.IRON_CHESTPLATE; - } else if (j == 4) { - return Item.DIAMOND_CHESTPLATE; - } - - case 2: - if (j == 0) { - return Item.LEATHER_LEGGINGS; - } else if (j == 1) { - return Item.GOLD_LEGGINGS; - } else if (j == 2) { - return Item.CHAINMAIL_LEGGINGS; - } else if (j == 3) { - return Item.IRON_LEGGINGS; - } else if (j == 4) { - return Item.DIAMOND_LEGGINGS; - } - - case 1: - if (j == 0) { - return Item.LEATHER_BOOTS; - } else if (j == 1) { - return Item.GOLD_BOOTS; - } else if (j == 2) { - return Item.CHAINMAIL_BOOTS; - } else if (j == 3) { - return Item.IRON_BOOTS; - } else if (j == 4) { - return Item.DIAMOND_BOOTS; - } - - default: - return null; - } - } - - protected void bI() { - if (this.bG() != null && this.random.nextFloat() < b[this.world.difficulty]) { - EnchantmentManager.a(this.random, this.bG(), 5 + this.world.difficulty * this.random.nextInt(6)); - } - - for (int i = 0; i < 4; ++i) { - ItemStack itemstack = this.q(i); - - if (itemstack != null && this.random.nextFloat() < c[this.world.difficulty]) { - EnchantmentManager.a(this.random, itemstack, 5 + this.world.difficulty * this.random.nextInt(6)); - } - } - } - - public void bJ() {} - - private int h() { - return this.hasEffect(MobEffectList.FASTER_DIG) ? 6 - (1 + this.getEffect(MobEffectList.FASTER_DIG).getAmplifier()) * 1 : (this.hasEffect(MobEffectList.SLOWER_DIG) ? 6 + (1 + this.getEffect(MobEffectList.SLOWER_DIG).getAmplifier()) * 2 : 6); - } - - public void bK() { - if (!this.br || this.bs >= this.h() / 2 || this.bs < 0) { - this.bs = -1; - this.br = true; - if (this.world instanceof WorldServer) { - ((WorldServer) this.world).getTracker().a((Entity) this, (Packet) (new Packet18ArmAnimation(this, 1))); - } - } - } - - public boolean bL() { - return false; - } - - public final int bM() { - return this.datawatcher.getByte(10); - } - - public final void r(int i) { - this.datawatcher.watch(10, Byte.valueOf((byte) i)); - } - - public EntityLiving bN() { - return (EntityLiving) (this.bt.c() != null ? this.bt.c() : (this.killer != null ? this.killer : (this.lastDamager != null ? this.lastDamager : null))); - } - - public String getLocalizedName() { - return this.hasCustomName() ? this.getCustomName() : super.getLocalizedName(); - } - - public void setCustomName(String s) { - this.datawatcher.watch(5, s); - } - - public String getCustomName() { - return this.datawatcher.getString(5); - } - - public boolean hasCustomName() { - return this.datawatcher.getString(5).length() > 0; - } - - public void setCustomNameVisible(boolean flag) { - this.datawatcher.watch(6, Byte.valueOf((byte) (flag ? 1 : 0))); - } - - public boolean getCustomNameVisible() { - return this.datawatcher.getByte(6) == 1; - } - - public void a(int i, float f) { - this.dropChances[i] = f; - } - - public boolean bT() { - return this.canPickUpLoot; - } - - public void h(boolean flag) { - this.canPickUpLoot = flag; - } - - public boolean bU() { - return this.persistent; + this.bq = f; } } diff --git a/src/main/java/net/minecraft/server/EntityMagmaCube.java b/src/main/java/net/minecraft/server/EntityMagmaCube.java index 40066247..3f9dd6a0 100644 --- a/src/main/java/net/minecraft/server/EntityMagmaCube.java +++ b/src/main/java/net/minecraft/server/EntityMagmaCube.java @@ -4,28 +4,31 @@ public class EntityMagmaCube extends EntitySlime { public EntityMagmaCube(World world) { super(world); - this.texture = "/mob/lava.png"; this.fireProof = true; - this.aO = 0.2F; + } + + protected void ax() { + super.ax(); + this.a(GenericAttributes.d).a(0.20000000298023224D); } public boolean canSpawn() { return this.world.difficulty > 0 && this.world.b(this.boundingBox) && this.world.getCubes(this, this.boundingBox).isEmpty() && !this.world.containsLiquid(this.boundingBox); } - public int aZ() { + public int aM() { return this.getSize() * 3; } - public float c(float f) { + public float d(float f) { return 1.0F; } - protected String h() { + protected String bF() { return "flame"; } - protected EntitySlime i() { + protected EntitySlime bG() { return new EntityMagmaCube(this.world); } @@ -58,38 +61,38 @@ public class EntityMagmaCube extends EntitySlime { return false; } - protected int j() { - return super.j() * 4; + protected int bH() { + return super.bH() * 4; } - protected void k() { - this.b *= 0.9F; + protected void bI() { + this.h *= 0.9F; } - protected void bl() { + protected void ba() { this.motY = (double) (0.42F + (float) this.getSize() * 0.1F); this.an = true; } - protected void a(float f) {} + protected void b(float f) {} - protected boolean l() { + protected boolean bJ() { return true; } - protected int m() { - return super.m() + 2; + protected int bK() { + return super.bK() + 2; } - protected String bc() { + protected String aK() { return "mob.slime." + (this.getSize() > 1 ? "big" : "small"); } - protected String bd() { + protected String aL() { return "mob.slime." + (this.getSize() > 1 ? "big" : "small"); } - protected String n() { + protected String bL() { return this.getSize() > 1 ? "mob.magmacube.big" : "mob.magmacube.small"; } @@ -97,7 +100,7 @@ public class EntityMagmaCube extends EntitySlime { return false; } - protected boolean o() { + protected boolean bM() { return true; } } diff --git a/src/main/java/net/minecraft/server/EntityMinecartAbstract.java b/src/main/java/net/minecraft/server/EntityMinecartAbstract.java index eed15778..126826cd 100644 --- a/src/main/java/net/minecraft/server/EntityMinecartAbstract.java +++ b/src/main/java/net/minecraft/server/EntityMinecartAbstract.java @@ -37,7 +37,6 @@ public abstract class EntityMinecartAbstract extends Entity { public EntityMinecartAbstract(World world) { super(world); - this.a = false; this.m = true; this.a(0.98F, 0.7F); this.height = this.length / 2.0F; @@ -66,14 +65,14 @@ public abstract class EntityMinecartAbstract extends Entity { } } - protected boolean f_() { + protected boolean e_() { return false; } protected void a() { this.datawatcher.a(17, new Integer(0)); this.datawatcher.a(18, new Integer(1)); - this.datawatcher.a(19, new Integer(0)); + this.datawatcher.a(19, new Float(0.0F)); this.datawatcher.a(20, new Integer(0)); this.datawatcher.a(21, new Integer(6)); this.datawatcher.a(22, Byte.valueOf((byte) 0)); @@ -93,7 +92,7 @@ public abstract class EntityMinecartAbstract extends Entity { public EntityMinecartAbstract(World world, double d0, double d1, double d2) { this(world); - this.setPosition(d0, d1 + (double) this.height, d2); + this.setPosition(d0, d1, d2); this.motX = 0.0D; this.motY = 0.0D; this.motZ = 0.0D; @@ -108,7 +107,7 @@ public abstract class EntityMinecartAbstract extends Entity { return (double) this.length * 0.0D - 0.30000001192092896D; } - public boolean damageEntity(DamageSource damagesource, int i) { + public boolean damageEntity(DamageSource damagesource, float f) { if (!this.world.isStatic && !this.dead) { if (this.isInvulnerable()) { return false; @@ -117,23 +116,23 @@ public abstract class EntityMinecartAbstract extends Entity { Vehicle vehicle = (Vehicle) this.getBukkitEntity(); org.bukkit.entity.Entity passenger = (damagesource.getEntity() == null) ? null : damagesource.getEntity().getBukkitEntity(); - VehicleDamageEvent event = new VehicleDamageEvent(vehicle, passenger, i); + VehicleDamageEvent event = new VehicleDamageEvent(vehicle, passenger, f); this.world.getServer().getPluginManager().callEvent(event); if (event.isCancelled()) { return true; } - i = event.getDamage(); + f = (float) event.getDamage(); // CraftBukkit end - this.j(-this.k()); - this.i(10); + this.h(-this.k()); + this.c(10); this.J(); - this.setDamage(this.getDamage() + i * 10); + this.setDamage(this.getDamage() + f * 10.0F); boolean flag = damagesource.getEntity() instanceof EntityHuman && ((EntityHuman) damagesource.getEntity()).abilities.canInstantlyBuild; - if (flag || this.getDamage() > 40) { + if (flag || this.getDamage() > 40.0F) { if (this.passenger != null) { this.passenger.mount(this); } @@ -198,11 +197,11 @@ public abstract class EntityMinecartAbstract extends Entity { } if (this.j() > 0) { - this.i(this.j() - 1); + this.c(this.j() - 1); } - if (this.getDamage() > 0) { - this.setDamage(this.getDamage() - 1); + if (this.getDamage() > 0.0F) { + this.setDamage(this.getDamage() - 1.0F); } if (this.locY < -64.0D) { @@ -229,7 +228,7 @@ public abstract class EntityMinecartAbstract extends Entity { b0 = -1; } - this.c(b0); + this.b(b0); } this.ap = false; @@ -285,7 +284,7 @@ public abstract class EntityMinecartAbstract extends Entity { double d5 = 0.0078125D; int l = this.world.getTypeId(j, i, k); - if (BlockMinecartTrackAbstract.d_(l)) { + if (BlockMinecartTrackAbstract.e_(l)) { int i1 = this.world.getData(j, i, k); this.a(j, i, k, d4, d5, l, i1); @@ -447,14 +446,20 @@ public abstract class EntityMinecartAbstract extends Entity { this.motZ = d6 * d3 / d4; double d7; double d8; - - if (this.passenger != null) { - d7 = this.passenger.motX * this.passenger.motX + this.passenger.motZ * this.passenger.motZ; - d8 = this.motX * this.motX + this.motZ * this.motZ; - if (d7 > 1.0E-4D && d8 < 0.01D) { - this.motX += this.passenger.motX * 0.1D; - this.motZ += this.passenger.motZ * 0.1D; - flag1 = false; + double d9; + double d10; + + if (this.passenger != null && this.passenger instanceof EntityLiving) { + d7 = (double) ((EntityLiving) this.passenger).bf; + if (d7 > 0.0D) { + d8 = -Math.sin((double) (this.passenger.yaw * 3.1415927F / 180.0F)); + d9 = Math.cos((double) (this.passenger.yaw * 3.1415927F / 180.0F)); + d10 = this.motX * this.motX + this.motZ * this.motZ; + if (d10 < 0.01D) { + this.motX += d8 * 0.1D; + this.motZ += d9 * 0.1D; + flag1 = false; + } } } @@ -473,8 +478,8 @@ public abstract class EntityMinecartAbstract extends Entity { d7 = 0.0D; d8 = (double) i + 0.5D + (double) aint[0][0] * 0.5D; - double d9 = (double) k + 0.5D + (double) aint[0][2] * 0.5D; - double d10 = (double) i + 0.5D + (double) aint[1][0] * 0.5D; + d9 = (double) k + 0.5D + (double) aint[0][2] * 0.5D; + d10 = (double) i + 0.5D + (double) aint[1][0] * 0.5D; double d11 = (double) k + 0.5D + (double) aint[1][2] * 0.5D; d2 = d10 - d8; @@ -598,7 +603,7 @@ public abstract class EntityMinecartAbstract extends Entity { int l = this.world.getTypeId(i, j, k); - if (BlockMinecartTrackAbstract.d_(l)) { + if (BlockMinecartTrackAbstract.e_(l)) { int i1 = this.world.getData(i, j, k); d1 = (double) j; @@ -654,9 +659,9 @@ public abstract class EntityMinecartAbstract extends Entity { protected void a(NBTTagCompound nbttagcompound) { if (nbttagcompound.getBoolean("CustomDisplayTile")) { - this.k(nbttagcompound.getInt("DisplayTile")); - this.l(nbttagcompound.getInt("DisplayData")); - this.m(nbttagcompound.getInt("DisplayOffset")); + this.i(nbttagcompound.getInt("DisplayTile")); + this.j(nbttagcompound.getInt("DisplayData")); + this.k(nbttagcompound.getInt("DisplayOffset")); } if (nbttagcompound.hasKey("CustomName") && nbttagcompound.getString("CustomName").length() > 0) { @@ -764,15 +769,15 @@ public abstract class EntityMinecartAbstract extends Entity { } } - public void setDamage(int i) { - this.datawatcher.watch(19, Integer.valueOf(i)); + public void setDamage(float f) { + this.datawatcher.watch(19, Float.valueOf(f)); } - public int getDamage() { - return this.datawatcher.getInt(19); + public float getDamage() { + return this.datawatcher.getFloat(19); } - public void i(int i) { + public void c(int i) { this.datawatcher.watch(17, Integer.valueOf(i)); } @@ -780,7 +785,7 @@ public abstract class EntityMinecartAbstract extends Entity { return this.datawatcher.getInt(17); } - public void j(int i) { + public void h(int i) { this.datawatcher.watch(18, Integer.valueOf(i)); } @@ -820,12 +825,12 @@ public abstract class EntityMinecartAbstract extends Entity { return 6; } - public void k(int i) { + public void i(int i) { this.getDataWatcher().watch(20, Integer.valueOf(i & '\uffff' | this.o() << 16)); this.a(true); } - public void l(int i) { + public void j(int i) { Block block = this.m(); int j = block == null ? 0 : block.id; @@ -833,7 +838,7 @@ public abstract class EntityMinecartAbstract extends Entity { this.a(true); } - public void m(int i) { + public void k(int i) { this.getDataWatcher().watch(21, Integer.valueOf(i)); this.a(true); } diff --git a/src/main/java/net/minecraft/server/EntityMinecartContainer.java b/src/main/java/net/minecraft/server/EntityMinecartContainer.java index c207076d..e89b1063 100644 --- a/src/main/java/net/minecraft/server/EntityMinecartContainer.java +++ b/src/main/java/net/minecraft/server/EntityMinecartContainer.java @@ -148,9 +148,9 @@ public abstract class EntityMinecartContainer extends EntityMinecartAbstract imp return 64; } - public void c(int i) { + public void b(int i) { this.b = false; - super.c(i); + super.b(i); } public void die() { @@ -224,7 +224,7 @@ public abstract class EntityMinecartContainer extends EntityMinecartAbstract imp } } - public boolean a_(EntityHuman entityhuman) { + public boolean c(EntityHuman entityhuman) { if (!this.world.isStatic) { entityhuman.openContainer(this); } diff --git a/src/main/java/net/minecraft/server/EntityMonster.java b/src/main/java/net/minecraft/server/EntityMonster.java index e9d15405..71d23ef6 100644 --- a/src/main/java/net/minecraft/server/EntityMonster.java +++ b/src/main/java/net/minecraft/server/EntityMonster.java @@ -6,15 +6,15 @@ public abstract class EntityMonster extends EntityCreature implements IMonster { public EntityMonster(World world) { super(world); - this.be = 5; + this.b = 5; } public void c() { - this.br(); - float f = this.c(1.0F); + this.aS(); + float f = this.d(1.0F); if (f > 0.5F) { - this.bC += 2; + this.aV += 2; } super.c(); @@ -30,13 +30,13 @@ public abstract class EntityMonster extends EntityCreature implements IMonster { protected Entity findTarget() { EntityHuman entityhuman = this.world.findNearbyVulnerablePlayer(this, 16.0D); - return entityhuman != null && this.n(entityhuman) ? entityhuman : null; + return entityhuman != null && this.o(entityhuman) ? entityhuman : null; } - public boolean damageEntity(DamageSource damagesource, int i) { + public boolean damageEntity(DamageSource damagesource, float f) { if (this.isInvulnerable()) { return false; - } else if (super.damageEntity(damagesource, i)) { + } else if (super.damageEntity(damagesource, f)) { Entity entity = damagesource.getEntity(); if (this.passenger != entity && this.vehicle != entity) { @@ -68,36 +68,27 @@ public abstract class EntityMonster extends EntityCreature implements IMonster { } public boolean m(Entity entity) { - int i = this.c(entity); - - if (this.hasEffect(MobEffectList.INCREASE_DAMAGE)) { - i += 3 << this.getEffect(MobEffectList.INCREASE_DAMAGE).getAmplifier(); - } - - if (this.hasEffect(MobEffectList.WEAKNESS)) { - i -= 2 << this.getEffect(MobEffectList.WEAKNESS).getAmplifier(); - } - - int j = 0; + float f = (float) this.a(GenericAttributes.e).e(); + int i = 0; if (entity instanceof EntityLiving) { - i += EnchantmentManager.a((EntityLiving) this, (EntityLiving) entity); - j += EnchantmentManager.getKnockbackEnchantmentLevel(this, (EntityLiving) entity); + f += EnchantmentManager.a((EntityLiving) this, (EntityLiving) entity); + i += EnchantmentManager.getKnockbackEnchantmentLevel(this, (EntityLiving) entity); } - boolean flag = entity.damageEntity(DamageSource.mobAttack(this), i); + boolean flag = entity.damageEntity(DamageSource.mobAttack(this), f); if (flag) { - if (j > 0) { - entity.g((double) (-MathHelper.sin(this.yaw * 3.1415927F / 180.0F) * (float) j * 0.5F), 0.1D, (double) (MathHelper.cos(this.yaw * 3.1415927F / 180.0F) * (float) j * 0.5F)); + if (i > 0) { + entity.g((double) (-MathHelper.sin(this.yaw * 3.1415927F / 180.0F) * (float) i * 0.5F), 0.1D, (double) (MathHelper.cos(this.yaw * 3.1415927F / 180.0F) * (float) i * 0.5F)); this.motX *= 0.6D; this.motZ *= 0.6D; } - int k = EnchantmentManager.getFireAspectEnchantmentLevel(this); + int j = EnchantmentManager.getFireAspectEnchantmentLevel(this); - if (k > 0) { - entity.setOnFire(k * 4); + if (j > 0) { + entity.setOnFire(j * 4); } if (entity instanceof EntityLiving) { @@ -129,7 +120,7 @@ public abstract class EntityMonster extends EntityCreature implements IMonster { } else { int l = this.world.getLightLevel(i, j, k); - if (this.world.O()) { + if (this.world.P()) { int i1 = this.world.j; this.world.j = 10; @@ -142,10 +133,11 @@ public abstract class EntityMonster extends EntityCreature implements IMonster { } public boolean canSpawn() { - return this.i_() && super.canSpawn(); + return this.world.difficulty > 0 && this.i_() && super.canSpawn(); } - public int c(Entity entity) { - return 2; + protected void ax() { + super.ax(); + this.aT().b(GenericAttributes.e); } } diff --git a/src/main/java/net/minecraft/server/EntityMushroomCow.java b/src/main/java/net/minecraft/server/EntityMushroomCow.java index 3f22c9fc..abf7d270 100644 --- a/src/main/java/net/minecraft/server/EntityMushroomCow.java +++ b/src/main/java/net/minecraft/server/EntityMushroomCow.java @@ -6,11 +6,10 @@ public class EntityMushroomCow extends EntityCow { public EntityMushroomCow(World world) { super(world); - this.texture = "/mob/redcow.png"; this.a(0.9F, 1.3F); } - public boolean a_(EntityHuman entityhuman) { + public boolean a(EntityHuman entityhuman) { ItemStack itemstack = entityhuman.inventory.getItemInHand(); if (itemstack != null && itemstack.id == Item.BOWL.id && this.getAge() >= 0) { @@ -42,7 +41,7 @@ public class EntityMushroomCow extends EntityCow { entitycow.setPositionRotation(this.locX, this.locY, this.locZ, this.yaw, this.pitch); entitycow.setHealth(this.getHealth()); - entitycow.ay = this.ay; + entitycow.aN = this.aN; this.world.addEntity(entitycow); for (int i = 0; i < 5; ++i) { @@ -52,7 +51,7 @@ public class EntityMushroomCow extends EntityCow { return true; } else { - return super.a_(entityhuman); + return super.a(entityhuman); } } diff --git a/src/main/java/net/minecraft/server/EntityOcelot.java b/src/main/java/net/minecraft/server/EntityOcelot.java index 48d311f1..e2f5a04f 100644 --- a/src/main/java/net/minecraft/server/EntityOcelot.java +++ b/src/main/java/net/minecraft/server/EntityOcelot.java @@ -2,25 +2,24 @@ package net.minecraft.server; public class EntityOcelot extends EntityTameableAnimal { - private PathfinderGoalTempt e; + private PathfinderGoalTempt bq; public EntityOcelot(World world) { super(world); - this.texture = "/mob/ozelot.png"; this.a(0.6F, 0.8F); this.getNavigation().a(true); this.goalSelector.a(1, new PathfinderGoalFloat(this)); - this.goalSelector.a(2, this.d); - this.goalSelector.a(3, this.e = new PathfinderGoalTempt(this, 0.18F, Item.RAW_FISH.id, true)); - this.goalSelector.a(4, new PathfinderGoalAvoidPlayer(this, EntityHuman.class, 16.0F, 0.23F, 0.4F)); - this.goalSelector.a(5, new PathfinderGoalFollowOwner(this, 0.3F, 10.0F, 5.0F)); - this.goalSelector.a(6, new PathfinderGoalJumpOnBlock(this, 0.4F)); + this.goalSelector.a(2, this.bp); + this.goalSelector.a(3, this.bq = new PathfinderGoalTempt(this, 0.6D, Item.RAW_FISH.id, true)); + this.goalSelector.a(4, new PathfinderGoalAvoidPlayer(this, EntityHuman.class, 16.0F, 0.8D, 1.33D)); + this.goalSelector.a(5, new PathfinderGoalFollowOwner(this, 1.0D, 10.0F, 5.0F)); + this.goalSelector.a(6, new PathfinderGoalJumpOnBlock(this, 1.33D)); this.goalSelector.a(7, new PathfinderGoalLeapAtTarget(this, 0.3F)); this.goalSelector.a(8, new PathfinderGoalOcelotAttack(this)); - this.goalSelector.a(9, new PathfinderGoalBreed(this, 0.23F)); - this.goalSelector.a(10, new PathfinderGoalRandomStroll(this, 0.23F)); + this.goalSelector.a(9, new PathfinderGoalBreed(this, 0.8D)); + this.goalSelector.a(10, new PathfinderGoalRandomStroll(this, 0.8D)); this.goalSelector.a(11, new PathfinderGoalLookAtPlayer(this, EntityHuman.class, 10.0F)); - this.targetSelector.a(1, new PathfinderGoalRandomTargetNonTamed(this, EntityChicken.class, 14.0F, 750, false)); + this.targetSelector.a(1, new PathfinderGoalRandomTargetNonTamed(this, EntityChicken.class, 750, false)); } protected void a() { @@ -28,14 +27,14 @@ public class EntityOcelot extends EntityTameableAnimal { this.datawatcher.a(18, Byte.valueOf((byte) 0)); } - public void bp() { + public void bg() { if (this.getControllerMove().a()) { - float f = this.getControllerMove().b(); + double d0 = this.getControllerMove().b(); - if (f == 0.18F) { + if (d0 == 0.6D) { this.setSneaking(true); this.setSprinting(false); - } else if (f == 0.4F) { + } else if (d0 == 1.33D) { this.setSneaking(false); this.setSprinting(true); } else { @@ -49,18 +48,20 @@ public class EntityOcelot extends EntityTameableAnimal { } protected boolean isTypeNotPersistent() { - return !this.isTamed(); + return !this.isTamed() && this.ticksLived > 2400; } - public boolean bh() { + public boolean bb() { return true; } - public int getMaxHealth() { - return 10; + protected void ax() { + super.ax(); + this.a(GenericAttributes.a).a(10.0D); + this.a(GenericAttributes.d).a(0.30000001192092896D); } - protected void a(float f) {} + protected void b(float f) {} public void b(NBTTagCompound nbttagcompound) { super.b(nbttagcompound); @@ -72,19 +73,19 @@ public class EntityOcelot extends EntityTameableAnimal { this.setCatType(nbttagcompound.getInt("CatType")); } - protected String bb() { - return this.isTamed() ? (this.r() ? "mob.cat.purr" : (this.random.nextInt(4) == 0 ? "mob.cat.purreow" : "mob.cat.meow")) : ""; + protected String r() { + return this.isTamed() ? (this.bU() ? "mob.cat.purr" : (this.random.nextInt(4) == 0 ? "mob.cat.purreow" : "mob.cat.meow")) : ""; } - protected String bc() { + protected String aK() { return "mob.cat.hitt"; } - protected String bd() { + protected String aL() { return "mob.cat.hitt"; } - protected float ba() { + protected float aW() { return 0.4F; } @@ -93,15 +94,15 @@ public class EntityOcelot extends EntityTameableAnimal { } public boolean m(Entity entity) { - return entity.damageEntity(DamageSource.mobAttack(this), 3); + return entity.damageEntity(DamageSource.mobAttack(this), 3.0F); } - public boolean damageEntity(DamageSource damagesource, int i) { + public boolean damageEntity(DamageSource damagesource, float f) { if (this.isInvulnerable()) { return false; } else { - this.d.setSitting(false); - return super.damageEntity(damagesource, i); + this.bp.setSitting(false); + return super.damageEntity(damagesource, f); } } @@ -109,14 +110,14 @@ public class EntityOcelot extends EntityTameableAnimal { org.bukkit.craftbukkit.event.CraftEventFactory.callEntityDeathEvent(this); // CraftBukkit - Call EntityDeathEvent } - public boolean a_(EntityHuman entityhuman) { + public boolean a(EntityHuman entityhuman) { ItemStack itemstack = entityhuman.inventory.getItemInHand(); if (this.isTamed()) { - if (entityhuman.name.equalsIgnoreCase(this.getOwnerName()) && !this.world.isStatic && !this.c(itemstack)) { - this.d.setSitting(!this.isSitting()); + if (entityhuman.getName().equalsIgnoreCase(this.getOwnerName()) && !this.world.isStatic && !this.c(itemstack)) { + this.bp.setSitting(!this.isSitting()); } - } else if (this.e.f() && itemstack != null && itemstack.id == Item.RAW_FISH.id && entityhuman.e(this) < 9.0D) { + } else if (this.bq.f() && itemstack != null && itemstack.id == Item.RAW_FISH.id && entityhuman.e(this) < 9.0D) { if (!entityhuman.abilities.canInstantlyBuild) { --itemstack.count; } @@ -130,12 +131,12 @@ public class EntityOcelot extends EntityTameableAnimal { if (this.random.nextInt(3) == 0 && !org.bukkit.craftbukkit.event.CraftEventFactory.callEntityTameEvent(this, entityhuman).isCancelled()) { this.setTamed(true); this.setCatType(1 + this.world.random.nextInt(3)); - this.setOwnerName(entityhuman.name); - this.i(true); - this.d.setSitting(true); + this.setOwnerName(entityhuman.getName()); + this.j(true); + this.bp.setSitting(true); this.world.broadcastEntityEffect(this, (byte) 7); } else { - this.i(false); + this.j(false); this.world.broadcastEntityEffect(this, (byte) 6); } } @@ -143,7 +144,7 @@ public class EntityOcelot extends EntityTameableAnimal { return true; } - return super.a_(entityhuman); + return super.a(entityhuman); } public EntityOcelot b(EntityAgeable entityageable) { @@ -172,7 +173,7 @@ public class EntityOcelot extends EntityTameableAnimal { } else { EntityOcelot entityocelot = (EntityOcelot) entityanimal; - return !entityocelot.isTamed() ? false : this.r() && entityocelot.r(); + return !entityocelot.isTamed() ? false : this.bU() && entityocelot.bU(); } } @@ -212,7 +213,8 @@ public class EntityOcelot extends EntityTameableAnimal { return this.hasCustomName() ? this.getCustomName() : (this.isTamed() ? "entity.Cat.name" : super.getLocalizedName()); } - public void bJ() { + public GroupDataEntity a(GroupDataEntity groupdataentity) { + groupdataentity = super.a(groupdataentity); if (this.world.random.nextInt(7) == 0) { for (int i = 0; i < 2; ++i) { EntityOcelot entityocelot = new EntityOcelot(this.world); @@ -222,6 +224,8 @@ public class EntityOcelot extends EntityTameableAnimal { this.world.addEntity(entityocelot); } } + + return groupdataentity; } public EntityAgeable createChild(EntityAgeable entityageable) { diff --git a/src/main/java/net/minecraft/server/EntityPainting.java b/src/main/java/net/minecraft/server/EntityPainting.java index 6fb2afa5..1bd0cccf 100644 --- a/src/main/java/net/minecraft/server/EntityPainting.java +++ b/src/main/java/net/minecraft/server/EntityPainting.java @@ -63,11 +63,19 @@ public class EntityPainting extends EntityHanging { return this.art.C; } - public int g() { + public int e() { return this.art.D; } - public void h() { + public void b(Entity entity) { + if (entity instanceof EntityHuman) { + EntityHuman entityhuman = (EntityHuman) entity; + + if (entityhuman.abilities.canInstantlyBuild) { + return; + } + } + this.a(new ItemStack(Item.PAINTING), 0.0F); } } diff --git a/src/main/java/net/minecraft/server/EntityPig.java b/src/main/java/net/minecraft/server/EntityPig.java index e9fe7cff..b77751e5 100644 --- a/src/main/java/net/minecraft/server/EntityPig.java +++ b/src/main/java/net/minecraft/server/EntityPig.java @@ -4,41 +4,40 @@ import org.bukkit.craftbukkit.event.CraftEventFactory; // CraftBukkit public class EntityPig extends EntityAnimal { - private final PathfinderGoalPassengerCarrotStick d; + private final PathfinderGoalPassengerCarrotStick bp; public EntityPig(World world) { super(world); - this.texture = "/mob/pig.png"; this.a(0.9F, 0.9F); this.getNavigation().a(true); - float f = 0.25F; - this.goalSelector.a(0, new PathfinderGoalFloat(this)); - this.goalSelector.a(1, new PathfinderGoalPanic(this, 0.38F)); - this.goalSelector.a(2, this.d = new PathfinderGoalPassengerCarrotStick(this, 0.34F)); - this.goalSelector.a(3, new PathfinderGoalBreed(this, f)); - this.goalSelector.a(4, new PathfinderGoalTempt(this, 0.3F, Item.CARROT_STICK.id, false)); - this.goalSelector.a(4, new PathfinderGoalTempt(this, 0.3F, Item.CARROT.id, false)); - this.goalSelector.a(5, new PathfinderGoalFollowParent(this, 0.28F)); - this.goalSelector.a(6, new PathfinderGoalRandomStroll(this, f)); + this.goalSelector.a(1, new PathfinderGoalPanic(this, 1.25D)); + this.goalSelector.a(2, this.bp = new PathfinderGoalPassengerCarrotStick(this, 0.3F)); + this.goalSelector.a(3, new PathfinderGoalBreed(this, 1.0D)); + this.goalSelector.a(4, new PathfinderGoalTempt(this, 1.2D, Item.CARROT_STICK.id, false)); + this.goalSelector.a(4, new PathfinderGoalTempt(this, 1.2D, Item.CARROT.id, false)); + this.goalSelector.a(5, new PathfinderGoalFollowParent(this, 1.1D)); + this.goalSelector.a(6, new PathfinderGoalRandomStroll(this, 1.0D)); this.goalSelector.a(7, new PathfinderGoalLookAtPlayer(this, EntityHuman.class, 6.0F)); this.goalSelector.a(8, new PathfinderGoalRandomLookaround(this)); } - public boolean bh() { + public boolean bb() { return true; } - public int getMaxHealth() { - return 10; + protected void ax() { + super.ax(); + this.a(GenericAttributes.a).a(10.0D); + this.a(GenericAttributes.d).a(0.25D); } - protected void bo() { - super.bo(); + protected void be() { + super.be(); } - public boolean bL() { - ItemStack itemstack = ((EntityHuman) this.passenger).bG(); + public boolean bu() { + ItemStack itemstack = ((EntityHuman) this.passenger).aV(); return itemstack != null && itemstack.id == Item.CARROT_STICK.id; } @@ -58,15 +57,15 @@ public class EntityPig extends EntityAnimal { this.setSaddle(nbttagcompound.getBoolean("Saddle")); } - protected String bb() { + protected String r() { return "mob.pig.say"; } - protected String bc() { + protected String aK() { return "mob.pig.say"; } - protected String bd() { + protected String aL() { return "mob.pig.death"; } @@ -74,8 +73,8 @@ public class EntityPig extends EntityAnimal { this.makeSound("mob.pig.step", 0.15F, 1.0F); } - public boolean a_(EntityHuman entityhuman) { - if (super.a_(entityhuman)) { + public boolean a(EntityHuman entityhuman) { + if (super.a(entityhuman)) { return true; } else if (this.hasSaddle() && !this.world.isStatic && (this.passenger == null || this.passenger == entityhuman)) { entityhuman.mount(this); @@ -139,8 +138,8 @@ public class EntityPig extends EntityAnimal { } } - protected void a(float f) { - super.a(f); + protected void b(float f) { + super.b(f); if (f > 5.0F && this.passenger instanceof EntityHuman) { ((EntityHuman) this.passenger).a((Statistic) AchievementList.u); } @@ -154,8 +153,8 @@ public class EntityPig extends EntityAnimal { return itemstack != null && itemstack.id == Item.CARROT.id; } - public PathfinderGoalPassengerCarrotStick n() { - return this.d; + public PathfinderGoalPassengerCarrotStick bQ() { + return this.bp; } public EntityAgeable createChild(EntityAgeable entityageable) { diff --git a/src/main/java/net/minecraft/server/EntityPigZombie.java b/src/main/java/net/minecraft/server/EntityPigZombie.java index 8a6dda60..3bc0f925 100644 --- a/src/main/java/net/minecraft/server/EntityPigZombie.java +++ b/src/main/java/net/minecraft/server/EntityPigZombie.java @@ -1,6 +1,7 @@ package net.minecraft.server; import java.util.List; +import java.util.UUID; // CraftBukkit start import org.bukkit.craftbukkit.inventory.CraftItemStack; @@ -9,24 +10,41 @@ import org.bukkit.event.entity.EntityTargetEvent; public class EntityPigZombie extends EntityZombie { - public int angerLevel = 0; // CraftBukkit - private -> public - private int soundDelay = 0; + private static final UUID bq = UUID.fromString("49455A49-7EC5-45BA-B886-3B90B23A1718"); + private static final AttributeModifier br = (new AttributeModifier(bq, "Attacking speed boost", 0.45D, 0)).a(false); + public int angerLevel; // CraftBukkit - private -> public + private int soundDelay; + private Entity bu; public EntityPigZombie(World world) { super(world); - this.texture = "/mob/pigzombie.png"; - this.bI = 0.5F; this.fireProof = true; } - protected boolean bh() { + protected void ax() { + super.ax(); + this.a(bp).a(0.0D); + this.a(GenericAttributes.d).a(0.5D); + this.a(GenericAttributes.e).a(5.0D); + } + + protected boolean bb() { return false; } public void l_() { - this.bI = this.target != null ? 0.95F : 0.5F; + if (this.bu != this.target && !this.world.isStatic) { + AttributeInstance attributeinstance = this.a(GenericAttributes.d); + + attributeinstance.b(br); + if (this.target != null) { + attributeinstance.a(br); + } + } + + this.bu = this.target; if (this.soundDelay > 0 && --this.soundDelay == 0) { - this.makeSound("mob.zombiepig.zpigangry", this.ba() * 2.0F, ((this.random.nextFloat() - this.random.nextFloat()) * 0.2F + 1.0F) * 1.8F); + this.makeSound("mob.zombiepig.zpigangry", this.aW() * 2.0F, ((this.random.nextFloat() - this.random.nextFloat()) * 0.2F + 1.0F) * 1.8F); } super.l_(); @@ -50,7 +68,7 @@ public class EntityPigZombie extends EntityZombie { return this.angerLevel == 0 ? null : super.findTarget(); } - public boolean damageEntity(DamageSource damagesource, int i) { + public boolean damageEntity(DamageSource damagesource, float f) { if (this.isInvulnerable()) { return false; } else { @@ -59,24 +77,24 @@ public class EntityPigZombie extends EntityZombie { if (entity instanceof EntityHuman) { List list = this.world.getEntities(this, this.boundingBox.grow(32.0D, 32.0D, 32.0D)); - for (int j = 0; j < list.size(); ++j) { - Entity entity1 = (Entity) list.get(j); + for (int i = 0; i < list.size(); ++i) { + Entity entity1 = (Entity) list.get(i); if (entity1 instanceof EntityPigZombie) { EntityPigZombie entitypigzombie = (EntityPigZombie) entity1; - entitypigzombie.p(entity); + entitypigzombie.c(entity); } } - this.p(entity); + this.c(entity); } - return super.damageEntity(damagesource, i); + return super.damageEntity(damagesource, f); } } - private void p(Entity entity) { + private void c(Entity entity) { // CraftBukkit start org.bukkit.entity.Entity bukkitTarget = entity == null ? null : entity.getBukkitEntity(); @@ -99,15 +117,15 @@ public class EntityPigZombie extends EntityZombie { this.soundDelay = this.random.nextInt(40); } - protected String bb() { + protected String r() { return "mob.zombiepig.zpig"; } - protected String bc() { + protected String aK() { return "mob.zombiepig.zpighurt"; } - protected String bd() { + protected String aL() { return "mob.zombiepig.zpigdeath"; } @@ -142,7 +160,7 @@ public class EntityPigZombie extends EntityZombie { // CraftBukkit end } - public boolean a_(EntityHuman entityhuman) { + public boolean a(EntityHuman entityhuman) { return false; } @@ -156,23 +174,13 @@ public class EntityPigZombie extends EntityZombie { return Item.ROTTEN_FLESH.id; } - protected void bH() { + protected void bs() { this.setEquipment(0, new ItemStack(Item.GOLD_SWORD)); } - public void bJ() { - super.bJ(); + public GroupDataEntity a(GroupDataEntity groupdataentity) { + super.a(groupdataentity); this.setVillager(false); - } - - public int c(Entity entity) { - ItemStack itemstack = this.bG(); - int i = 5; - - if (itemstack != null) { - i += itemstack.a((Entity) this); - } - - return i; + return groupdataentity; } } diff --git a/src/main/java/net/minecraft/server/EntityPlayer.java b/src/main/java/net/minecraft/server/EntityPlayer.java index 7de5b48b..094da966 100644 --- a/src/main/java/net/minecraft/server/EntityPlayer.java +++ b/src/main/java/net/minecraft/server/EntityPlayer.java @@ -23,7 +23,7 @@ import org.bukkit.event.player.PlayerTeleportEvent.TeleportCause; public class EntityPlayer extends EntityHuman implements ICrafting { - private LocaleLanguage locale = new LocaleLanguage("en_US"); + private String locale = "en_US"; public PlayerConnection playerConnection; public MinecraftServer server; public PlayerInteractManager playerInteractManager; @@ -31,18 +31,19 @@ public class EntityPlayer extends EntityHuman implements ICrafting { public double e; public final List chunkCoordIntPairQueue = new LinkedList(); public final List removeQueue = new LinkedList(); - private int cm = -99999999; - private int cn = -99999999; - private boolean co = true; + private float bO = Float.MIN_VALUE; + private float bP = -1.0E8F; + private int bQ = -99999999; + private boolean bR = true; public int lastSentExp = -99999999; // CraftBukkit - private -> public public int invulnerableTicks = 60; // CraftBukkit - private -> public - private int cr = 0; - private int cs = 0; - private boolean ct = true; - private int containerCounter = 0; + private int bU; + private int bV; + private boolean bW = true; + private int containerCounter; public boolean h; public int ping; - public boolean viewingCredits = false; + public boolean viewingCredits; // CraftBukkit start public String displayName; public String listName; @@ -54,16 +55,16 @@ public class EntityPlayer extends EntityHuman implements ICrafting { // CraftBukkit end public EntityPlayer(MinecraftServer minecraftserver, World world, String s, PlayerInteractManager playerinteractmanager) { - super(world); + super(world, s); playerinteractmanager.player = this; this.playerInteractManager = playerinteractmanager; - this.cr = minecraftserver.getPlayerList().o(); + this.bU = minecraftserver.getPlayerList().o(); ChunkCoordinates chunkcoordinates = world.getSpawn(); int i = chunkcoordinates.x; int j = chunkcoordinates.z; int k = chunkcoordinates.y; - if (!world.worldProvider.f && world.getWorldData().getGameType() != EnumGamemode.ADVENTURE) { + if (!world.worldProvider.g && world.getWorldData().getGameType() != EnumGamemode.ADVENTURE) { int l = Math.max(5, minecraftserver.getSpawnProtection() - 6); i += this.random.nextInt(l * 2) - l; @@ -73,7 +74,6 @@ public class EntityPlayer extends EntityHuman implements ICrafting { this.server = minecraftserver; this.Y = 0.0F; - this.name = s; this.height = 0.0F; this.setPositionRotation((double) i + 0.5D, (double) k, (double) j + 0.5D, 0.0F, 0.0F); @@ -84,7 +84,7 @@ public class EntityPlayer extends EntityHuman implements ICrafting { // CraftBukkit start this.displayName = this.name; this.listName = this.name; - this.canPickUpLoot = true; + // this.canPickUpLoot = true; TODO // CraftBukkit end } @@ -140,7 +140,7 @@ public class EntityPlayer extends EntityHuman implements ICrafting { this.activeContainer.addSlotListener(this); } - protected void e_() { + protected void d_() { this.height = 0.0F; } @@ -152,6 +152,10 @@ public class EntityPlayer extends EntityHuman implements ICrafting { this.playerInteractManager.a(); --this.invulnerableTicks; this.activeContainer.b(); + if (!this.world.isStatic && !this.activeContainer.a((EntityHuman) this)) { + this.closeInventory(); + this.activeContainer = this.defaultContainer; + } // CraftBukkit start - Check inventory status every tick if (!this.activeContainer.a(this)) { // Should be stillValid @@ -207,19 +211,13 @@ public class EntityPlayer extends EntityHuman implements ICrafting { while (iterator2.hasNext()) { Chunk chunk = (Chunk) iterator2.next(); - this.o().getTracker().a(this, chunk); + this.p().getTracker().a(this, chunk); } } } } - public void setHealth(int i) { - super.setHealth(i); - // CraftBukkit - Update ALL the scores! - this.world.getServer().getScoreboardManager().updateAllScoresForList(IScoreboardCriteria.f, this.getLocalizedName(), com.google.common.collect.ImmutableList.of(this)); - } - - public void g() { + public void h() { try { super.l_(); @@ -235,12 +233,18 @@ public class EntityPlayer extends EntityHuman implements ICrafting { } } - if (this.getHealth() != this.cm || this.cn != this.foodData.a() || this.foodData.e() == 0.0F != this.co) { + if (this.getHealth() != this.bP || this.bQ != this.foodData.a() || this.foodData.e() == 0.0F != this.bR) { // CraftBukkit - this.getHealth() -> this.getScaledHealth() this.playerConnection.sendPacket(new Packet8UpdateHealth(this.getScaledHealth(), this.foodData.a(), this.foodData.e())); - this.cm = this.getHealth(); - this.cn = this.foodData.a(); - this.co = this.foodData.e() == 0.0F; + this.bP = this.getHealth(); + this.bQ = this.foodData.a(); + this.bR = this.foodData.e() == 0.0F; + } + + if (this.getHealth() + this.bj() != this.bO) { + this.bO = this.getHealth() + this.bj(); + // CraftBukkit - Update ALL the scores! + this.world.getServer().getScoreboardManager().updateAllScoresForList(IScoreboardCriteria.f, this.getLocalizedName(), com.google.common.collect.ImmutableList.of(this)); } if (this.expTotal != this.lastSentExp) { @@ -290,12 +294,19 @@ public class EntityPlayer extends EntityHuman implements ICrafting { } } - org.bukkit.event.entity.PlayerDeathEvent event = CraftEventFactory.callPlayerDeathEvent(this, loot, this.bt.b()); + ChatMessage chatmessage = this.aN().b(); + + String deathmessage = chatmessage.toString(); + org.bukkit.event.entity.PlayerDeathEvent event = CraftEventFactory.callPlayerDeathEvent(this, loot, deathmessage); String deathMessage = event.getDeathMessage(); if (deathMessage != null && deathMessage.length() > 0) { - this.server.getPlayerList().k(event.getDeathMessage()); + if (deathMessage.equals(chatmessage.toString())) { + this.server.getPlayerList().sendMessage(chatmessage); + } else { + this.server.getPlayerList().sendMessage(ChatMessage.d(event.getDeathMessage())); + } } // CraftBukkit - we clean the player's inventory after the EntityDeathEvent is called so plugins can get the exact state of the inventory. @@ -322,19 +333,21 @@ public class EntityPlayer extends EntityHuman implements ICrafting { scoreboardscore.incrementScore(); } - EntityLiving entityliving = this.bN(); + EntityLiving entityliving = this.aO(); if (entityliving != null) { - entityliving.c(this, this.aM); + entityliving.b(this, this.bb); } + + this.a(StatisticList.y, 1); } - public boolean damageEntity(DamageSource damagesource, int i) { + public boolean damageEntity(DamageSource damagesource, float f) { if (this.isInvulnerable()) { return false; } else { // CraftBukkit - this.server.getPvP() -> this.world.pvpMode - boolean flag = this.server.T() && this.world.pvpMode && "fall".equals(damagesource.translationIndex); + boolean flag = this.server.V() && this.world.pvpMode && "fall".equals(damagesource.translationIndex); if (!flag && this.invulnerableTicks > 0 && damagesource != DamageSource.OUT_OF_WORLD) { return false; @@ -355,7 +368,7 @@ public class EntityPlayer extends EntityHuman implements ICrafting { } } - return super.damageEntity(damagesource, i); + return super.damageEntity(damagesource, f); } } } @@ -365,14 +378,14 @@ public class EntityPlayer extends EntityHuman implements ICrafting { return !this.world.pvpMode ? false : super.a(entityhuman); } - public void c(int i) { + public void b(int i) { if (this.dimension == 1 && i == 1) { this.a((Statistic) AchievementList.C); this.world.kill(this); this.viewingCredits = true; this.playerConnection.sendPacket(new Packet70Bed(4, 0)); } else { - if (this.dimension == 1 && i == 0) { + if (this.dimension == 0 && i == 1) { this.a((Statistic) AchievementList.B); // CraftBukkit start - Rely on custom portal management /* @@ -394,8 +407,8 @@ public class EntityPlayer extends EntityHuman implements ICrafting { this.server.getPlayerList().changeDimension(this, i, cause); // CraftBukkit end this.lastSentExp = -1; - this.cm = -1; - this.cn = -1; + this.bP = -1.0F; + this.bQ = -1; } } @@ -420,7 +433,7 @@ public class EntityPlayer extends EntityHuman implements ICrafting { if (enumbedresult == EnumBedResult.OK) { Packet17EntityLocationAction packet17entitylocationaction = new Packet17EntityLocationAction(this, 0, i, j, k); - this.o().getTracker().a((Entity) this, (Packet) packet17entitylocationaction); + this.p().getTracker().a((Entity) this, (Packet) packet17entitylocationaction); this.playerConnection.a(this.locX, this.locY, this.locZ, this.yaw, this.pitch); this.playerConnection.sendPacket(packet17entitylocationaction); } @@ -432,7 +445,7 @@ public class EntityPlayer extends EntityHuman implements ICrafting { if (this.fauxSleeping && !this.sleeping) return; // CraftBukkit - Can't leave bed if not in one! if (this.isSleeping()) { - this.o().getTracker().sendPacketToEntity(this, new Packet18ArmAnimation(this, 3)); + this.p().getTracker().sendPacketToEntity(this, new Packet18ArmAnimation(this, 3)); } super.a(flag, flag1, flag2); @@ -453,7 +466,7 @@ public class EntityPlayer extends EntityHuman implements ICrafting { super.setPassengerOf(entity); // CraftBukkit end - this.playerConnection.sendPacket(new Packet39AttachEntity(this, this.vehicle)); + this.playerConnection.sendPacket(new Packet39AttachEntity(0, this, this.vehicle)); this.playerConnection.a(this.locX, this.locY, this.locZ, this.yaw, this.pitch); } @@ -631,6 +644,23 @@ public class EntityPlayer extends EntityHuman implements ICrafting { } } + public void openHorseInventory(EntityHorse entityhorse, IInventory iinventory) { + // CraftBukkit start - Inventory open hook + Container container = CraftEventFactory.callInventoryOpenEvent(this, new ContainerHorse(this.inventory, iinventory, entityhorse)); + if(container == null) return; + // CraftBukkit end + + if (this.activeContainer != this.defaultContainer) { + this.closeInventory(); + } + + this.nextContainerCounter(); + this.playerConnection.sendPacket(new Packet100OpenWindow(this.containerCounter, 11, iinventory.getName(), iinventory.getSize(), iinventory.c(), entityhorse.id)); + this.activeContainer = container; // CraftBukkit - Use container we passed to event + this.activeContainer.windowId = this.containerCounter; + this.activeContainer.addSlotListener(this); + } + public void a(Container container, int i, ItemStack itemstack) { if (!(container.getSlot(i) instanceof SlotResult)) { if (!this.h) { @@ -660,7 +690,7 @@ public class EntityPlayer extends EntityHuman implements ICrafting { public void closeInventory() { CraftEventFactory.handleInventoryCloseEvent(this); // CraftBukkit this.playerConnection.sendPacket(new Packet101CloseWindow(this.activeContainer.windowId)); - this.j(); + this.k(); } public void broadcastCarriedItem() { @@ -669,25 +699,35 @@ public class EntityPlayer extends EntityHuman implements ICrafting { } } - public void j() { + public void k() { this.activeContainer.b((EntityHuman) this); this.activeContainer = this.defaultContainer; } + public void a(float f, float f1, boolean flag, boolean flag1) { + if (this.vehicle != null) { + if (f >= -1.0F && f <= 1.0F) { + this.be = f; + } + + if (f1 >= -1.0F && f1 <= 1.0F) { + this.bf = f1; + } + + this.bd = flag; + this.setSneaking(flag1); + } + } + public void a(Statistic statistic, int i) { if (statistic != null) { if (!statistic.f) { - while (i > 100) { - this.playerConnection.sendPacket(new Packet200Statistic(statistic.e, 100)); - i -= 100; - } - this.playerConnection.sendPacket(new Packet200Statistic(statistic.e, i)); } } } - public void k() { + public void l() { if (this.passenger != null) { this.passenger.mount(this); } @@ -698,34 +738,31 @@ public class EntityPlayer extends EntityHuman implements ICrafting { } public void triggerHealthUpdate() { - this.cm = -99999999; + this.bP = -1.0E8F; this.lastSentExp = -1; // CraftBukkit - Added to reset } - public void b(String s) { - LocaleLanguage localelanguage = LocaleLanguage.a(); - String s1 = localelanguage.a(s); - - this.playerConnection.sendPacket(new Packet3Chat(s1)); + public void a(String s) { + this.playerConnection.sendPacket(new Packet3Chat(ChatMessage.e(s))); } - protected void m() { + protected void n() { this.playerConnection.sendPacket(new Packet38EntityStatus(this.id, (byte) 9)); - super.m(); + super.n(); } public void a(ItemStack itemstack, int i) { super.a(itemstack, i); - if (itemstack != null && itemstack.getItem() != null && itemstack.getItem().b_(itemstack) == EnumAnimation.EAT) { - this.o().getTracker().sendPacketToEntity(this, new Packet18ArmAnimation(this, 5)); + if (itemstack != null && itemstack.getItem() != null && itemstack.getItem().c_(itemstack) == EnumAnimation.EAT) { + this.p().getTracker().sendPacketToEntity(this, new Packet18ArmAnimation(this, 5)); } } public void copyTo(EntityHuman entityhuman, boolean flag) { super.copyTo(entityhuman, flag); this.lastSentExp = -1; - this.cm = -1; - this.cn = -1; + this.bP = -1.0F; + this.bQ = -1; this.removeQueue.addAll(((EntityPlayer) entityhuman).removeQueue); } @@ -749,11 +786,11 @@ public class EntityPlayer extends EntityHuman implements ICrafting { } public void b(Entity entity) { - this.o().getTracker().sendPacketToEntity(this, new Packet18ArmAnimation(entity, 6)); + this.p().getTracker().sendPacketToEntity(this, new Packet18ArmAnimation(entity, 6)); } public void c(Entity entity) { - this.o().getTracker().sendPacketToEntity(this, new Packet18ArmAnimation(entity, 7)); + this.p().getTracker().sendPacketToEntity(this, new Packet18ArmAnimation(entity, 7)); } public void updateAbilities() { @@ -762,7 +799,7 @@ public class EntityPlayer extends EntityHuman implements ICrafting { } } - public WorldServer o() { + public WorldServer p() { return (WorldServer) this.world; } @@ -771,15 +808,15 @@ public class EntityPlayer extends EntityHuman implements ICrafting { this.playerConnection.sendPacket(new Packet70Bed(3, enumgamemode.a())); } - public void sendMessage(String s) { - this.playerConnection.sendPacket(new Packet3Chat(s)); + public void sendMessage(ChatMessage chatmessage) { + this.playerConnection.sendPacket(new Packet3Chat(chatmessage)); } public boolean a(int i, String s) { - return "seed".equals(s) && !this.server.T() ? true : (!"tell".equals(s) && !"help".equals(s) && !"me".equals(s) ? this.server.getPlayerList().isOp(this.name) : true); + return "seed".equals(s) && !this.server.V() ? true : (!"tell".equals(s) && !"help".equals(s) && !"me".equals(s) ? (this.server.getPlayerList().isOp(this.name) ? this.server.k() >= i : false) : true); } - public String p() { + public String q() { String s = this.playerConnection.networkManager.getSocketAddress().toString(); s = s.substring(s.indexOf("/") + 1); @@ -788,31 +825,24 @@ public class EntityPlayer extends EntityHuman implements ICrafting { } public void a(Packet204LocaleAndViewDistance packet204localeandviewdistance) { - if (this.locale.b().containsKey(packet204localeandviewdistance.d())) { - this.locale.a(packet204localeandviewdistance.d(), false); - } - + this.locale = packet204localeandviewdistance.d(); int i = 256 >> packet204localeandviewdistance.f(); if (i > 3 && i < 15) { - this.cr = i; + this.bU = i; } - this.cs = packet204localeandviewdistance.g(); - this.ct = packet204localeandviewdistance.h(); - if (this.server.I() && this.server.H().equals(this.name)) { + this.bV = packet204localeandviewdistance.g(); + this.bW = packet204localeandviewdistance.h(); + if (this.server.K() && this.server.J().equals(this.name)) { this.server.c(packet204localeandviewdistance.i()); } this.b(1, !packet204localeandviewdistance.j()); } - public LocaleLanguage getLocale() { - return this.locale; - } - public int getChatFlags() { - return this.cs; + return this.bV; } public void a(String s, int i) { @@ -859,7 +889,7 @@ public class EntityPlayer extends EntityHuman implements ICrafting { public void resetPlayerWeather() { this.weather = null; - this.setPlayerWeather(this.o().getWorldData().hasStorm() ? WeatherType.DOWNFALL : WeatherType.CLEAR, false); + this.setPlayerWeather(this.world.getWorldData().hasStorm() ? WeatherType.DOWNFALL : WeatherType.CLEAR, false); } @Override @@ -877,7 +907,7 @@ public class EntityPlayer extends EntityHuman implements ICrafting { this.newLevel = this.expLevel; } - this.health = this.maxHealth; + this.setHealth(this.maxHealth); this.fireTicks = 0; this.fallDistance = 0; this.foodData = new FoodMetaData(); @@ -890,7 +920,7 @@ public class EntityPlayer extends EntityHuman implements ICrafting { this.activeContainer = this.defaultContainer; this.killer = null; this.lastDamager = null; - this.bt = new CombatTracker(this); // Should be combatTracker + this.combatTracker = new CombatTracker(this); this.lastSentExp = -1; if (this.keepLevel || keepInventory) { this.exp = exp; diff --git a/src/main/java/net/minecraft/server/EntityPotion.java b/src/main/java/net/minecraft/server/EntityPotion.java index be9e339c..a4330c74 100644 --- a/src/main/java/net/minecraft/server/EntityPotion.java +++ b/src/main/java/net/minecraft/server/EntityPotion.java @@ -32,7 +32,7 @@ public class EntityPotion extends EntityProjectile { this.c = itemstack; } - protected float g() { + protected float e() { return 0.05F; } diff --git a/src/main/java/net/minecraft/server/EntityProjectile.java b/src/main/java/net/minecraft/server/EntityProjectile.java index 2ab11b3c..688c4d80 100644 --- a/src/main/java/net/minecraft/server/EntityProjectile.java +++ b/src/main/java/net/minecraft/server/EntityProjectile.java @@ -7,13 +7,13 @@ public abstract class EntityProjectile extends Entity implements IProjectile { private int blockX = -1; private int blockY = -1; private int blockZ = -1; - private int inBlockId = 0; - protected boolean inGround = false; - public int shake = 0; + private int inBlockId; + protected boolean inGround; + public int shake; public EntityLiving shooter; // CraftBukkit - private -> public - public String shooterName = null; // CraftBukkit - private -> public + public String shooterName; // CraftBukkit - private -> public private int i; - private int j = 0; + private int j; public EntityProjectile(World world) { super(world); @@ -188,7 +188,7 @@ public abstract class EntityProjectile extends Entity implements IProjectile { this.pitch = this.lastPitch + (this.pitch - this.lastPitch) * 0.2F; this.yaw = this.lastYaw + (this.yaw - this.lastYaw) * 0.2F; float f2 = 0.99F; - float f3 = this.g(); + float f3 = this.e(); if (this.G()) { for (int k = 0; k < 4; ++k) { @@ -207,7 +207,7 @@ public abstract class EntityProjectile extends Entity implements IProjectile { this.setPosition(this.locX, this.locY, this.locZ); } - protected float g() { + protected float e() { return 0.03F; } diff --git a/src/main/java/net/minecraft/server/EntitySheep.java b/src/main/java/net/minecraft/server/EntitySheep.java index a1f0fcb4..7bf82d9b 100644 --- a/src/main/java/net/minecraft/server/EntitySheep.java +++ b/src/main/java/net/minecraft/server/EntitySheep.java @@ -9,51 +9,50 @@ import org.bukkit.event.player.PlayerShearEntityEvent; public class EntitySheep extends EntityAnimal { - private final InventoryCrafting e = new InventoryCrafting(new ContainerSheepBreed(this), 2, 1); - public static final float[][] d = new float[][] { { 1.0F, 1.0F, 1.0F}, { 0.85F, 0.5F, 0.2F}, { 0.7F, 0.3F, 0.85F}, { 0.4F, 0.6F, 0.85F}, { 0.9F, 0.9F, 0.2F}, { 0.5F, 0.8F, 0.1F}, { 0.95F, 0.5F, 0.65F}, { 0.3F, 0.3F, 0.3F}, { 0.6F, 0.6F, 0.6F}, { 0.3F, 0.5F, 0.6F}, { 0.5F, 0.25F, 0.7F}, { 0.2F, 0.3F, 0.7F}, { 0.4F, 0.3F, 0.2F}, { 0.4F, 0.5F, 0.2F}, { 0.6F, 0.2F, 0.2F}, { 0.1F, 0.1F, 0.1F}}; - private int f; - private PathfinderGoalEatTile g = new PathfinderGoalEatTile(this); + private final InventoryCrafting bq = new InventoryCrafting(new ContainerSheepBreed(this), 2, 1); + public static final float[][] bp = new float[][] { { 1.0F, 1.0F, 1.0F}, { 0.85F, 0.5F, 0.2F}, { 0.7F, 0.3F, 0.85F}, { 0.4F, 0.6F, 0.85F}, { 0.9F, 0.9F, 0.2F}, { 0.5F, 0.8F, 0.1F}, { 0.95F, 0.5F, 0.65F}, { 0.3F, 0.3F, 0.3F}, { 0.6F, 0.6F, 0.6F}, { 0.3F, 0.5F, 0.6F}, { 0.5F, 0.25F, 0.7F}, { 0.2F, 0.3F, 0.7F}, { 0.4F, 0.3F, 0.2F}, { 0.4F, 0.5F, 0.2F}, { 0.6F, 0.2F, 0.2F}, { 0.1F, 0.1F, 0.1F}}; + private int br; + private PathfinderGoalEatTile bs = new PathfinderGoalEatTile(this); public EntitySheep(World world) { super(world); - this.texture = "/mob/sheep.png"; this.a(0.9F, 1.3F); - float f = 0.23F; - this.getNavigation().a(true); this.goalSelector.a(0, new PathfinderGoalFloat(this)); - this.goalSelector.a(1, new PathfinderGoalPanic(this, 0.38F)); - this.goalSelector.a(2, new PathfinderGoalBreed(this, f)); - this.goalSelector.a(3, new PathfinderGoalTempt(this, 0.25F, Item.WHEAT.id, false)); - this.goalSelector.a(4, new PathfinderGoalFollowParent(this, 0.25F)); - this.goalSelector.a(5, this.g); - this.goalSelector.a(6, new PathfinderGoalRandomStroll(this, f)); + this.goalSelector.a(1, new PathfinderGoalPanic(this, 1.25D)); + this.goalSelector.a(2, new PathfinderGoalBreed(this, 1.0D)); + this.goalSelector.a(3, new PathfinderGoalTempt(this, 1.1D, Item.WHEAT.id, false)); + this.goalSelector.a(4, new PathfinderGoalFollowParent(this, 1.1D)); + this.goalSelector.a(5, this.bs); + this.goalSelector.a(6, new PathfinderGoalRandomStroll(this, 1.0D)); this.goalSelector.a(7, new PathfinderGoalLookAtPlayer(this, EntityHuman.class, 6.0F)); this.goalSelector.a(8, new PathfinderGoalRandomLookaround(this)); - this.e.setItem(0, new ItemStack(Item.INK_SACK, 1, 0)); - this.e.setItem(1, new ItemStack(Item.INK_SACK, 1, 0)); - this.e.resultInventory = new InventoryCraftResult(); // CraftBukkit - add result slot for event + this.bq.setItem(0, new ItemStack(Item.INK_SACK, 1, 0)); + this.bq.setItem(1, new ItemStack(Item.INK_SACK, 1, 0)); + this.bq.resultInventory = new InventoryCraftResult(); // CraftBukkit - add result slot for event } - protected boolean bh() { + protected boolean bb() { return true; } - protected void bo() { - this.f = this.g.f(); - super.bo(); + protected void be() { + this.br = this.bs.f(); + super.be(); } public void c() { if (this.world.isStatic) { - this.f = Math.max(0, this.f - 1); + this.br = Math.max(0, this.br - 1); } super.c(); } - public int getMaxHealth() { - return 8; + protected void ax() { + super.ax(); + this.a(GenericAttributes.a).a(8.0D); + this.a(GenericAttributes.d).a(0.23000000417232513D); } protected void a() { @@ -77,7 +76,7 @@ public class EntitySheep extends EntityAnimal { return Block.WOOL.id; } - public boolean a_(EntityHuman entityhuman) { + public boolean a(EntityHuman entityhuman) { ItemStack itemstack = entityhuman.inventory.getItemInHand(); if (itemstack != null && itemstack.id == Item.SHEARS.id && !this.isSheared() && !this.isBaby()) { @@ -107,7 +106,7 @@ public class EntitySheep extends EntityAnimal { this.makeSound("mob.sheep.shear", 1.0F, 1.0F); } - return super.a_(entityhuman); + return super.a(entityhuman); } public void b(NBTTagCompound nbttagcompound) { @@ -122,15 +121,15 @@ public class EntitySheep extends EntityAnimal { this.setColor(nbttagcompound.getByte("Color")); } - protected String bb() { + protected String r() { return "mob.sheep.say"; } - protected String bc() { + protected String aK() { return "mob.sheep.say"; } - protected String bd() { + protected String aL() { return "mob.sheep.say"; } @@ -177,7 +176,7 @@ public class EntitySheep extends EntityAnimal { return entitysheep1; } - public void aK() { + public void n() { // CraftBukkit start SheepRegrowWoolEvent event = new SheepRegrowWoolEvent((org.bukkit.entity.Sheep) this.getBukkitEntity()); this.world.getServer().getPluginManager().callEvent(event); @@ -188,27 +187,23 @@ public class EntitySheep extends EntityAnimal { // CraftBukkit end if (this.isBaby()) { - int i = this.getAge() + 1200; - - if (i > 0) { - i = 0; - } - - this.setAge(i); + this.a(60); } } - public void bJ() { + public GroupDataEntity a(GroupDataEntity groupdataentity) { + groupdataentity = super.a(groupdataentity); this.setColor(a(this.world.random)); + return groupdataentity; } private int a(EntityAnimal entityanimal, EntityAnimal entityanimal1) { int i = this.b(entityanimal); int j = this.b(entityanimal1); - this.e.getItem(0).setData(i); - this.e.getItem(1).setData(j); - ItemStack itemstack = CraftingManager.getInstance().craft(this.e, ((EntitySheep) entityanimal).world); + this.bq.getItem(0).setData(i); + this.bq.getItem(1).setData(j); + ItemStack itemstack = CraftingManager.getInstance().craft(this.bq, ((EntitySheep) entityanimal).world); int k; if (itemstack != null && itemstack.getItem().id == Item.INK_SACK.id) { diff --git a/src/main/java/net/minecraft/server/EntitySilverfish.java b/src/main/java/net/minecraft/server/EntitySilverfish.java index 4ea06d0a..fe212d4a 100644 --- a/src/main/java/net/minecraft/server/EntitySilverfish.java +++ b/src/main/java/net/minecraft/server/EntitySilverfish.java @@ -4,20 +4,21 @@ import org.bukkit.craftbukkit.event.CraftEventFactory; // CraftBukkit public class EntitySilverfish extends EntityMonster { - private int d; + private int bp; public EntitySilverfish(World world) { super(world); - this.texture = "/mob/silverfish.png"; this.a(0.3F, 0.7F); - this.bI = 0.6F; } - public int getMaxHealth() { - return 8; + protected void ax() { + super.ax(); + this.a(GenericAttributes.a).a(8.0D); + this.a(GenericAttributes.d).a(0.6000000238418579D); + this.a(GenericAttributes.e).a(1.0D); } - protected boolean f_() { + protected boolean e_() { return false; } @@ -27,27 +28,27 @@ public class EntitySilverfish extends EntityMonster { return this.world.findNearbyVulnerablePlayer(this, d0); } - protected String bb() { + protected String r() { return "mob.silverfish.say"; } - protected String bc() { + protected String aK() { return "mob.silverfish.hit"; } - protected String bd() { + protected String aL() { return "mob.silverfish.kill"; } - public boolean damageEntity(DamageSource damagesource, int i) { + public boolean damageEntity(DamageSource damagesource, float f) { if (this.isInvulnerable()) { return false; } else { - if (this.d <= 0 && (damagesource instanceof EntityDamageSource || damagesource == DamageSource.MAGIC)) { - this.d = 20; + if (this.bp <= 0 && (damagesource instanceof EntityDamageSource || damagesource == DamageSource.MAGIC)) { + this.bp = 20; } - return super.damageEntity(damagesource, i); + return super.damageEntity(damagesource, f); } } @@ -67,21 +68,21 @@ public class EntitySilverfish extends EntityMonster { } public void l_() { - this.ay = this.yaw; + this.aN = this.yaw; super.l_(); } - protected void bq() { - super.bq(); + protected void bh() { + super.bh(); if (!this.world.isStatic) { int i; int j; int k; int l; - if (this.d > 0) { - --this.d; - if (this.d == 0) { + if (this.bp > 0) { + --this.bp; + if (this.bp == 0) { i = MathHelper.floor(this.locX); j = MathHelper.floor(this.locY); k = MathHelper.floor(this.locZ); @@ -99,7 +100,23 @@ public class EntitySilverfish extends EntityMonster { } // CraftBukkit end - this.world.setAir(i + i1, j + l, k + j1, false); + if (!this.world.getGameRules().getBoolean("mobGriefing")) { + int l1 = this.world.getData(i + i1, j + l, k + j1); + Block block = Block.STONE; + + if (l1 == 1) { + block = Block.COBBLESTONE; + } + + if (l1 == 2) { + block = Block.SMOOTH_BRICK; + } + + this.world.setTypeIdAndData(i + i1, j + l, k + j1, block.id, 0, 3); + } else { + this.world.setAir(i + i1, j + l, k + j1, false); + } + Block.MONSTER_EGGS.postBreak(this.world, i + i1, j + l, k + j1, 0); if (this.random.nextBoolean()) { flag = true; @@ -112,27 +129,27 @@ public class EntitySilverfish extends EntityMonster { } } - if (this.target == null && !this.k()) { + if (this.target == null && !this.bI()) { i = MathHelper.floor(this.locX); j = MathHelper.floor(this.locY + 0.5D); k = MathHelper.floor(this.locZ); - int l1 = this.random.nextInt(6); + int i2 = this.random.nextInt(6); - l = this.world.getTypeId(i + Facing.b[l1], j + Facing.c[l1], k + Facing.d[l1]); + l = this.world.getTypeId(i + Facing.b[i2], j + Facing.c[i2], k + Facing.d[i2]); if (BlockMonsterEggs.d(l)) { // CraftBukkit start - if (CraftEventFactory.callEntityChangeBlockEvent(this, i + Facing.b[l1], j + Facing.c[l1], k + Facing.d[l1], Block.MONSTER_EGGS.id, BlockMonsterEggs.e(l)).isCancelled()) { + if (CraftEventFactory.callEntityChangeBlockEvent(this, i + Facing.b[i2], j + Facing.c[i2], k + Facing.d[i2], Block.MONSTER_EGGS.id, BlockMonsterEggs.e(l)).isCancelled()) { return; } // CraftBukkit end - this.world.setTypeIdAndData(i + Facing.b[l1], j + Facing.c[l1], k + Facing.d[l1], Block.MONSTER_EGGS.id, BlockMonsterEggs.e(l), 3); - this.aU(); + this.world.setTypeIdAndData(i + Facing.b[i2], j + Facing.c[i2], k + Facing.d[i2], Block.MONSTER_EGGS.id, BlockMonsterEggs.e(l), 3); + this.q(); this.die(); } else { - this.i(); + this.bG(); } - } else if (this.target != null && !this.k()) { + } else if (this.target != null && !this.bI()) { this.target = null; } } @@ -156,10 +173,6 @@ public class EntitySilverfish extends EntityMonster { } } - public int c(Entity entity) { - return 1; - } - public EnumMonsterType getMonsterType() { return EnumMonsterType.ARTHROPOD; } diff --git a/src/main/java/net/minecraft/server/EntitySkeleton.java b/src/main/java/net/minecraft/server/EntitySkeleton.java index 94946271..e5db8a1c 100644 --- a/src/main/java/net/minecraft/server/EntitySkeleton.java +++ b/src/main/java/net/minecraft/server/EntitySkeleton.java @@ -6,48 +6,47 @@ import org.bukkit.event.entity.EntityCombustEvent; // CraftBukkit public class EntitySkeleton extends EntityMonster implements IRangedEntity { - private PathfinderGoalArrowAttack d = new PathfinderGoalArrowAttack(this, 0.25F, 20, 60, 15.0F); - private PathfinderGoalMeleeAttack e = new PathfinderGoalMeleeAttack(this, EntityHuman.class, 0.31F, false); + private PathfinderGoalArrowAttack bp = new PathfinderGoalArrowAttack(this, 1.0D, 20, 60, 15.0F); + private PathfinderGoalMeleeAttack bq = new PathfinderGoalMeleeAttack(this, EntityHuman.class, 1.2D, false); public EntitySkeleton(World world) { super(world); - this.texture = "/mob/skeleton.png"; - this.bI = 0.25F; this.goalSelector.a(1, new PathfinderGoalFloat(this)); this.goalSelector.a(2, new PathfinderGoalRestrictSun(this)); - this.goalSelector.a(3, new PathfinderGoalFleeSun(this, this.bI)); - this.goalSelector.a(5, new PathfinderGoalRandomStroll(this, this.bI)); + this.goalSelector.a(3, new PathfinderGoalFleeSun(this, 1.0D)); + this.goalSelector.a(5, new PathfinderGoalRandomStroll(this, 1.0D)); this.goalSelector.a(6, new PathfinderGoalLookAtPlayer(this, EntityHuman.class, 8.0F)); this.goalSelector.a(6, new PathfinderGoalRandomLookaround(this)); this.targetSelector.a(1, new PathfinderGoalHurtByTarget(this, false)); - this.targetSelector.a(2, new PathfinderGoalNearestAttackableTarget(this, EntityHuman.class, 16.0F, 0, true)); + this.targetSelector.a(2, new PathfinderGoalNearestAttackableTarget(this, EntityHuman.class, 0, true)); if (world != null && !world.isStatic) { - this.m(); + this.bP(); } } + protected void ax() { + super.ax(); + this.a(GenericAttributes.d).a(0.25D); + } + protected void a() { super.a(); this.datawatcher.a(13, new Byte((byte) 0)); } - public boolean bh() { + public boolean bb() { return true; } - public int getMaxHealth() { - return 20; - } - - protected String bb() { + protected String r() { return "mob.skeleton.say"; } - protected String bc() { + protected String aK() { return "mob.skeleton.hurt"; } - protected String bd() { + protected String aL() { return "mob.skeleton.death"; } @@ -67,28 +66,13 @@ public class EntitySkeleton extends EntityMonster implements IRangedEntity { } } - public int c(Entity entity) { - if (this.getSkeletonType() == 1) { - ItemStack itemstack = this.bG(); - int i = 4; - - if (itemstack != null) { - i += itemstack.a((Entity) this); - } - - return i; - } else { - return super.c(entity); - } - } - public EnumMonsterType getMonsterType() { return EnumMonsterType.UNDEAD; } public void c() { if (this.world.v() && !this.world.isStatic) { - float f = this.c(1.0F); + float f = this.d(1.0F); if (f > 0.5F && this.random.nextFloat() * 30.0F < (f - 0.4F) * 2.0F && this.world.l(MathHelper.floor(this.locX), MathHelper.floor(this.locY), MathHelper.floor(this.locZ))) { boolean flag = true; @@ -108,13 +92,13 @@ public class EntitySkeleton extends EntityMonster implements IRangedEntity { if (flag) { // CraftBukkit start - EntityCombustEvent event = new EntityCombustEvent(this.getBukkitEntity(), 8); - this.world.getServer().getPluginManager().callEvent(event); + EntityCombustEvent event = new EntityCombustEvent(this.getBukkitEntity(), 8); + this.world.getServer().getPluginManager().callEvent(event); - if (!event.isCancelled()) { - this.setOnFire(event.getDuration()); - } - // CraftBukkit end + if (!event.isCancelled()) { + this.setOnFire(event.getDuration()); + } + // CraftBukkit end } } } @@ -126,6 +110,15 @@ public class EntitySkeleton extends EntityMonster implements IRangedEntity { super.c(); } + public void T() { + super.T(); + if (this.vehicle instanceof EntityCreature) { + EntityCreature entitycreature = (EntityCreature) this.vehicle; + + this.aN = entitycreature.aN; + } + } + public void die(DamageSource damagesource) { super.die(damagesource); if (damagesource.h() instanceof EntityArrow && damagesource.getEntity() instanceof EntityHuman) { @@ -186,52 +179,56 @@ public class EntitySkeleton extends EntityMonster implements IRangedEntity { return new ItemStack(Item.SKULL.id, 1, 1); // CraftBukkit } - return null; + return null; // CraftBukkit } - protected void bH() { - super.bH(); + protected void bs() { + super.bs(); this.setEquipment(0, new ItemStack(Item.BOW)); } - public void bJ() { - if (this.world.worldProvider instanceof WorldProviderHell && this.aE().nextInt(5) > 0) { - this.goalSelector.a(4, this.e); + public GroupDataEntity a(GroupDataEntity groupdataentity) { + groupdataentity = super.a(groupdataentity); + if (this.world.worldProvider instanceof WorldProviderHell && this.aB().nextInt(5) > 0) { + this.goalSelector.a(4, this.bq); this.setSkeletonType(1); this.setEquipment(0, new ItemStack(Item.STONE_SWORD)); + this.a(GenericAttributes.e).a(4.0D); } else { - this.goalSelector.a(4, this.d); - this.bH(); - this.bI(); + this.goalSelector.a(4, this.bp); + this.bs(); + this.bt(); } - this.h(this.random.nextFloat() < au[this.world.difficulty]); + this.h(this.random.nextFloat() < 0.55F * this.world.b(this.locX, this.locY, this.locZ)); if (this.getEquipment(4) == null) { - Calendar calendar = this.world.V(); + Calendar calendar = this.world.W(); if (calendar.get(2) + 1 == 10 && calendar.get(5) == 31 && this.random.nextFloat() < 0.25F) { this.setEquipment(4, new ItemStack(this.random.nextFloat() < 0.1F ? Block.JACK_O_LANTERN : Block.PUMPKIN)); this.dropChances[4] = 0.0F; } } + + return groupdataentity; } - public void m() { - this.goalSelector.a((PathfinderGoal) this.e); - this.goalSelector.a((PathfinderGoal) this.d); - ItemStack itemstack = this.bG(); + public void bP() { + this.goalSelector.a((PathfinderGoal) this.bq); + this.goalSelector.a((PathfinderGoal) this.bp); + ItemStack itemstack = this.aV(); if (itemstack != null && itemstack.id == Item.BOW.id) { - this.goalSelector.a(4, this.d); + this.goalSelector.a(4, this.bp); } else { - this.goalSelector.a(4, this.e); + this.goalSelector.a(4, this.bq); } } public void a(EntityLiving entityliving, float f) { EntityArrow entityarrow = new EntityArrow(this.world, this, entityliving, 1.6F, (float) (14 - this.world.difficulty * 4)); - int i = EnchantmentManager.getEnchantmentLevel(Enchantment.ARROW_DAMAGE.id, this.bG()); - int j = EnchantmentManager.getEnchantmentLevel(Enchantment.ARROW_KNOCKBACK.id, this.bG()); + int i = EnchantmentManager.getEnchantmentLevel(Enchantment.ARROW_DAMAGE.id, this.aV()); + int j = EnchantmentManager.getEnchantmentLevel(Enchantment.ARROW_KNOCKBACK.id, this.aV()); entityarrow.b((double) (f * 2.0F) + this.random.nextGaussian() * 0.25D + (double) ((float) this.world.difficulty * 0.11F)); if (i > 0) { @@ -242,11 +239,11 @@ public class EntitySkeleton extends EntityMonster implements IRangedEntity { entityarrow.a(j); } - if (EnchantmentManager.getEnchantmentLevel(Enchantment.ARROW_FIRE.id, this.bG()) > 0 || this.getSkeletonType() == 1) { + if (EnchantmentManager.getEnchantmentLevel(Enchantment.ARROW_FIRE.id, this.aV()) > 0 || this.getSkeletonType() == 1) { entityarrow.setOnFire(100); } - this.makeSound("random.bow", 1.0F, 1.0F / (this.aE().nextFloat() * 0.4F + 0.8F)); + this.makeSound("random.bow", 1.0F, 1.0F / (this.aB().nextFloat() * 0.4F + 0.8F)); this.world.addEntity(entityarrow); } @@ -272,7 +269,7 @@ public class EntitySkeleton extends EntityMonster implements IRangedEntity { this.setSkeletonType(b0); } - this.m(); + this.bP(); } public void b(NBTTagCompound nbttagcompound) { @@ -283,7 +280,11 @@ public class EntitySkeleton extends EntityMonster implements IRangedEntity { public void setEquipment(int i, ItemStack itemstack) { super.setEquipment(i, itemstack); if (!this.world.isStatic && i == 0) { - this.m(); + this.bP(); } } + + public double V() { + return super.V() - 0.5D; + } } diff --git a/src/main/java/net/minecraft/server/EntitySlime.java b/src/main/java/net/minecraft/server/EntitySlime.java index f6a0c9e6..6789d2fb 100644 --- a/src/main/java/net/minecraft/server/EntitySlime.java +++ b/src/main/java/net/minecraft/server/EntitySlime.java @@ -4,21 +4,19 @@ package net.minecraft.server; import org.bukkit.craftbukkit.entity.CraftEntity; import org.bukkit.craftbukkit.event.CraftEventFactory; import org.bukkit.event.entity.EntityTargetEvent; -import org.bukkit.event.entity.SlimeSplitEvent; +import org.bukkit.event.entity.SlimeSplitEvent; // CraftBukkit end -public class EntitySlime extends EntityLiving implements IMonster { +public class EntitySlime extends EntityInsentient implements IMonster { - private static final float[] e = new float[] { 1.0F, 0.75F, 0.5F, 0.25F, 0.0F, 0.25F, 0.5F, 0.75F}; - public float b; - public float c; - public float d; - private int jumpDelay = 0; + public float h; + public float i; + public float j; + private int jumpDelay; private Entity lastTarget; // CraftBukkit public EntitySlime(World world) { super(world); - this.texture = "/mob/slime.png"; int i = 1 << this.random.nextInt(3); this.height = 0.0F; @@ -37,19 +35,14 @@ public class EntitySlime extends EntityLiving implements IMonster { this.datawatcher.watch(16, new Byte((byte) i)); this.a(0.6F * (float) i, 0.6F * (float) i); this.setPosition(this.locX, this.locY, this.locZ); + this.a(GenericAttributes.a).a((double) (i * i)); // CraftBukkit start if (updateMaxHealth) { this.maxHealth = this.getMaxHealth(); } this.setHealth(this.maxHealth); // CraftBukkit end - this.be = i; - } - - public int getMaxHealth() { - int i = this.getSize(); - - return i * i; + this.b = i; } public int getSize() { @@ -66,11 +59,11 @@ public class EntitySlime extends EntityLiving implements IMonster { this.setSize(nbttagcompound.getInt("Size") + 1); } - protected String h() { + protected String bF() { return "slime"; } - protected String n() { + protected String bL() { return "mob.slime." + (this.getSize() > 1 ? "big" : "small"); } @@ -79,8 +72,8 @@ public class EntitySlime extends EntityLiving implements IMonster { this.dead = true; } - this.c += (this.b - this.c) * 0.5F; - this.d = this.c; + this.i += (this.h - this.i) * 0.5F; + this.j = this.i; boolean flag = this.onGround; super.l_(); @@ -95,27 +88,27 @@ public class EntitySlime extends EntityLiving implements IMonster { float f2 = MathHelper.sin(f) * (float) i * 0.5F * f1; float f3 = MathHelper.cos(f) * (float) i * 0.5F * f1; - this.world.addParticle(this.h(), this.locX + (double) f2, this.boundingBox.b, this.locZ + (double) f3, 0.0D, 0.0D, 0.0D); + this.world.addParticle(this.bF(), this.locX + (double) f2, this.boundingBox.b, this.locZ + (double) f3, 0.0D, 0.0D, 0.0D); } - if (this.o()) { - this.makeSound(this.n(), this.ba(), ((this.random.nextFloat() - this.random.nextFloat()) * 0.2F + 1.0F) / 0.8F); + if (this.bM()) { + this.makeSound(this.bL(), this.aW(), ((this.random.nextFloat() - this.random.nextFloat()) * 0.2F + 1.0F) / 0.8F); } - this.b = -0.5F; + this.h = -0.5F; } else if (!this.onGround && flag) { - this.b = 1.0F; + this.h = 1.0F; } - this.k(); + this.bI(); if (this.world.isStatic) { i = this.getSize(); this.a(0.6F * (float) i, 0.6F * (float) i); } } - protected void bq() { - this.bn(); + protected void bh() { + this.bk(); // CraftBukkit start Entity entityhuman = this.world.findNearbyVulnerablePlayer(this, 16.0D); // EntityHuman -> Entity EntityTargetEvent event = null; @@ -138,42 +131,42 @@ public class EntitySlime extends EntityLiving implements IMonster { } if (this.onGround && this.jumpDelay-- <= 0) { - this.jumpDelay = this.j(); + this.jumpDelay = this.bH(); if (entityhuman != null) { this.jumpDelay /= 3; } - this.bG = true; - if (this.q()) { - this.makeSound(this.n(), this.ba(), ((this.random.nextFloat() - this.random.nextFloat()) * 0.2F + 1.0F) * 0.8F); + this.bd = true; + if (this.bO()) { + this.makeSound(this.bL(), this.aW(), ((this.random.nextFloat() - this.random.nextFloat()) * 0.2F + 1.0F) * 0.8F); } - this.bD = 1.0F - this.random.nextFloat() * 2.0F; - this.bE = (float) (1 * this.getSize()); + this.be = 1.0F - this.random.nextFloat() * 2.0F; + this.bf = (float) (1 * this.getSize()); } else { - this.bG = false; + this.bd = false; if (this.onGround) { - this.bD = this.bE = 0.0F; + this.be = this.bf = 0.0F; } } } - protected void k() { - this.b *= 0.6F; + protected void bI() { + this.h *= 0.6F; } - protected int j() { + protected int bH() { return this.random.nextInt(20) + 10; } - protected EntitySlime i() { + protected EntitySlime bG() { return new EntitySlime(this.world); } public void die() { int i = this.getSize(); - if (!this.world.isStatic && i > 1 && this.getHealth() <= 0) { + if (!this.world.isStatic && i > 1 && this.getHealth() <= 0.0F) { int j = 2 + this.random.nextInt(3); // CraftBukkit start @@ -191,7 +184,7 @@ public class EntitySlime extends EntityLiving implements IMonster { for (int k = 0; k < j; ++k) { float f = ((float) (k % 2) - 0.5F) * (float) i / 4.0F; float f1 = ((float) (k / 2) - 0.5F) * (float) i / 4.0F; - EntitySlime entityslime = this.i(); + EntitySlime entityslime = this.bG(); entityslime.setSize(i / 2); entityslime.setPositionRotation(this.locX + (double) f, this.locY + 0.5D, this.locZ + (double) f1, this.random.nextFloat() * 360.0F, 0.0F); @@ -203,28 +196,28 @@ public class EntitySlime extends EntityLiving implements IMonster { } public void b_(EntityHuman entityhuman) { - if (this.l()) { + if (this.bJ()) { int i = this.getSize(); - if (this.n(entityhuman) && this.e(entityhuman) < 0.6D * (double) i * 0.6D * (double) i && entityhuman.damageEntity(DamageSource.mobAttack(this), this.m())) { + if (this.o(entityhuman) && this.e(entityhuman) < 0.6D * (double) i * 0.6D * (double) i && entityhuman.damageEntity(DamageSource.mobAttack(this), (float) this.bK())) { this.makeSound("mob.attack", 1.0F, (this.random.nextFloat() - this.random.nextFloat()) * 0.2F + 1.0F); } } } - protected boolean l() { + protected boolean bJ() { return this.getSize() > 1; } - protected int m() { + protected int bK() { return this.getSize(); } - protected String bc() { + protected String aK() { return "mob.slime." + (this.getSize() > 1 ? "big" : "small"); } - protected String bd() { + protected String aL() { return "mob.slime." + (this.getSize() > 1 ? "big" : "small"); } @@ -241,7 +234,7 @@ public class EntitySlime extends EntityLiving implements IMonster { if (this.getSize() == 1 || this.world.difficulty > 0) { BiomeBase biomebase = this.world.getBiome(MathHelper.floor(this.locX), MathHelper.floor(this.locZ)); - if (biomebase == BiomeBase.SWAMPLAND && this.locY > 50.0D && this.locY < 70.0D && this.random.nextFloat() < 0.5F && this.random.nextFloat() < e[this.world.w()] && this.world.getLightLevel(MathHelper.floor(this.locX), MathHelper.floor(this.locY), MathHelper.floor(this.locZ)) <= this.random.nextInt(8)) { + if (biomebase == BiomeBase.SWAMPLAND && this.locY > 50.0D && this.locY < 70.0D && this.random.nextFloat() < 0.5F && this.random.nextFloat() < this.world.x() && this.world.getLightLevel(MathHelper.floor(this.locX), MathHelper.floor(this.locY), MathHelper.floor(this.locZ)) <= this.random.nextInt(8)) { return super.canSpawn(); } @@ -254,19 +247,19 @@ public class EntitySlime extends EntityLiving implements IMonster { } } - protected float ba() { + protected float aW() { return 0.4F * (float) this.getSize(); } - public int bs() { + public int bl() { return 0; } - protected boolean q() { + protected boolean bO() { return this.getSize() > 0; } - protected boolean o() { + protected boolean bM() { return this.getSize() > 2; } } diff --git a/src/main/java/net/minecraft/server/EntitySmallFireball.java b/src/main/java/net/minecraft/server/EntitySmallFireball.java index abc95ca2..68bd2123 100644 --- a/src/main/java/net/minecraft/server/EntitySmallFireball.java +++ b/src/main/java/net/minecraft/server/EntitySmallFireball.java @@ -22,7 +22,7 @@ public class EntitySmallFireball extends EntityFireball { protected void a(MovingObjectPosition movingobjectposition) { if (!this.world.isStatic) { if (movingobjectposition.entity != null) { - if (!movingobjectposition.entity.isFireproof() && movingobjectposition.entity.damageEntity(DamageSource.fireball(this, this.shooter), 5)) { + if (!movingobjectposition.entity.isFireproof() && movingobjectposition.entity.damageEntity(DamageSource.fireball(this, this.shooter), 5.0F)) { // CraftBukkit start - Entity damage by entity event + combust event EntityCombustByEntityEvent event = new EntityCombustByEntityEvent((org.bukkit.entity.Projectile) this.getBukkitEntity(), movingobjectposition.entity.getBukkitEntity(), 5); movingobjectposition.entity.world.getServer().getPluginManager().callEvent(event); @@ -79,7 +79,7 @@ public class EntitySmallFireball extends EntityFireball { return false; } - public boolean damageEntity(DamageSource damagesource, int i) { + public boolean damageEntity(DamageSource damagesource, float f) { return false; } } diff --git a/src/main/java/net/minecraft/server/EntitySnowman.java b/src/main/java/net/minecraft/server/EntitySnowman.java index 8b9fb83c..6499a7bd 100644 --- a/src/main/java/net/minecraft/server/EntitySnowman.java +++ b/src/main/java/net/minecraft/server/EntitySnowman.java @@ -9,35 +9,36 @@ public class EntitySnowman extends EntityGolem implements IRangedEntity { public EntitySnowman(World world) { super(world); - this.texture = "/mob/snowman.png"; this.a(0.4F, 1.8F); this.getNavigation().a(true); - this.goalSelector.a(1, new PathfinderGoalArrowAttack(this, 0.25F, 20, 10.0F)); - this.goalSelector.a(2, new PathfinderGoalRandomStroll(this, 0.2F)); + this.goalSelector.a(1, new PathfinderGoalArrowAttack(this, 1.25D, 20, 10.0F)); + this.goalSelector.a(2, new PathfinderGoalRandomStroll(this, 1.0D)); this.goalSelector.a(3, new PathfinderGoalLookAtPlayer(this, EntityHuman.class, 6.0F)); this.goalSelector.a(4, new PathfinderGoalRandomLookaround(this)); - this.targetSelector.a(1, new PathfinderGoalNearestAttackableTarget(this, EntityLiving.class, 16.0F, 0, true, false, IMonster.a)); + this.targetSelector.a(1, new PathfinderGoalNearestAttackableTarget(this, EntityInsentient.class, 0, true, false, IMonster.a)); } - public boolean bh() { + public boolean bb() { return true; } - public int getMaxHealth() { - return 4; + protected void ax() { + super.ax(); + this.a(GenericAttributes.a).a(4.0D); + this.a(GenericAttributes.d).a(0.20000000298023224D); } public void c() { super.c(); if (this.F()) { - this.damageEntity(DamageSource.DROWN, 1); + this.damageEntity(DamageSource.DROWN, 1.0F); } int i = MathHelper.floor(this.locX); int j = MathHelper.floor(this.locZ); if (this.world.getBiome(i, j).j() > 1.0F) { - this.damageEntity(CraftEventFactory.MELTING, 1); // CraftBukkit - DamageSource.BURN -> CraftEventFactory.MELTING + this.damageEntity(CraftEventFactory.MELTING, 1.0F); // CraftBukkit - DamageSource.BURN -> CraftEventFactory.MELTING } for (i = 0; i < 4; ++i) { @@ -86,7 +87,7 @@ public class EntitySnowman extends EntityGolem implements IRangedEntity { float f1 = MathHelper.sqrt(d0 * d0 + d2 * d2) * 0.2F; entitysnowball.shoot(d0, d1 + (double) f1, d2, 1.6F, 12.0F); - this.makeSound("random.bow", 1.0F, 1.0F / (this.aE().nextFloat() * 0.4F + 0.8F)); + this.makeSound("random.bow", 1.0F, 1.0F / (this.aB().nextFloat() * 0.4F + 0.8F)); this.world.addEntity(entitysnowball); } } diff --git a/src/main/java/net/minecraft/server/EntitySpider.java b/src/main/java/net/minecraft/server/EntitySpider.java index a7598034..061119fd 100644 --- a/src/main/java/net/minecraft/server/EntitySpider.java +++ b/src/main/java/net/minecraft/server/EntitySpider.java @@ -6,9 +6,7 @@ public class EntitySpider extends EntityMonster { public EntitySpider(World world) { super(world); - this.texture = "/mob/spider.png"; this.a(1.4F, 0.9F); - this.bI = 0.8F; } protected void a() { @@ -23,16 +21,14 @@ public class EntitySpider extends EntityMonster { } } - public int getMaxHealth() { - return 16; - } - - public double W() { - return (double) this.length * 0.75D - 0.5D; + protected void ax() { + super.ax(); + this.a(GenericAttributes.a).a(16.0D); + this.a(GenericAttributes.d).a(0.800000011920929D); } protected Entity findTarget() { - float f = this.c(1.0F); + float f = this.d(1.0F); if (f < 0.5F) { double d0 = 16.0D; @@ -43,15 +39,15 @@ public class EntitySpider extends EntityMonster { } } - protected String bb() { + protected String r() { return "mob.spider.say"; } - protected String bc() { + protected String aK() { return "mob.spider.say"; } - protected String bd() { + protected String aL() { return "mob.spider.death"; } @@ -60,7 +56,7 @@ public class EntitySpider extends EntityMonster { } protected void a(Entity entity, float f) { - float f1 = this.c(1.0F); + float f1 = this.d(1.0F); if (f1 > 0.5F && this.random.nextInt(100) == 0) { // CraftBukkit start @@ -119,11 +115,11 @@ public class EntitySpider extends EntityMonster { // CraftBukkit end } - public boolean g_() { - return this.o(); + public boolean e() { + return this.bP(); } - public void al() {} + public void ak() {} public EnumMonsterType getMonsterType() { return EnumMonsterType.ARTHROPOD; @@ -133,7 +129,7 @@ public class EntitySpider extends EntityMonster { return mobeffect.getEffectId() == MobEffectList.POISON.id ? false : super.e(mobeffect); } - public boolean o() { + public boolean bP() { return (this.datawatcher.getByte(16) & 1) != 0; } @@ -149,14 +145,33 @@ public class EntitySpider extends EntityMonster { this.datawatcher.watch(16, Byte.valueOf(b0)); } - public void bJ() { + public GroupDataEntity a(GroupDataEntity groupdataentity) { + Object object = super.a(groupdataentity); + if (this.world.random.nextInt(100) == 0) { EntitySkeleton entityskeleton = new EntitySkeleton(this.world); entityskeleton.setPositionRotation(this.locX, this.locY, this.locZ, this.yaw, 0.0F); - entityskeleton.bJ(); + entityskeleton.a((GroupDataEntity) null); this.world.addEntity(entityskeleton); entityskeleton.mount(this); } + + if (object == null) { + object = new GroupDataSpider(); + if (this.world.difficulty > 2 && this.world.random.nextFloat() < 0.1F * this.world.b(this.locX, this.locY, this.locZ)) { + ((GroupDataSpider) object).a(this.world.random); + } + } + + if (object instanceof GroupDataSpider) { + int i = ((GroupDataSpider) object).a; + + if (i > 0 && MobEffectList.byId[i] != null) { + this.addEffect(new MobEffect(i, Integer.MAX_VALUE)); + } + } + + return (GroupDataEntity) object; } } diff --git a/src/main/java/net/minecraft/server/EntitySquid.java b/src/main/java/net/minecraft/server/EntitySquid.java index c6e8f786..70b40c78 100644 --- a/src/main/java/net/minecraft/server/EntitySquid.java +++ b/src/main/java/net/minecraft/server/EntitySquid.java @@ -4,45 +4,45 @@ import org.bukkit.craftbukkit.TrigMath; // CraftBukkit public class EntitySquid extends EntityWaterAnimal { - public float d = 0.0F; - public float e = 0.0F; - public float f = 0.0F; - public float g = 0.0F; - public float h = 0.0F; - public float i = 0.0F; - public float j = 0.0F; - public float bK = 0.0F; - private float bL = 0.0F; - private float bM = 0.0F; - private float bN = 0.0F; - private float bO = 0.0F; - private float bP = 0.0F; - private float bQ = 0.0F; + public float bp; + public float bq; + public float br; + public float bs; + public float bt; + public float bu; + public float bv; + public float bw; + private float bx; + private float by; + private float bz; + private float bA; + private float bB; + private float bC; public EntitySquid(World world) { super(world); - this.texture = "/mob/squid.png"; this.a(0.95F, 0.95F); - this.bM = 1.0F / (this.random.nextFloat() + 1.0F) * 0.2F; + this.by = 1.0F / (this.random.nextFloat() + 1.0F) * 0.2F; } - public int getMaxHealth() { - return 10; + protected void ax() { + super.ax(); + this.a(GenericAttributes.a).a(10.0D); } - protected String bb() { + protected String r() { return null; } - protected String bc() { + protected String aK() { return null; } - protected String bd() { + protected String aL() { return null; } - protected float ba() { + protected float aW() { return 0.4F; } @@ -50,6 +50,10 @@ public class EntitySquid extends EntityWaterAnimal { return 0; } + protected boolean e_() { + return false; + } + protected void dropDeathLoot(boolean flag, int i) { // CraftBukkit start - Whole method java.util.List<org.bukkit.inventory.ItemStack> loot = new java.util.ArrayList<org.bukkit.inventory.ItemStack>(); @@ -71,51 +75,51 @@ public class EntitySquid extends EntityWaterAnimal { public void c() { super.c(); - this.e = this.d; - this.g = this.f; - this.i = this.h; - this.bK = this.j; - this.h += this.bM; - if (this.h > 6.2831855F) { - this.h -= 6.2831855F; + this.bq = this.bp; + this.bs = this.br; + this.bu = this.bt; + this.bw = this.bv; + this.bt += this.by; + if (this.bt > 6.2831855F) { + this.bt -= 6.2831855F; if (this.random.nextInt(10) == 0) { - this.bM = 1.0F / (this.random.nextFloat() + 1.0F) * 0.2F; + this.by = 1.0F / (this.random.nextFloat() + 1.0F) * 0.2F; } } if (this.G()) { float f; - if (this.h < 3.1415927F) { - f = this.h / 3.1415927F; - this.j = MathHelper.sin(f * f * 3.1415927F) * 3.1415927F * 0.25F; + if (this.bt < 3.1415927F) { + f = this.bt / 3.1415927F; + this.bv = MathHelper.sin(f * f * 3.1415927F) * 3.1415927F * 0.25F; if ((double) f > 0.75D) { - this.bL = 1.0F; - this.bN = 1.0F; + this.bx = 1.0F; + this.bz = 1.0F; } else { - this.bN *= 0.8F; + this.bz *= 0.8F; } } else { - this.j = 0.0F; - this.bL *= 0.9F; - this.bN *= 0.99F; + this.bv = 0.0F; + this.bx *= 0.9F; + this.bz *= 0.99F; } if (!this.world.isStatic) { - this.motX = (double) (this.bO * this.bL); - this.motY = (double) (this.bP * this.bL); - this.motZ = (double) (this.bQ * this.bL); + this.motX = (double) (this.bA * this.bx); + this.motY = (double) (this.bB * this.bx); + this.motZ = (double) (this.bC * this.bx); } f = MathHelper.sqrt(this.motX * this.motX + this.motZ * this.motZ); // CraftBukkit - Math -> TrigMath - this.ay += (-((float) TrigMath.atan2(this.motX, this.motZ)) * 180.0F / 3.1415927F - this.ay) * 0.1F; - this.yaw = this.ay; - this.f += 3.1415927F * this.bN * 1.5F; + this.aN += (-((float) TrigMath.atan2(this.motX, this.motZ)) * 180.0F / 3.1415927F - this.aN) * 0.1F; + this.yaw = this.aN; + this.br += 3.1415927F * this.bz * 1.5F; // CraftBukkit - Math -> TrigMath - this.d += (-((float) TrigMath.atan2((double) f, this.motY)) * 180.0F / 3.1415927F - this.d) * 0.1F; + this.bp += (-((float) TrigMath.atan2((double) f, this.motY)) * 180.0F / 3.1415927F - this.bp) * 0.1F; } else { - this.j = MathHelper.abs(MathHelper.sin(this.h)) * 3.1415927F * 0.25F; + this.bv = MathHelper.abs(MathHelper.sin(this.bt)) * 3.1415927F * 0.25F; if (!this.world.isStatic) { this.motX = 0.0D; this.motY -= 0.08D; @@ -123,7 +127,7 @@ public class EntitySquid extends EntityWaterAnimal { this.motZ = 0.0D; } - this.d = (float) ((double) this.d + (double) (-90.0F - this.d) * 0.02D); + this.bp = (float) ((double) this.bp + (double) (-90.0F - this.bp) * 0.02D); } } @@ -131,19 +135,19 @@ public class EntitySquid extends EntityWaterAnimal { this.move(this.motX, this.motY, this.motZ); } - protected void bq() { - ++this.bC; - if (this.bC > 100) { - this.bO = this.bP = this.bQ = 0.0F; - } else if (this.random.nextInt(50) == 0 || !this.inWater || this.bO == 0.0F && this.bP == 0.0F && this.bQ == 0.0F) { + protected void bh() { + ++this.aV; + if (this.aV > 100) { + this.bA = this.bB = this.bC = 0.0F; + } else if (this.random.nextInt(50) == 0 || !this.inWater || this.bA == 0.0F && this.bB == 0.0F && this.bC == 0.0F) { float f = this.random.nextFloat() * 3.1415927F * 2.0F; - this.bO = MathHelper.cos(f) * 0.2F; - this.bP = -0.1F + this.random.nextFloat() * 0.2F; - this.bQ = MathHelper.sin(f) * 0.2F; + this.bA = MathHelper.cos(f) * 0.2F; + this.bB = -0.1F + this.random.nextFloat() * 0.2F; + this.bC = MathHelper.sin(f) * 0.2F; } - this.bn(); + this.bk(); } public boolean canSpawn() { diff --git a/src/main/java/net/minecraft/server/EntityTNTPrimed.java b/src/main/java/net/minecraft/server/EntityTNTPrimed.java index 41139997..99e7ac2b 100644 --- a/src/main/java/net/minecraft/server/EntityTNTPrimed.java +++ b/src/main/java/net/minecraft/server/EntityTNTPrimed.java @@ -11,7 +11,6 @@ public class EntityTNTPrimed extends Entity { public EntityTNTPrimed(World world) { super(world); - this.fuseTicks = 0; this.m = true; this.a(0.98F, 0.98F); this.height = this.length / 2.0F; @@ -34,7 +33,7 @@ public class EntityTNTPrimed extends Entity { protected void a() {} - protected boolean f_() { + protected boolean e_() { return false; } diff --git a/src/main/java/net/minecraft/server/EntityThrownExpBottle.java b/src/main/java/net/minecraft/server/EntityThrownExpBottle.java index eb8b59f3..51695390 100644 --- a/src/main/java/net/minecraft/server/EntityThrownExpBottle.java +++ b/src/main/java/net/minecraft/server/EntityThrownExpBottle.java @@ -14,7 +14,7 @@ public class EntityThrownExpBottle extends EntityProjectile { super(world, d0, d1, d2); } - protected float g() { + protected float e() { return 0.07F; } diff --git a/src/main/java/net/minecraft/server/EntityTracker.java b/src/main/java/net/minecraft/server/EntityTracker.java index 9e2b76f8..a8e45dd0 100644 --- a/src/main/java/net/minecraft/server/EntityTracker.java +++ b/src/main/java/net/minecraft/server/EntityTracker.java @@ -73,14 +73,12 @@ public class EntityTracker { this.addEntity(entity, 160, 10, true); } else if (entity instanceof EntityFallingBlock) { this.addEntity(entity, 160, 20, true); - } else if (entity instanceof EntityPainting) { + } else if (entity instanceof EntityHanging) { this.addEntity(entity, 160, Integer.MAX_VALUE, false); } else if (entity instanceof EntityExperienceOrb) { this.addEntity(entity, 160, 20, true); } else if (entity instanceof EntityEnderCrystal) { this.addEntity(entity, 256, Integer.MAX_VALUE, false); - } else if (entity instanceof EntityItemFrame) { - this.addEntity(entity, 160, Integer.MAX_VALUE, false); } } diff --git a/src/main/java/net/minecraft/server/EntityTrackerEntry.java b/src/main/java/net/minecraft/server/EntityTrackerEntry.java index 5c037329..e58af635 100644 --- a/src/main/java/net/minecraft/server/EntityTrackerEntry.java +++ b/src/main/java/net/minecraft/server/EntityTrackerEntry.java @@ -1,5 +1,6 @@ package net.minecraft.server; +import java.util.Collection; import java.util.HashSet; import java.util.Iterator; import java.util.List; @@ -24,16 +25,16 @@ public class EntityTrackerEntry { public double j; public double k; public double l; - public int m = 0; + public int m; private double p; private double q; private double r; - private boolean s = false; + private boolean s; private boolean isMoving; - private int u = 0; + private int u; private Entity v; - private boolean w = false; - public boolean n = false; + private boolean w; + public boolean n; public Set trackedPlayers = new HashSet(); public EntityTrackerEntry(Entity entity, int i, int j, boolean flag) { @@ -70,37 +71,33 @@ public class EntityTrackerEntry { if (this.v != this.tracker.vehicle /* || this.tracker.vehicle != null && this.m % 60 == 0 */) { // CraftBukkit - Revert to 1.4 logic, this packet is a toggle this.v = this.tracker.vehicle; - this.broadcast(new Packet39AttachEntity(this.tracker, this.tracker.vehicle)); + this.broadcast(new Packet39AttachEntity(0, this.tracker, this.tracker.vehicle)); } if (this.tracker instanceof EntityItemFrame /*&& this.m % 10 == 0*/) { // CraftBukkit - Moved below, should always enter this block - EntityItemFrame i4 = (EntityItemFrame) this.tracker; - ItemStack i5 = i4.i(); + EntityItemFrame i3 = (EntityItemFrame) this.tracker; + ItemStack i4 = i3.h(); - if (this.m % 10 == 0 && i5 != null && i5.getItem() instanceof ItemWorldMap) { // CraftBukkit - Moved this.m % 10 logic here so item frames do not enter the other blocks - WorldMap i7 = Item.MAP.getSavedMap(i5, this.tracker.world); - Iterator j0 = this.trackedPlayers.iterator(); // CraftBukkit + if (this.m % 10 == 0 && i4 != null && i4.getItem() instanceof ItemWorldMap) { // CraftBukkit - Moved this.m % 10 logic here so item frames do not enter the other blocks + WorldMap i6 = Item.MAP.getSavedMap(i4, this.tracker.world); + Iterator i7 = this.trackedPlayers.iterator(); // CraftBukkit - while (j0.hasNext()) { - EntityHuman j1 = (EntityHuman) j0.next(); - EntityPlayer j2 = (EntityPlayer) j1; + while (i7.hasNext()) { + EntityHuman i8 = (EntityHuman) i7.next(); + EntityPlayer i9 = (EntityPlayer) i8; - i7.a(j2, i5); - if (j2.playerConnection.lowPriorityCount() <= 5) { - Packet j3 = Item.MAP.c(i5, this.tracker.world, j2); + i6.a(i9, i4); + if (i9.playerConnection.lowPriorityCount() <= 5) { + Packet j0 = Item.MAP.c(i4, this.tracker.world, i9); - if (j3 != null) { - j2.playerConnection.sendPacket(j3); + if (j0 != null) { + i9.playerConnection.sendPacket(j0); } } } } - DataWatcher i9 = this.tracker.getDataWatcher(); - - if (i9.a()) { - this.broadcastIncludingSelf(new Packet40EntityMetadata(this.tracker.id, i9, false)); - } + this.b(); } else if (this.m % this.c == 0 || this.tracker.an || this.tracker.getDataWatcher().a()) { int i; int j; @@ -171,12 +168,7 @@ public class EntityTrackerEntry { this.broadcast((Packet) object); } - DataWatcher datawatcher1 = this.tracker.getDataWatcher(); - - if (datawatcher1.a()) { - this.broadcastIncludingSelf(new Packet40EntityMetadata(this.tracker.id, datawatcher1, false)); - } - + this.b(); /* CraftBukkit start - Code moved up if (flag) { this.xLoc = i; @@ -205,12 +197,7 @@ public class EntityTrackerEntry { this.xLoc = this.tracker.at.a(this.tracker.locX); this.yLoc = MathHelper.floor(this.tracker.locY * 32.0D); this.zLoc = this.tracker.at.a(this.tracker.locZ); - DataWatcher datawatcher2 = this.tracker.getDataWatcher(); - - if (datawatcher2.a()) { - this.broadcastIncludingSelf(new Packet40EntityMetadata(this.tracker.id, datawatcher2, false)); - } - + this.b(); this.w = true; } @@ -251,6 +238,25 @@ public class EntityTrackerEntry { } } + private void b() { + DataWatcher datawatcher = this.tracker.getDataWatcher(); + + if (datawatcher.a()) { + this.broadcastIncludingSelf(new Packet40EntityMetadata(this.tracker.id, datawatcher, false)); + } + + if (this.tracker instanceof EntityLiving) { + AttributeMapServer attributemapserver = (AttributeMapServer) ((EntityLiving) this.tracker).aT(); + Set set = attributemapserver.b(); + + if (!set.isEmpty()) { + this.broadcastIncludingSelf(new Packet44UpdateAttributes(this.tracker.id, set)); + } + + set.clear(); + } + } + public void broadcast(Packet packet) { Iterator iterator = this.trackedPlayers.iterator(); @@ -304,13 +310,22 @@ public class EntityTrackerEntry { // CraftBukkit end this.trackedPlayers.add(entityplayer); - Packet packet = this.b(); + Packet packet = this.c(); entityplayer.playerConnection.sendPacket(packet); if (!this.tracker.getDataWatcher().d()) { entityplayer.playerConnection.sendPacket(new Packet40EntityMetadata(this.tracker.id, this.tracker.getDataWatcher(), true)); } + if (this.tracker instanceof EntityLiving) { + AttributeMapServer attributemapserver = (AttributeMapServer) ((EntityLiving) this.tracker).aT(); + Collection collection = attributemapserver.c(); + + if (!collection.isEmpty()) { + entityplayer.playerConnection.sendPacket(new Packet44UpdateAttributes(this.tracker.id, collection)); + } + } + this.j = this.tracker.motX; this.k = this.tracker.motY; this.l = this.tracker.motZ; @@ -320,9 +335,13 @@ public class EntityTrackerEntry { // CraftBukkit start if (this.tracker.vehicle != null && this.tracker.id > this.tracker.vehicle.id) { - entityplayer.playerConnection.sendPacket(new Packet39AttachEntity(this.tracker, this.tracker.vehicle)); + entityplayer.playerConnection.sendPacket(new Packet39AttachEntity(0, this.tracker, this.tracker.vehicle)); } else if (this.tracker.passenger != null && this.tracker.id > this.tracker.passenger.id) { - entityplayer.playerConnection.sendPacket(new Packet39AttachEntity(this.tracker.passenger, this.tracker)); + entityplayer.playerConnection.sendPacket(new Packet39AttachEntity(0, this.tracker.passenger, this.tracker)); + } + + if (this.tracker instanceof EntityInsentient && ((EntityInsentient) this.tracker).bE() != null) { + entityplayer.playerConnection.sendPacket(new Packet39AttachEntity(1, this.tracker, ((EntityInsentient) this.tracker).bE())); } // CraftBukkit end @@ -368,7 +387,7 @@ public class EntityTrackerEntry { } private boolean d(EntityPlayer entityplayer) { - return entityplayer.o().getPlayerChunkMap().a(entityplayer, this.tracker.aj, this.tracker.al); + return entityplayer.p().getPlayerChunkMap().a(entityplayer, this.tracker.aj, this.tracker.al); } public void scanPlayers(List list) { @@ -377,7 +396,7 @@ public class EntityTrackerEntry { } } - private Packet b() { + private Packet c() { if (this.tracker.dead) { // CraftBukkit start - Remove useless error spam, just return // this.tracker.world.getLogger().warning("Fetching addPacket for removed entity"); @@ -461,6 +480,14 @@ public class EntityTrackerEntry { packet23vehiclespawn.c = MathHelper.d((float) (entityitemframe.y * 32)); packet23vehiclespawn.d = MathHelper.d((float) (entityitemframe.z * 32)); return packet23vehiclespawn; + } else if (this.tracker instanceof EntityLeash) { + EntityLeash entityleash = (EntityLeash) this.tracker; + + packet23vehiclespawn = new Packet23VehicleSpawn(this.tracker, 77); + packet23vehiclespawn.b = MathHelper.d((float) (entityleash.x * 32)); + packet23vehiclespawn.c = MathHelper.d((float) (entityleash.y * 32)); + packet23vehiclespawn.d = MathHelper.d((float) (entityleash.z * 32)); + return packet23vehiclespawn; } else if (this.tracker instanceof EntityExperienceOrb) { return new Packet26AddExpOrb((EntityExperienceOrb) this.tracker); } else { diff --git a/src/main/java/net/minecraft/server/EntityWitch.java b/src/main/java/net/minecraft/server/EntityWitch.java index e44d7bee..368652de 100644 --- a/src/main/java/net/minecraft/server/EntityWitch.java +++ b/src/main/java/net/minecraft/server/EntityWitch.java @@ -2,23 +2,24 @@ package net.minecraft.server; import java.util.Iterator; import java.util.List; +import java.util.UUID; public class EntityWitch extends EntityMonster implements IRangedEntity { - private static final int[] d = new int[] { Item.GLOWSTONE_DUST.id, Item.SUGAR.id, Item.REDSTONE.id, Item.SPIDER_EYE.id, Item.GLASS_BOTTLE.id, Item.SULPHUR.id, Item.STICK.id, Item.STICK.id}; - private int e = 0; + private static final UUID bp = UUID.fromString("5CD17E52-A79A-43D3-A529-90FDE04B181E"); + private static final AttributeModifier bq = (new AttributeModifier(bp, "Drinking speed penalty", -0.25D, 0)).a(false); + private static final int[] br = new int[] { Item.GLOWSTONE_DUST.id, Item.SUGAR.id, Item.REDSTONE.id, Item.SPIDER_EYE.id, Item.GLASS_BOTTLE.id, Item.SULPHUR.id, Item.STICK.id, Item.STICK.id}; + private int bs; public EntityWitch(World world) { super(world); - this.texture = "/mob/villager/witch.png"; - this.bI = 0.25F; this.goalSelector.a(1, new PathfinderGoalFloat(this)); - this.goalSelector.a(2, new PathfinderGoalArrowAttack(this, this.bI, 60, 10.0F)); - this.goalSelector.a(2, new PathfinderGoalRandomStroll(this, this.bI)); + this.goalSelector.a(2, new PathfinderGoalArrowAttack(this, 1.0D, 60, 10.0F)); + this.goalSelector.a(2, new PathfinderGoalRandomStroll(this, 1.0D)); this.goalSelector.a(3, new PathfinderGoalLookAtPlayer(this, EntityHuman.class, 8.0F)); this.goalSelector.a(3, new PathfinderGoalRandomLookaround(this)); this.targetSelector.a(1, new PathfinderGoalHurtByTarget(this, false)); - this.targetSelector.a(2, new PathfinderGoalNearestAttackableTarget(this, EntityHuman.class, 16.0F, 0, true)); + this.targetSelector.a(2, new PathfinderGoalNearestAttackableTarget(this, EntityHuman.class, 0, true)); } protected void a() { @@ -26,15 +27,15 @@ public class EntityWitch extends EntityMonster implements IRangedEntity { this.getDataWatcher().a(21, Byte.valueOf((byte) 0)); } - protected String bb() { + protected String r() { return "mob.witch.idle"; } - protected String bc() { + protected String aK() { return "mob.witch.hurt"; } - protected String bd() { + protected String aL() { return "mob.witch.death"; } @@ -42,24 +43,26 @@ public class EntityWitch extends EntityMonster implements IRangedEntity { this.getDataWatcher().watch(21, Byte.valueOf((byte) (flag ? 1 : 0))); } - public boolean m() { + public boolean bP() { return this.getDataWatcher().getByte(21) == 1; } - public int getMaxHealth() { - return 26; + protected void ax() { + super.ax(); + this.a(GenericAttributes.a).a(26.0D); + this.a(GenericAttributes.d).a(0.25D); } - public boolean bh() { + public boolean bb() { return true; } public void c() { if (!this.world.isStatic) { - if (this.m()) { - if (this.e-- <= 0) { + if (this.bP()) { + if (this.bs-- <= 0) { this.a(false); - ItemStack itemstack = this.bG(); + ItemStack itemstack = this.aV(); this.setEquipment(0, (ItemStack) null); if (itemstack != null && itemstack.id == Item.POTION.id) { @@ -75,13 +78,15 @@ public class EntityWitch extends EntityMonster implements IRangedEntity { } } } + + this.a(GenericAttributes.d).b(bq); } } else { short short1 = -1; if (this.random.nextFloat() < 0.15F && this.isBurning() && !this.hasEffect(MobEffectList.FIRE_RESISTANCE)) { short1 = 16307; - } else if (this.random.nextFloat() < 0.05F && this.health < this.maxHealth) { // CraftBukkit - this.getMaxHealth -> this.maxHealth + } else if (this.random.nextFloat() < 0.05F && this.getHealth() < this.maxHealth) { // CraftBukkit - this.getMaxHealth() -> this.maxHealth short1 = 16341; } else if (this.random.nextFloat() < 0.25F && this.getGoalTarget() != null && !this.hasEffect(MobEffectList.FASTER_MOVEMENT) && this.getGoalTarget().e(this) > 121.0D) { short1 = 16274; @@ -91,8 +96,12 @@ public class EntityWitch extends EntityMonster implements IRangedEntity { if (short1 > -1) { this.setEquipment(0, new ItemStack(Item.POTION, 1, short1)); - this.e = this.bG().n(); + this.bs = this.aV().n(); this.a(true); + AttributeInstance attributeinstance = this.a(GenericAttributes.d); + + attributeinstance.b(bq); + attributeinstance.a(bq); } } @@ -104,24 +113,14 @@ public class EntityWitch extends EntityMonster implements IRangedEntity { super.c(); } - protected int c(DamageSource damagesource, int i) { - i = super.c(damagesource, i); + protected float c(DamageSource damagesource, float f) { + f = super.c(damagesource, f); if (damagesource.getEntity() == this) { - i = 0; + f = 0.0F; } if (damagesource.q()) { - i = (int) ((double) i * 0.15D); - } - - return i; - } - - public float bE() { - float f = super.bE(); - - if (this.m()) { - f *= 0.75F; + f = (float) ((double) f * 0.15D); } return f; @@ -135,7 +134,7 @@ public class EntityWitch extends EntityMonster implements IRangedEntity { for (int k = 0; k < j; ++k) { int l = this.random.nextInt(3); - int i1 = d[this.random.nextInt(d.length)]; + int i1 = br[this.random.nextInt(br.length)]; if (i > 0) { l += this.random.nextInt(i + 1); @@ -149,7 +148,7 @@ public class EntityWitch extends EntityMonster implements IRangedEntity { } public void a(EntityLiving entityliving, float f) { - if (!this.m()) { + if (!this.bP()) { EntityPotion entitypotion = new EntityPotion(this.world, this, 32732); entitypotion.pitch -= -20.0F; @@ -160,7 +159,7 @@ public class EntityWitch extends EntityMonster implements IRangedEntity { if (f1 >= 8.0F && !entityliving.hasEffect(MobEffectList.SLOWER_MOVEMENT)) { entitypotion.setPotionValue(32698); - } else if (entityliving.getHealth() >= 8 && !entityliving.hasEffect(MobEffectList.POISON)) { + } else if (entityliving.getHealth() >= 8.0F && !entityliving.hasEffect(MobEffectList.POISON)) { entitypotion.setPotionValue(32660); } else if (f1 <= 3.0F && !entityliving.hasEffect(MobEffectList.WEAKNESS) && this.random.nextFloat() < 0.25F) { entitypotion.setPotionValue(32696); diff --git a/src/main/java/net/minecraft/server/EntityWither.java b/src/main/java/net/minecraft/server/EntityWither.java index 176f8099..bd260822 100644 --- a/src/main/java/net/minecraft/server/EntityWither.java +++ b/src/main/java/net/minecraft/server/EntityWither.java @@ -9,36 +9,33 @@ import org.bukkit.event.entity.ExplosionPrimeEvent; public class EntityWither extends EntityMonster implements IRangedEntity { - private float[] d = new float[2]; - private float[] e = new float[2]; - private float[] f = new float[2]; - private float[] g = new float[2]; - private int[] h = new int[2]; - private int[] i = new int[2]; - private int j; - private static final IEntitySelector bK = new EntitySelectorNotUndead(); + private float[] bp = new float[2]; + private float[] bq = new float[2]; + private float[] br = new float[2]; + private float[] bs = new float[2]; + private int[] bt = new int[2]; + private int[] bu = new int[2]; + private int bv; + private static final IEntitySelector bw = new EntitySelectorNotUndead(); public EntityWither(World world) { super(world); this.setHealth(this.getMaxHealth()); - this.texture = "/mob/wither.png"; this.a(0.9F, 4.0F); this.fireProof = true; - this.bI = 0.6F; this.getNavigation().e(true); this.goalSelector.a(0, new PathfinderGoalFloat(this)); - this.goalSelector.a(2, new PathfinderGoalArrowAttack(this, this.bI, 40, 20.0F)); - this.goalSelector.a(5, new PathfinderGoalRandomStroll(this, this.bI)); + this.goalSelector.a(2, new PathfinderGoalArrowAttack(this, 1.0D, 40, 20.0F)); + this.goalSelector.a(5, new PathfinderGoalRandomStroll(this, 1.0D)); this.goalSelector.a(6, new PathfinderGoalLookAtPlayer(this, EntityHuman.class, 8.0F)); this.goalSelector.a(7, new PathfinderGoalRandomLookaround(this)); this.targetSelector.a(1, new PathfinderGoalHurtByTarget(this, false)); - this.targetSelector.a(2, new PathfinderGoalNearestAttackableTarget(this, EntityLiving.class, 30.0F, 0, false, false, bK)); - this.be = 50; + this.targetSelector.a(2, new PathfinderGoalNearestAttackableTarget(this, EntityInsentient.class, 0, false, false, bw)); + this.b = 50; } protected void a() { super.a(); - this.datawatcher.a(16, new Integer(100)); this.datawatcher.a(17, new Integer(0)); this.datawatcher.a(18, new Integer(0)); this.datawatcher.a(19, new Integer(0)); @@ -47,42 +44,37 @@ public class EntityWither extends EntityMonster implements IRangedEntity { public void b(NBTTagCompound nbttagcompound) { super.b(nbttagcompound); - nbttagcompound.setInt("Invul", this.n()); + nbttagcompound.setInt("Invul", this.bQ()); } public void a(NBTTagCompound nbttagcompound) { super.a(nbttagcompound); - this.t(nbttagcompound.getInt("Invul")); - this.datawatcher.watch(16, Integer.valueOf(this.health)); + this.p(nbttagcompound.getInt("Invul")); } - protected String bb() { + protected String r() { return "mob.wither.idle"; } - protected String bc() { + protected String aK() { return "mob.wither.hurt"; } - protected String bd() { + protected String aL() { return "mob.wither.death"; } public void c() { - if (!this.world.isStatic) { - this.datawatcher.watch(16, Integer.valueOf(this.getScaledHealth())); // CraftBukkit - this.health -> this.getScaledHealth() - } - this.motY *= 0.6000000238418579D; double d0; double d1; double d2; - if (!this.world.isStatic && this.u(0) > 0) { - Entity entity = this.world.getEntity(this.u(0)); + if (!this.world.isStatic && this.q(0) > 0) { + Entity entity = this.world.getEntity(this.q(0)); if (entity != null) { - if (this.locY < entity.locY || !this.o() && this.locY < entity.locY + 5.0D) { + if (this.locY < entity.locY || !this.bR() && this.locY < entity.locY + 5.0D) { if (this.motY < 0.0D) { this.motY = 0.0D; } @@ -111,14 +103,14 @@ public class EntityWither extends EntityMonster implements IRangedEntity { int i; for (i = 0; i < 2; ++i) { - this.g[i] = this.e[i]; - this.f[i] = this.d[i]; + this.bs[i] = this.bq[i]; + this.br[i] = this.bp[i]; } int j; for (i = 0; i < 2; ++i) { - j = this.u(i + 1); + j = this.q(i + 1); Entity entity1 = null; if (j > 0) { @@ -126,9 +118,9 @@ public class EntityWither extends EntityMonster implements IRangedEntity { } if (entity1 != null) { - d0 = this.v(i + 1); - d1 = this.w(i + 1); - d2 = this.x(i + 1); + d0 = this.r(i + 1); + d1 = this.s(i + 1); + d2 = this.t(i + 1); double d4 = entity1.locX - d0; double d5 = entity1.locY + (double) entity1.getHeadHeight() - d1; double d6 = entity1.locZ - d2; @@ -136,19 +128,19 @@ public class EntityWither extends EntityMonster implements IRangedEntity { float f = (float) (Math.atan2(d6, d4) * 180.0D / 3.1415927410125732D) - 90.0F; float f1 = (float) (-(Math.atan2(d5, d7) * 180.0D / 3.1415927410125732D)); - this.d[i] = this.b(this.d[i], f1, 40.0F); - this.e[i] = this.b(this.e[i], f, 10.0F); + this.bp[i] = this.b(this.bp[i], f1, 40.0F); + this.bq[i] = this.b(this.bq[i], f, 10.0F); } else { - this.e[i] = this.b(this.e[i], this.ay, 10.0F); + this.bq[i] = this.b(this.bq[i], this.aN, 10.0F); } } - boolean flag = this.o(); + boolean flag = this.bR(); for (j = 0; j < 3; ++j) { - double d8 = this.v(j); - double d9 = this.w(j); - double d10 = this.x(j); + double d8 = this.r(j); + double d9 = this.s(j); + double d10 = this.t(j); this.world.addParticle("smoke", d8 + this.random.nextGaussian() * 0.30000001192092896D, d9 + this.random.nextGaussian() * 0.30000001192092896D, d10 + this.random.nextGaussian() * 0.30000001192092896D, 0.0D, 0.0D, 0.0D); if (flag && this.world.random.nextInt(4) == 0) { @@ -156,18 +148,18 @@ public class EntityWither extends EntityMonster implements IRangedEntity { } } - if (this.n() > 0) { + if (this.bQ() > 0) { for (j = 0; j < 3; ++j) { this.world.addParticle("mobSpell", this.locX + this.random.nextGaussian() * 1.0D, this.locY + (double) (this.random.nextFloat() * 3.3F), this.locZ + this.random.nextGaussian() * 1.0D, 0.699999988079071D, 0.699999988079071D, 0.8999999761581421D); } } } - protected void bo() { + protected void be() { int i; - if (this.n() > 0) { - i = this.n() - 1; + if (this.bQ() > 0) { + i = this.bQ() - 1; if (i <= 0) { // CraftBukkit start ExplosionPrimeEvent event = new ExplosionPrimeEvent(this.getBukkitEntity(), 7.0F, false); @@ -178,26 +170,27 @@ public class EntityWither extends EntityMonster implements IRangedEntity { } // CraftBukkit end + this.world.createExplosion(this, this.locX, this.locY + (double) this.getHeadHeight(), this.locZ, 7.0F, false, this.world.getGameRules().getBoolean("mobGriefing")); this.world.d(1013, (int) this.locX, (int) this.locY, (int) this.locZ, 0); } - this.t(i); + this.p(i); if (this.ticksLived % 10 == 0) { - this.heal(10, org.bukkit.event.entity.EntityRegainHealthEvent.RegainReason.WITHER_SPAWN); // CraftBukkit + this.heal(10.0F, org.bukkit.event.entity.EntityRegainHealthEvent.RegainReason.WITHER_SPAWN); // CraftBukkit } } else { - super.bo(); + super.be(); int j; for (i = 1; i < 3; ++i) { - if (this.ticksLived >= this.h[i - 1]) { - this.h[i - 1] = this.ticksLived + 10 + this.random.nextInt(10); + if (this.ticksLived >= this.bt[i - 1]) { + this.bt[i - 1] = this.ticksLived + 10 + this.random.nextInt(10); if (this.world.difficulty >= 2) { int i1001 = i - 1; - int i1003 = this.i[i - 1]; + int i1003 = this.bu[i - 1]; - this.i[i1001] = this.i[i - 1] + 1; + this.bu[i1001] = this.bu[i - 1] + 1; if (i1003 > 15) { float f = 10.0F; float f1 = 5.0F; @@ -206,28 +199,28 @@ public class EntityWither extends EntityMonster implements IRangedEntity { double d2 = MathHelper.a(this.random, this.locZ - (double) f, this.locZ + (double) f); this.a(i + 1, d0, d1, d2, true); - this.i[i - 1] = 0; + this.bu[i - 1] = 0; } } - j = this.u(i); + j = this.q(i); if (j > 0) { Entity entity = this.world.getEntity(j); - if (entity != null && entity.isAlive() && this.e(entity) <= 900.0D && this.n(entity)) { + if (entity != null && entity.isAlive() && this.e(entity) <= 900.0D && this.o(entity)) { this.a(i + 1, (EntityLiving) entity); - this.h[i - 1] = this.ticksLived + 40 + this.random.nextInt(20); - this.i[i - 1] = 0; + this.bt[i - 1] = this.ticksLived + 40 + this.random.nextInt(20); + this.bu[i - 1] = 0; } else { this.c(i, 0); } } else { - List list = this.world.a(EntityLiving.class, this.boundingBox.grow(20.0D, 8.0D, 20.0D), bK); + List list = this.world.a(EntityLiving.class, this.boundingBox.grow(20.0D, 8.0D, 20.0D), bw); for (int i1 = 0; i1 < 10 && !list.isEmpty(); ++i1) { EntityLiving entityliving = (EntityLiving) list.get(this.random.nextInt(list.size())); - if (entityliving != this && entityliving.isAlive() && this.n(entityliving)) { + if (entityliving != this && entityliving.isAlive() && this.o(entityliving)) { if (entityliving instanceof EntityHuman) { if (!((EntityHuman) entityliving).abilities.isInvulnerable) { this.c(i, entityliving.id); @@ -250,9 +243,9 @@ public class EntityWither extends EntityMonster implements IRangedEntity { this.c(0, 0); } - if (this.j > 0) { - --this.j; - if (this.j == 0 && this.world.getGameRules().getBoolean("mobGriefing")) { + if (this.bv > 0) { + --this.bv; + if (this.bv == 0 && this.world.getGameRules().getBoolean("mobGriefing")) { i = MathHelper.floor(this.locY); j = MathHelper.floor(this.locX); int j1 = MathHelper.floor(this.locZ); @@ -286,42 +279,42 @@ public class EntityWither extends EntityMonster implements IRangedEntity { } if (this.ticksLived % 20 == 0) { - this.heal(1); + this.heal(1.0F); } } } - public void m() { - this.t(220); - this.setHealth(this.getMaxHealth() / 3); + public void bP() { + this.p(220); + this.setHealth(this.getMaxHealth() / 3.0F); } - public void al() {} + public void ak() {} - public int aZ() { + public int aM() { return 4; } - private double v(int i) { + private double r(int i) { if (i <= 0) { return this.locX; } else { - float f = (this.ay + (float) (180 * (i - 1))) / 180.0F * 3.1415927F; + float f = (this.aN + (float) (180 * (i - 1))) / 180.0F * 3.1415927F; float f1 = MathHelper.cos(f); return this.locX + (double) f1 * 1.3D; } } - private double w(int i) { + private double s(int i) { return i <= 0 ? this.locY + 3.0D : this.locY + 2.2D; } - private double x(int i) { + private double t(int i) { if (i <= 0) { return this.locZ; } else { - float f = (this.ay + (float) (180 * (i - 1))) / 180.0F * 3.1415927F; + float f = (this.aN + (float) (180 * (i - 1))) / 180.0F * 3.1415927F; float f1 = MathHelper.sin(f); return this.locZ + (double) f1 * 1.3D; @@ -348,9 +341,9 @@ public class EntityWither extends EntityMonster implements IRangedEntity { private void a(int i, double d0, double d1, double d2, boolean flag) { this.world.a((EntityHuman) null, 1014, (int) this.locX, (int) this.locY, (int) this.locZ, 0); - double d3 = this.v(i); - double d4 = this.w(i); - double d5 = this.x(i); + double d3 = this.r(i); + double d4 = this.s(i); + double d5 = this.t(i); double d6 = d0 - d3; double d7 = d1 - d4; double d8 = d2 - d5; @@ -370,17 +363,17 @@ public class EntityWither extends EntityMonster implements IRangedEntity { this.a(0, entityliving); } - public boolean damageEntity(DamageSource damagesource, int i) { + public boolean damageEntity(DamageSource damagesource, float f) { if (this.isInvulnerable()) { return false; } else if (damagesource == DamageSource.DROWN) { return false; - } else if (this.n() > 0) { + } else if (this.bQ() > 0) { return false; } else { Entity entity; - if (this.o()) { + if (this.bR()) { entity = damagesource.h(); if (entity instanceof EntityArrow) { return false; @@ -391,15 +384,15 @@ public class EntityWither extends EntityMonster implements IRangedEntity { if (entity != null && !(entity instanceof EntityHuman) && entity instanceof EntityLiving && ((EntityLiving) entity).getMonsterType() == this.getMonsterType()) { return false; } else { - if (this.j <= 0) { - this.j = 20; + if (this.bv <= 0) { + this.bv = 20; } - for (int j = 0; j < this.i.length; ++j) { - this.i[j] += 3; + for (int i = 0; i < this.bu.length; ++i) { + this.bu[i] += 3; } - return super.damageEntity(damagesource, i); + return super.damageEntity(damagesource, f); } } } @@ -412,39 +405,39 @@ public class EntityWither extends EntityMonster implements IRangedEntity { // CraftBukkit end } - protected void bn() { - this.bC = 0; + protected void bk() { + this.aV = 0; } public boolean K() { return !this.dead; } - public int b() { - return this.datawatcher.getInt(16); + protected void b(float f) { } - protected void a(float f) {} - public void addEffect(MobEffect mobeffect) {} - protected boolean bh() { + protected boolean bb() { return true; } - public int getMaxHealth() { - return 300; + protected void ax() { + super.ax(); + this.a(GenericAttributes.a).a(300.0D); + this.a(GenericAttributes.d).a(0.6000000238418579D); + this.a(GenericAttributes.b).a(40.0D); } - public int n() { + public int bQ() { return this.datawatcher.getInt(20); } - public void t(int i) { + public void p(int i) { this.datawatcher.watch(20, Integer.valueOf(i)); } - public int u(int i) { + public int q(int i) { return this.datawatcher.getInt(17 + i); } @@ -452,8 +445,8 @@ public class EntityWither extends EntityMonster implements IRangedEntity { this.datawatcher.watch(17 + i, Integer.valueOf(j)); } - public boolean o() { - return this.b() <= this.maxHealth / 2; // CraftBukkit - this.getMaxHealth() -> this.maxHealth + public boolean bR() { + return this.getHealth() <= this.maxHealth / 2.0F; // CraftBukkit - this.getMaxHealth() -> this.maxHealth } public EnumMonsterType getMonsterType() { diff --git a/src/main/java/net/minecraft/server/EntityWitherSkull.java b/src/main/java/net/minecraft/server/EntityWitherSkull.java index fab412aa..546430ca 100644 --- a/src/main/java/net/minecraft/server/EntityWitherSkull.java +++ b/src/main/java/net/minecraft/server/EntityWitherSkull.java @@ -36,8 +36,8 @@ public class EntityWitherSkull extends EntityFireball { if (!this.world.isStatic) { if (movingobjectposition.entity != null) { if (this.shooter != null) { - if (movingobjectposition.entity.damageEntity(DamageSource.mobAttack(this.shooter), 8) && !movingobjectposition.entity.isAlive()) { - this.shooter.heal(5, org.bukkit.event.entity.EntityRegainHealthEvent.RegainReason.WITHER); // CraftBukkit + if (movingobjectposition.entity.damageEntity(DamageSource.mobAttack(this.shooter), 8.0F) && !movingobjectposition.entity.isAlive()) { + this.shooter.heal(5.0F, org.bukkit.event.entity.EntityRegainHealthEvent.RegainReason.WITHER); // CraftBukkit } } else { movingobjectposition.entity.damageEntity(DamageSource.MAGIC, 5); @@ -77,7 +77,7 @@ public class EntityWitherSkull extends EntityFireball { return false; } - public boolean damageEntity(DamageSource damagesource, int i) { + public boolean damageEntity(DamageSource damagesource, float f) { return false; } diff --git a/src/main/java/net/minecraft/server/EntityWolf.java b/src/main/java/net/minecraft/server/EntityWolf.java index 132b55f9..d3593bc0 100644 --- a/src/main/java/net/minecraft/server/EntityWolf.java +++ b/src/main/java/net/minecraft/server/EntityWolf.java @@ -1,60 +1,84 @@ package net.minecraft.server; +import java.util.Iterator; +import java.util.List; + public class EntityWolf extends EntityTameableAnimal { - private float e; - private float f; - private boolean g; - private boolean h; - private float i; - private float j; + private float bq; + private float br; + private boolean bs; + private boolean bt; + private float bu; + private float bv; public EntityWolf(World world) { super(world); - this.texture = "/mob/wolf.png"; this.a(0.6F, 0.8F); - this.bI = 0.3F; this.getNavigation().a(true); this.goalSelector.a(1, new PathfinderGoalFloat(this)); - this.goalSelector.a(2, this.d); + this.goalSelector.a(2, this.bp); this.goalSelector.a(3, new PathfinderGoalLeapAtTarget(this, 0.4F)); - this.goalSelector.a(4, new PathfinderGoalMeleeAttack(this, this.bI, true)); - this.goalSelector.a(5, new PathfinderGoalFollowOwner(this, this.bI, 10.0F, 2.0F)); - this.goalSelector.a(6, new PathfinderGoalBreed(this, this.bI)); - this.goalSelector.a(7, new PathfinderGoalRandomStroll(this, this.bI)); + this.goalSelector.a(4, new PathfinderGoalMeleeAttack(this, 1.0D, true)); + this.goalSelector.a(5, new PathfinderGoalFollowOwner(this, 1.0D, 10.0F, 2.0F)); + this.goalSelector.a(6, new PathfinderGoalBreed(this, 1.0D)); + this.goalSelector.a(7, new PathfinderGoalRandomStroll(this, 1.0D)); this.goalSelector.a(8, new PathfinderGoalBeg(this, 8.0F)); this.goalSelector.a(9, new PathfinderGoalLookAtPlayer(this, EntityHuman.class, 8.0F)); this.goalSelector.a(9, new PathfinderGoalRandomLookaround(this)); this.targetSelector.a(1, new PathfinderGoalOwnerHurtByTarget(this)); this.targetSelector.a(2, new PathfinderGoalOwnerHurtTarget(this)); this.targetSelector.a(3, new PathfinderGoalHurtByTarget(this, true)); - this.targetSelector.a(4, new PathfinderGoalRandomTargetNonTamed(this, EntitySheep.class, 16.0F, 200, false)); + this.targetSelector.a(4, new PathfinderGoalRandomTargetNonTamed(this, EntitySheep.class, 200, false)); + this.setTamed(false); } - public boolean bh() { + protected void ax() { + super.ax(); + this.a(GenericAttributes.d).a(0.30000001192092896D); + if (this.isTamed()) { + this.a(GenericAttributes.a).a(20.0D); + } else { + this.a(GenericAttributes.a).a(8.0D); + } + } + + public boolean bb() { return true; } public void setGoalTarget(EntityLiving entityliving) { super.setGoalTarget(entityliving); - if (entityliving instanceof EntityHuman) { + if (entityliving == null) { + if (!this.isAngry()) { + return; + } + + this.setAngry(false); + List list = this.world.a(this.getClass(), AxisAlignedBB.a().a(this.locX, this.locY, this.locZ, this.locX + 1.0D, this.locY + 1.0D, this.locZ + 1.0D).grow(16.0D, 10.0D, 16.0D)); + Iterator iterator = list.iterator(); + + while (iterator.hasNext()) { + EntityWolf entitywolf = (EntityWolf) iterator.next(); + + if (this != entitywolf) { + entitywolf.setAngry(false); + } + } + } else { this.setAngry(true); } } - protected void bp() { - this.datawatcher.watch(18, Integer.valueOf(this.getScaledHealth())); // CraftBukkit - this.getHealth() -> this.getScaledHealth() - } - - public int getMaxHealth() { - return this.isTamed() ? 20 : 8; + protected void bg() { + this.datawatcher.watch(18, Float.valueOf(this.getScaledHealth())); // CraftBukkit - this.getHealth() -> this.getScaledHealth() } protected void a() { super.a(); - this.datawatcher.a(18, new Integer(this.getHealth())); + this.datawatcher.a(18, new Float(this.getHealth())); this.datawatcher.a(19, new Byte((byte) 0)); - this.datawatcher.a(20, new Byte((byte) BlockCloth.g_(1))); + this.datawatcher.a(20, new Byte((byte) BlockCloth.j_(1))); } protected void a(int i, int j, int k, int l) { @@ -75,24 +99,20 @@ public class EntityWolf extends EntityTameableAnimal { } } - protected boolean isTypeNotPersistent() { - return this.isAngry() && !this.isTamed(); - } - - protected String bb() { + protected String r() { // CraftBukkit - getInt(18) < 10 -> < this.maxHealth / 2 - return this.isAngry() ? "mob.wolf.growl" : (this.random.nextInt(3) == 0 ? (this.isTamed() && this.datawatcher.getInt(18) < this.maxHealth / 2 ? "mob.wolf.whine" : "mob.wolf.panting") : "mob.wolf.bark"); + return this.isAngry() ? "mob.wolf.growl" : (this.random.nextInt(3) == 0 ? (this.isTamed() && this.datawatcher.getFloat(18) < this.maxHealth / 2 ? "mob.wolf.whine" : "mob.wolf.panting") : "mob.wolf.bark"); } - protected String bc() { + protected String aK() { return "mob.wolf.hurt"; } - protected String bd() { + protected String aL() { return "mob.wolf.death"; } - protected float ba() { + protected float aW() { return 0.4F; } @@ -102,49 +122,49 @@ public class EntityWolf extends EntityTameableAnimal { public void c() { super.c(); - if (!this.world.isStatic && this.g && !this.h && !this.k() && this.onGround) { - this.h = true; - this.i = 0.0F; - this.j = 0.0F; + if (!this.world.isStatic && this.bs && !this.bt && !this.bI() && this.onGround) { + this.bt = true; + this.bu = 0.0F; + this.bv = 0.0F; this.world.broadcastEntityEffect(this, (byte) 8); } } public void l_() { super.l_(); - this.f = this.e; - if (this.bY()) { - this.e += (1.0F - this.e) * 0.4F; + this.br = this.bq; + if (this.ca()) { + this.bq += (1.0F - this.bq) * 0.4F; } else { - this.e += (0.0F - this.e) * 0.4F; + this.bq += (0.0F - this.bq) * 0.4F; } - if (this.bY()) { - this.bJ = 10; + if (this.ca()) { + this.g = 10; } if (this.F()) { - this.g = true; - this.h = false; - this.i = 0.0F; - this.j = 0.0F; - } else if ((this.g || this.h) && this.h) { - if (this.i == 0.0F) { - this.makeSound("mob.wolf.shake", this.ba(), (this.random.nextFloat() - this.random.nextFloat()) * 0.2F + 1.0F); + this.bs = true; + this.bt = false; + this.bu = 0.0F; + this.bv = 0.0F; + } else if ((this.bs || this.bt) && this.bt) { + if (this.bu == 0.0F) { + this.makeSound("mob.wolf.shake", this.aW(), (this.random.nextFloat() - this.random.nextFloat()) * 0.2F + 1.0F); } - this.j = this.i; - this.i += 0.05F; - if (this.j >= 2.0F) { - this.g = false; - this.h = false; - this.j = 0.0F; - this.i = 0.0F; + this.bv = this.bu; + this.bu += 0.05F; + if (this.bv >= 2.0F) { + this.bs = false; + this.bt = false; + this.bv = 0.0F; + this.bu = 0.0F; } - if (this.i > 0.4F) { + if (this.bu > 0.4F) { float f = (float) this.boundingBox.b; - int i = (int) (MathHelper.sin((this.i - 0.4F) * 3.1415927F) * 7.0F); + int i = (int) (MathHelper.sin((this.bu - 0.4F) * 3.1415927F) * 7.0F); for (int j = 0; j < i; ++j) { float f1 = (this.random.nextFloat() * 2.0F - 1.0F) * this.width * 0.5F; @@ -160,32 +180,41 @@ public class EntityWolf extends EntityTameableAnimal { return this.length * 0.8F; } - public int bs() { - return this.isSitting() ? 20 : super.bs(); + public int bl() { + return this.isSitting() ? 20 : super.bl(); } - public boolean damageEntity(DamageSource damagesource, int i) { + public boolean damageEntity(DamageSource damagesource, float f) { if (this.isInvulnerable()) { return false; } else { Entity entity = damagesource.getEntity(); - this.d.setSitting(false); + this.bp.setSitting(false); if (entity != null && !(entity instanceof EntityHuman) && !(entity instanceof EntityArrow)) { - i = (i + 1) / 2; + f = (f + 1.0F) / 2.0F; } - return super.damageEntity(damagesource, i); + return super.damageEntity(damagesource, f); } } public boolean m(Entity entity) { int i = this.isTamed() ? 4 : 2; - return entity.damageEntity(DamageSource.mobAttack(this), i); + return entity.damageEntity(DamageSource.mobAttack(this), (float) i); } - public boolean a_(EntityHuman entityhuman) { + public void setTamed(boolean flag) { + super.setTamed(flag); + if (flag) { + this.a(GenericAttributes.a).a(20.0D); + } else { + this.a(GenericAttributes.a).a(8.0D); + } + } + + public boolean a(EntityHuman entityhuman) { ItemStack itemstack = entityhuman.inventory.getItemInHand(); if (this.isTamed()) { @@ -193,12 +222,12 @@ public class EntityWolf extends EntityTameableAnimal { if (Item.byId[itemstack.id] instanceof ItemFood) { ItemFood itemfood = (ItemFood) Item.byId[itemstack.id]; - if (itemfood.i() && this.datawatcher.getInt(18) < 20) { + if (itemfood.j() && this.datawatcher.getFloat(18) < 20.0F) { if (!entityhuman.abilities.canInstantlyBuild) { --itemstack.count; } - this.heal(itemfood.getNutrition()); + this.heal((float) itemfood.getNutrition()); if (itemstack.count <= 0) { entityhuman.inventory.setItem(entityhuman.inventory.itemInHandIndex, (ItemStack) null); } @@ -206,7 +235,7 @@ public class EntityWolf extends EntityTameableAnimal { return true; } } else if (itemstack.id == Item.INK_SACK.id) { - int i = BlockCloth.g_(itemstack.getData()); + int i = BlockCloth.j_(itemstack.getData()); if (i != this.getCollarColor()) { this.setCollarColor(i); @@ -219,9 +248,9 @@ public class EntityWolf extends EntityTameableAnimal { } } - if (entityhuman.name.equalsIgnoreCase(this.getOwnerName()) && !this.world.isStatic && !this.c(itemstack)) { - this.d.setSitting(!this.isSitting()); - this.bG = false; + if (entityhuman.getName().equalsIgnoreCase(this.getOwnerName()) && !this.world.isStatic && !this.c(itemstack)) { + this.bp.setSitting(!this.isSitting()); + this.bd = false; this.setPathEntity((PathEntity) null); } } else if (itemstack != null && itemstack.id == Item.BONE.id && !this.isAngry()) { @@ -240,18 +269,18 @@ public class EntityWolf extends EntityTameableAnimal { this.setTamed(true); this.setPathEntity((PathEntity) null); this.setGoalTarget((EntityLiving) null); - this.d.setSitting(true); + this.bp.setSitting(true); // CraftBukkit start if (updateMaxHealth) { this.maxHealth = this.getMaxHealth(); } this.setHealth(this.maxHealth); // CraftBukkit end - this.setOwnerName(entityhuman.name); - this.i(true); + this.setOwnerName(entityhuman.getName()); + this.j(true); this.world.broadcastEntityEffect(this, (byte) 7); } else { - this.i(false); + this.j(false); this.world.broadcastEntityEffect(this, (byte) 6); } } @@ -259,14 +288,14 @@ public class EntityWolf extends EntityTameableAnimal { return true; } - return super.a_(entityhuman); + return super.a(entityhuman); } public boolean c(ItemStack itemstack) { - return itemstack == null ? false : (!(Item.byId[itemstack.id] instanceof ItemFood) ? false : ((ItemFood) Item.byId[itemstack.id]).i()); + return itemstack == null ? false : (!(Item.byId[itemstack.id] instanceof ItemFood) ? false : ((ItemFood) Item.byId[itemstack.id]).j()); } - public int by() { + public int br() { return 8; } @@ -304,9 +333,7 @@ public class EntityWolf extends EntityTameableAnimal { return entitywolf; } - public void m(boolean flag) { - byte b0 = this.datawatcher.getByte(19); - + public void n(boolean flag) { if (flag) { this.datawatcher.watch(19, Byte.valueOf((byte) 1)); } else { @@ -324,14 +351,18 @@ public class EntityWolf extends EntityTameableAnimal { } else { EntityWolf entitywolf = (EntityWolf) entityanimal; - return !entitywolf.isTamed() ? false : (entitywolf.isSitting() ? false : this.r() && entitywolf.r()); + return !entitywolf.isTamed() ? false : (entitywolf.isSitting() ? false : this.bU() && entitywolf.bU()); } } - public boolean bY() { + public boolean ca() { return this.datawatcher.getByte(19) == 1; } + protected boolean isTypeNotPersistent() { + return !this.isTamed() && this.ticksLived > 2400; + } + public EntityAgeable createChild(EntityAgeable entityageable) { return this.b(entityageable); } diff --git a/src/main/java/net/minecraft/server/EntityZombie.java b/src/main/java/net/minecraft/server/EntityZombie.java index 352127d0..75ca31c0 100644 --- a/src/main/java/net/minecraft/server/EntityZombie.java +++ b/src/main/java/net/minecraft/server/EntityZombie.java @@ -1,6 +1,7 @@ package net.minecraft.server; import java.util.Calendar; +import java.util.UUID; //CraftBukkit start import org.bukkit.craftbukkit.entity.CraftLivingEntity; @@ -10,34 +11,35 @@ import org.bukkit.event.entity.EntityCombustEvent; public class EntityZombie extends EntityMonster { - private int d = 0; + protected static final IAttribute bp = (new AttributeRanged("zombie.spawnReinforcements", 0.0D, 0.0D, 1.0D)).a("Spawn Reinforcements Chance"); + private static final UUID bq = UUID.fromString("B9766B59-9566-4402-BC1F-2EE2A276D836"); + private static final AttributeModifier br = new AttributeModifier(bq, "Baby speed boost", 0.5D, 0); + private int bs; private int lastTick = MinecraftServer.currentTick; // CraftBukkit public EntityZombie(World world) { super(world); - this.texture = "/mob/zombie.png"; - this.bI = 0.23F; this.getNavigation().b(true); this.goalSelector.a(0, new PathfinderGoalFloat(this)); this.goalSelector.a(1, new PathfinderGoalBreakDoor(this)); - this.goalSelector.a(2, new PathfinderGoalMeleeAttack(this, EntityHuman.class, this.bI, false)); - this.goalSelector.a(3, new PathfinderGoalMeleeAttack(this, EntityVillager.class, this.bI, true)); - this.goalSelector.a(4, new PathfinderGoalMoveTowardsRestriction(this, this.bI)); - this.goalSelector.a(5, new PathfinderGoalMoveThroughVillage(this, this.bI, false)); - this.goalSelector.a(6, new PathfinderGoalRandomStroll(this, this.bI)); + this.goalSelector.a(2, new PathfinderGoalMeleeAttack(this, EntityHuman.class, 1.0D, false)); + this.goalSelector.a(3, new PathfinderGoalMeleeAttack(this, EntityVillager.class, 1.0D, true)); + this.goalSelector.a(4, new PathfinderGoalMoveTowardsRestriction(this, 1.0D)); + this.goalSelector.a(5, new PathfinderGoalMoveThroughVillage(this, 1.0D, false)); + this.goalSelector.a(6, new PathfinderGoalRandomStroll(this, 1.0D)); this.goalSelector.a(7, new PathfinderGoalLookAtPlayer(this, EntityHuman.class, 8.0F)); this.goalSelector.a(7, new PathfinderGoalRandomLookaround(this)); this.targetSelector.a(1, new PathfinderGoalHurtByTarget(this, true)); - this.targetSelector.a(2, new PathfinderGoalNearestAttackableTarget(this, EntityHuman.class, 16.0F, 0, true)); - this.targetSelector.a(2, new PathfinderGoalNearestAttackableTarget(this, EntityVillager.class, 16.0F, 0, false)); + this.targetSelector.a(2, new PathfinderGoalNearestAttackableTarget(this, EntityHuman.class, 0, true)); + this.targetSelector.a(2, new PathfinderGoalNearestAttackableTarget(this, EntityVillager.class, 0, false)); } - protected int ay() { - return 40; - } - - public float bE() { - return super.bE() * (this.isBaby() ? 1.5F : 1.0F); + protected void ax() { + super.ax(); + this.a(GenericAttributes.b).a(40.0D); + this.a(GenericAttributes.d).a(0.23000000417232513D); + this.a(GenericAttributes.e).a(3.0D); + this.aT().b(bp).a(this.random.nextDouble() * 0.10000000149011612D); } protected void a() { @@ -47,12 +49,8 @@ public class EntityZombie extends EntityMonster { this.getDataWatcher().a(14, Byte.valueOf((byte) 0)); } - public int getMaxHealth() { - return 20; - } - - public int aZ() { - int i = super.aZ() + 2; + public int aM() { + int i = super.aM() + 2; if (i > 20) { i = 20; @@ -61,7 +59,7 @@ public class EntityZombie extends EntityMonster { return i; } - protected boolean bh() { + protected boolean bb() { return true; } @@ -70,7 +68,15 @@ public class EntityZombie extends EntityMonster { } public void setBaby(boolean flag) { - this.getDataWatcher().watch(12, Byte.valueOf((byte) (flag ? 1 : 0))); // CraftBukkit - added flag + this.getDataWatcher().watch(12, Byte.valueOf((byte) (flag ? 1 : 0))); + if (this.world != null && !this.world.isStatic) { + AttributeInstance attributeinstance = this.a(GenericAttributes.d); + + attributeinstance.b(br); + if (flag) { + attributeinstance.a(br); + } + } } public boolean isVillager() { @@ -83,7 +89,7 @@ public class EntityZombie extends EntityMonster { public void c() { if (this.world.v() && !this.world.isStatic && !this.isBaby()) { - float f = this.c(1.0F); + float f = this.d(1.0F); if (f > 0.5F && this.random.nextFloat() * 30.0F < (f - 0.4F) * 2.0F && this.world.l(MathHelper.floor(this.locX), MathHelper.floor(this.locY), MathHelper.floor(this.locZ))) { boolean flag = true; @@ -117,9 +123,52 @@ public class EntityZombie extends EntityMonster { super.c(); } + public boolean damageEntity(DamageSource damagesource, float f) { + if (!super.damageEntity(damagesource, f)) { + return false; + } else { + EntityLiving entityliving = this.getGoalTarget(); + + if (entityliving == null && this.bJ() instanceof EntityLiving) { + entityliving = (EntityLiving) this.bJ(); + } + + if (entityliving == null && damagesource.getEntity() instanceof EntityLiving) { + entityliving = (EntityLiving) damagesource.getEntity(); + } + + if (entityliving != null && this.world.difficulty >= 3 && (double) this.random.nextFloat() < this.a(bp).e()) { + int i = MathHelper.floor(this.locX); + int j = MathHelper.floor(this.locY); + int k = MathHelper.floor(this.locZ); + EntityZombie entityzombie = new EntityZombie(this.world); + + for (int l = 0; l < 50; ++l) { + int i1 = i + MathHelper.nextInt(this.random, 7, 40) * MathHelper.nextInt(this.random, -1, 1); + int j1 = j + MathHelper.nextInt(this.random, 7, 40) * MathHelper.nextInt(this.random, -1, 1); + int k1 = k + MathHelper.nextInt(this.random, 7, 40) * MathHelper.nextInt(this.random, -1, 1); + + if (this.world.w(i1, j1 - 1, k1) && this.world.getLightLevel(i1, j1, k1) < 10) { + entityzombie.setPosition((double) i1, (double) j1, (double) k1); + if (this.world.b(entityzombie.boundingBox) && this.world.getCubes(entityzombie, entityzombie.boundingBox).isEmpty() && !this.world.containsLiquid(entityzombie.boundingBox)) { + this.world.addEntity(entityzombie); + entityzombie.setGoalTarget(entityliving); + entityzombie.a((GroupDataEntity) null); + this.a(bp).a(new AttributeModifier("Zombie reinforcement caller charge", -0.05000000074505806D, 0)); + entityzombie.a(bp).a(new AttributeModifier("Zombie reinforcement callee charge", -0.05000000074505806D, 0)); + break; + } + } + } + } + + return true; + } + } + public void l_() { - if (!this.world.isStatic && this.o()) { - int i = this.q(); + if (!this.world.isStatic && this.bR()) { + int i = this.bT(); // CraftBukkit start - Use wall time instead of ticks for villager conversion int elapsedTicks = MinecraftServer.currentTick - this.lastTick; @@ -127,9 +176,9 @@ public class EntityZombie extends EntityMonster { i *= elapsedTicks; // CraftBukkit end - this.d -= i; - if (this.d <= 0) { - this.p(); + this.bs -= i; + if (this.bs <= 0) { + this.bS(); } } @@ -139,7 +188,7 @@ public class EntityZombie extends EntityMonster { public boolean m(Entity entity) { boolean flag = super.m(entity); - if (flag && this.bG() == null && this.isBurning() && this.random.nextFloat() < (float) this.world.difficulty * 0.3F) { + if (flag && this.aV() == null && this.isBurning() && this.random.nextFloat() < (float) this.world.difficulty * 0.3F) { // CraftBukkit start EntityCombustByEntityEvent event = new EntityCombustByEntityEvent(this.getBukkitEntity(), entity.getBukkitEntity(), 2 * this.world.difficulty); this.world.getServer().getPluginManager().callEvent(event); @@ -153,28 +202,15 @@ public class EntityZombie extends EntityMonster { return flag; } - public int c(Entity entity) { - ItemStack itemstack = this.bG(); - // CraftBukkit - getMaxHealth() -> ((CraftLivingEntity) this.bukkitEntity).getMaxHealth() - float f = (float) (((CraftLivingEntity) this.bukkitEntity).getMaxHealth() - this.getHealth()) / (float) ((CraftLivingEntity) this.bukkitEntity).getMaxHealth(); - int i = 3 + MathHelper.d(f * 4.0F); - - if (itemstack != null) { - i += itemstack.a((Entity) this); - } - - return i; - } - - protected String bb() { + protected String r() { return "mob.zombie.say"; } - protected String bc() { + protected String aK() { return "mob.zombie.hurt"; } - protected String bd() { + protected String aL() { return "mob.zombie.death"; } @@ -205,8 +241,8 @@ public class EntityZombie extends EntityMonster { } // CraftBukkit end - protected void bH() { - super.bH(); + protected void bs() { + super.bs(); if (this.random.nextFloat() < (this.world.difficulty == 3 ? 0.05F : 0.01F)) { int i = this.random.nextInt(3); @@ -228,7 +264,7 @@ public class EntityZombie extends EntityMonster { nbttagcompound.setBoolean("IsVillager", true); } - nbttagcompound.setInt("ConversionTime", this.o() ? this.d : -1); + nbttagcompound.setInt("ConversionTime", this.bR() ? this.bs : -1); } public void a(NBTTagCompound nbttagcompound) { @@ -255,9 +291,9 @@ public class EntityZombie extends EntityMonster { EntityZombie entityzombie = new EntityZombie(this.world); - entityzombie.k(entityliving); + entityzombie.j(entityliving); this.world.kill(entityliving); - entityzombie.bJ(); + entityzombie.a((GroupDataEntity) null); entityzombie.setVillager(true); if (entityliving.isBaby()) { entityzombie.setBaby(true); @@ -268,26 +304,38 @@ public class EntityZombie extends EntityMonster { } } - public void bJ() { - this.h(this.random.nextFloat() < au[this.world.difficulty]); + public GroupDataEntity a(GroupDataEntity groupdataentity) { + groupdataentity = super.a(groupdataentity); + float f = this.world.b(this.locX, this.locY, this.locZ); + + this.h(this.random.nextFloat() < 0.55F * f); if (this.world.random.nextFloat() < 0.05F) { this.setVillager(true); } - this.bH(); - this.bI(); + this.bs(); + this.bt(); if (this.getEquipment(4) == null) { - Calendar calendar = this.world.V(); + Calendar calendar = this.world.W(); if (calendar.get(2) + 1 == 10 && calendar.get(5) == 31 && this.random.nextFloat() < 0.25F) { this.setEquipment(4, new ItemStack(this.random.nextFloat() < 0.1F ? Block.JACK_O_LANTERN : Block.PUMPKIN)); this.dropChances[4] = 0.0F; } } + + this.a(GenericAttributes.c).a(new AttributeModifier("Random spawn bonus", this.random.nextDouble() * 0.05000000074505806D, 0)); + this.a(GenericAttributes.b).a(new AttributeModifier("Random zombie-spawn bonus", this.random.nextDouble() * 1.5D, 2)); + if (this.random.nextFloat() < f * 0.05F) { + this.a(bp).a(new AttributeModifier("Leader zombie bonus", this.random.nextDouble() * 0.25D + 0.5D, 0)); + this.a(GenericAttributes.a).a(new AttributeModifier("Leader zombie bonus", this.random.nextDouble() * 3.0D + 1.0D, 2)); + } + + return groupdataentity; } - public boolean a_(EntityHuman entityhuman) { - ItemStack itemstack = entityhuman.cd(); + public boolean a(EntityHuman entityhuman) { + ItemStack itemstack = entityhuman.bt(); if (itemstack != null && itemstack.getItem() == Item.GOLDEN_APPLE && itemstack.getData() == 0 && this.isVillager() && this.hasEffect(MobEffectList.WEAKNESS)) { if (!entityhuman.abilities.canInstantlyBuild) { @@ -309,23 +357,27 @@ public class EntityZombie extends EntityMonster { } protected void a(int i) { - this.d = i; + this.bs = i; this.getDataWatcher().watch(14, Byte.valueOf((byte) 1)); - this.o(MobEffectList.WEAKNESS.id); + this.k(MobEffectList.WEAKNESS.id); this.addEffect(new MobEffect(MobEffectList.INCREASE_DAMAGE.id, i, Math.min(this.world.difficulty - 1, 0))); this.world.broadcastEntityEffect(this, (byte) 16); } - public boolean o() { + protected boolean isTypeNotPersistent() { + return !this.bR(); + } + + public boolean bR() { return this.getDataWatcher().getByte(14) == 1; } - protected void p() { + protected void bS() { EntityVillager entityvillager = new EntityVillager(this.world); - entityvillager.k(this); - entityvillager.bJ(); - entityvillager.q(); + entityvillager.j(this); + entityvillager.a((GroupDataEntity) null); + entityvillager.bT(); if (this.isBaby()) { entityvillager.setAge(-24000); } @@ -336,7 +388,7 @@ public class EntityZombie extends EntityMonster { this.world.a((EntityHuman) null, 1017, (int) this.locX, (int) this.locY, (int) this.locZ, 0); } - protected int q() { + protected int bT() { int i = 1; if (this.random.nextFloat() < 0.01F) { diff --git a/src/main/java/net/minecraft/server/Explosion.java b/src/main/java/net/minecraft/server/Explosion.java index ef220c1f..758d447b 100644 --- a/src/main/java/net/minecraft/server/Explosion.java +++ b/src/main/java/net/minecraft/server/Explosion.java @@ -19,7 +19,7 @@ import org.bukkit.Location; public class Explosion { - public boolean a = false; + public boolean a; public boolean b = true; private int i = 16; private Random j = new Random(); @@ -133,7 +133,7 @@ public class Explosion { // CraftBukkit start - Explosion damage hook org.bukkit.entity.Entity damagee = (entity == null) ? null : entity.getBukkitEntity(); - int damageDone = (int) ((d10 * d10 + d10) / 2.0D * 8.0D * (double) this.size + 1.0D); + float damageDone = (float) ((int) ((d10 * d10 + d10) / 2.0D * 8.0D * (double) this.size + 1.0D)); if (damagee == null) { // nothing was hurt @@ -143,7 +143,7 @@ public class Explosion { if (!event.isCancelled()) { damagee.setLastDamageCause(event); - entity.damageEntity(DamageSource.explosion(this), event.getDamage()); + entity.damageEntity(DamageSource.explosion(this), (float) event.getDamage()); double d11 = EnchantmentProtection.a(entity, d10); entity.motX += d0 * d11; @@ -168,7 +168,7 @@ public class Explosion { if (!event.isCancelled()) { entity.getBukkitEntity().setLastDamageCause(event); - entity.damageEntity(DamageSource.explosion(this), event.getDamage()); + entity.damageEntity(DamageSource.explosion(this), (float) event.getDamage()); entity.motX += d0 * d10; entity.motY += d1 * d10; @@ -287,7 +287,7 @@ public class Explosion { l = this.world.getTypeId(i, j, k); int i1 = this.world.getTypeId(i, j - 1, k); - if (l == 0 && Block.s[i1] && this.j.nextInt(3) == 0) { + if (l == 0 && Block.t[i1] && this.j.nextInt(3) == 0) { // CraftBukkit start - Ignition by explosion if (!org.bukkit.craftbukkit.event.CraftEventFactory.callBlockIgniteEvent(this.world, i, j, k, this).isCancelled()) { this.world.setTypeIdUpdate(i, j, k, Block.FIRE.id); diff --git a/src/main/java/net/minecraft/server/FoodMetaData.java b/src/main/java/net/minecraft/server/FoodMetaData.java index f26d5522..543a430a 100644 --- a/src/main/java/net/minecraft/server/FoodMetaData.java +++ b/src/main/java/net/minecraft/server/FoodMetaData.java @@ -8,7 +8,7 @@ public class FoodMetaData { public int foodLevel = 20; public float saturationLevel = 5.0F; public float exhaustionLevel; - public int foodTickTimer = 0; + public int foodTickTimer; // CraftBukkit end private int e = 20; @@ -44,18 +44,18 @@ public class FoodMetaData { } } - if (this.foodLevel >= 18 && entityhuman.co()) { + if (entityhuman.world.getGameRules().getBoolean("naturalRegeneration") && this.foodLevel >= 18 && entityhuman.bE()) { ++this.foodTickTimer; if (this.foodTickTimer >= 80) { // CraftBukkit - added RegainReason - entityhuman.heal(1, org.bukkit.event.entity.EntityRegainHealthEvent.RegainReason.SATIATED); + entityhuman.heal(1.0F, org.bukkit.event.entity.EntityRegainHealthEvent.RegainReason.SATIATED); this.foodTickTimer = 0; } } else if (this.foodLevel <= 0) { ++this.foodTickTimer; if (this.foodTickTimer >= 80) { - if (entityhuman.getHealth() > 10 || i >= 3 || entityhuman.getHealth() > 1 && i >= 2) { - entityhuman.damageEntity(DamageSource.STARVE, 1); + if (entityhuman.getHealth() > 10.0F || i >= 3 || entityhuman.getHealth() > 1.0F && i >= 2) { + entityhuman.damageEntity(DamageSource.STARVE, 1.0F); } this.foodTickTimer = 0; diff --git a/src/main/java/net/minecraft/server/InventoryHorseChest.java b/src/main/java/net/minecraft/server/InventoryHorseChest.java new file mode 100644 index 00000000..1fa3d5f4 --- /dev/null +++ b/src/main/java/net/minecraft/server/InventoryHorseChest.java @@ -0,0 +1,55 @@ +package net.minecraft.server; + +// CraftBukkit start +import java.util.List; +import org.bukkit.craftbukkit.entity.CraftHumanEntity; +import org.bukkit.entity.HumanEntity; +// CraftBukkit end + +public class InventoryHorseChest extends InventorySubcontainer { + + public InventoryHorseChest(String s, int i) { + super(s, false, i); + } + + // CraftBukkit start + public List<HumanEntity> transaction = new java.util.ArrayList<HumanEntity>(); + public org.bukkit.entity.Player player; + private int maxStack = MAX_STACK; + + @Override + public ItemStack[] getContents() { + return this.items; + } + + @Override + public void onOpen(CraftHumanEntity who) { + transaction.add(who); + } + + @Override + public void onClose(CraftHumanEntity who) { + transaction.remove(who); + } + + @Override + public List<HumanEntity> getViewers() { + return transaction; + } + + @Override + public org.bukkit.inventory.InventoryHolder getOwner() { + return this.player; + } + + @Override + public void setMaxStackSize(int size) { + maxStack = size; + } + + @Override + public int getMaxStackSize() { + return maxStack; + } + // CraftBukkit end +}
\ No newline at end of file diff --git a/src/main/java/net/minecraft/server/InventoryMerchant.java b/src/main/java/net/minecraft/server/InventoryMerchant.java index d89bcb30..9ab8fdc5 100644 --- a/src/main/java/net/minecraft/server/InventoryMerchant.java +++ b/src/main/java/net/minecraft/server/InventoryMerchant.java @@ -177,6 +177,8 @@ public class InventoryMerchant implements IInventory { } } } + + this.merchant.a_(this.getItem(2)); } public MerchantRecipe getRecipe() { diff --git a/src/main/java/net/minecraft/server/InventorySubcontainer.java b/src/main/java/net/minecraft/server/InventorySubcontainer.java index c288380c..825d5ac9 100644 --- a/src/main/java/net/minecraft/server/InventorySubcontainer.java +++ b/src/main/java/net/minecraft/server/InventorySubcontainer.java @@ -1,5 +1,6 @@ package net.minecraft.server; +import java.util.ArrayList; import java.util.List; public abstract class InventorySubcontainer implements IInventory { // CraftBukkit - abstract @@ -17,6 +18,18 @@ public abstract class InventorySubcontainer implements IInventory { // CraftBukk this.items = new ItemStack[i]; } + public void a(IInventoryListener iinventorylistener) { + if (this.d == null) { + this.d = new ArrayList(); + } + + this.d.add(iinventorylistener); + } + + public void b(IInventoryListener iinventorylistener) { + this.d.remove(iinventorylistener); + } + public ItemStack getItem(int i) { return this.items[i]; } @@ -76,6 +89,11 @@ public abstract class InventorySubcontainer implements IInventory { // CraftBukk return this.e; } + public void a(String s) { + this.e = true; + this.a = s; + } + public int getMaxStackSize() { return 64; } diff --git a/src/main/java/net/minecraft/server/ItemBed.java b/src/main/java/net/minecraft/server/ItemBed.java index 311fa730..f72133d6 100644 --- a/src/main/java/net/minecraft/server/ItemBed.java +++ b/src/main/java/net/minecraft/server/ItemBed.java @@ -37,7 +37,7 @@ public class ItemBed extends Item { } if (entityhuman.a(i, j, k, l, itemstack) && entityhuman.a(i + b0, j, k + b1, l, itemstack)) { - if (world.isEmpty(i, j, k) && world.isEmpty(i + b0, j, k + b1) && world.w(i, j - 1, k) && world.v(i + b0, j - 1, k + b1)) { + if (world.isEmpty(i, j, k) && world.isEmpty(i + b0, j, k + b1) && world.w(i, j - 1, k) && world.w(i + b0, j - 1, k + b1)) { // CraftBukkit start // world.setTypeIdAndData(i, j, k, blockbed.id, i1, 3); if (!ItemBlock.processBlockPlace(world, entityhuman, null, i, j, k, blockbed.id, i1, clickedX, clickedY, clickedZ)) { diff --git a/src/main/java/net/minecraft/server/ItemBlock.java b/src/main/java/net/minecraft/server/ItemBlock.java index 01c06af2..b2c3ed8d 100644 --- a/src/main/java/net/minecraft/server/ItemBlock.java +++ b/src/main/java/net/minecraft/server/ItemBlock.java @@ -14,7 +14,7 @@ public class ItemBlock extends Item { } public boolean interactWith(ItemStack itemstack, EntityHuman entityhuman, World world, int i, int j, int k, int l, float f, float f1, float f2) { - final int clickedX = i, clickedY = j, clickedZ = k; + final int clickedX = i, clickedY = j, clickedZ = k; // CraftBukkit int i1 = world.getTypeId(i, j, k); if (i1 == Block.SNOW.id && (world.getData(i, j, k) & 7) < 1) { @@ -67,6 +67,8 @@ public class ItemBlock extends Item { world.makeSound((double) ((float) i + 0.5F), (double) ((float) j + 0.5F), (double) ((float) k + 0.5F), block.stepSound.getPlaceSound(), (block.stepSound.getVolume1() + 1.0F) / 2.0F, block.stepSound.getVolume2() * 0.8F); --itemstack.count; } + + return true; */ return processBlockPlace(world, entityhuman, itemstack, i, j, k, this.id, k1, clickedX, clickedY, clickedZ); // CraftBukkit end diff --git a/src/main/java/net/minecraft/server/ItemBoat.java b/src/main/java/net/minecraft/server/ItemBoat.java index 494c4d31..4ebf389e 100644 --- a/src/main/java/net/minecraft/server/ItemBoat.java +++ b/src/main/java/net/minecraft/server/ItemBoat.java @@ -31,7 +31,7 @@ public class ItemBoat extends Item { if (movingobjectposition == null) { return itemstack; } else { - Vec3D vec3d2 = entityhuman.i(f); + Vec3D vec3d2 = entityhuman.j(f); boolean flag = false; float f9 = 1.0F; List list = world.getEntities(entityhuman, entityhuman.boundingBox.a(vec3d2.c * d3, vec3d2.d * d3, vec3d2.e * d3).grow((double) f9, (double) f9, (double) f9)); diff --git a/src/main/java/net/minecraft/server/ItemBow.java b/src/main/java/net/minecraft/server/ItemBow.java index ad34840d..7b0bb510 100644 --- a/src/main/java/net/minecraft/server/ItemBow.java +++ b/src/main/java/net/minecraft/server/ItemBow.java @@ -2,7 +2,7 @@ package net.minecraft.server; public class ItemBow extends Item { - public static final String[] a = new String[] { "bow_pull_0", "bow_pull_1", "bow_pull_2"}; + public static final String[] a = new String[] { "pulling_0", "pulling_1", "pulling_2"}; public ItemBow(int i) { super(i); @@ -15,7 +15,7 @@ public class ItemBow extends Item { boolean flag = entityhuman.abilities.canInstantlyBuild || EnchantmentManager.getEnchantmentLevel(Enchantment.ARROW_INFINITE.id, itemstack) > 0; if (flag || entityhuman.inventory.e(Item.ARROW.id)) { - int j = this.c_(itemstack) - i; + int j = this.d_(itemstack) - i; float f = (float) j / 20.0F; f = (f * f + f * 2.0F) / 3.0F; @@ -62,7 +62,7 @@ public class ItemBow extends Item { // CraftBukkit end itemstack.damage(1, entityhuman); - world.makeSound(entityhuman, "random.bow", 1.0F, 1.0F / (e.nextFloat() * 0.4F + 1.2F) + f * 0.5F); + world.makeSound(entityhuman, "random.bow", 1.0F, 1.0F / (Item.f.nextFloat() * 0.4F + 1.2F) + f * 0.5F); // CraftBukkit - Fix compilation if (flag) { entityarrow.fromPlayer = 2; } else { @@ -76,17 +76,17 @@ public class ItemBow extends Item { return itemstack; } - public int c_(ItemStack itemstack) { + public int d_(ItemStack itemstack) { return 72000; } - public EnumAnimation b_(ItemStack itemstack) { + public EnumAnimation c_(ItemStack itemstack) { return EnumAnimation.BOW; } public ItemStack a(ItemStack itemstack, World world, EntityHuman entityhuman) { if (entityhuman.abilities.canInstantlyBuild || entityhuman.inventory.e(Item.ARROW.id)) { - entityhuman.a(itemstack, this.c_(itemstack)); + entityhuman.a(itemstack, this.d_(itemstack)); } return itemstack; diff --git a/src/main/java/net/minecraft/server/ItemBucket.java b/src/main/java/net/minecraft/server/ItemBucket.java index ecab05b2..86522a76 100644 --- a/src/main/java/net/minecraft/server/ItemBucket.java +++ b/src/main/java/net/minecraft/server/ItemBucket.java @@ -19,10 +19,6 @@ public class ItemBucket extends Item { } public ItemStack a(ItemStack itemstack, World world, EntityHuman entityhuman) { - float f = 1.0F; - double d0 = entityhuman.lastX + (entityhuman.locX - entityhuman.lastX) * (double) f; - double d1 = entityhuman.lastY + (entityhuman.locY - entityhuman.lastY) * (double) f + 1.62D - (double) entityhuman.height; - double d2 = entityhuman.lastZ + (entityhuman.locZ - entityhuman.lastZ) * (double) f; boolean flag = this.a == 0; MovingObjectPosition movingobjectposition = this.a(world, entityhuman, flag); @@ -143,44 +139,41 @@ public class ItemBucket extends Item { } // CraftBukkit end - if (this.a(world, d0, d1, d2, i, j, k) && !entityhuman.abilities.canInstantlyBuild) { + if (this.a(world, i, j, k) && !entityhuman.abilities.canInstantlyBuild) { return CraftItemStack.asNMSCopy(event.getItemStack()); // CraftBukkit } } - } else if (this.a == 0 && movingobjectposition.entity instanceof EntityCow) { - // CraftBukkit start - This codepath seems to be *NEVER* called - org.bukkit.Location loc = movingobjectposition.entity.getBukkitEntity().getLocation(); - PlayerBucketFillEvent event = CraftEventFactory.callPlayerBucketFillEvent(entityhuman, loc.getBlockX(), loc.getBlockY(), loc.getBlockZ(), -1, itemstack, Item.MILK_BUCKET); - - if (event.isCancelled()) { - return itemstack; - } - - return CraftItemStack.asNMSCopy(event.getItemStack()); - // CraftBukkit end } return itemstack; } } - public boolean a(World world, double d0, double d1, double d2, int i, int j, int k) { + public boolean a(World world, int i, int j, int k) { if (this.a <= 0) { return false; - } else if (!world.isEmpty(i, j, k) && world.getMaterial(i, j, k).isBuildable()) { - return false; } else { - if (world.worldProvider.e && this.a == Block.WATER.id) { - world.makeSound(d0 + 0.5D, d1 + 0.5D, d2 + 0.5D, "random.fizz", 0.5F, 2.6F + (world.random.nextFloat() - world.random.nextFloat()) * 0.8F); + boolean flag = !world.getMaterial(i, j, k).isBuildable(); - for (int l = 0; l < 8; ++l) { - world.addParticle("largesmoke", (double) i + Math.random(), (double) j + Math.random(), (double) k + Math.random(), 0.0D, 0.0D, 0.0D); - } + if (!world.isEmpty(i, j, k) && !flag) { + return false; } else { - world.setTypeIdAndData(i, j, k, this.a, 0, 3); - } + if (!world.isStatic && flag) { + world.setAir(i, j, k, true); + } + + if (world.worldProvider.f && this.a == Block.WATER.id) { + world.makeSound((double) ((float) i + 0.5F), (double) ((float) j + 0.5F), (double) ((float) k + 0.5F), "random.fizz", 0.5F, 2.6F + (world.random.nextFloat() - world.random.nextFloat()) * 0.8F); - return true; + for (int l = 0; l < 8; ++l) { + world.addParticle("largesmoke", (double) i + Math.random(), (double) j + Math.random(), (double) k + Math.random(), 0.0D, 0.0D, 0.0D); + } + } else { + world.setTypeIdAndData(i, j, k, this.a, 0, 3); + } + + return true; + } } } } diff --git a/src/main/java/net/minecraft/server/ItemDoor.java b/src/main/java/net/minecraft/server/ItemDoor.java index 438a69ad..708fcf8e 100644 --- a/src/main/java/net/minecraft/server/ItemDoor.java +++ b/src/main/java/net/minecraft/server/ItemDoor.java @@ -86,7 +86,7 @@ public class ItemDoor extends Item { // CraftBukkit start if (entityhuman != null) { - if(!ItemBlock.processBlockPlace(world, entityhuman, null, i, j, k, block.id, l, clickedX, clickedY, clickedZ)) { + if (!ItemBlock.processBlockPlace(world, entityhuman, null, i, j, k, block.id, l, clickedX, clickedY, clickedZ)) { ((EntityPlayer) entityhuman).playerConnection.sendPacket(new Packet53BlockChange(i, j + 1, k, world)); return false; } diff --git a/src/main/java/net/minecraft/server/ItemDye.java b/src/main/java/net/minecraft/server/ItemDye.java index cb971d74..d0ffd84f 100644 --- a/src/main/java/net/minecraft/server/ItemDye.java +++ b/src/main/java/net/minecraft/server/ItemDye.java @@ -8,7 +8,7 @@ import org.bukkit.event.entity.SheepDyeWoolEvent; public class ItemDye extends Item { public static final String[] a = new String[] { "black", "red", "green", "brown", "blue", "purple", "cyan", "silver", "gray", "pink", "lime", "yellow", "lightBlue", "magenta", "orange", "white"}; - public static final String[] b = new String[] { "dyePowder_black", "dyePowder_red", "dyePowder_green", "dyePowder_brown", "dyePowder_blue", "dyePowder_purple", "dyePowder_cyan", "dyePowder_silver", "dyePowder_gray", "dyePowder_pink", "dyePowder_lime", "dyePowder_yellow", "dyePowder_lightBlue", "dyePowder_magenta", "dyePowder_orange", "dyePowder_white"}; + public static final String[] b = new String[] { "black", "red", "green", "brown", "blue", "purple", "cyan", "silver", "gray", "pink", "lime", "yellow", "light_blue", "magenta", "orange", "white"}; public static final int[] c = new int[] { 1973019, 11743532, 3887386, 5320730, 2437522, 8073150, 2651799, 11250603, 4408131, 14188952, 4312372, 14602026, 6719955, 12801229, 15435844, 15790320}; public ItemDye(int i) { @@ -29,7 +29,7 @@ public class ItemDye extends Item { return false; } else { if (itemstack.getData() == 15) { - if (a(itemstack, world, i, j, k, entityhuman)) { + if (a(itemstack, world, i, j, k)) { if (!world.isStatic) { world.triggerEffect(2005, i, j, k, 0); } @@ -40,7 +40,7 @@ public class ItemDye extends Item { int i1 = world.getTypeId(i, j, k); int j1 = world.getData(i, j, k); - if (i1 == Block.LOG.id && BlockLog.d(j1) == 3) { + if (i1 == Block.LOG.id && BlockLog.f(j1) == 3) { if (l == 0) { return false; } @@ -67,6 +67,7 @@ public class ItemDye extends Item { if (world.isEmpty(i, j, k)) { int k1 = Block.byId[Block.COCOA.id].getPlacedData(world, i, j, k, l, f, f1, f2, 0); + world.setTypeIdAndData(i, j, k, Block.COCOA.id, k1, 2); if (!entityhuman.abilities.canInstantlyBuild) { --itemstack.count; @@ -149,20 +150,20 @@ public class ItemDye extends Item { int l1 = k; for (int i2 = 0; i2 < i1 / 16; ++i2) { - j1 += e.nextInt(3) - 1; - k1 += (e.nextInt(3) - 1) * e.nextInt(3) / 2; - l1 += e.nextInt(3) - 1; + j1 += f.nextInt(3) - 1; + k1 += (f.nextInt(3) - 1) * f.nextInt(3) / 2; + l1 += f.nextInt(3) - 1; if (world.getTypeId(j1, k1 - 1, l1) != Block.GRASS.id || world.u(j1, k1, l1)) { continue label102; } } if (world.getTypeId(j1, k1, l1) == 0) { - if (e.nextInt(10) != 0) { + if (f.nextInt(10) != 0) { if (Block.LONG_GRASS.f(world, j1, k1, l1)) { world.setTypeIdAndData(j1, k1, l1, Block.LONG_GRASS.id, 1, 3); } - } else if (e.nextInt(3) != 0) { + } else if (f.nextInt(3) != 0) { if (Block.YELLOW_FLOWER.f(world, j1, k1, l1)) { world.setTypeIdUpdate(j1, k1, l1, Block.YELLOW_FLOWER.id); } @@ -190,8 +191,8 @@ public class ItemDye extends Item { if (!world.isStatic) { if ((double) world.random.nextFloat() < 0.4D) { // CraftBukkit start - Validate - Player player = (entityhuman instanceof EntityPlayer) ? (Player) entityhuman.getBukkitEntity() : null; - ((BlockMushroom) Block.byId[l]).grow(world, i, j, k, world.random, true, player, itemstack); + Player player = (entityhuman instanceof EntityPlayer) ? (Player) entityhuman.getBukkitEntity() : null; + ((BlockMushroom) Block.byId[l]).grow(world, i, j, k, world.random, true, player, itemstack); } //--itemstack.count; - called later if the bonemeal attempt was not cancelled by a plugin @@ -202,10 +203,10 @@ public class ItemDye extends Item { } } - public boolean a(ItemStack itemstack, EntityLiving entityliving) { + public boolean a(ItemStack itemstack, EntityHuman entityhuman, EntityLiving entityliving) { if (entityliving instanceof EntitySheep) { EntitySheep entitysheep = (EntitySheep) entityliving; - int i = BlockCloth.g_(itemstack.getData()); + int i = BlockCloth.j_(itemstack.getData()); if (!entitysheep.isSheared() && entitysheep.getColor() != i) { // CraftBukkit start diff --git a/src/main/java/net/minecraft/server/ItemFireball.java b/src/main/java/net/minecraft/server/ItemFireball.java index 81777fcf..3145c943 100644 --- a/src/main/java/net/minecraft/server/ItemFireball.java +++ b/src/main/java/net/minecraft/server/ItemFireball.java @@ -50,7 +50,7 @@ public class ItemFireball extends Item { } // CraftBukkit end - world.makeSound((double) i + 0.5D, (double) j + 0.5D, (double) k + 0.5D, "fire.ignite", 1.0F, e.nextFloat() * 0.4F + 0.8F); + world.makeSound((double) i + 0.5D, (double) j + 0.5D, (double) k + 0.5D, "fire.ignite", 1.0F, Item.f.nextFloat() * 0.4F + 0.8F); // CraftBukkit - Fix compilation world.setTypeIdUpdate(i, j, k, Block.FIRE.id); } diff --git a/src/main/java/net/minecraft/server/ItemFishingRod.java b/src/main/java/net/minecraft/server/ItemFishingRod.java index 7b92c92f..eb510781 100644 --- a/src/main/java/net/minecraft/server/ItemFishingRod.java +++ b/src/main/java/net/minecraft/server/ItemFishingRod.java @@ -16,7 +16,7 @@ public class ItemFishingRod extends Item { int i = entityhuman.hookedFish.c(); itemstack.damage(i, entityhuman); - entityhuman.bK(); + entityhuman.aR(); } else { // CraftBukkit start EntityFishingHook hook = new EntityFishingHook(world, entityhuman); @@ -27,13 +27,12 @@ public class ItemFishingRod extends Item { return itemstack; } // CraftBukkit end - - world.makeSound(entityhuman, "random.bow", 0.5F, 0.4F / (e.nextFloat() * 0.4F + 0.8F)); + world.makeSound(entityhuman, "random.bow", 0.5F, 0.4F / (f.nextFloat() * 0.4F + 0.8F)); if (!world.isStatic) { world.addEntity(hook); // CraftBukkit - moved creation up } - entityhuman.bK(); + entityhuman.aR(); } return itemstack; diff --git a/src/main/java/net/minecraft/server/ItemFlintAndSteel.java b/src/main/java/net/minecraft/server/ItemFlintAndSteel.java index 3f106a5e..e2d0a141 100644 --- a/src/main/java/net/minecraft/server/ItemFlintAndSteel.java +++ b/src/main/java/net/minecraft/server/ItemFlintAndSteel.java @@ -56,7 +56,7 @@ public class ItemFlintAndSteel extends Item { CraftBlockState blockState = CraftBlockState.getBlockState(world, i, j, k); // CraftBukkit end - world.makeSound((double) i + 0.5D, (double) j + 0.5D, (double) k + 0.5D, "fire.ignite", 1.0F, e.nextFloat() * 0.4F + 0.8F); + world.makeSound((double) i + 0.5D, (double) j + 0.5D, (double) k + 0.5D, "fire.ignite", 1.0F, Item.f.nextFloat() * 0.4F + 0.8F); // CraftBukkit - fix compilation world.setTypeIdUpdate(i, j, k, Block.FIRE.id); // CraftBukkit start diff --git a/src/main/java/net/minecraft/server/ItemFood.java b/src/main/java/net/minecraft/server/ItemFood.java index 409addf8..5b77fc72 100644 --- a/src/main/java/net/minecraft/server/ItemFood.java +++ b/src/main/java/net/minecraft/server/ItemFood.java @@ -6,11 +6,11 @@ public class ItemFood extends Item { private final int b; private final float c; private final boolean d; - private boolean cu; - private int cv; - private int cw; - private int cx; - private float cy; + private boolean cB; + private int cC; + private int cD; + private int cE; + private float cF; public ItemFood(int i, int j, float f, boolean flag) { super(i); @@ -39,28 +39,29 @@ public class ItemFood extends Item { ((EntityPlayer) entityhuman).playerConnection.sendPacket(new Packet8UpdateHealth(entityhuman.getHealth(), entityhuman.getFoodData().foodLevel, entityhuman.getFoodData().saturationLevel)); // CraftBukkit end + entityhuman.getFoodData().a(this); world.makeSound(entityhuman, "random.burp", 0.5F, world.random.nextFloat() * 0.1F + 0.9F); this.c(itemstack, world, entityhuman); return itemstack; } protected void c(ItemStack itemstack, World world, EntityHuman entityhuman) { - if (!world.isStatic && this.cv > 0 && world.random.nextFloat() < this.cy) { - entityhuman.addEffect(new MobEffect(this.cv, this.cw * 20, this.cx)); + if (!world.isStatic && this.cC > 0 && world.random.nextFloat() < this.cF) { + entityhuman.addEffect(new MobEffect(this.cC, this.cD * 20, this.cE)); } } - public int c_(ItemStack itemstack) { + public int d_(ItemStack itemstack) { return 32; } - public EnumAnimation b_(ItemStack itemstack) { + public EnumAnimation c_(ItemStack itemstack) { return EnumAnimation.EAT; } public ItemStack a(ItemStack itemstack, World world, EntityHuman entityhuman) { - if (entityhuman.i(this.cu)) { - entityhuman.a(itemstack, this.c_(itemstack)); + if (entityhuman.g(this.cB)) { + entityhuman.a(itemstack, this.d_(itemstack)); } return itemstack; @@ -74,20 +75,20 @@ public class ItemFood extends Item { return this.c; } - public boolean i() { + public boolean j() { return this.d; } public ItemFood a(int i, int j, int k, float f) { - this.cv = i; - this.cw = j; - this.cx = k; - this.cy = f; + this.cC = i; + this.cD = j; + this.cE = k; + this.cF = f; return this; } - public ItemFood j() { - this.cu = true; + public ItemFood k() { + this.cB = true; return this; } } diff --git a/src/main/java/net/minecraft/server/ItemHanging.java b/src/main/java/net/minecraft/server/ItemHanging.java index 27d4c259..bfcd283d 100644 --- a/src/main/java/net/minecraft/server/ItemHanging.java +++ b/src/main/java/net/minecraft/server/ItemHanging.java @@ -39,7 +39,7 @@ public class ItemHanging extends Item { world.getServer().getPluginManager().callEvent(event); PaintingPlaceEvent paintingEvent = null; - if(entityhanging instanceof EntityPainting) { + if (entityhanging instanceof EntityPainting) { // Fire old painting event until it can be removed paintingEvent = new PaintingPlaceEvent((org.bukkit.entity.Painting) entityhanging.getBukkitEntity(), who, blockClicked, blockFace); paintingEvent.setCancelled(event.isCancelled()); diff --git a/src/main/java/net/minecraft/server/ItemHoe.java b/src/main/java/net/minecraft/server/ItemHoe.java index aa96737e..4d216e83 100644 --- a/src/main/java/net/minecraft/server/ItemHoe.java +++ b/src/main/java/net/minecraft/server/ItemHoe.java @@ -20,9 +20,7 @@ public class ItemHoe extends Item { int i1 = world.getTypeId(i, j, k); int j1 = world.getTypeId(i, j + 1, k); - if ((l == 0 || j1 != 0 || i1 != Block.GRASS.id) && i1 != Block.DIRT.id) { - return false; - } else { + if (l != 0 && j1 == 0 && (i1 == Block.GRASS.id || i1 == Block.DIRT.id)) { Block block = Block.SOIL; world.makeSound((double) ((float) i + 0.5F), (double) ((float) j + 0.5F), (double) ((float) k + 0.5F), block.stepSound.getStepSound(), (block.stepSound.getVolume1() + 1.0F) / 2.0F, block.stepSound.getVolume2() * 0.8F); @@ -39,6 +37,8 @@ public class ItemHoe extends Item { itemstack.damage(1, entityhuman); return true; } + } else { + return false; } } } diff --git a/src/main/java/net/minecraft/server/ItemMinecart.java b/src/main/java/net/minecraft/server/ItemMinecart.java index b4320456..5df0c320 100644 --- a/src/main/java/net/minecraft/server/ItemMinecart.java +++ b/src/main/java/net/minecraft/server/ItemMinecart.java @@ -16,7 +16,7 @@ public class ItemMinecart extends Item { public boolean interactWith(ItemStack itemstack, EntityHuman entityhuman, World world, int i, int j, int k, int l, float f, float f1, float f2) { int i1 = world.getTypeId(i, j, k); - if (BlockMinecartTrack.d_(i1)) { + if (BlockMinecartTrackAbstract.e_(i1)) { if (!world.isStatic) { // CraftBukkit start - Minecarts org.bukkit.event.player.PlayerInteractEvent event = org.bukkit.craftbukkit.event.CraftEventFactory.callPlayerInteractEvent(entityhuman, org.bukkit.event.block.Action.RIGHT_CLICK_BLOCK, i, j, k, l, itemstack); diff --git a/src/main/java/net/minecraft/server/ItemMonsterEgg.java b/src/main/java/net/minecraft/server/ItemMonsterEgg.java index a1fe7039..06967d8a 100644 --- a/src/main/java/net/minecraft/server/ItemMonsterEgg.java +++ b/src/main/java/net/minecraft/server/ItemMonsterEgg.java @@ -8,7 +8,7 @@ public class ItemMonsterEgg extends Item { this.a(CreativeModeTab.f); } - public String i(ItemStack itemstack) { + public String l(ItemStack itemstack) { String s = ("" + LocaleI18n.get(this.getName() + ".name")).trim(); String s1 = EntityTypes.b(itemstack.getData()); @@ -38,7 +38,7 @@ public class ItemMonsterEgg extends Item { if (entity != null) { if (entity instanceof EntityLiving && itemstack.hasName()) { - ((EntityLiving) entity).setCustomName(itemstack.getName()); + ((EntityInsentient) entity).setCustomName(itemstack.getName()); } if (!entityhuman.abilities.canInstantlyBuild) { @@ -50,6 +50,48 @@ public class ItemMonsterEgg extends Item { } } + public ItemStack a(ItemStack itemstack, World world, EntityHuman entityhuman) { + if (world.isStatic) { + return itemstack; + } else { + MovingObjectPosition movingobjectposition = this.a(world, entityhuman, true); + + if (movingobjectposition == null) { + return itemstack; + } else { + if (movingobjectposition.type == EnumMovingObjectType.TILE) { + int i = movingobjectposition.b; + int j = movingobjectposition.c; + int k = movingobjectposition.d; + + if (!world.a(entityhuman, i, j, k)) { + return itemstack; + } + + if (!entityhuman.a(i, j, k, movingobjectposition.face, itemstack)) { + return itemstack; + } + + if (world.getMaterial(i, j, k) == Material.WATER) { + Entity entity = a(world, itemstack.getData(), (double) i, (double) j, (double) k); + + if (entity != null) { + if (entity instanceof EntityLiving && itemstack.hasName()) { + ((EntityInsentient) entity).setCustomName(itemstack.getName()); + } + + if (!entityhuman.abilities.canInstantlyBuild) { + --itemstack.count; + } + } + } + } + + return itemstack; + } + } + } + public static Entity a(World world, int i, double d0, double d1, double d2) { if (!EntityTypes.a.containsKey(Integer.valueOf(i))) { return null; @@ -59,14 +101,14 @@ public class ItemMonsterEgg extends Item { for (int j = 0; j < 1; ++j) { entity = EntityTypes.a(i, world); if (entity != null && entity instanceof EntityLiving) { - EntityLiving entityliving = (EntityLiving) entity; + EntityInsentient entityinsentient = (EntityInsentient) entity; entity.setPositionRotation(d0, d1, d2, MathHelper.g(world.random.nextFloat() * 360.0F), 0.0F); - entityliving.aA = entityliving.yaw; - entityliving.ay = entityliving.yaw; - entityliving.bJ(); + entityinsentient.aP = entityinsentient.yaw; + entityinsentient.aN = entityinsentient.yaw; + entityinsentient.a((GroupDataEntity) null); world.addEntity(entity, org.bukkit.event.entity.CreatureSpawnEvent.SpawnReason.SPAWNER_EGG); // CraftBukkit - entityliving.aR(); + entityinsentient.p(); } } diff --git a/src/main/java/net/minecraft/server/ItemSeeds.java b/src/main/java/net/minecraft/server/ItemSeeds.java index bd1a46f1..381d028e 100644 --- a/src/main/java/net/minecraft/server/ItemSeeds.java +++ b/src/main/java/net/minecraft/server/ItemSeeds.java @@ -16,7 +16,7 @@ public class ItemSeeds extends Item { final int clickedX = i, clickedY = j, clickedZ = k; // CraftBukkit if (l != 1) { return false; - } else if (entityhuman.e(i, j, k) && entityhuman.e(i, j + 1, k)) { + } else if (entityhuman.a(i, j, k, l, itemstack) && entityhuman.a(i, j + 1, k, l, itemstack)) { int i1 = world.getTypeId(i, j, k); if (i1 == this.b && world.isEmpty(i, j + 1, k)) { diff --git a/src/main/java/net/minecraft/server/ItemSkull.java b/src/main/java/net/minecraft/server/ItemSkull.java index 9d8f8ffb..063f50b6 100644 --- a/src/main/java/net/minecraft/server/ItemSkull.java +++ b/src/main/java/net/minecraft/server/ItemSkull.java @@ -3,7 +3,7 @@ package net.minecraft.server; public class ItemSkull extends Item { private static final String[] b = new String[] { "skeleton", "wither", "zombie", "char", "creeper"}; - public static final String[] a = new String[] { "skull_skeleton", "skull_wither", "skull_zombie", "skull_char", "skull_creeper"}; + public static final String[] a = new String[] { "skeleton", "wither", "zombie", "steve", "creeper"}; public ItemSkull(int i) { super(i); diff --git a/src/main/java/net/minecraft/server/ItemSnow.java b/src/main/java/net/minecraft/server/ItemSnow.java index 916aecc0..1cee156e 100644 --- a/src/main/java/net/minecraft/server/ItemSnow.java +++ b/src/main/java/net/minecraft/server/ItemSnow.java @@ -7,7 +7,7 @@ public class ItemSnow extends ItemBlockWithAuxData { } public boolean interactWith(ItemStack itemstack, EntityHuman entityhuman, World world, int i, int j, int k, int l, float f, float f1, float f2) { - final int clickedX = i, clickedY = j, clickedZ = k; + final int clickedX = i, clickedY = j, clickedZ = k; // CraftBukkit if (itemstack.count == 0) { return false; } else if (!entityhuman.a(i, j, k, l, itemstack)) { diff --git a/src/main/java/net/minecraft/server/ItemStack.java b/src/main/java/net/minecraft/server/ItemStack.java index 343b8cb5..f42f1622 100644 --- a/src/main/java/net/minecraft/server/ItemStack.java +++ b/src/main/java/net/minecraft/server/ItemStack.java @@ -1,15 +1,19 @@ package net.minecraft.server; +import com.google.common.collect.HashMultimap; +import com.google.common.collect.Multimap; +import java.text.DecimalFormat; import java.util.Random; public final class ItemStack { + public static final DecimalFormat a = new DecimalFormat("#.###"); public int count; - public int b; + public int c; public int id; public NBTTagCompound tag; private int damage; - private EntityItemFrame f; + private EntityItemFrame g; public ItemStack(Block block) { this(block, 1); @@ -36,12 +40,11 @@ public final class ItemStack { } public ItemStack(int i, int j, int k) { - this.count = 0; - this.f = null; this.id = i; this.count = j; // CraftBukkit start - Pass to setData to do filtering this.setData(k); + //this.damage = k; //if (this.damage < 0) { // this.damage = 0; //} @@ -55,10 +58,7 @@ public final class ItemStack { return itemstack.getItem() != null ? itemstack : null; } - private ItemStack() { - this.count = 0; - this.f = null; - } + private ItemStack() {} public ItemStack a(int i) { ItemStack itemstack = new ItemStack(this.id, i, this.damage); @@ -135,7 +135,7 @@ public final class ItemStack { } public boolean usesData() { - return Item.byId[this.id].m(); + return Item.byId[this.id].n(); } public boolean i() { @@ -206,13 +206,18 @@ public final class ItemStack { public void damage(int i, EntityLiving entityliving) { if (!(entityliving instanceof EntityHuman) || !((EntityHuman) entityliving).abilities.canInstantlyBuild) { if (this.g()) { - if (this.isDamaged(i, entityliving.aE())) { + if (this.isDamaged(i, entityliving.aB())) { entityliving.a(this); + --this.count; if (entityliving instanceof EntityHuman) { - ((EntityHuman) entityliving).a(StatisticList.F[this.id], 1); + EntityHuman entityhuman = (EntityHuman) entityliving; + + entityhuman.a(StatisticList.F[this.id], 1); + if (this.count == 0 && this.getItem() instanceof ItemBow) { + entityhuman.bu(); + } } - --this.count; if (this.count < 0) { this.count = 0; } @@ -245,16 +250,12 @@ public final class ItemStack { } } - public int a(Entity entity) { - return Item.byId[this.id].a(entity); - } - public boolean b(Block block) { return Item.byId[this.id].canDestroySpecialBlock(block); } - public boolean a(EntityLiving entityliving) { - return Item.byId[this.id].a(this, entityliving); + public boolean a(EntityHuman entityhuman, EntityLiving entityliving) { + return Item.byId[this.id].a(this, entityhuman, entityliving); } public ItemStack cloneItemStack() { @@ -296,8 +297,8 @@ public final class ItemStack { } public void a(World world, Entity entity, int i, boolean flag) { - if (this.b > 0) { - --this.b; + if (this.c > 0) { + --this.c; } Item.byId[this.id].a(this, world, entity, i, flag); @@ -309,11 +310,11 @@ public final class ItemStack { } public int n() { - return this.getItem().c_(this); + return this.getItem().d_(this); } public EnumAnimation o() { - return this.getItem().b_(this); + return this.getItem().c_(this); } public void b(World world, EntityHuman entityhuman, int i) { @@ -362,12 +363,28 @@ public final class ItemStack { this.tag.getCompound("display").setString("Name", s); } + public void t() { + if (this.tag != null) { + if (this.tag.hasKey("display")) { + NBTTagCompound nbttagcompound = this.tag.getCompound("display"); + + nbttagcompound.remove("Name"); + if (nbttagcompound.isEmpty()) { + this.tag.remove("display"); + if (this.tag.isEmpty()) { + this.setTag((NBTTagCompound) null); + } + } + } + } + } + public boolean hasName() { return this.tag == null ? false : (!this.tag.hasKey("display") ? false : this.tag.getCompound("display").hasKey("Name")); } - public boolean w() { - return !this.getItem().d_(this) ? false : !this.hasEnchantments(); + public boolean x() { + return !this.getItem().e_(this) ? false : !this.hasEnchantments(); } public void addEnchantment(Enchantment enchantment, int i) { @@ -399,20 +416,20 @@ public final class ItemStack { this.tag.set(s, nbtbase); } - public boolean y() { - return this.getItem().y(); + public boolean z() { + return this.getItem().z(); } - public boolean z() { - return this.f != null; + public boolean A() { + return this.g != null; } public void a(EntityItemFrame entityitemframe) { - this.f = entityitemframe; + this.g = entityitemframe; } - public EntityItemFrame A() { - return this.f; + public EntityItemFrame B() { + return this.g; } public int getRepairCost() { @@ -426,4 +443,26 @@ public final class ItemStack { this.tag.setInt("RepairCost", i); } + + public Multimap D() { + Object object; + + if (this.hasTag() && this.tag.hasKey("AttributeModifiers")) { + object = HashMultimap.create(); + NBTTagList nbttaglist = this.tag.getList("AttributeModifiers"); + + for (int i = 0; i < nbttaglist.size(); ++i) { + NBTTagCompound nbttagcompound = (NBTTagCompound) nbttaglist.get(i); + AttributeModifier attributemodifier = GenericAttributes.a(nbttagcompound); + + if (attributemodifier.a().getLeastSignificantBits() != 0L && attributemodifier.a().getMostSignificantBits() != 0L) { + ((Multimap) object).put(nbttagcompound.getString("AttributeName"), attributemodifier); + } + } + } else { + object = this.getItem().h(); + } + + return (Multimap) object; + } } diff --git a/src/main/java/net/minecraft/server/ItemStep.java b/src/main/java/net/minecraft/server/ItemStep.java index 67af6d68..4f5a8846 100644 --- a/src/main/java/net/minecraft/server/ItemStep.java +++ b/src/main/java/net/minecraft/server/ItemStep.java @@ -90,6 +90,7 @@ public class ItemStep extends ItemBlock { // CraftBukkit end --itemstack.count; } + return true; } else { return false; diff --git a/src/main/java/net/minecraft/server/ItemWorldMap.java b/src/main/java/net/minecraft/server/ItemWorldMap.java index cf3bb1ff..cf6ebd11 100644 --- a/src/main/java/net/minecraft/server/ItemWorldMap.java +++ b/src/main/java/net/minecraft/server/ItemWorldMap.java @@ -50,7 +50,7 @@ public class ItemWorldMap extends ItemWorldMapBase { int i1 = MathHelper.floor(entity.locZ - (double) k) / i + short2 / 2; int j1 = 128 / i; - if (world.worldProvider.f) { + if (world.worldProvider.g) { j1 /= 2; } @@ -84,7 +84,7 @@ public class ItemWorldMap extends ItemWorldMapBase { int l4; int i5; - if (world.worldProvider.f) { + if (world.worldProvider.g) { j4 = i3 + j3 * 231871; j4 = j4 * j4 * 31287121 + j4 * 11; if ((j4 >> 20 & 1) == 0) { @@ -108,7 +108,7 @@ public class ItemWorldMap extends ItemWorldMapBase { j5 = chunk.getTypeId(j4 + k3, l4 - 1, k4 + l3); if (j5 == 0) { flag1 = false; - } else if (l4 > 0 && j5 > 0 && Block.byId[j5].material.G == MaterialMapColor.b) { + } else if (l4 > 0 && j5 > 0 && Block.byId[j5].material.H == MaterialMapColor.b) { flag1 = false; } @@ -165,7 +165,7 @@ public class ItemWorldMap extends ItemWorldMapBase { i5 = 0; if (k4 > 0) { - MaterialMapColor materialmapcolor = Block.byId[k4].material.G; + MaterialMapColor materialmapcolor = Block.byId[k4].material.H; if (materialmapcolor == MaterialMapColor.n) { d2 = (double) i4 * 0.1D + (double) (k1 + j2 & 1) * 0.2D; diff --git a/src/main/java/net/minecraft/server/MinecraftServer.java b/src/main/java/net/minecraft/server/MinecraftServer.java index 3e134fb7..96d291df 100644 --- a/src/main/java/net/minecraft/server/MinecraftServer.java +++ b/src/main/java/net/minecraft/server/MinecraftServer.java @@ -2,6 +2,7 @@ package net.minecraft.server; import java.awt.GraphicsEnvironment; import java.io.File; +import java.net.Proxy; import java.security.KeyPair; import java.text.SimpleDateFormat; import java.util.ArrayList; @@ -26,51 +27,52 @@ import org.bukkit.event.world.WorldSaveEvent; public abstract class MinecraftServer implements ICommandListener, Runnable, IMojangStatistics { - private static MinecraftServer k = null; + private static MinecraftServer l; public Convertable convertable; // CraftBukkit - private final -> public - private final MojangStatisticsGenerator m = new MojangStatisticsGenerator("server", this); + private final MojangStatisticsGenerator n = new MojangStatisticsGenerator("server", this, aq()); public File universe; // CraftBukkit - private final -> public - private final List o = new ArrayList(); - private final ICommandHandler p; + private final List p = new ArrayList(); + private final ICommandHandler q; public final MethodProfiler methodProfiler = new MethodProfiler(); private String serverIp; - private int r = -1; + private int s = -1; public WorldServer[] worldServer; - private PlayerList s; + private PlayerList t; private boolean isRunning = true; - private boolean isStopped = false; - private int ticks = 0; - public String c; - public int d; + private boolean isStopped; + private int ticks; + protected Proxy c; + public String d; + public int e; private boolean onlineMode; private boolean spawnAnimals; private boolean spawnNPCs; private boolean pvpMode; private boolean allowFlight; private String motd; - private int C; - private long D; + private int D; private long E; private long F; private long G; - public final long[] e = new long[100]; - public final long[] f = new long[100]; - public final long[] g = new long[100]; - public final long[] h = new long[100]; - public final long[] i = new long[100]; - public long[][] j; - private KeyPair H; - private String I; + private long H; + public final long[] f; + public final long[] g; + public final long[] h; + public final long[] i; + public final long[] j; + public long[][] k; + private KeyPair I; private String J; + private String K; private boolean demoMode; - private boolean M; private boolean N; - private String O = ""; - private boolean P = false; - private long Q; - private String R; - private boolean S; - private boolean T = false; + private boolean O; + private String P; + private boolean Q; + private long R; + private String S; + private boolean T; + private boolean U; // CraftBukkit start public List<WorldServer> worlds = new ArrayList<WorldServer>(); @@ -86,11 +88,18 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo // CraftBukkit end public MinecraftServer(OptionSet options) { // CraftBukkit - signature file -> OptionSet - k = this; + this.c = Proxy.NO_PROXY; + this.f = new long[100]; + this.g = new long[100]; + this.h = new long[100]; + this.i = new long[100]; + this.j = new long[100]; + this.P = ""; + l = this; // this.universe = file1; // CraftBukkit - this.p = new CommandDispatcher(); + this.q = new CommandDispatcher(); // this.convertable = new WorldLoaderServer(server.getWorldContainer()); // CraftBukkit - moved to DedicatedServer.init - this.an(); + this.ar(); // CraftBukkit start this.options = options; @@ -117,27 +126,27 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo public abstract PropertyManager getPropertyManager(); // CraftBukkit end - private void an() { + private void ar() { DispenserRegistry.a(); } protected abstract boolean init() throws java.net.UnknownHostException; // CraftBukkit - throws UnknownHostException - protected void b(String s) { + protected void a(String s) { if (this.getConvertable().isConvertable(s)) { this.getLogger().info("Converting map!"); - this.c("menu.convertingLevel"); + this.b("menu.convertingLevel"); this.getConvertable().convert(s, new ConvertProgressUpdater(this)); } } - protected synchronized void c(String s) { - this.R = s; + protected synchronized void b(String s) { + this.S = s; } protected void a(String s, String s1, long i, WorldType worldtype, String s2) { - this.b(s); - this.c("menu.loadingLevel"); + this.a(s); + this.b("menu.loadingLevel"); this.worldServer = new WorldServer[3]; // CraftBukkit - Removed ticktime arrays IDataManager idatamanager = this.convertable.a(s, true); @@ -173,7 +182,7 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo worldsettings.a(s2); if (j == 0) { - if (this.M()) { // Strip out DEMO? + if (this.O()) { // Strip out DEMO? // CraftBukkit world = new DemoWorldServer(this, new ServerNBTManager(server.getWorldContainer(), s1, true), s1, dimension, this.methodProfiler, this.getLogger()); } else { @@ -231,56 +240,55 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo this.server.getPluginManager().callEvent(new org.bukkit.event.world.WorldInitEvent(world.getWorld())); world.addIWorldAccess(new WorldManager(this, world)); - if (!this.I()) { + if (!this.K()) { world.getWorldData().setGameType(this.getGamemode()); } this.worlds.add(world); - this.s.setPlayerFileData(this.worlds.toArray(new WorldServer[this.worlds.size()])); + this.t.setPlayerFileData(this.worlds.toArray(new WorldServer[this.worlds.size()])); // CraftBukkit end } this.c(this.getDifficulty()); - this.e(); + this.f(); } - protected void e() { - long i = System.currentTimeMillis(); // CraftBukkit - current time + protected void f() { + boolean flag = true; + boolean flag1 = true; + boolean flag2 = true; + boolean flag3 = true; + int i = 0; - this.c("menu.generatingTerrain"); + this.b("menu.generatingTerrain"); byte b0 = 0; // CraftBukkit start - for (int j = 0; j < this.worlds.size(); ++j) { - WorldServer worldserver = this.worlds.get(j); - this.getLogger().info("Preparing start region for level " + j + " (Seed: " + worldserver.getSeed() + ")"); + for (int m = 0; m < this.worlds.size(); ++m) { + WorldServer worldserver = this.worlds.get(m); + this.getLogger().info("Preparing start region for level " + b0 + " (Seed: " + worldserver.getSeed() + ")"); if (!worldserver.getWorld().getKeepSpawnInMemory()) { continue; } ChunkCoordinates chunkcoordinates = worldserver.getSpawn(); + long j = aq(); for (int k = -192; k <= 192 && this.isRunning(); k += 16) { for (int l = -192; l <= 192 && this.isRunning(); l += 16) { - long i1 = System.currentTimeMillis(); - - if (i1 < i) { - i = i1; - } + long i1 = aq(); - if (i1 > i + 1000L) { - int j1 = (192 * 2 + 1) * (192 * 2 + 1); - int k1 = (k + 192) * (192 * 2 + 1) + l + 1; - - this.a_("Preparing spawn area", k1 * 100 / j1); - i = i1; + if (i1 - j > 1000L) { + this.a_("Preparing spawn area", i * 100 / 625); + j = i1; } + ++i; worldserver.chunkProviderServer.getChunkAt(chunkcoordinates.x + k >> 4, chunkcoordinates.z + l >> 4); } } } // CraftBukkit end - this.j(); + this.l(); } public abstract boolean getGenerateStructures(); @@ -291,21 +299,23 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo public abstract boolean isHardcore(); + public abstract int k(); + protected void a_(String s, int i) { - this.c = s; - this.d = i; + this.d = s; + this.e = i; this.getLogger().info(s + ": " + i + "%"); } - protected void j() { - this.c = null; - this.d = 0; + protected void l() { + this.d = null; + this.e = 0; this.server.enablePlugins(org.bukkit.plugin.PluginLoadOrder.POSTWORLD); // CraftBukkit } protected void saveChunks(boolean flag) throws ExceptionWorldConflict { // CraftBukkit - added throws - if (!this.N) { + if (!this.O) { // CraftBukkit start for (int j = 0; j < this.worlds.size(); ++j) { WorldServer worldserver = this.worlds.get(j); @@ -327,7 +337,7 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo } public void stop() throws ExceptionWorldConflict { // CraftBukkit - added throws - if (!this.N) { + if (!this.O) { this.getLogger().info("Stopping server"); // CraftBukkit start if (this.server != null) { @@ -335,14 +345,14 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo } // CraftBukkit end - if (this.ae() != null) { - this.ae().a(); + if (this.ag() != null) { + this.ag().a(); } - if (this.s != null) { + if (this.t != null) { this.getLogger().info("Saving players"); - this.s.savePlayers(); - this.s.r(); + this.t.savePlayers(); + this.t.r(); } this.getLogger().info("Saving worlds"); @@ -355,8 +365,8 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo worldserver.saveLevel(); } // CraftBukkit end */ - if (this.m != null && this.m.d()) { - this.m.e(); + if (this.n != null && this.n.d()) { + this.n.e(); } } } @@ -365,7 +375,7 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo return this.serverIp; } - public void d(String s) { + public void c(String s) { this.serverIp = s; } @@ -380,17 +390,17 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo public void run() { try { if (this.init()) { - long i = System.currentTimeMillis(); + long i = aq(); - for (long j = 0L; this.isRunning; this.P = true) { - long k = System.currentTimeMillis(); + for (long j = 0L; this.isRunning; this.Q = true) { + long k = aq(); long l = k - i; - if (l > 2000L && i - this.Q >= 15000L) { + if (l > 2000L && i - this.R >= 15000L) { if (this.server.getWarnOnOverload()) // CraftBukkit - Added option to suppress warning messages this.getLogger().warning("Can\'t keep up! Did the system time change, or is the server overloaded?"); l = 2000L; - this.Q = i; + this.R = i; } if (l < 0L) { @@ -401,13 +411,13 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo j += l; i = k; if (this.worlds.get(0).everyoneDeeplySleeping()) { // CraftBukkit - this.q(); + this.s(); j = 0L; } else { while (j > 50L) { MinecraftServer.currentTick = (int) (System.currentTimeMillis() / 50); // CraftBukkit j -= 50L; - this.q(); + this.s(); } } @@ -427,7 +437,7 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo crashreport = this.b(new CrashReport("Exception in server tick loop", throwable)); } - File file1 = new File(new File(this.o(), "crash-reports"), "crash-" + (new SimpleDateFormat("yyyy-MM-dd_HH.mm.ss")).format(new Date()) + "-server.txt"); + File file1 = new File(new File(this.q(), "crash-reports"), "crash-" + (new SimpleDateFormat("yyyy-MM-dd_HH.mm.ss")).format(new Date()) + "-server.txt"); if (crashreport.a(file1, this.getLogger())) { this.getLogger().severe("This crash report has been saved to: " + file1.getAbsolutePath()); @@ -449,64 +459,64 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo } catch (Exception e) { } // CraftBukkit end - this.p(); + this.r(); } } } - protected File o() { + protected File q() { return new File("."); } protected void a(CrashReport crashreport) {} - protected void p() {} + protected void r() {} - protected void q() throws ExceptionWorldConflict { // CraftBukkit - added throws + protected void s() throws ExceptionWorldConflict { // CraftBukkit - added throws long i = System.nanoTime(); AxisAlignedBB.a().a(); ++this.ticks; - if (this.S) { - this.S = false; + if (this.T) { + this.T = false; this.methodProfiler.a = true; this.methodProfiler.a(); } this.methodProfiler.a("root"); - this.r(); + this.t(); if ((this.autosavePeriod > 0) && ((this.ticks % this.autosavePeriod) == 0)) { // CraftBukkit this.methodProfiler.a("save"); - this.s.savePlayers(); + this.t.savePlayers(); this.saveChunks(true); this.methodProfiler.b(); } this.methodProfiler.a("tallying"); - this.i[this.ticks % 100] = System.nanoTime() - i; - this.e[this.ticks % 100] = Packet.q - this.D; - this.D = Packet.q; - this.f[this.ticks % 100] = Packet.r - this.E; - this.E = Packet.r; - this.g[this.ticks % 100] = Packet.o - this.F; - this.F = Packet.o; - this.h[this.ticks % 100] = Packet.p - this.G; - this.G = Packet.p; + this.j[this.ticks % 100] = System.nanoTime() - i; + this.f[this.ticks % 100] = Packet.q - this.E; + this.E = Packet.q; + this.g[this.ticks % 100] = Packet.r - this.F; + this.F = Packet.r; + this.h[this.ticks % 100] = Packet.o - this.G; + this.G = Packet.o; + this.i[this.ticks % 100] = Packet.p - this.H; + this.H = Packet.p; this.methodProfiler.b(); this.methodProfiler.a("snooper"); - if (!this.m.d() && this.ticks > 100) { - this.m.a(); + if (!this.n.d() && this.ticks > 100) { + this.n.a(); } if (this.ticks % 6000 == 0) { - this.m.b(); + this.n.b(); } this.methodProfiler.b(); this.methodProfiler.b(); } - public void r() { + public void t() { this.methodProfiler.a("levels"); // CraftBukkit start @@ -523,7 +533,7 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo if (this.ticks % 20 == 0) { for (int i = 0; i < this.getPlayerList().players.size(); ++i) { EntityPlayer entityplayer = (EntityPlayer) this.getPlayerList().players.get(i); - entityplayer.playerConnection.sendPacket(new Packet4UpdateTime(entityplayer.world.getTime(), entityplayer.getPlayerTime())); // Add support for per player time + entityplayer.playerConnection.sendPacket(new Packet4UpdateTime(entityplayer.world.getTime(), entityplayer.getPlayerTime(), entityplayer.world.getGameRules().getBoolean("doDaylightCycle"))); // Add support for per player time } } @@ -542,7 +552,7 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo /* Drop global time updates if (this.ticks % 20 == 0) { this.methodProfiler.a("timeSync"); - this.s.a(new Packet4UpdateTime(worldserver.getTime(), worldserver.getDayTime()), worldserver.worldProvider.dimension); + this.t.a(new Packet4UpdateTime(worldserver.getTime(), worldserver.getDayTime(), worldserver.getGameRules().getBoolean("doDaylightCycle")), worldserver.worldProvider.dimension); this.methodProfiler.b(); } // CraftBukkit end */ @@ -574,17 +584,17 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo this.methodProfiler.b(); // } // CraftBukkit - // this.j[i][this.ticks % 100] = System.nanoTime() - j; // CraftBukkit + // this.k[i][this.ticks % 100] = System.nanoTime() - j; // CraftBukkit } this.methodProfiler.c("connection"); - this.ae().b(); + this.ag().b(); this.methodProfiler.c("players"); - this.s.tick(); + this.t.tick(); this.methodProfiler.c("tickables"); - for (i = 0; i < this.o.size(); ++i) { - ((IUpdatePlayerListBox) this.o.get(i)).a(); + for (i = 0; i < this.p.size(); ++i) { + ((IUpdatePlayerListBox) this.p.get(i)).a(); } this.methodProfiler.b(); @@ -595,7 +605,7 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo } public void a(IUpdatePlayerListBox iupdateplayerlistbox) { - this.o.add(iupdateplayerlistbox); + this.p.add(iupdateplayerlistbox); } public static void main(final OptionSet options) { // CraftBukkit - replaces main(String[] astring) @@ -604,7 +614,7 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo try { /* CraftBukkit start - Replace everything - boolean flag = false; + boolean flag = !GraphicsEnvironment.isHeadless(); String s = null; String s1 = "."; String s2 = null; @@ -665,16 +675,15 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo } if (options.has("world")) { - dedicatedserver.l((String) options.valueOf("world")); + dedicatedserver.j((String) options.valueOf("world")); } - /* if (s != null) { - dedicatedserver.k(s); + dedicatedserver.j(s); } if (s2 != null) { - dedicatedserver.l(s2); + dedicatedserver.k(s2); } if (i >= 0) { @@ -690,7 +699,7 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo } if (flag) { - dedicatedserver.ap(); + dedicatedserver.at(); } */ @@ -706,12 +715,12 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo } } - public void t() { + public void v() { // (new ThreadServerApplication(this, "Server thread")).start(); // CraftBukkit - prevent abuse } - public File e(String s) { - return new File(this.o(), s); + public File d(String s) { + return new File(this.q(), s); } public void info(String s) { @@ -734,32 +743,32 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo // CraftBukkit end } - public String u() { + public String w() { return this.serverIp; } - public int v() { - return this.r; + public int x() { + return this.s; } - public String w() { + public String y() { return this.motd; } public String getVersion() { - return "1.5.2"; + return "1.6.1"; } - public int y() { - return this.s.getPlayerCount(); + public int A() { + return this.t.getPlayerCount(); } - public int z() { - return this.s.getMaxPlayers(); + public int B() { + return this.t.getMaxPlayers(); } public String[] getPlayers() { - return this.s.d(); + return this.t.d(); } public String getPlugins() { @@ -790,11 +799,11 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo } // CraftBukkit start - public String h(final String s) { // CraftBukkit - final parameter + public String g(final String s) { // CraftBukkit - final parameter Waitable<String> waitable = new Waitable<String>() { @Override protected String evaluate() { - RemoteControlCommandListener.instance.c(); + RemoteControlCommandListener.instance.d(); // Event changes start RemoteServerCommandEvent event = new RemoteServerCommandEvent(MinecraftServer.this.remoteConsole, s); MinecraftServer.this.server.getPluginManager().callEvent(event); @@ -802,7 +811,7 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo ServerCommand servercommand = new ServerCommand(event.getCommand(), RemoteControlCommandListener.instance); // this.p.a(RemoteControlCommandListener.instance, s); MinecraftServer.this.server.dispatchServerCommand(MinecraftServer.this.remoteConsole, servercommand); // CraftBukkit - return RemoteControlCommandListener.instance.d(); + return RemoteControlCommandListener.instance.e(); }}; processQueue.add(waitable); try { @@ -820,11 +829,11 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo return this.getPropertyManager().getBoolean("debug", false); // CraftBukkit - don't hardcode } - public void i(String s) { + public void h(String s) { this.getLogger().severe(s); } - public void j(String s) { + public void i(String s) { if (this.isDebugging()) { this.getLogger().info(s); } @@ -836,11 +845,11 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo public CrashReport b(CrashReport crashreport) { crashreport.g().a("Profiler Position", (Callable) (new CrashReportProfilerPosition(this))); - if (this.worlds != null && this.worlds.size() > 0 && this.worlds.get(0) != null) { + if (this.worlds != null && this.worlds.size() > 0 && this.worlds.get(0) != null) { // CraftBukkit crashreport.g().a("Vec3 Pool Size", (Callable) (new CrashReportVec3DPoolSize(this))); } - if (this.s != null) { + if (this.t != null) { crashreport.g().a("Player Count", (Callable) (new CrashReportPlayerCount(this))); } @@ -894,63 +903,59 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo } public static MinecraftServer getServer() { - return k; + return l; } public String getName() { return "Server"; } - public void sendMessage(String s) { - this.getLogger().info(StripColor.a(s)); + public void sendMessage(ChatMessage chatmessage) { + this.getLogger().info(chatmessage.toString()); } public boolean a(int i, String s) { return true; } - public String a(String s, Object... aobject) { - return LocaleLanguage.a().a(s, aobject); - } - public ICommandHandler getCommandHandler() { - return this.p; + return this.q; } - public KeyPair F() { - return this.H; + public KeyPair H() { + return this.I; } - public int G() { - return this.r; + public int I() { + return this.s; } public void setPort(int i) { - this.r = i; + this.s = i; } - public String H() { - return this.I; + public String J() { + return this.J; } - public void k(String s) { - this.I = s; + public void j(String s) { + this.J = s; } - public boolean I() { - return this.I != null; + public boolean K() { + return this.J != null; } - public String J() { - return this.J; + public String L() { + return this.K; } - public void l(String s) { - this.J = s; + public void k(String s) { + this.K = s; } public void a(KeyPair keypair) { - this.H = keypair; + this.I = keypair; } public void c(int i) { @@ -963,7 +968,7 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo if (worldserver.getWorldData().isHardcore()) { worldserver.difficulty = 3; worldserver.setSpawnFlags(true, true); - } else if (this.I()) { + } else if (this.K()) { worldserver.difficulty = i; worldserver.setSpawnFlags(worldserver.difficulty > 0, true); } else { @@ -978,7 +983,7 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo return true; } - public boolean M() { + public boolean O() { return this.demoMode; } @@ -987,15 +992,15 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo } public void c(boolean flag) { - this.M = flag; + this.N = flag; } public Convertable getConvertable() { return this.convertable; } - public void P() { - this.N = true; + public void R() { + this.O = true; this.getConvertable().d(); // CraftBukkit start - This needs review, what does it do? (it's new) @@ -1013,26 +1018,27 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo } public String getTexturePack() { - return this.O; + return this.P; } public void setTexturePack(String s) { - this.O = s; + this.P = s; } public void a(MojangStatisticsGenerator mojangstatisticsgenerator) { mojangstatisticsgenerator.a("whitelist_enabled", Boolean.valueOf(false)); mojangstatisticsgenerator.a("whitelist_count", Integer.valueOf(0)); - mojangstatisticsgenerator.a("players_current", Integer.valueOf(this.y())); - mojangstatisticsgenerator.a("players_max", Integer.valueOf(this.z())); - mojangstatisticsgenerator.a("players_seen", Integer.valueOf(this.s.getSeenPlayers().length)); + mojangstatisticsgenerator.a("players_current", Integer.valueOf(this.A())); + mojangstatisticsgenerator.a("players_max", Integer.valueOf(this.B())); + mojangstatisticsgenerator.a("players_seen", Integer.valueOf(this.t.getSeenPlayers().length)); mojangstatisticsgenerator.a("uses_auth", Boolean.valueOf(this.onlineMode)); - mojangstatisticsgenerator.a("gui_state", this.ag() ? "enabled" : "disabled"); - mojangstatisticsgenerator.a("avg_tick_ms", Integer.valueOf((int) (MathHelper.a(this.i) * 1.0E-6D))); - mojangstatisticsgenerator.a("avg_sent_packet_count", Integer.valueOf((int) MathHelper.a(this.e))); - mojangstatisticsgenerator.a("avg_sent_packet_size", Integer.valueOf((int) MathHelper.a(this.f))); - mojangstatisticsgenerator.a("avg_rec_packet_count", Integer.valueOf((int) MathHelper.a(this.g))); - mojangstatisticsgenerator.a("avg_rec_packet_size", Integer.valueOf((int) MathHelper.a(this.h))); + mojangstatisticsgenerator.a("gui_state", this.ai() ? "enabled" : "disabled"); + mojangstatisticsgenerator.a("run_time", Long.valueOf((aq() - mojangstatisticsgenerator.g()) / 60L * 1000L)); + mojangstatisticsgenerator.a("avg_tick_ms", Integer.valueOf((int) (MathHelper.a(this.j) * 1.0E-6D))); + mojangstatisticsgenerator.a("avg_sent_packet_count", Integer.valueOf((int) MathHelper.a(this.f))); + mojangstatisticsgenerator.a("avg_sent_packet_size", Integer.valueOf((int) MathHelper.a(this.g))); + mojangstatisticsgenerator.a("avg_rec_packet_count", Integer.valueOf((int) MathHelper.a(this.h))); + mojangstatisticsgenerator.a("avg_rec_packet_size", Integer.valueOf((int) MathHelper.a(this.i))); int i = 0; // CraftBukkit start @@ -1048,8 +1054,8 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo mojangstatisticsgenerator.a("world[" + i + "][hardcore]", Boolean.valueOf(worlddata.isHardcore())); mojangstatisticsgenerator.a("world[" + i + "][generator_name]", worlddata.getType().name()); mojangstatisticsgenerator.a("world[" + i + "][generator_version]", Integer.valueOf(worlddata.getType().getVersion())); - mojangstatisticsgenerator.a("world[" + i + "][height]", Integer.valueOf(this.C)); - mojangstatisticsgenerator.a("world[" + i + "][chunks_loaded]", Integer.valueOf(worldserver.K().getLoadedChunks())); + mojangstatisticsgenerator.a("world[" + i + "][height]", Integer.valueOf(this.D)); + mojangstatisticsgenerator.a("world[" + i + "][chunks_loaded]", Integer.valueOf(worldserver.L().getLoadedChunks())); ++i; // } // CraftBukkit } @@ -1058,21 +1064,21 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo } public void b(MojangStatisticsGenerator mojangstatisticsgenerator) { - mojangstatisticsgenerator.a("singleplayer", Boolean.valueOf(this.I())); + mojangstatisticsgenerator.a("singleplayer", Boolean.valueOf(this.K())); mojangstatisticsgenerator.a("server_brand", this.getServerModName()); mojangstatisticsgenerator.a("gui_supported", GraphicsEnvironment.isHeadless() ? "headless" : "supported"); - mojangstatisticsgenerator.a("dedicated", Boolean.valueOf(this.T())); + mojangstatisticsgenerator.a("dedicated", Boolean.valueOf(this.V())); } public boolean getSnooperEnabled() { return true; } - public int S() { + public int U() { return 16; } - public abstract boolean T(); + public abstract boolean V(); public boolean getOnlineMode() { return this.server.getOnlineMode(); // CraftBukkit @@ -1125,11 +1131,11 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo } public int getMaxBuildHeight() { - return this.C; + return this.D; } public void d(int i) { - this.C = i; + this.D = i; } public boolean isStopped() { @@ -1137,11 +1143,11 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo } public PlayerList getPlayerList() { - return this.s; + return this.t; } public void a(PlayerList playerlist) { - this.s = playerlist; + this.t = playerlist; } public void a(EnumGamemode enumgamemode) { @@ -1152,26 +1158,30 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo } } - public abstract ServerConnection ae(); + public abstract ServerConnection ag(); - public boolean ag() { + public boolean ai() { return false; } public abstract String a(EnumGamemode enumgamemode, boolean flag); - public int ah() { + public int aj() { return this.ticks; } - public void ai() { - this.S = true; + public void ak() { + this.T = true; } public ChunkCoordinates b() { return new ChunkCoordinates(0, 0, 0); } + public World f_() { + return this.worlds.get(0); // CraftBukkit + } + public int getSpawnProtection() { return 16; } @@ -1183,14 +1193,22 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo public abstract IConsoleLogManager getLogger(); public void setForceGamemode(boolean flag) { - this.T = flag; + this.U = flag; } public boolean getForceGamemode() { - return this.T; + return this.U; + } + + public Proxy ap() { + return this.c; + } + + public static long aq() { + return System.currentTimeMillis(); } public static PlayerList a(MinecraftServer minecraftserver) { - return minecraftserver.s; + return minecraftserver.t; } } diff --git a/src/main/java/net/minecraft/server/MobEffectList.java b/src/main/java/net/minecraft/server/MobEffectList.java index 6a5a5f17..ab2432f4 100644 --- a/src/main/java/net/minecraft/server/MobEffectList.java +++ b/src/main/java/net/minecraft/server/MobEffectList.java @@ -1,5 +1,11 @@ package net.minecraft.server; +import com.google.common.collect.Maps; +import java.util.Iterator; +import java.util.Map; +import java.util.UUID; +import java.util.Map.Entry; + // CraftBukkit start import org.bukkit.craftbukkit.event.CraftEventFactory; import org.bukkit.event.entity.EntityRegainHealthEvent.RegainReason; @@ -9,11 +15,11 @@ public class MobEffectList { public static final MobEffectList[] byId = new MobEffectList[32]; public static final MobEffectList b = null; - public static final MobEffectList FASTER_MOVEMENT = (new MobEffectList(1, false, 8171462)).b("potion.moveSpeed").b(0, 0); - public static final MobEffectList SLOWER_MOVEMENT = (new MobEffectList(2, true, 5926017)).b("potion.moveSlowdown").b(1, 0); + public static final MobEffectList FASTER_MOVEMENT = (new MobEffectList(1, false, 8171462)).b("potion.moveSpeed").b(0, 0).a(GenericAttributes.d, "91AEAA56-376B-4498-935B-2F7F68070635", 0.20000000298023224D, 2); + public static final MobEffectList SLOWER_MOVEMENT = (new MobEffectList(2, true, 5926017)).b("potion.moveSlowdown").b(1, 0).a(GenericAttributes.d, "7107DE5E-7CE8-4030-940E-514C1F160890", -0.15000000596046448D, 2); public static final MobEffectList FASTER_DIG = (new MobEffectList(3, false, 14270531)).b("potion.digSpeed").b(2, 0).a(1.5D); public static final MobEffectList SLOWER_DIG = (new MobEffectList(4, true, 4866583)).b("potion.digSlowDown").b(3, 0); - public static final MobEffectList INCREASE_DAMAGE = (new MobEffectList(5, false, 9643043)).b("potion.damageBoost").b(4, 0); + public static final MobEffectList INCREASE_DAMAGE = (new MobEffectAttackDamage(5, false, 9643043)).b("potion.damageBoost").b(4, 0).a(GenericAttributes.e, "648D7064-6A60-4F59-8ABE-C2C23A6DD7A9", 3.0D, 2); public static final MobEffectList HEAL = (new InstantMobEffect(6, false, 16262179)).b("potion.heal"); public static final MobEffectList HARM = (new InstantMobEffect(7, true, 4393481)).b("potion.harm"); public static final MobEffectList JUMP = (new MobEffectList(8, false, 7889559)).b("potion.jump").b(2, 1); @@ -26,12 +32,12 @@ public class MobEffectList { public static final MobEffectList BLINDNESS = (new MobEffectList(15, true, 2039587)).b("potion.blindness").b(5, 1).a(0.25D); public static final MobEffectList NIGHT_VISION = (new MobEffectList(16, false, 2039713)).b("potion.nightVision").b(4, 1); public static final MobEffectList HUNGER = (new MobEffectList(17, true, 5797459)).b("potion.hunger").b(1, 1); - public static final MobEffectList WEAKNESS = (new MobEffectList(18, true, 4738376)).b("potion.weakness").b(5, 0); + public static final MobEffectList WEAKNESS = (new MobEffectAttackDamage(18, true, 4738376)).b("potion.weakness").b(5, 0).a(GenericAttributes.e, "22653B89-116E-49DC-9B6B-9971489B5BE5", 2.0D, 0); public static final MobEffectList POISON = (new MobEffectList(19, true, 5149489)).b("potion.poison").b(6, 0).a(0.25D); public static final MobEffectList WITHER = (new MobEffectList(20, true, 3484199)).b("potion.wither").b(1, 2).a(0.25D); - public static final MobEffectList w = null; - public static final MobEffectList x = null; - public static final MobEffectList y = null; + public static final MobEffectList HEALTH_BOOST = (new MobEffectHealthBoost(21, false, 16284963)).b("potion.healthBoost").b(2, 2).a(GenericAttributes.a, "5D6F0BA2-1186-46AC-B896-C61C5CEE99CC", 4.0D, 0); + public static final MobEffectList ABSORPTION = (new MobEffectAbsorption(22, false, 2445989)).b("potion.absorption").b(2, 2); + public static final MobEffectList SATURATION = (new InstantMobEffect(23, false, 16262179)).b("potion.saturation"); public static final MobEffectList z = null; public static final MobEffectList A = null; public static final MobEffectList B = null; @@ -41,30 +47,31 @@ public class MobEffectList { public static final MobEffectList F = null; public static final MobEffectList G = null; public final int id; - private String I = ""; - private int J = -1; - private final boolean K; - private double L; - private boolean M; - private final int N; + private final Map I = Maps.newHashMap(); + private final boolean J; + private final int K; + private String L = ""; + private int M = -1; + private double N; + private boolean O; protected MobEffectList(int i, boolean flag, int j) { this.id = i; byId[i] = this; - this.K = flag; + this.J = flag; if (flag) { - this.L = 0.5D; + this.N = 0.5D; } else { - this.L = 1.0D; + this.N = 1.0D; } - this.N = j; + this.K = j; org.bukkit.potion.PotionEffectType.registerPotionEffectType(new org.bukkit.craftbukkit.potion.CraftPotionEffectType(this)); // CraftBukkit } protected MobEffectList b(int i, int j) { - this.J = i + j * 8; + this.M = i + j * 8; return this; } @@ -75,22 +82,26 @@ public class MobEffectList { public void tick(EntityLiving entityliving, int i) { if (this.id == REGENERATION.id) { if (entityliving.getHealth() < entityliving.maxHealth) { // CraftBukkit - .getMaxHealth() -> .maxHealth - entityliving.heal(1, RegainReason.MAGIC_REGEN); // CraftBukkit + entityliving.heal(1.0F, RegainReason.MAGIC_REGEN); // CraftBukkit } } else if (this.id == POISON.id) { - if (entityliving.getHealth() > 1) { - entityliving.damageEntity(CraftEventFactory.POISON, 1); // CraftBukkit - DamageSource.MAGIC -> CraftEventFactory.POISON + if (entityliving.getHealth() > 1.0F) { + entityliving.damageEntity(CraftEventFactory.POISON, 1.0F); // CraftBukkit - DamageSource.MAGIC -> CraftEventFactory.POISON } } else if (this.id == WITHER.id) { - entityliving.damageEntity(DamageSource.WITHER, 1); + entityliving.damageEntity(DamageSource.WITHER, 1.0F); } else if (this.id == HUNGER.id && entityliving instanceof EntityHuman) { - ((EntityHuman) entityliving).j(0.025F * (float) (i + 1)); - } else if ((this.id != HEAL.id || entityliving.bD()) && (this.id != HARM.id || !entityliving.bD())) { - if (this.id == HARM.id && !entityliving.bD() || this.id == HEAL.id && entityliving.bD()) { - entityliving.damageEntity(DamageSource.MAGIC, 6 << i); + ((EntityHuman) entityliving).a(0.025F * (float) (i + 1)); + } else if (this.id == SATURATION.id && entityliving instanceof EntityHuman) { + if (!entityliving.world.isStatic) { + ((EntityHuman) entityliving).getFoodData().eat(i + 1, 1.0F); + } + } else if ((this.id != HEAL.id || entityliving.aI()) && (this.id != HARM.id || !entityliving.aI())) { + if (this.id == HARM.id && !entityliving.aI() || this.id == HEAL.id && entityliving.aI()) { + entityliving.damageEntity(DamageSource.MAGIC, (float) (6 << i)); } } else { - entityliving.heal(6 << i, RegainReason.MAGIC); // CraftBukkit + entityliving.heal((float) Math.max(4 << i, 0), RegainReason.MAGIC); // CraftBukkit } } @@ -103,19 +114,19 @@ public class MobEffectList { // CraftBukkit end int j; - if ((this.id != HEAL.id || entityliving1.bD()) && (this.id != HARM.id || !entityliving1.bD())) { - if (this.id == HARM.id && !entityliving1.bD() || this.id == HEAL.id && entityliving1.bD()) { + if ((this.id != HEAL.id || entityliving1.aI()) && (this.id != HARM.id || !entityliving1.aI())) { + if (this.id == HARM.id && !entityliving1.aI() || this.id == HEAL.id && entityliving1.aI()) { j = (int) (d0 * (double) (6 << i) + 0.5D); if (entityliving == null) { - entityliving1.damageEntity(DamageSource.MAGIC, j); + entityliving1.damageEntity(DamageSource.MAGIC, (float) j); } else { // CraftBukkit - The "damager" needs to be the potion - entityliving1.damageEntity(DamageSource.b(potion != null ? potion : entityliving1, entityliving), j); + entityliving1.damageEntity(DamageSource.b(potion != null ? potion : entityliving1, entityliving), (float) j); } } } else { - j = (int) (d0 * (double) (6 << i) + 0.5D); - entityliving1.heal(j, RegainReason.MAGIC); // CraftBukkit + j = (int) (d0 * (double) (4 << i) + 0.5D); + entityliving1.heal((float) j, RegainReason.MAGIC); } } @@ -126,42 +137,83 @@ public class MobEffectList { public boolean a(int i, int j) { int k; - if (this.id != REGENERATION.id && this.id != POISON.id) { - if (this.id == WITHER.id) { - k = 40 >> j; - return k > 0 ? i % k == 0 : true; - } else { - return this.id == HUNGER.id; - } - } else { + if (this.id == REGENERATION.id) { + k = 50 >> j; + return k > 0 ? i % k == 0 : true; + } else if (this.id == POISON.id) { k = 25 >> j; return k > 0 ? i % k == 0 : true; + } else if (this.id == WITHER.id) { + k = 40 >> j; + return k > 0 ? i % k == 0 : true; + } else { + return this.id == HUNGER.id; } } public MobEffectList b(String s) { - this.I = s; + this.L = s; return this; } public String a() { - return this.I; + return this.L; } protected MobEffectList a(double d0) { - this.L = d0; + this.N = d0; return this; } public double getDurationModifier() { - return this.L; + return this.N; } public boolean i() { - return this.M; + return this.O; } public int j() { - return this.N; + return this.K; + } + + public MobEffectList a(IAttribute iattribute, String s, double d0, int i) { + AttributeModifier attributemodifier = new AttributeModifier(UUID.fromString(s), this.a(), d0, i); + + this.I.put(iattribute, attributemodifier); + return this; + } + + public void a(EntityLiving entityliving, AttributeMapBase attributemapbase, int i) { + Iterator iterator = this.I.entrySet().iterator(); + + while (iterator.hasNext()) { + Entry entry = (Entry) iterator.next(); + AttributeInstance attributeinstance = attributemapbase.a((IAttribute) entry.getKey()); + + if (attributeinstance != null) { + attributeinstance.b((AttributeModifier) entry.getValue()); + } + } + } + + public void b(EntityLiving entityliving, AttributeMapBase attributemapbase, int i) { + Iterator iterator = this.I.entrySet().iterator(); + + while (iterator.hasNext()) { + Entry entry = (Entry) iterator.next(); + AttributeInstance attributeinstance = attributemapbase.a((IAttribute) entry.getKey()); + + if (attributeinstance != null) { + AttributeModifier attributemodifier = (AttributeModifier) entry.getValue(); + + attributeinstance.b(attributemodifier); + attributeinstance.a(new AttributeModifier(attributemodifier.a(), this.a() + " " + i, this.a(i, attributemodifier), attributemodifier.c())); + } + } + } + + public double a(int i, AttributeModifier attributemodifier) { + return attributemodifier.d() * (double) (i + 1); } } diff --git a/src/main/java/net/minecraft/server/MobSpawnerAbstract.java b/src/main/java/net/minecraft/server/MobSpawnerAbstract.java index 4ba4735c..108b375b 100644 --- a/src/main/java/net/minecraft/server/MobSpawnerAbstract.java +++ b/src/main/java/net/minecraft/server/MobSpawnerAbstract.java @@ -11,10 +11,10 @@ public abstract class MobSpawnerAbstract { public int spawnDelay = 20; private String mobName = "Pig"; - private List mobs = null; - private TileEntityMobSpawnerData spawnData = null; + private List mobs; + private TileEntityMobSpawnerData spawnData; public double c; - public double d = 0.0D; + public double d; private int minSpawnDelay = 200; private int maxSpawnDelay = 800; private int spawnCount = 4; @@ -91,14 +91,14 @@ public abstract class MobSpawnerAbstract { d0 = (double) this.b() + (this.a().random.nextDouble() - this.a().random.nextDouble()) * (double) this.spawnRange; double d3 = (double) (this.c() + this.a().random.nextInt(3) - 1); double d4 = (double) this.d() + (this.a().random.nextDouble() - this.a().random.nextDouble()) * (double) this.spawnRange; - EntityLiving entityliving = entity instanceof EntityLiving ? (EntityLiving) entity : null; + EntityInsentient entityinsentient = entity instanceof EntityInsentient ? (EntityInsentient) entity : null; entity.setPositionRotation(d0, d3, d4, this.a().random.nextFloat() * 360.0F, 0.0F); - if (entityliving == null || entityliving.canSpawn()) { + if (entityinsentient == null || entityinsentient.canSpawn()) { this.a(entity); this.a().triggerEffect(2004, this.b(), this.c(), this.d(), 0); - if (entityliving != null) { - entityliving.aU(); + if (entityinsentient != null) { + entityinsentient.q(); } flag = true; @@ -134,7 +134,7 @@ public abstract class MobSpawnerAbstract { for (Entity entity1 = entity; nbttagcompound.hasKey("Riding"); nbttagcompound = nbttagcompound1) { nbttagcompound1 = nbttagcompound.getCompound("Riding"); - Entity entity2 = EntityTypes.createEntityByName(nbttagcompound1.getString("id"), this.a()); + Entity entity2 = EntityTypes.createEntityByName(nbttagcompound1.getString("id"), entity.world); if (entity2 != null) { NBTTagCompound nbttagcompound2 = new NBTTagCompound(); @@ -150,15 +150,18 @@ public abstract class MobSpawnerAbstract { entity2.f(nbttagcompound2); entity2.setPositionRotation(entity1.locX, entity1.locY, entity1.locZ, entity1.yaw, entity1.pitch); - this.a().addEntity(entity2, CreatureSpawnEvent.SpawnReason.SPAWNER); // CraftBukkit); + if (entity.world != null) { + entity.world.addEntity(entity2, CreatureSpawnEvent.SpawnReason.SPAWNER); // CraftBukkit + } + entity1.mount(entity2); } entity1 = entity2; } } else if (entity instanceof EntityLiving && entity.world != null) { - ((EntityLiving) entity).bJ(); - this.a().addEntity(entity, CreatureSpawnEvent.SpawnReason.SPAWNER); // CraftBukkit); + ((EntityInsentient) entity).a((GroupDataEntity) null); + this.a().addEntity(entity, CreatureSpawnEvent.SpawnReason.SPAWNER); // CraftBukkit } return entity; diff --git a/src/main/java/net/minecraft/server/NetworkManager.java b/src/main/java/net/minecraft/server/NetworkManager.java index 1862863c..c60abf13 100644 --- a/src/main/java/net/minecraft/server/NetworkManager.java +++ b/src/main/java/net/minecraft/server/NetworkManager.java @@ -2,6 +2,7 @@ package net.minecraft.server; import java.io.BufferedOutputStream; import java.io.DataInputStream; +import java.io.DataOutput; import java.io.DataOutputStream; import java.io.InputStream; import java.net.Socket; @@ -28,25 +29,25 @@ public class NetworkManager implements INetworkManager { private volatile DataInputStream input; private volatile DataOutputStream output; private volatile boolean n = true; - private volatile boolean o = false; + private volatile boolean o; private java.util.Queue inboundQueue = new java.util.concurrent.ConcurrentLinkedQueue(); // CraftBukkit - Concurrent linked queue private List highPriorityQueue = Collections.synchronizedList(new ArrayList()); private List lowPriorityQueue = Collections.synchronizedList(new ArrayList()); private Connection connection; - private boolean t = false; + private boolean t; private Thread u; private Thread v; private String w = ""; private Object[] x; - private int y = 0; - private int z = 0; + private int y; + private int z; public static int[] c = new int[256]; public static int[] d = new int[256]; - public int e = 0; - boolean f = false; - boolean g = false; - private SecretKey A = null; - private PrivateKey B = null; + public int e; + boolean f; + boolean g; + private SecretKey A; + private PrivateKey B; private int lowPriorityQueueDelay = 50; public NetworkManager(IConsoleLogManager iconsolelogmanager, Socket socket, String s, Connection connection, PrivateKey privatekey) throws IOException { // CraftBukkit - throws IOException @@ -94,10 +95,10 @@ public class NetworkManager implements INetworkManager { int i; int[] aint; - if (this.e == 0 || !this.highPriorityQueue.isEmpty() && System.currentTimeMillis() - ((Packet) this.highPriorityQueue.get(0)).timestamp >= (long) this.e) { + if (this.e == 0 || !this.highPriorityQueue.isEmpty() && MinecraftServer.aq() - ((Packet) this.highPriorityQueue.get(0)).timestamp >= (long) this.e) { packet = this.a(false); if (packet != null) { - Packet.a(packet, this.output); + Packet.a(packet, (DataOutput) this.output); if (packet instanceof Packet252KeyResponse && !this.g) { if (!this.connection.a()) { this.A = ((Packet252KeyResponse) packet).d(); @@ -117,7 +118,7 @@ public class NetworkManager implements INetworkManager { if ((flag || this.lowPriorityQueueDelay-- <= 0) && !this.lowPriorityQueue.isEmpty() && (this.highPriorityQueue.isEmpty() || ((Packet) this.highPriorityQueue.get(0)).timestamp > ((Packet) this.lowPriorityQueue.get(0)).timestamp)) { packet = this.a(true); if (packet != null) { - Packet.a(packet, this.output); + Packet.a(packet, (DataOutput) this.output); aint = d; i = packet.n(); aint[i] += packet.a() + 1; diff --git a/src/main/java/net/minecraft/server/Packet.java b/src/main/java/net/minecraft/server/Packet.java index 1b367da9..b11c26b1 100644 --- a/src/main/java/net/minecraft/server/Packet.java +++ b/src/main/java/net/minecraft/server/Packet.java @@ -1,7 +1,7 @@ package net.minecraft.server; -import java.io.DataInputStream; -import java.io.DataOutputStream; +import java.io.DataInput; +import java.io.DataOutput; import java.io.EOFException; import java.io.IOException; import java.net.Socket; @@ -10,6 +10,8 @@ import java.util.HashSet; import java.util.Map; import java.util.Set; +import org.bukkit.craftbukkit.inventory.CraftItemStack; // CraftBukkit + public abstract class Packet { public static IntHashMap l = new IntHashMap(); @@ -17,12 +19,12 @@ public abstract class Packet { private static Set b = new HashSet(); private static Set c = new HashSet(); protected IConsoleLogManager m; - public final long timestamp = System.currentTimeMillis(); + public final long timestamp = MinecraftServer.aq(); public static long o; public static long p; public static long q; public static long r; - public boolean lowPriority = false; + public boolean lowPriority; // CraftBukkit start - Calculate packet ID once - used a bunch of times private int packetID; @@ -61,20 +63,20 @@ public abstract class Packet { } } - public static void a(DataOutputStream dataoutputstream, byte[] abyte) throws IOException { // CraftBukkit - throws IOException - dataoutputstream.writeShort(abyte.length); - dataoutputstream.write(abyte); + public static void a(DataOutput dataoutput, byte[] abyte) throws IOException { // CraftBukkit - throws IOException + dataoutput.writeShort(abyte.length); + dataoutput.write(abyte); } - public static byte[] b(DataInputStream datainputstream) throws IOException { // CraftBukkit - throws IOException - short short1 = datainputstream.readShort(); + public static byte[] b(DataInput datainput) throws IOException { // CraftBukkit - throws IOException + short short1 = datainput.readShort(); if (short1 < 0) { throw new IOException("Key was smaller than nothing! Weird key!"); } else { byte[] abyte = new byte[short1]; - datainputstream.readFully(abyte); + datainput.readFully(abyte); return abyte; } } @@ -83,7 +85,7 @@ public abstract class Packet { return packetID; // ((Integer) a.get(this.getClass())).intValue(); // CraftBukkit } - public static Packet a(IConsoleLogManager iconsolelogmanager, DataInputStream datainputstream, boolean flag, Socket socket) throws IOException { // CraftBukkit - throws IOException + public static Packet a(IConsoleLogManager iconsolelogmanager, DataInput datainput, boolean flag, Socket socket) throws IOException { // CraftBukkit - throws IOException boolean flag1 = false; Packet packet = null; int i = socket.getSoTimeout(); @@ -91,11 +93,7 @@ public abstract class Packet { int j; try { - j = datainputstream.read(); - if (j == -1) { - return null; - } - + j = datainput.readUnsignedByte(); if (flag && !c.contains(Integer.valueOf(j)) || !flag && !b.contains(Integer.valueOf(j))) { throw new IOException("Bad packet id " + j); } @@ -110,11 +108,11 @@ public abstract class Packet { socket.setSoTimeout(1500); } - packet.a(datainputstream); + packet.a(datainput); ++o; p += (long) packet.a(); } catch (EOFException eofexception) { - iconsolelogmanager.severe("Reached end of stream"); + iconsolelogmanager.severe("Reached end of stream for " + socket.getInetAddress()); return null; } @@ -135,24 +133,24 @@ public abstract class Packet { return packet; } - public static void a(Packet packet, DataOutputStream dataoutputstream) throws IOException { // CraftBukkit - throws IOException - dataoutputstream.write(packet.n()); - packet.a(dataoutputstream); + public static void a(Packet packet, DataOutput dataoutput) throws IOException { // CraftBukkit - throws IOException + dataoutput.write(packet.n()); + packet.a(dataoutput); ++q; r += (long) packet.a(); } - public static void a(String s, DataOutputStream dataoutputstream) throws IOException { // CraftBukkit - throws IOException + public static void a(String s, DataOutput dataoutput) throws IOException { // CraftBukkit - throws IOException if (s.length() > 32767) { throw new IOException("String too big"); } else { - dataoutputstream.writeShort(s.length()); - dataoutputstream.writeChars(s); + dataoutput.writeShort(s.length()); + dataoutput.writeChars(s); } } - public static String a(DataInputStream datainputstream, int i) throws IOException { // CraftBukkit - throws IOException - short short1 = datainputstream.readShort(); + public static String a(DataInput datainput, int i) throws IOException { // CraftBukkit - throws IOException + short short1 = datainput.readShort(); if (short1 > i) { throw new IOException("Received string length longer than maximum allowed (" + short1 + " > " + i + ")"); @@ -162,16 +160,16 @@ public abstract class Packet { StringBuilder stringbuilder = new StringBuilder(); for (int j = 0; j < short1; ++j) { - stringbuilder.append(datainputstream.readChar()); + stringbuilder.append(datainput.readChar()); } return stringbuilder.toString(); } } - public abstract void a(DataInputStream datainputstream) throws IOException; // CraftBukkit - throws IOException + public abstract void a(DataInput datainput) throws IOException; // CraftBukkit - throws IOException - public abstract void a(DataOutputStream dataoutputstream) throws IOException; // CraftBukkit - throws IOException + public abstract void a(DataOutput dataoutput) throws IOException; // CraftBukkit - throws IOException public abstract void handle(Connection connection); @@ -186,7 +184,7 @@ public abstract class Packet { } public boolean a_() { - return false; + return this instanceof Packet3Chat && !((Packet3Chat) this).message.startsWith("/"); // CraftBukkit - async chat } public String toString() { @@ -195,59 +193,64 @@ public abstract class Packet { return s; } - public static ItemStack c(DataInputStream datainputstream) throws IOException { // CraftBukkit - throws IOException + public static ItemStack c(DataInput datainput) throws IOException { // CraftBukkit - throws IOException ItemStack itemstack = null; - short short1 = datainputstream.readShort(); + short short1 = datainput.readShort(); if (short1 >= 0) { - byte b0 = datainputstream.readByte(); - short short2 = datainputstream.readShort(); + byte b0 = datainput.readByte(); + short short2 = datainput.readShort(); itemstack = new ItemStack(short1, b0, short2); - itemstack.tag = d(datainputstream); + itemstack.tag = d(datainput); + // CraftBukkit start + if (itemstack.tag != null) { + CraftItemStack.setItemMeta(itemstack, CraftItemStack.getItemMeta(itemstack)); + } + // CraftBukkit end } return itemstack; } - public static void a(ItemStack itemstack, DataOutputStream dataoutputstream) throws IOException { // CraftBukkit - throws IOException + public static void a(ItemStack itemstack, DataOutput dataoutput) throws IOException { // CraftBukkit - throws IOException if (itemstack == null || itemstack.getItem() == null) { // CraftBukkit - NPE fix itemstack.getItem() - dataoutputstream.writeShort(-1); + dataoutput.writeShort(-1); } else { - dataoutputstream.writeShort(itemstack.id); - dataoutputstream.writeByte(itemstack.count); - dataoutputstream.writeShort(itemstack.getData()); + dataoutput.writeShort(itemstack.id); + dataoutput.writeByte(itemstack.count); + dataoutput.writeShort(itemstack.getData()); NBTTagCompound nbttagcompound = null; - if (itemstack.getItem().usesDurability() || itemstack.getItem().r()) { + if (itemstack.getItem().usesDurability() || itemstack.getItem().s()) { nbttagcompound = itemstack.tag; } - a(nbttagcompound, dataoutputstream); + a(nbttagcompound, dataoutput); } } - public static NBTTagCompound d(DataInputStream datainputstream) throws IOException { // CraftBukkit - throws IOException - short short1 = datainputstream.readShort(); + public static NBTTagCompound d(DataInput datainput) throws IOException { // CraftBukkit - throws IOException + short short1 = datainput.readShort(); if (short1 < 0) { return null; } else { byte[] abyte = new byte[short1]; - datainputstream.readFully(abyte); + datainput.readFully(abyte); return NBTCompressedStreamTools.a(abyte); } } - protected static void a(NBTTagCompound nbttagcompound, DataOutputStream dataoutputstream) throws IOException { // CraftBukkit - throws IOException + protected static void a(NBTTagCompound nbttagcompound, DataOutput dataoutput) throws IOException { // CraftBukkit - throws IOException if (nbttagcompound == null) { - dataoutputstream.writeShort(-1); + dataoutput.writeShort(-1); } else { byte[] abyte = NBTCompressedStreamTools.a(nbttagcompound); - dataoutputstream.writeShort((short) abyte.length); - dataoutputstream.write(abyte); + dataoutput.writeShort((short) abyte.length); + dataoutput.write(abyte); } } @@ -278,6 +281,7 @@ public abstract class Packet { a(24, true, false, Packet24MobSpawn.class); a(25, true, false, Packet25EntityPainting.class); a(26, true, false, Packet26AddExpOrb.class); + a(27, false, true, Packet27PlayerInput.class); a(28, true, false, Packet28EntityVelocity.class); a(29, true, false, Packet29DestroyEntity.class); a(30, true, false, Packet30Entity.class); @@ -292,6 +296,7 @@ public abstract class Packet { a(41, true, false, Packet41MobEffect.class); a(42, true, false, Packet42RemoveMobEffect.class); a(43, true, false, Packet43SetExperience.class); + a(44, true, false, Packet44UpdateAttributes.class); a(51, true, false, Packet51MapChunk.class); a(52, true, false, Packet52MultiBlockChange.class); a(53, true, false, Packet53BlockChange.class); diff --git a/src/main/java/net/minecraft/server/Packet20NamedEntitySpawn.java b/src/main/java/net/minecraft/server/Packet20NamedEntitySpawn.java index 1d4a4311..1843d9ce 100644 --- a/src/main/java/net/minecraft/server/Packet20NamedEntitySpawn.java +++ b/src/main/java/net/minecraft/server/Packet20NamedEntitySpawn.java @@ -1,7 +1,7 @@ package net.minecraft.server; -import java.io.DataInputStream; -import java.io.DataOutputStream; +import java.io.DataInput; +import java.io.DataOutput; import java.util.List; import java.io.IOException; // CraftBukkit @@ -32,6 +32,7 @@ public class Packet20NamedEntitySpawn extends Packet { } // CraftBukkit end + this.b = entityhuman.getName(); this.c = MathHelper.floor(entityhuman.locX * 32.0D); this.d = MathHelper.floor(entityhuman.locY * 32.0D); this.e = MathHelper.floor(entityhuman.locZ * 32.0D); @@ -43,28 +44,28 @@ public class Packet20NamedEntitySpawn extends Packet { this.i = entityhuman.getDataWatcher(); } - public void a(DataInputStream datainputstream) throws IOException { // CraftBukkit - this.a = datainputstream.readInt(); - this.b = a(datainputstream, 16); - this.c = datainputstream.readInt(); - this.d = datainputstream.readInt(); - this.e = datainputstream.readInt(); - this.f = datainputstream.readByte(); - this.g = datainputstream.readByte(); - this.h = datainputstream.readShort(); - this.j = DataWatcher.a(datainputstream); + public void a(DataInput datainput) throws IOException { // CraftBukkit + this.a = datainput.readInt(); + this.b = a(datainput, 16); + this.c = datainput.readInt(); + this.d = datainput.readInt(); + this.e = datainput.readInt(); + this.f = datainput.readByte(); + this.g = datainput.readByte(); + this.h = datainput.readShort(); + this.j = DataWatcher.a(datainput); } - public void a(DataOutputStream dataoutputstream) throws IOException { // CraftBukkit - dataoutputstream.writeInt(this.a); - a(this.b, dataoutputstream); - dataoutputstream.writeInt(this.c); - dataoutputstream.writeInt(this.d); - dataoutputstream.writeInt(this.e); - dataoutputstream.writeByte(this.f); - dataoutputstream.writeByte(this.g); - dataoutputstream.writeShort(this.h); - this.i.a(dataoutputstream); + public void a(DataOutput dataoutput) throws IOException { // CraftBukkit + dataoutput.writeInt(this.a); + a(this.b, dataoutput); + dataoutput.writeInt(this.c); + dataoutput.writeInt(this.d); + dataoutput.writeInt(this.e); + dataoutput.writeByte(this.f); + dataoutput.writeByte(this.g); + dataoutput.writeShort(this.h); + this.i.a(dataoutput); } public void handle(Connection connection) { diff --git a/src/main/java/net/minecraft/server/Packet2Handshake.java b/src/main/java/net/minecraft/server/Packet2Handshake.java index 343af93d..1e7bad08 100644 --- a/src/main/java/net/minecraft/server/Packet2Handshake.java +++ b/src/main/java/net/minecraft/server/Packet2Handshake.java @@ -1,7 +1,7 @@ package net.minecraft.server; -import java.io.DataInputStream; -import java.io.DataOutputStream; +import java.io.DataInput; +import java.io.DataOutput; import java.io.IOException; // CraftBukkit @@ -14,18 +14,18 @@ public class Packet2Handshake extends Packet { public Packet2Handshake() {} - public void a(DataInputStream datainputstream) throws IOException { // CraftBukkit - throws IOException - this.a = datainputstream.readByte(); - this.b = a(datainputstream, 16); - this.c = a(datainputstream, 255); - this.d = datainputstream.readInt(); + public void a(DataInput datainput) throws IOException { // CraftBukkit - throws IOException + this.a = datainput.readByte(); + this.b = a(datainput, 16); + this.c = a(datainput, 255); + this.d = datainput.readInt(); } - public void a(DataOutputStream dataoutputstream) throws IOException { // CraftBukkit - throws IOException - dataoutputstream.writeByte(this.a); - a(this.b, dataoutputstream); - a(this.c, dataoutputstream); - dataoutputstream.writeInt(this.d); + public void a(DataOutput dataoutput) throws IOException { // CraftBukkit - throws IOException + dataoutput.writeByte(this.a); + a(this.b, dataoutput); + a(this.c, dataoutput); + dataoutput.writeInt(this.d); } public void handle(Connection connection) { diff --git a/src/main/java/net/minecraft/server/Packet3Chat.java b/src/main/java/net/minecraft/server/Packet3Chat.java deleted file mode 100644 index e48348bc..00000000 --- a/src/main/java/net/minecraft/server/Packet3Chat.java +++ /dev/null @@ -1,58 +0,0 @@ -package net.minecraft.server; - -import java.io.DataInputStream; -import java.io.DataOutputStream; - -import java.io.IOException; // CraftBukkit - -public class Packet3Chat extends Packet { - - public static int a = 119; - public String message; - private boolean c; - - public Packet3Chat() { - this.c = true; - } - - public Packet3Chat(String s) { - this(s, true); - } - - public Packet3Chat(String s, boolean flag) { - this.c = true; - - /* CraftBukkit start - Handle this later - if (s.length() > b) { - s = s.substring(0, b); - } - // CraftBukkit end */ - - this.message = s; - this.c = flag; - } - - public void a(DataInputStream datainputstream) throws IOException { // CraftBukkit - this.message = a(datainputstream, a); - } - - public void a(DataOutputStream dataoutputstream) throws IOException { // CraftBukkit - a(this.message, dataoutputstream); - } - - public void handle(Connection connection) { - connection.a(this); - } - - public int a() { - return 2 + this.message.length() * 2; - } - - public boolean isServer() { - return this.c; - } - - public boolean a_() { - return !this.message.startsWith("/"); - } -} diff --git a/src/main/java/net/minecraft/server/Packet51MapChunk.java b/src/main/java/net/minecraft/server/Packet51MapChunk.java deleted file mode 100644 index 97c953bb..00000000 --- a/src/main/java/net/minecraft/server/Packet51MapChunk.java +++ /dev/null @@ -1,186 +0,0 @@ -package net.minecraft.server; - -import java.io.DataInputStream; -import java.io.DataOutputStream; -import java.io.IOException; -import java.util.zip.DataFormatException; -import java.util.zip.Deflater; -import java.util.zip.Inflater; - -public class Packet51MapChunk extends Packet { - - public int a; - public int b; - public int c; - public int d; - private byte[] buffer; - private byte[] inflatedBuffer; - public boolean e; - private int size; - private static byte[] buildBuffer = new byte[196864]; - - public Packet51MapChunk() { - this.lowPriority = true; - } - - public Packet51MapChunk(Chunk chunk, boolean flag, int i) { - this.lowPriority = true; - this.a = chunk.x; - this.b = chunk.z; - this.e = flag; - ChunkMap chunkmap = a(chunk, flag, i); - Deflater deflater = new Deflater(-1); - - this.d = chunkmap.c; - this.c = chunkmap.b; - - try { - this.inflatedBuffer = chunkmap.a; - deflater.setInput(chunkmap.a, 0, chunkmap.a.length); - deflater.finish(); - this.buffer = new byte[chunkmap.a.length]; - this.size = deflater.deflate(this.buffer); - } finally { - deflater.end(); - } - } - - public void a(DataInputStream datainputstream) throws IOException { // CraftBukkit - throws IOException - this.a = datainputstream.readInt(); - this.b = datainputstream.readInt(); - this.e = datainputstream.readBoolean(); - this.c = datainputstream.readShort(); - this.d = datainputstream.readShort(); - this.size = datainputstream.readInt(); - if (buildBuffer.length < this.size) { - buildBuffer = new byte[this.size]; - } - - datainputstream.readFully(buildBuffer, 0, this.size); - int i = 0; - - int j; - - for (j = 0; j < 16; ++j) { - i += this.c >> j & 1; - } - - j = 12288 * i; - if (this.e) { - j += 256; - } - - this.inflatedBuffer = new byte[j]; - Inflater inflater = new Inflater(); - - inflater.setInput(buildBuffer, 0, this.size); - - try { - inflater.inflate(this.inflatedBuffer); - } catch (DataFormatException dataformatexception) { - throw new IOException("Bad compressed data format"); - } finally { - inflater.end(); - } - } - - public void a(DataOutputStream dataoutputstream) throws IOException { // CraftBukkit - throws IOException - dataoutputstream.writeInt(this.a); - dataoutputstream.writeInt(this.b); - dataoutputstream.writeBoolean(this.e); - dataoutputstream.writeShort((short) (this.c & '\uffff')); - dataoutputstream.writeShort((short) (this.d & '\uffff')); - dataoutputstream.writeInt(this.size); - dataoutputstream.write(this.buffer, 0, this.size); - } - - public void handle(Connection connection) { - connection.a(this); - } - - public int a() { - return 17 + this.size; - } - - public static ChunkMap a(Chunk chunk, boolean flag, int i) { - int j = 0; - ChunkSection[] achunksection = chunk.i(); - int k = 0; - ChunkMap chunkmap = new ChunkMap(); - byte[] abyte = buildBuffer; - - if (flag) { - chunk.seenByPlayer = true; - } - - int l; - - for (l = 0; l < achunksection.length; ++l) { - if (achunksection[l] != null && (!flag || !achunksection[l].isEmpty()) && (i & 1 << l) != 0) { - chunkmap.b |= 1 << l; - if (achunksection[l].getExtendedIdArray() != null) { - chunkmap.c |= 1 << l; - ++k; - } - } - } - - for (l = 0; l < achunksection.length; ++l) { - if (achunksection[l] != null && (!flag || !achunksection[l].isEmpty()) && (i & 1 << l) != 0) { - byte[] abyte1 = achunksection[l].getIdArray(); - - System.arraycopy(abyte1, 0, abyte, j, abyte1.length); - j += abyte1.length; - } - } - - NibbleArray nibblearray; - - for (l = 0; l < achunksection.length; ++l) { - if (achunksection[l] != null && (!flag || !achunksection[l].isEmpty()) && (i & 1 << l) != 0) { - nibblearray = achunksection[l].getDataArray(); - System.arraycopy(nibblearray.a, 0, abyte, j, nibblearray.a.length); - j += nibblearray.a.length; - } - } - - for (l = 0; l < achunksection.length; ++l) { - if (achunksection[l] != null && (!flag || !achunksection[l].isEmpty()) && (i & 1 << l) != 0) { - nibblearray = achunksection[l].getEmittedLightArray(); - System.arraycopy(nibblearray.a, 0, abyte, j, nibblearray.a.length); - j += nibblearray.a.length; - } - } - - if (!chunk.world.worldProvider.f) { - for (l = 0; l < achunksection.length; ++l) { - if (achunksection[l] != null && (!flag || !achunksection[l].isEmpty()) && (i & 1 << l) != 0) { - nibblearray = achunksection[l].getSkyLightArray(); - System.arraycopy(nibblearray.a, 0, abyte, j, nibblearray.a.length); - j += nibblearray.a.length; - } - } - } - - if (k > 0) { - for (l = 0; l < achunksection.length; ++l) { - if (achunksection[l] != null && (!flag || !achunksection[l].isEmpty()) && achunksection[l].getExtendedIdArray() != null && (i & 1 << l) != 0) { - nibblearray = achunksection[l].getExtendedIdArray(); - System.arraycopy(nibblearray.a, 0, abyte, j, nibblearray.a.length); - j += nibblearray.a.length; - } - } - } - - if (flag) { - byte[] abyte2 = chunk.m(); - - System.arraycopy(abyte2, 0, abyte, j, abyte2.length); - j += abyte2.length; - } - - chunkmap.a = new byte[j]; - System.arraycopy(abyte, 0, chunkmap.a, 0, j); - return chunkmap; - } -} diff --git a/src/main/java/net/minecraft/server/Packet56MapChunkBulk.java b/src/main/java/net/minecraft/server/Packet56MapChunkBulk.java index 129dc4f1..04c44fcc 100644 --- a/src/main/java/net/minecraft/server/Packet56MapChunkBulk.java +++ b/src/main/java/net/minecraft/server/Packet56MapChunkBulk.java @@ -1,7 +1,7 @@ package net.minecraft.server; -import java.io.DataInputStream; -import java.io.DataOutputStream; +import java.io.DataInput; +import java.io.DataOutput; import java.io.IOException; import java.util.List; import java.util.zip.DataFormatException; @@ -39,7 +39,7 @@ public class Packet56MapChunkBulk extends Packet { this.a = new int[i]; this.b = new int[i]; this.inflatedBuffers = new byte[i][]; - this.h = !list.isEmpty() && !((Chunk) list.get(0)).world.worldProvider.f; + this.h = !list.isEmpty() && !((Chunk) list.get(0)).world.worldProvider.g; int j = 0; for (int k = 0; k < i; ++k) { @@ -92,11 +92,11 @@ public class Packet56MapChunkBulk extends Packet { } // CraftBukkit end - public void a(DataInputStream datainputstream) throws IOException { // CraftBukkit - throws IOException - short short1 = datainputstream.readShort(); + public void a(DataInput datainput) throws IOException { // CraftBukkit - throws IOException + short short1 = datainput.readShort(); - this.size = datainputstream.readInt(); - this.h = datainputstream.readBoolean(); + this.size = datainput.readInt(); + this.h = datainput.readBoolean(); this.c = new int[short1]; this.d = new int[short1]; this.a = new int[short1]; @@ -106,7 +106,7 @@ public class Packet56MapChunkBulk extends Packet { buildBuffer = new byte[this.size]; } - datainputstream.readFully(buildBuffer, 0, this.size); + datainput.readFully(buildBuffer, 0, this.size); byte[] abyte = new byte[196864 * short1]; Inflater inflater = new Inflater(); @@ -123,10 +123,10 @@ public class Packet56MapChunkBulk extends Packet { int i = 0; for (int j = 0; j < short1; ++j) { - this.c[j] = datainputstream.readInt(); - this.d[j] = datainputstream.readInt(); - this.a[j] = datainputstream.readShort(); - this.b[j] = datainputstream.readShort(); + this.c[j] = datainput.readInt(); + this.d[j] = datainput.readInt(); + this.a[j] = datainput.readShort(); + this.b[j] = datainput.readShort(); int k = 0; int l = 0; @@ -149,18 +149,18 @@ public class Packet56MapChunkBulk extends Packet { } } - public void a(DataOutputStream dataoutputstream) throws IOException { // CraftBukkit - throws IOException + public void a(DataOutput dataoutput) throws IOException { // CraftBukkit - throws IOException compress(); // CraftBukkit - dataoutputstream.writeShort(this.c.length); - dataoutputstream.writeInt(this.size); - dataoutputstream.writeBoolean(this.h); - dataoutputstream.write(this.buffer, 0, this.size); + dataoutput.writeShort(this.c.length); + dataoutput.writeInt(this.size); + dataoutput.writeBoolean(this.h); + dataoutput.write(this.buffer, 0, this.size); for (int i = 0; i < this.c.length; ++i) { - dataoutputstream.writeInt(this.c[i]); - dataoutputstream.writeInt(this.d[i]); - dataoutputstream.writeShort((short) (this.a[i] & '\uffff')); - dataoutputstream.writeShort((short) (this.b[i] & '\uffff')); + dataoutput.writeInt(this.c[i]); + dataoutput.writeInt(this.d[i]); + dataoutput.writeShort((short) (this.a[i] & '\uffff')); + dataoutput.writeShort((short) (this.b[i] & '\uffff')); } } diff --git a/src/main/java/net/minecraft/server/Path.java b/src/main/java/net/minecraft/server/Path.java index 530cf09b..90c3ef97 100644 --- a/src/main/java/net/minecraft/server/Path.java +++ b/src/main/java/net/minecraft/server/Path.java @@ -3,7 +3,7 @@ package net.minecraft.server; public class Path { private PathPoint[] a = new PathPoint[128]; // CraftBukkit - reduce default size - private int b = 0; + private int b; public Path() {} diff --git a/src/main/java/net/minecraft/server/PathfinderGoalArrowAttack.java b/src/main/java/net/minecraft/server/PathfinderGoalArrowAttack.java index 5470591b..cb2af02f 100644 --- a/src/main/java/net/minecraft/server/PathfinderGoalArrowAttack.java +++ b/src/main/java/net/minecraft/server/PathfinderGoalArrowAttack.java @@ -4,34 +4,33 @@ import org.bukkit.event.entity.EntityTargetEvent; // CraftBukkit public class PathfinderGoalArrowAttack extends PathfinderGoal { - private final EntityLiving a; + private final EntityInsentient a; private final IRangedEntity b; private EntityLiving c; private int d; - private float e; + private double e; private int f; private int g; private int h; private float i; private float j; - public PathfinderGoalArrowAttack(IRangedEntity irangedentity, float f, int i, float f1) { - this(irangedentity, f, i, i, f1); + public PathfinderGoalArrowAttack(IRangedEntity irangedentity, double d0, int i, float f) { + this(irangedentity, d0, i, i, f); } - public PathfinderGoalArrowAttack(IRangedEntity irangedentity, float f, int i, int j, float f1) { + public PathfinderGoalArrowAttack(IRangedEntity irangedentity, double d0, int i, int j, float f) { this.d = -1; - this.f = 0; if (!(irangedentity instanceof EntityLiving)) { throw new IllegalArgumentException("ArrowAttackGoal requires Mob implements RangedAttackMob"); } else { this.b = irangedentity; - this.a = (EntityLiving) irangedentity; - this.e = f; + this.a = (EntityInsentient) irangedentity; + this.e = d0; this.g = i; this.h = j; - this.i = f1; - this.j = f1 * f1; + this.i = f; + this.j = f * f; this.a(3); } } @@ -48,7 +47,7 @@ public class PathfinderGoalArrowAttack extends PathfinderGoal { } public boolean b() { - return this.a() || !this.a.getNavigation().f(); + return this.a() || !this.a.getNavigation().g(); } public void d() { @@ -72,9 +71,9 @@ public class PathfinderGoalArrowAttack extends PathfinderGoal { } if (d0 <= (double) this.j && this.f >= 20) { - this.a.getNavigation().g(); + this.a.getNavigation().h(); } else { - this.a.getNavigation().a(this.c, this.e); + this.a.getNavigation().a((Entity) this.c, this.e); } this.a.getControllerLook().a(this.c, 30.0F, 30.0F); diff --git a/src/main/java/net/minecraft/server/PathfinderGoalBreakDoor.java b/src/main/java/net/minecraft/server/PathfinderGoalBreakDoor.java index 86b194ce..8f8b077e 100644 --- a/src/main/java/net/minecraft/server/PathfinderGoalBreakDoor.java +++ b/src/main/java/net/minecraft/server/PathfinderGoalBreakDoor.java @@ -5,8 +5,8 @@ public class PathfinderGoalBreakDoor extends PathfinderGoalDoorInteract { private int i; private int j = -1; - public PathfinderGoalBreakDoor(EntityLiving entityliving) { - super(entityliving); + public PathfinderGoalBreakDoor(EntityInsentient entityinsentient) { + super(entityinsentient); } public boolean a() { @@ -31,7 +31,7 @@ public class PathfinderGoalBreakDoor extends PathfinderGoalDoorInteract { public void e() { super.e(); - if (this.a.aE().nextInt(20) == 0) { + if (this.a.aB().nextInt(20) == 0) { this.a.world.triggerEffect(1010, this.b, this.c, this.d, 0); } diff --git a/src/main/java/net/minecraft/server/PathfinderGoalBreed.java b/src/main/java/net/minecraft/server/PathfinderGoalBreed.java index ca544f36..a2560043 100644 --- a/src/main/java/net/minecraft/server/PathfinderGoalBreed.java +++ b/src/main/java/net/minecraft/server/PathfinderGoalBreed.java @@ -9,18 +9,18 @@ public class PathfinderGoalBreed extends PathfinderGoal { private EntityAnimal d; World a; private EntityAnimal e; - int b = 0; - float c; + int b; + double c; - public PathfinderGoalBreed(EntityAnimal entityanimal, float f) { + public PathfinderGoalBreed(EntityAnimal entityanimal, double d0) { this.d = entityanimal; this.a = entityanimal.world; - this.c = f; + this.c = d0; this.a(3); } public boolean a() { - if (!this.d.r()) { + if (!this.d.bU()) { return false; } else { this.e = this.f(); @@ -29,7 +29,7 @@ public class PathfinderGoalBreed extends PathfinderGoal { } public boolean b() { - return this.e.isAlive() && this.e.r() && this.b < 60; + return this.e.isAlive() && this.e.bU() && this.b < 60; } public void d() { @@ -38,8 +38,8 @@ public class PathfinderGoalBreed extends PathfinderGoal { } public void e() { - this.d.getControllerLook().a(this.e, 10.0F, (float) this.d.bs()); - this.d.getNavigation().a((EntityLiving) this.e, this.c); + this.d.getControllerLook().a(this.e, 10.0F, (float) this.d.bl()); + this.d.getNavigation().a((Entity) this.e, this.c); ++this.b; if (this.b >= 60 && this.d.e(this.e) < 9.0D) { this.g(); @@ -71,12 +71,12 @@ public class PathfinderGoalBreed extends PathfinderGoal { if (entityageable != null) { this.d.setAge(6000); this.e.setAge(6000); - this.d.s(); - this.e.s(); + this.d.bV(); + this.e.bV(); entityageable.setAge(-24000); entityageable.setPositionRotation(this.d.locX, this.d.locY, this.d.locZ, 0.0F, 0.0F); this.a.addEntity(entityageable, org.bukkit.event.entity.CreatureSpawnEvent.SpawnReason.BREEDING); // CraftBukkit - added SpawnReason - Random random = this.d.aE(); + Random random = this.d.aB(); for (int i = 0; i < 7; ++i) { double d0 = random.nextGaussian() * 0.02D; diff --git a/src/main/java/net/minecraft/server/PathfinderGoalEatTile.java b/src/main/java/net/minecraft/server/PathfinderGoalEatTile.java index 1feced1a..3048b694 100644 --- a/src/main/java/net/minecraft/server/PathfinderGoalEatTile.java +++ b/src/main/java/net/minecraft/server/PathfinderGoalEatTile.java @@ -7,18 +7,18 @@ import org.bukkit.Material; public class PathfinderGoalEatTile extends PathfinderGoal { - private EntityLiving b; + private EntityInsentient b; private World c; - int a = 0; + int a; - public PathfinderGoalEatTile(EntityLiving entityliving) { - this.b = entityliving; - this.c = entityliving.world; + public PathfinderGoalEatTile(EntityInsentient entityinsentient) { + this.b = entityinsentient; + this.c = entityinsentient.world; this.a(7); } public boolean a() { - if (this.b.aE().nextInt(this.b.isBaby() ? 50 : 1000) != 0) { + if (this.b.aB().nextInt(this.b.isBaby() ? 50 : 1000) != 0) { return false; } else { int i = MathHelper.floor(this.b.locX); @@ -32,7 +32,7 @@ public class PathfinderGoalEatTile extends PathfinderGoal { public void c() { this.a = 40; this.c.broadcastEntityEffect(this.b, (byte) 10); - this.b.getNavigation().g(); + this.b.getNavigation().h(); } public void d() { diff --git a/src/main/java/net/minecraft/server/PathfinderGoalMeleeAttack.java b/src/main/java/net/minecraft/server/PathfinderGoalMeleeAttack.java index e5d13f5f..8b7a0152 100644 --- a/src/main/java/net/minecraft/server/PathfinderGoalMeleeAttack.java +++ b/src/main/java/net/minecraft/server/PathfinderGoalMeleeAttack.java @@ -5,26 +5,24 @@ import org.bukkit.event.entity.EntityTargetEvent; // CraftBukkit public class PathfinderGoalMeleeAttack extends PathfinderGoal { World a; - EntityLiving b; - EntityLiving c; - int d; - float e; - boolean f; - PathEntity g; - Class h; - private int i; - - public PathfinderGoalMeleeAttack(EntityLiving entityliving, Class oclass, float f, boolean flag) { - this(entityliving, f, flag); - this.h = oclass; + EntityCreature b; + int c; + double d; + boolean e; + PathEntity f; + Class g; + private int h; + + public PathfinderGoalMeleeAttack(EntityCreature entitycreature, Class oclass, double d0, boolean flag) { + this(entitycreature, d0, flag); + this.g = oclass; } - public PathfinderGoalMeleeAttack(EntityLiving entityliving, float f, boolean flag) { - this.d = 0; - this.b = entityliving; - this.a = entityliving.world; - this.e = f; - this.f = flag; + public PathfinderGoalMeleeAttack(EntityCreature entitycreature, double d0, boolean flag) { + this.b = entitycreature; + this.a = entitycreature.world; + this.d = d0; + this.e = flag; this.a(3); } @@ -33,54 +31,58 @@ public class PathfinderGoalMeleeAttack extends PathfinderGoal { if (entityliving == null) { return false; - } else if (this.h != null && !this.h.isAssignableFrom(entityliving.getClass())) { + } else if (!entityliving.isAlive()) { + return false; + } else if (this.g != null && !this.g.isAssignableFrom(entityliving.getClass())) { return false; } else { - this.c = entityliving; - this.g = this.b.getNavigation().a(this.c); - return this.g != null; + this.f = this.b.getNavigation().a(entityliving); + return this.f != null; } } public boolean b() { EntityLiving entityliving = this.b.getGoalTarget(); - return entityliving == null ? false : (!this.c.isAlive() ? false : (!this.f ? !this.b.getNavigation().f() : this.b.d(MathHelper.floor(this.c.locX), MathHelper.floor(this.c.locY), MathHelper.floor(this.c.locZ)))); + // CraftBukkit start + EntityTargetEvent.TargetReason reason = this.b.getGoalTarget() == null ? EntityTargetEvent.TargetReason.FORGOT_TARGET : EntityTargetEvent.TargetReason.TARGET_DIED; + if (this.b.getGoalTarget() == null || (this.b.getGoalTarget() != null && !this.b.getGoalTarget().isAlive())) { + org.bukkit.craftbukkit.event.CraftEventFactory.callEntityTargetEvent(b, null, reason); + } + // CraftBukkit end + + return entityliving == null ? false : (!entityliving.isAlive() ? false : (!this.e ? !this.b.getNavigation().g() : this.b.b(MathHelper.floor(entityliving.locX), MathHelper.floor(entityliving.locY), MathHelper.floor(entityliving.locZ)))); } public void c() { - this.b.getNavigation().a(this.g, this.e); - this.i = 0; + this.b.getNavigation().a(this.f, this.d); + this.h = 0; } public void d() { - // CraftBukkit start - EntityTargetEvent.TargetReason reason = this.c.isAlive() ? EntityTargetEvent.TargetReason.FORGOT_TARGET : EntityTargetEvent.TargetReason.TARGET_DIED; - org.bukkit.craftbukkit.event.CraftEventFactory.callEntityTargetEvent(b, null, reason); - // CraftBukkit end - - this.c = null; - this.b.getNavigation().g(); + this.b.getNavigation().h(); } public void e() { - this.b.getControllerLook().a(this.c, 30.0F, 30.0F); - if ((this.f || this.b.getEntitySenses().canSee(this.c)) && --this.i <= 0) { - this.i = 4 + this.b.aE().nextInt(7); - this.b.getNavigation().a(this.c, this.e); + EntityLiving entityliving = this.b.getGoalTarget(); + + this.b.getControllerLook().a(entityliving, 30.0F, 30.0F); + if ((this.e || this.b.getEntitySenses().canSee(entityliving)) && --this.h <= 0) { + this.h = 4 + this.b.aB().nextInt(7); + this.b.getNavigation().a((Entity) entityliving, this.d); } - this.d = Math.max(this.d - 1, 0); - double d0 = (double) (this.b.width * 2.0F * this.b.width * 2.0F); + this.c = Math.max(this.c - 1, 0); + double d0 = (double) (this.b.width * 2.0F * this.b.width * 2.0F + entityliving.width); - if (this.b.e(this.c.locX, this.c.boundingBox.b, this.c.locZ) <= d0) { - if (this.d <= 0) { - this.d = 20; - if (this.b.bG() != null) { - this.b.bK(); + if (this.b.e(entityliving.locX, entityliving.boundingBox.b, entityliving.locZ) <= d0) { + if (this.c <= 0) { + this.c = 20; + if (this.b.aV() != null) { + this.b.aR(); } - this.b.m(this.c); + this.b.m(entityliving); } } } diff --git a/src/main/java/net/minecraft/server/PathfinderGoalSelector.java b/src/main/java/net/minecraft/server/PathfinderGoalSelector.java index 28608784..1da9a42c 100644 --- a/src/main/java/net/minecraft/server/PathfinderGoalSelector.java +++ b/src/main/java/net/minecraft/server/PathfinderGoalSelector.java @@ -13,7 +13,7 @@ public class PathfinderGoalSelector { private List b = new UnsafeList(); // CraftBukkit end private final MethodProfiler c; - private int d = 0; + private int d; private int e = 3; public PathfinderGoalSelector(MethodProfiler methodprofiler) { @@ -130,7 +130,7 @@ public class PathfinderGoalSelector { ((UnsafeList.Itr) iterator).valid = false; // CraftBukkit - mark iterator for reuse return false; } - // CraftBukkit - switch order + // CraftBukkit - switch order } else if (!pathfindergoalselectoritem1.a.i() && this.b.contains(pathfindergoalselectoritem1)) { this.c.b(); ((UnsafeList.Itr) iterator).valid = false; // CraftBukkit - mark iterator for reuse diff --git a/src/main/java/net/minecraft/server/PathfinderGoalSit.java b/src/main/java/net/minecraft/server/PathfinderGoalSit.java index 031005ed..ff300bff 100644 --- a/src/main/java/net/minecraft/server/PathfinderGoalSit.java +++ b/src/main/java/net/minecraft/server/PathfinderGoalSit.java @@ -2,38 +2,38 @@ package net.minecraft.server; public class PathfinderGoalSit extends PathfinderGoal { - private EntityTameableAnimal a; - private boolean b = false; + private EntityTameableAnimal entity; + private boolean willSit; public PathfinderGoalSit(EntityTameableAnimal entitytameableanimal) { - this.a = entitytameableanimal; + this.entity = entitytameableanimal; this.a(5); } public boolean a() { - if (!this.a.isTamed()) { - return this.b && this.a.getGoalTarget() == null; // CraftBukkit - Allow sitting for wild animals - } else if (this.a.G()) { + if (!this.entity.isTamed()) { + return this.willSit && this.entity.getGoalTarget() == null; // CraftBukkit - Allow sitting for wild animals + } else if (this.entity.G()) { return false; - } else if (!this.a.onGround) { + } else if (!this.entity.onGround) { return false; } else { - EntityLiving entityliving = this.a.getOwner(); + EntityLiving entityliving = this.entity.getOwner(); - return entityliving == null ? true : (this.a.e(entityliving) < 144.0D && entityliving.aF() != null ? false : this.b); + return entityliving == null ? true : (this.entity.e(entityliving) < 144.0D && entityliving.getLastDamager() != null ? false : this.willSit); } } public void c() { - this.a.getNavigation().g(); - this.a.setSitting(true); + this.entity.getNavigation().h(); + this.entity.setSitting(true); } public void d() { - this.a.setSitting(false); + this.entity.setSitting(false); } public void setSitting(boolean flag) { - this.b = flag; + this.willSit = flag; } } diff --git a/src/main/java/net/minecraft/server/PathfinderGoalTarget.java b/src/main/java/net/minecraft/server/PathfinderGoalTarget.java index 0dd60150..5a840830 100644 --- a/src/main/java/net/minecraft/server/PathfinderGoalTarget.java +++ b/src/main/java/net/minecraft/server/PathfinderGoalTarget.java @@ -1,5 +1,7 @@ package net.minecraft.server; +import org.apache.commons.lang3.StringUtils; + // CraftBukkit start import org.bukkit.craftbukkit.entity.CraftEntity; import org.bukkit.event.entity.EntityTargetEvent; @@ -7,89 +9,94 @@ import org.bukkit.event.entity.EntityTargetEvent; public abstract class PathfinderGoalTarget extends PathfinderGoal { - protected EntityLiving d; - protected float e; - protected boolean f; + protected EntityCreature c; + protected boolean d; private boolean a; private int b; - private int c; - private int g; + private int e; + private int f; - public PathfinderGoalTarget(EntityLiving entityliving, float f, boolean flag) { - this(entityliving, f, flag, false); + public PathfinderGoalTarget(EntityCreature entitycreature, boolean flag) { + this(entitycreature, flag, false); } - public PathfinderGoalTarget(EntityLiving entityliving, float f, boolean flag, boolean flag1) { - this.b = 0; - this.c = 0; - this.g = 0; - this.d = entityliving; - this.e = f; - this.f = flag; + public PathfinderGoalTarget(EntityCreature entitycreature, boolean flag, boolean flag1) { + this.c = entitycreature; + this.d = flag; this.a = flag1; } public boolean b() { - EntityLiving entityliving = this.d.getGoalTarget(); + EntityLiving entityliving = this.c.getGoalTarget(); if (entityliving == null) { return false; } else if (!entityliving.isAlive()) { return false; - } else if (this.d.e(entityliving) > (double) (this.e * this.e)) { - return false; } else { - if (this.f) { - if (this.d.getEntitySenses().canSee(entityliving)) { - this.g = 0; - } else if (++this.g > 60) { - return false; + double d0 = this.f(); + + if (this.c.e(entityliving) > d0 * d0) { + return false; + } else { + if (this.d) { + if (this.c.getEntitySenses().canSee(entityliving)) { + this.f = 0; + } else if (++this.f > 60) { + return false; + } } - } - return true; + return true; + } } } + protected double f() { + AttributeInstance attributeinstance = this.c.a(GenericAttributes.b); + + return attributeinstance == null ? 16.0D : attributeinstance.e(); + } + public void c() { this.b = 0; - this.c = 0; - this.g = 0; + this.e = 0; + this.f = 0; } public void d() { - this.d.setGoalTarget((EntityLiving) null); + this.c.setGoalTarget((EntityLiving) null); } protected boolean a(EntityLiving entityliving, boolean flag) { if (entityliving == null) { return false; - } else if (entityliving == this.d) { + } else if (entityliving == this.c) { return false; } else if (!entityliving.isAlive()) { return false; - } else if (!this.d.a(entityliving.getClass())) { + } else if (!this.c.a(entityliving.getClass())) { return false; } else { - if (this.d instanceof EntityTameableAnimal && ((EntityTameableAnimal) this.d).isTamed()) { - if (entityliving instanceof EntityTameableAnimal && ((EntityTameableAnimal) entityliving).isTamed()) { + if (this.c instanceof EntityOwnable && StringUtils.isNotEmpty(((EntityOwnable) this.c).getOwnerName())) { + if (entityliving instanceof EntityOwnable && ((EntityOwnable) this.c).getOwnerName().equals(((EntityOwnable) entityliving).getOwnerName())) { return false; } - if (entityliving == ((EntityTameableAnimal) this.d).getOwner()) { + if (entityliving == ((EntityOwnable) this.c).getOwner()) { return false; } } else if (entityliving instanceof EntityHuman && !flag && ((EntityHuman) entityliving).abilities.isInvulnerable) { return false; } - if (!this.d.d(MathHelper.floor(entityliving.locX), MathHelper.floor(entityliving.locY), MathHelper.floor(entityliving.locZ))) { + if (!this.c.b(MathHelper.floor(entityliving.locX), MathHelper.floor(entityliving.locY), MathHelper.floor(entityliving.locZ))) { return false; - } else if (this.f && !this.d.getEntitySenses().canSee(entityliving)) { + } else if (this.d && !this.c.getEntitySenses().canSee(entityliving)) { return false; } else { if (this.a) { - if (--this.c <= 0) { + if (--this.e <= 0) { this.b = 0; } @@ -119,15 +126,15 @@ public abstract class PathfinderGoalTarget extends PathfinderGoal { reason = EntityTargetEvent.TargetReason.OWNER_ATTACKED_TARGET; } - org.bukkit.event.entity.EntityTargetLivingEntityEvent event = org.bukkit.craftbukkit.event.CraftEventFactory.callEntityTargetLivingEvent(this.d, entityliving, reason); + org.bukkit.event.entity.EntityTargetLivingEntityEvent event = org.bukkit.craftbukkit.event.CraftEventFactory.callEntityTargetLivingEvent(this.c, entityliving, reason); if (event.isCancelled() || event.getTarget() == null) { - this.d.setGoalTarget(null); + this.c.setGoalTarget(null); return false; } else if (entityliving.getBukkitEntity() != event.getTarget()) { - this.d.setGoalTarget((EntityLiving) ((CraftEntity) event.getTarget()).getHandle()); + this.c.setGoalTarget((EntityLiving) ((CraftEntity) event.getTarget()).getHandle()); } - if (this.d instanceof EntityCreature) { - ((EntityCreature) this.d).target = ((CraftEntity) event.getTarget()).getHandle(); + if (this.c instanceof EntityCreature) { + ((EntityCreature) this.c).target = ((CraftEntity) event.getTarget()).getHandle(); } // CraftBukkit end @@ -137,8 +144,8 @@ public abstract class PathfinderGoalTarget extends PathfinderGoal { } private boolean a(EntityLiving entityliving) { - this.c = 10 + this.d.aE().nextInt(5); - PathEntity pathentity = this.d.getNavigation().a(entityliving); + this.e = 10 + this.c.aB().nextInt(5); + PathEntity pathentity = this.c.getNavigation().a(entityliving); if (pathentity == null) { return false; diff --git a/src/main/java/net/minecraft/server/PendingConnection.java b/src/main/java/net/minecraft/server/PendingConnection.java index 17cfacc9..252cea7c 100644 --- a/src/main/java/net/minecraft/server/PendingConnection.java +++ b/src/main/java/net/minecraft/server/PendingConnection.java @@ -9,7 +9,6 @@ import java.util.Arrays; import java.util.Iterator; import java.util.List; import java.util.Random; -import java.util.logging.Logger; import javax.crypto.SecretKey; public class PendingConnection extends Connection { @@ -18,18 +17,18 @@ public class PendingConnection extends Connection { private byte[] d; private final MinecraftServer server; public final NetworkManager networkManager; - public boolean b = false; - private int f = 0; - private String g = null; - private volatile boolean h = false; + public boolean b; + private int f; + private String g; + private volatile boolean h; private String loginKey = Long.toString(random.nextLong(), 16); // CraftBukkit - Security fix - private boolean j = false; - private SecretKey k = null; + private boolean j; + private SecretKey k; public String hostname = ""; // CraftBukkit - add field public PendingConnection(MinecraftServer minecraftserver, Socket socket, String s) throws java.io.IOException { // CraftBukkit - throws IOException this.server = minecraftserver; - this.networkManager = new NetworkManager(minecraftserver.getLogger(), socket, s, this, minecraftserver.F().getPrivate()); + this.networkManager = new NetworkManager(minecraftserver.getLogger(), socket, s, this, minecraftserver.H().getPrivate()); this.networkManager.e = 0; } @@ -70,10 +69,10 @@ public class PendingConnection extends Connection { if (!this.g.equals(StripColor.a(this.g))) { this.disconnect("Invalid username!"); } else { - PublicKey publickey = this.server.F().getPublic(); + PublicKey publickey = this.server.H().getPublic(); - if (packet2handshake.d() != 61) { - if (packet2handshake.d() > 61) { + if (packet2handshake.d() != 73) { + if (packet2handshake.d() > 73) { this.disconnect("Outdated server!"); } else { this.disconnect("Outdated client!"); @@ -88,7 +87,7 @@ public class PendingConnection extends Connection { } public void a(Packet252KeyResponse packet252keyresponse) { - PrivateKey privatekey = this.server.F().getPrivate(); + PrivateKey privatekey = this.server.H().getPrivate(); this.k = packet252keyresponse.a(privatekey); if (!Arrays.equals(this.d, packet252keyresponse.b(privatekey))) { @@ -100,12 +99,13 @@ public class PendingConnection extends Connection { public void a(Packet205ClientCommand packet205clientcommand) { if (packet205clientcommand.a == 0) { + if (this.j) { + this.disconnect("Duplicate login"); + return; + } + + this.j = true; if (this.server.getOnlineMode()) { - if (this.j) { - this.disconnect("Duplicate login"); - return; - } - this.j = true; (new ThreadLoginVerifier(this, server.server)).start(); // CraftBukkit - add CraftServer } else { this.h = true; @@ -120,10 +120,11 @@ public class PendingConnection extends Connection { EntityPlayer s = this.server.getPlayerList().attemptLogin(this, this.g, this.hostname); if (s == null) { + // this.disconnect(s); return; // CraftBukkit end } else { - EntityPlayer entityplayer = this.server.getPlayerList().processLogin(s); // CraftBukkit - this.h -> s + EntityPlayer entityplayer = this.server.getPlayerList().processLogin(s); // CraftBukkit - this.g -> s if (entityplayer != null) { this.server.getPlayerList().a((INetworkManager) this.networkManager, entityplayer); @@ -145,24 +146,22 @@ public class PendingConnection extends Connection { String s = null; // CraftBukkit org.bukkit.event.server.ServerListPingEvent pingEvent = org.bukkit.craftbukkit.event.CraftEventFactory.callServerListPingEvent(this.server.server, getSocket().getInetAddress(), this.server.getMotd(), playerlist.getPlayerCount(), playerlist.getMaxPlayers()); + if (packet254getinfo.d()) { + // CraftBukkit + s = pingEvent.getMotd() + "\u00A7" + playerlist.getPlayerCount() + "\u00A7" + pingEvent.getMaxPlayers(); + } else { + List list = Arrays.asList(new Serializable[] { Integer.valueOf(1), Integer.valueOf(73), this.server.getVersion(), this.server.getMotd(), Integer.valueOf(playerlist.getPlayerCount()), Integer.valueOf(playerlist.getMaxPlayers())}); - if (packet254getinfo.a == 1) { - // CraftBukkit start - Fix decompile issues, don't create a list from an array - Object[] list = new Object[] { 1, 61, this.server.getVersion(), pingEvent.getMotd(), playerlist.getPlayerCount(), pingEvent.getMaxPlayers() }; + Object object; - for (Object object : list) { + for (Iterator iterator = list.iterator(); iterator.hasNext(); s = s + object.toString().replaceAll("\0", "")) { + object = iterator.next(); if (s == null) { s = "\u00A7"; } else { - s = s + "\0"; + s = s + '\0'; } - - s += org.apache.commons.lang.StringUtils.replace(object.toString(), "\0", ""); } - // CraftBukkit end - } else { - // CraftBukkit - s = pingEvent.getMotd() + "\u00A7" + playerlist.getPlayerCount() + "\u00A7" + pingEvent.getMaxPlayers(); } InetAddress inetaddress = null; @@ -173,8 +172,8 @@ public class PendingConnection extends Connection { this.networkManager.queue(new Packet255KickDisconnect(s)); this.networkManager.d(); - if (inetaddress != null && this.server.ae() instanceof DedicatedServerConnection) { - ((DedicatedServerConnection) this.server.ae()).a(inetaddress); + if (inetaddress != null && this.server.ag() instanceof DedicatedServerConnection) { + ((DedicatedServerConnection) this.server.ag()).a(inetaddress); } this.b = true; diff --git a/src/main/java/net/minecraft/server/PlayerAbilities.java b/src/main/java/net/minecraft/server/PlayerAbilities.java index 5ce83dda..7acea6e9 100644 --- a/src/main/java/net/minecraft/server/PlayerAbilities.java +++ b/src/main/java/net/minecraft/server/PlayerAbilities.java @@ -2,10 +2,10 @@ package net.minecraft.server; public class PlayerAbilities { - public boolean isInvulnerable = false; - public boolean isFlying = false; - public boolean canFly = false; - public boolean canInstantlyBuild = false; + public boolean isInvulnerable; + public boolean isFlying; + public boolean canFly; + public boolean canInstantlyBuild; public boolean mayBuild = true; public float flySpeed = 0.05F; // CraftBukkit private -> public public float walkSpeed = 0.1F; // CraftBukkit private -> public diff --git a/src/main/java/net/minecraft/server/PlayerChunk.java b/src/main/java/net/minecraft/server/PlayerChunk.java index 10a43b64..81d66e45 100644 --- a/src/main/java/net/minecraft/server/PlayerChunk.java +++ b/src/main/java/net/minecraft/server/PlayerChunk.java @@ -10,6 +10,7 @@ class PlayerChunk { private short[] dirtyBlocks; private int dirtyCount; private int f; + private long g; private boolean loaded = false; // CraftBukkit final PlayerChunkMap playerChunkMap; @@ -18,7 +19,6 @@ class PlayerChunk { this.playerChunkMap = playerchunkmap; this.b = new ArrayList(); this.dirtyBlocks = new short[64]; - this.dirtyCount = 0; this.location = new ChunkCoordIntPair(i, j); // CraftBukkit start playerchunkmap.a().chunkProviderServer.getChunkAt(i, j, new Runnable() { @@ -33,6 +33,10 @@ class PlayerChunk { if (this.b.contains(entityplayer)) { throw new IllegalStateException("Failed to add player. " + entityplayer + " already is in chunk " + this.location.x + ", " + this.location.z); } else { + if (this.b.isEmpty()) { + this.g = PlayerChunkMap.a(this.playerChunkMap).getTime(); + } + this.b.add(entityplayer); // CraftBukkit start @@ -52,15 +56,19 @@ class PlayerChunk { public void b(EntityPlayer entityplayer) { if (this.b.contains(entityplayer)) { - entityplayer.playerConnection.sendPacket(new Packet51MapChunk(PlayerChunkMap.a(this.playerChunkMap).getChunkAt(this.location.x, this.location.z), true, 0)); + Chunk chunk = PlayerChunkMap.a(this.playerChunkMap).getChunkAt(this.location.x, this.location.z); + + entityplayer.playerConnection.sendPacket(new Packet51MapChunk(chunk, true, 0)); this.b.remove(entityplayer); entityplayer.chunkCoordIntPairQueue.remove(this.location); if (this.b.isEmpty()) { long i = (long) this.location.x + 2147483647L | (long) this.location.z + 2147483647L << 32; + this.a(chunk); PlayerChunkMap.b(this.playerChunkMap).remove(i); + PlayerChunkMap.c(this.playerChunkMap).remove(this); if (this.dirtyCount > 0) { - PlayerChunkMap.c(this.playerChunkMap).remove(this); + PlayerChunkMap.d(this.playerChunkMap).remove(this); } this.playerChunkMap.a().chunkProviderServer.queueUnload(this.location.x, this.location.z); @@ -68,9 +76,18 @@ class PlayerChunk { } } + public void a() { + this.a(PlayerChunkMap.a(this.playerChunkMap).getChunkAt(this.location.x, this.location.z)); + } + + private void a(Chunk chunk) { + chunk.q += PlayerChunkMap.a(this.playerChunkMap).getTime() - this.g; + this.g = PlayerChunkMap.a(this.playerChunkMap).getTime(); + } + public void a(int i, int j, int k) { if (this.dirtyCount == 0) { - PlayerChunkMap.c(this.playerChunkMap).add(this); + PlayerChunkMap.d(this.playerChunkMap).add(this); } this.f |= 1 << (j >> 4); @@ -97,7 +114,7 @@ class PlayerChunk { } } - public void a() { + public void b() { if (this.dirtyCount != 0) { int i; int j; @@ -107,7 +124,7 @@ class PlayerChunk { i = this.location.x * 16 + (this.dirtyBlocks[0] >> 12 & 15); j = this.dirtyBlocks[0] & 255; k = this.location.z * 16 + (this.dirtyBlocks[0] >> 8 & 15); - this.sendAll(new Packet53BlockChange(i, j, k, PlayerChunkMap.a(this.playerChunkMap))); + this.sendAll(new Packet51MapChunk(PlayerChunkMap.a(this.playerChunkMap).getChunkAt(this.location.x, this.location.z), (this.f == 0xFFFF), this.f)); // CraftBukkit - send everything (including biome) if all sections flagged if (PlayerChunkMap.a(this.playerChunkMap).isTileEntity(i, j, k)) { this.sendTileEntity(PlayerChunkMap.a(this.playerChunkMap).getTileEntity(i, j, k)); } @@ -117,7 +134,7 @@ class PlayerChunk { if (this.dirtyCount == 64) { i = this.location.x * 16; j = this.location.z * 16; - this.sendAll(new Packet51MapChunk(PlayerChunkMap.a(this.playerChunkMap).getChunkAt(this.location.x, this.location.z), (this.f == 0xFFFF), this.f)); // CraftBukkit - send everything (including biome) if all sections flagged + this.sendAll(new Packet51MapChunk(PlayerChunkMap.a(this.playerChunkMap).getChunkAt(this.location.x, this.location.z), false, this.f)); for (k = 0; k < 16; ++k) { if ((this.f & 1 << k) != 0) { diff --git a/src/main/java/net/minecraft/server/PlayerChunkMap.java b/src/main/java/net/minecraft/server/PlayerChunkMap.java index 0dfd1907..4e0398c7 100644 --- a/src/main/java/net/minecraft/server/PlayerChunkMap.java +++ b/src/main/java/net/minecraft/server/PlayerChunkMap.java @@ -15,8 +15,10 @@ public class PlayerChunkMap { private final List managedPlayers = new ArrayList(); private final LongHashMap c = new LongHashMap(); private final Queue d = new java.util.concurrent.ConcurrentLinkedQueue(); // CraftBukkit ArrayList -> ConcurrentLinkedQueue - private final int e; - private final int[][] f = new int[][] { { 1, 0}, { 0, 1}, { -1, 0}, { 0, -1}}; + private final Queue e = new java.util.concurrent.ConcurrentLinkedQueue(); // CraftBukkit ArrayList -> ConcurrentLinkedQueue + private final int f; + private long g; + private final int[][] h = new int[][] { { 1, 0}, { 0, 1}, { -1, 0}, { 0, -1}}; private boolean wasNotEmpty; // CraftBukkit public PlayerChunkMap(WorldServer worldserver, int i) { @@ -25,7 +27,7 @@ public class PlayerChunkMap { } else if (i < 3) { throw new IllegalArgumentException("Too small view radius!"); } else { - this.e = i; + this.f = i; this.world = worldserver; } } @@ -35,15 +37,30 @@ public class PlayerChunkMap { } public void flush() { - // CraftBukkit start - Use iterator - java.util.Iterator iterator = this.d.iterator(); + long i = this.world.getTime(); + int j; + PlayerChunk playerchunk; + + if (i - this.g > 8000L) { + this.g = i; + + // CraftBukkit start - Use iterator + java.util.Iterator iterator = this.e.iterator(); + while (iterator.hasNext()) { + playerchunk = (PlayerChunk) iterator.next(); + playerchunk.b(); + playerchunk.a(); + } + } else { + java.util.Iterator iterator = this.d.iterator(); - while (iterator.hasNext()) { - PlayerChunk playerinstance = (PlayerChunk) iterator.next(); - playerinstance.a(); - iterator.remove(); + while (iterator.hasNext()) { + playerchunk = (PlayerChunk) iterator.next(); + playerchunk.b(); + iterator.remove(); + // CraftBukkit end + } } - // CraftBukkit end // this.d.clear(); // CraftBukkit - Removals are already covered if (this.managedPlayers.isEmpty()) { @@ -68,6 +85,7 @@ public class PlayerChunkMap { if (playerchunk == null && flag) { playerchunk = new PlayerChunk(this, i, j); this.c.put(k, playerchunk); + this.e.add(playerchunk); } return playerchunk; @@ -101,8 +119,8 @@ public class PlayerChunkMap { // CraftBukkit start - Load nearby chunks first List<ChunkCoordIntPair> chunkList = new LinkedList<ChunkCoordIntPair>(); - for (int k = i - this.e; k <= i + this.e; ++k) { - for (int l = j - this.e; l <= j + this.e; ++l) { + for (int k = i - this.f; k <= i + this.f; ++k) { + for (int l = j - this.f; l <= j + this.f; ++l) { chunkList.add(new ChunkCoordIntPair(k, l)); } } @@ -120,7 +138,7 @@ public class PlayerChunkMap { public void b(EntityPlayer entityplayer) { ArrayList arraylist = new ArrayList(entityplayer.chunkCoordIntPairQueue); int i = 0; - int j = this.e; + int j = this.f; int k = (int) entityplayer.locX >> 4; int l = (int) entityplayer.locZ >> 4; int i1 = 0; @@ -136,7 +154,7 @@ public class PlayerChunkMap { for (k1 = 1; k1 <= j * 2; ++k1) { for (int l1 = 0; l1 < 2; ++l1) { - int[] aint = this.f[i++ % 4]; + int[] aint = this.h[i++ % 4]; for (int i2 = 0; i2 < k1; ++i2) { i1 += aint[0]; @@ -152,8 +170,8 @@ public class PlayerChunkMap { i %= 4; for (k1 = 0; k1 < j * 2; ++k1) { - i1 += this.f[i][0]; - j1 += this.f[i][1]; + i1 += this.h[i][0]; + j1 += this.h[i][1]; chunkcoordintpair = PlayerChunk.a(this.a(k + i1, l + j1, true)); if (arraylist.contains(chunkcoordintpair)) { entityplayer.chunkCoordIntPairQueue.add(chunkcoordintpair); @@ -165,8 +183,8 @@ public class PlayerChunkMap { int i = (int) entityplayer.d >> 4; int j = (int) entityplayer.e >> 4; - for (int k = i - this.e; k <= i + this.e; ++k) { - for (int l = j - this.e; l <= j + this.e; ++l) { + for (int k = i - this.f; k <= i + this.f; ++k) { + for (int l = j - this.f; l <= j + this.f; ++l) { PlayerChunk playerchunk = this.a(k, l, false); if (playerchunk != null) { @@ -195,7 +213,7 @@ public class PlayerChunkMap { if (d2 >= 64.0D) { int k = (int) entityplayer.d >> 4; int l = (int) entityplayer.e >> 4; - int i1 = this.e; + int i1 = this.f; int j1 = i - k; int k1 = j - l; List<ChunkCoordIntPair> chunksToLoad = new LinkedList<ChunkCoordIntPair>(); // CraftBukkit @@ -254,6 +272,10 @@ public class PlayerChunkMap { } static Queue c(PlayerChunkMap playermanager) { // CraftBukkit List -> Queue + return playermanager.e; + } + + static Queue d(PlayerChunkMap playermanager) { // CraftBukkit List -> Queue return playermanager.d; } diff --git a/src/main/java/net/minecraft/server/PlayerConnection.java b/src/main/java/net/minecraft/server/PlayerConnection.java index 018c314f..f82d932d 100644 --- a/src/main/java/net/minecraft/server/PlayerConnection.java +++ b/src/main/java/net/minecraft/server/PlayerConnection.java @@ -1,6 +1,7 @@ package net.minecraft.server; import java.io.ByteArrayInputStream; +import java.io.DataInput; import java.io.DataInputStream; import java.io.IOException; import java.util.ArrayList; @@ -8,6 +9,8 @@ import java.util.Iterator; import java.util.Random; import java.util.concurrent.Callable; +import org.apache.commons.lang3.StringUtils; + // CraftBukkit start import java.io.UnsupportedEncodingException; import java.util.concurrent.ExecutionException; @@ -54,7 +57,7 @@ public class PlayerConnection extends Connection { public final INetworkManager networkManager; private final MinecraftServer minecraftServer; - public boolean disconnected = false; + public boolean disconnected; public EntityPlayer player; private int e; private int f; @@ -63,7 +66,7 @@ public class PlayerConnection extends Connection { private long i; private static Random j = new Random(); private long k; - private volatile int chatThrottle = 0; private static final AtomicIntegerFieldUpdater chatSpamField = AtomicIntegerFieldUpdater.newUpdater(PlayerConnection.class, "chatThrottle"); // CraftBukkit - multithreaded field + private volatile int chatThrottle; private static final AtomicIntegerFieldUpdater chatSpamField = AtomicIntegerFieldUpdater.newUpdater(PlayerConnection.class, "chatThrottle"); // CraftBukkit - multithreaded field private int x = 0; private double y; private double z; @@ -141,7 +144,7 @@ public class PlayerConnection extends Connection { public void disconnect(String s) { if (!this.disconnected) { // CraftBukkit start - String leaveMessage = EnumChatFormat.YELLOW + this.player.name + " left the game."; + String leaveMessage = EnumChatFormat.YELLOW + this.player.getName() + " left the game."; PlayerKickEvent event = new PlayerKickEvent(this.server.getPlayer(this.player), s, leaveMessage); @@ -157,14 +160,14 @@ public class PlayerConnection extends Connection { s = event.getReason(); // CraftBukkit end - this.player.k(); + this.player.l(); this.sendPacket(new Packet255KickDisconnect(s)); this.networkManager.d(); // CraftBukkit start leaveMessage = event.getLeaveMessage(); if (leaveMessage != null && leaveMessage.length() > 0) { - this.minecraftServer.getPlayerList().sendAll(new Packet3Chat(leaveMessage)); + this.minecraftServer.getPlayerList().sendMessage(ChatMessage.d(leaveMessage)); } // CraftBukkit end @@ -173,6 +176,10 @@ public class PlayerConnection extends Connection { } } + public void a(Packet27PlayerInput packet27playerinput) { + this.player.a(packet27playerinput.d(), packet27playerinput.f(), packet27playerinput.g(), packet27playerinput.h()); + } + public void a(Packet10Flying packet10flying) { WorldServer worldserver = this.minecraftServer.getWorldServer(this.player.dimension); @@ -276,7 +283,7 @@ public class PlayerConnection extends Connection { if (packet10flying.hasPos && packet10flying.y == -999.0D && packet10flying.stance == -999.0D) { if (Math.abs(packet10flying.x) > 1.0D || Math.abs(packet10flying.z) > 1.0D) { - System.err.println(this.player.name + " was caught trying to crash the server with an invalid position."); + System.err.println(this.player.getName() + " was caught trying to crash the server with an invalid position."); this.disconnect("Nope!"); return; } @@ -286,13 +293,13 @@ public class PlayerConnection extends Connection { } this.player.onGround = packet10flying.g; - this.player.g(); + this.player.h(); this.player.move(d5, 0.0D, d4); this.player.setLocation(d1, d2, d3, f, f1); this.player.motX = d5; this.player.motZ = d4; if (this.player.vehicle != null) { - worldserver.vehicleEnteredWorld(this.player.vehicle, true); + // worldserver.vehicleEnteredWorld(this.player.vehicle, true); // CraftBukkit - removed } if (this.player.vehicle != null) { @@ -300,15 +307,18 @@ public class PlayerConnection extends Connection { } this.minecraftServer.getPlayerList().d(this.player); - this.y = this.player.locX; - this.z = this.player.locY; - this.p = this.player.locZ; + if (this.checkMovement) { + this.y = this.player.locX; + this.z = this.player.locY; + this.p = this.player.locZ; + } + worldserver.playerJoinedWorld(this.player); return; } if (this.player.isSleeping()) { - this.player.g(); + this.player.h(); this.player.setLocation(this.y, this.z, this.p, this.player.yaw, this.player.pitch); worldserver.playerJoinedWorld(this.player); return; @@ -335,7 +345,7 @@ public class PlayerConnection extends Connection { d4 = packet10flying.stance - packet10flying.y; if (!this.player.isSleeping() && (d4 > 1.65D || d4 < 0.1D)) { this.disconnect("Illegal stance"); - this.minecraftServer.getLogger().warning(this.player.name + " had an illegal stance: " + d4); + this.minecraftServer.getLogger().warning(this.player.getName() + " had an illegal stance: " + d4); return; } @@ -351,7 +361,7 @@ public class PlayerConnection extends Connection { f3 = packet10flying.pitch; } - this.player.g(); + this.player.h(); this.player.X = 0.0F; this.player.setLocation(this.y, this.z, this.p, f2, f3); if (!this.checkMovement) { @@ -368,8 +378,8 @@ public class PlayerConnection extends Connection { // CraftBukkit end double d11 = d8 * d8 + d9 * d9 + d10 * d10; - if (d11 > 100.0D && this.checkMovement && (!this.minecraftServer.I() || !this.minecraftServer.H().equals(this.player.name))) { // CraftBukkit - Added this.checkMovement condition to solve this check being triggered by teleports - this.minecraftServer.getLogger().warning(this.player.name + " moved too quickly! " + d4 + "," + d6 + "," + d7 + " (" + d8 + ", " + d9 + ", " + d10 + ")"); + if (d11 > 100.0D && this.checkMovement && (!this.minecraftServer.K() || !this.minecraftServer.H().equals(this.player.getName()))) { // CraftBukkit - Added this.checkMovement condition to solve this check being triggered by teleports + this.minecraftServer.getLogger().warning(this.player.getName() + " moved too quickly! " + d4 + "," + d6 + "," + d7 + " (" + d8 + ", " + d9 + ", " + d10 + ")"); this.a(this.y, this.z, this.p, this.player.yaw, this.player.pitch); return; } @@ -378,7 +388,7 @@ public class PlayerConnection extends Connection { boolean flag = worldserver.getCubes(this.player, this.player.boundingBox.clone().shrink((double) f4, (double) f4, (double) f4)).isEmpty(); if (this.player.onGround && !packet10flying.g && d6 > 0.0D) { - this.player.j(0.2F); + this.player.a(0.2F); } this.player.move(d4, d6, d7); @@ -398,7 +408,7 @@ public class PlayerConnection extends Connection { if (d11 > 0.0625D && !this.player.isSleeping() && !this.player.playerInteractManager.isCreative()) { flag1 = true; - this.minecraftServer.getLogger().warning(this.player.name + " moved wrongly!"); + this.minecraftServer.getLogger().warning(this.player.getName() + " moved wrongly!"); } this.player.setLocation(d1, d2, d3, f2, f3); @@ -415,7 +425,7 @@ public class PlayerConnection extends Connection { if (d12 >= -0.03125D) { ++this.f; if (this.f > 80) { - this.minecraftServer.getLogger().warning(this.player.name + " was kicked for floating too long!"); + this.minecraftServer.getLogger().warning(this.player.getName() + " was kicked for floating too long!"); this.disconnect("Flying is not enabled on this server"); return; } @@ -428,6 +438,8 @@ public class PlayerConnection extends Connection { this.minecraftServer.getPlayerList().d(this.player); if (this.player.playerInteractManager.isCreative()) return; // CraftBukkit - fixed fall distance accumulating while being in Creative mode. this.player.b(this.player.locY - d0, packet10flying.g); + } else if (this.e % 20 == 0) { + this.a(this.y, this.z, this.p, this.player.yaw, this.player.pitch); } } } @@ -496,7 +508,7 @@ public class PlayerConnection extends Connection { // Else we increment the drop count and check the amount. this.dropCount++; if (this.dropCount >= 20) { - this.minecraftServer.getLogger().warning(this.player.name + " dropped their items too quickly!"); + this.minecraftServer.getLogger().warning(this.player.getName() + " dropped their items too quickly!"); this.disconnect("You dropped your items too quickly (Hacking?)"); return; } @@ -506,7 +518,7 @@ public class PlayerConnection extends Connection { } else if (packet14blockdig.e == 3) { this.player.a(true); } else if (packet14blockdig.e == 5) { - this.player.bZ(); + this.player.bo(); } else { boolean flag = false; @@ -625,7 +637,7 @@ public class PlayerConnection extends Connection { always = (itemstack.count != itemstackAmount); // CraftBukkit end } else if (packet15place.f() >= this.minecraftServer.getMaxBuildHeight() - 1 && (packet15place.getFace() == 1 || packet15place.f() >= this.minecraftServer.getMaxBuildHeight())) { - this.player.playerConnection.sendPacket(new Packet3Chat("" + EnumChatFormat.GRAY + "Height limit for building is " + this.minecraftServer.getMaxBuildHeight())); + this.player.playerConnection.sendPacket(new Packet3Chat(ChatMessage.b("build.tooHigh", new Object[] { Integer.valueOf(this.minecraftServer.getMaxBuildHeight())}).a(EnumChatFormat.RED))); flag = true; } else { // CraftBukkit start - Check if we can actually do something over this large a distance @@ -692,15 +704,15 @@ public class PlayerConnection extends Connection { public void a(String s, Object[] aobject) { if (this.disconnected) return; // CraftBukkit - Rarely it would send a disconnect line twice - this.minecraftServer.getLogger().info(this.player.name + " lost connection: " + s); + this.minecraftServer.getLogger().info(this.player.getName() + " lost connection: " + s); // CraftBukkit start - We need to handle custom quit messages String quitMessage = this.minecraftServer.getPlayerList().disconnect(this.player); if ((quitMessage != null) && (quitMessage.length() > 0)) { - this.minecraftServer.getPlayerList().sendAll(new Packet3Chat(quitMessage)); + this.minecraftServer.getPlayerList().sendMessage(ChatMessage.d(quitMessage)); } // CraftBukkit end this.disconnected = true; - if (this.minecraftServer.I() && this.player.name.equals(this.minecraftServer.H())) { + if (this.minecraftServer.K() && this.player.getName().equals(this.minecraftServer.J())) { this.minecraftServer.getLogger().info("Stopping singleplayer server as player logged out"); this.minecraftServer.safeShutdown(); } @@ -770,14 +782,14 @@ public class PlayerConnection extends Connection { this.player.inventory.itemInHandIndex = packet16blockitemswitch.itemInHandIndex; } else { - this.minecraftServer.getLogger().warning(this.player.name + " tried to set an invalid carried item"); + this.minecraftServer.getLogger().warning(this.player.getName() + " tried to set an invalid carried item"); this.disconnect("Nope!"); // CraftBukkit } } public void a(Packet3Chat packet3chat) { if (this.player.getChatFlags() == 2) { - this.sendPacket(new Packet3Chat("Cannot send chat message.")); + this.sendPacket(new Packet3Chat(ChatMessage.e("chat.cannotSend").a(EnumChatFormat.RED))); } else { String s = packet3chat.message; @@ -806,7 +818,7 @@ public class PlayerConnection extends Connection { } // CraftBukkit end } else { - s = s.trim(); + s = StringUtils.normalizeSpace(s); for (int i = 0; i < s.length(); ++i) { if (!SharedConstants.isAllowedChatCharacter(s.charAt(i))) { @@ -846,7 +858,7 @@ public class PlayerConnection extends Connection { this.chat(s, packet3chat.a_()); // This section stays because it is only applicable to packets - if (chatSpamField.addAndGet(this, 20) > 200 && !this.minecraftServer.getPlayerList().isOp(this.player.name)) { // CraftBukkit use thread-safe spam + if (chatSpamField.addAndGet(this, 20) > 200 && !this.minecraftServer.getPlayerList().isOp(this.player.getName())) { // CraftBukkit use thread-safe spam if (packet3chat.a_()) { Waitable waitable = new Waitable() { @Override @@ -876,7 +888,7 @@ public class PlayerConnection extends Connection { public void chat(String s, boolean async) { if (!this.player.dead) { if (s.length() == 0) { - this.minecraftServer.getLogger().warning(this.player.name + " tried to send an empty message"); + this.minecraftServer.getLogger().warning(this.player.getName() + " tried to send an empty message"); return; } @@ -910,7 +922,7 @@ public class PlayerConnection extends Connection { PlayerConnection.this.minecraftServer.console.sendMessage(message); if (((LazyPlayerSet) queueEvent.getRecipients()).isLazy()) { for (Object player : PlayerConnection.this.minecraftServer.getPlayerList().players) { - ((EntityPlayer) player).sendMessage(message); + ((EntityPlayer) player).sendMessage(ChatMessage.d(message)); } } else { for (Player player : queueEvent.getRecipients()) { @@ -940,7 +952,7 @@ public class PlayerConnection extends Connection { minecraftServer.console.sendMessage(s); if (((LazyPlayerSet) event.getRecipients()).isLazy()) { for (Object recipient : minecraftServer.getPlayerList().players) { - ((EntityPlayer) recipient).sendMessage(s); + ((EntityPlayer) recipient).sendMessage(ChatMessage.d(s)); } } else { for (Player recipient : event.getRecipients()) { @@ -1017,7 +1029,7 @@ public class PlayerConnection extends Connection { if (event.isCancelled()) return; // CraftBukkit end - this.player.bK(); + this.player.aR(); } } @@ -1055,6 +1067,12 @@ public class PlayerConnection extends Connection { } else if (packet19entityaction.animation == 3) { this.player.a(false, true, true); // this.checkMovement = false; // CraftBukkit - this is handled in teleport + } else if (packet19entityaction.animation == 6) { + if (this.player.vehicle != null && this.player.vehicle instanceof EntityHorse) { + ((EntityHorse) this.player.vehicle).u(packet19entityaction.c); + } + } else if (packet19entityaction.animation == 7 && this.player.vehicle != null && this.player.vehicle instanceof EntityHorse) { + ((EntityHorse) this.player.vehicle).f(this.player); } } @@ -1073,7 +1091,7 @@ public class PlayerConnection extends Connection { Entity entity = worldserver.getEntity(packet7useentity.target); if (entity != null) { - boolean flag = this.player.n(entity); + boolean flag = this.player.o(entity); double d0 = 36.0D; if (!flag) { @@ -1097,10 +1115,11 @@ public class PlayerConnection extends Connection { this.player.updateInventory(this.player.activeContainer); } } else if (packet7useentity.action == 1) { - if ((entity instanceof EntityItem) || (entity instanceof EntityExperienceOrb) || (entity instanceof EntityArrow)) { + // CraftBukkit - Check for player + if ((entity instanceof EntityItem) || (entity instanceof EntityExperienceOrb) || (entity instanceof EntityArrow) || (entity == this.player)) { String type = entity.getClass().getSimpleName(); disconnect("Attacking an " + type + " is not permitted"); - System.out.println("Player " + player.name + " tried to attack an " + type + ", so I have disconnected them for exploiting."); + System.out.println("Player " + player.getName() + " tried to attack an " + type + ", so I have disconnected them for exploiting."); return; } @@ -1119,19 +1138,19 @@ public class PlayerConnection extends Connection { if (packet205clientcommand.a == 1) { if (this.player.viewingCredits) { this.minecraftServer.getPlayerList().changeDimension(this.player, 0, PlayerTeleportEvent.TeleportCause.END_PORTAL); // CraftBukkit - reroute logic through custom portal management - } else if (this.player.o().getWorldData().isHardcore()) { - if (this.minecraftServer.I() && this.player.name.equals(this.minecraftServer.H())) { + } else if (this.player.p().getWorldData().isHardcore()) { + if (this.minecraftServer.K() && this.player.getName().equals(this.minecraftServer.J())) { this.player.playerConnection.disconnect("You have died. Game over, man, it\'s game over!"); - this.minecraftServer.P(); + this.minecraftServer.R(); } else { - BanEntry banentry = new BanEntry(this.player.name); + BanEntry banentry = new BanEntry(this.player.getName()); banentry.setReason("Death in Hardcore"); this.minecraftServer.getPlayerList().getNameBans().add(banentry); this.player.playerConnection.disconnect("You have died. Game over, man, it\'s game over!"); } } else { - if (this.player.getHealth() > 0) { + if (this.player.getHealth() > 0.0F) { return; } @@ -1151,7 +1170,7 @@ public class PlayerConnection extends Connection { CraftEventFactory.handleInventoryCloseEvent(this.player); // CraftBukkit - this.player.j(); + this.player.k(); } public void a(Packet102WindowClick packet102windowclick) { @@ -1240,7 +1259,7 @@ public class PlayerConnection extends Connection { action = InventoryAction.NOTHING; } else { Slot slot = this.player.activeContainer.getSlot(packet102windowclick.slot); - if (slot != null && slot.a(this.player) && slot.d()) { // Should be Slot.hasItem() + if (slot != null && slot.a(this.player) && slot.e()) { // Should be Slot.hasItem() action = InventoryAction.MOVE_TO_OTHER_INVENTORY; } else { action = InventoryAction.NOTHING; @@ -1254,7 +1273,7 @@ public class PlayerConnection extends Connection { if (clickedSlot.a(player)) { ItemStack hotbar = this.player.inventory.getItem(packet102windowclick.button); boolean canCleanSwap = hotbar == null || (clickedSlot.inventory == player.inventory && clickedSlot.isAllowed(hotbar)); // the slot will accept the hotbar item - if (clickedSlot.d()) { + if (clickedSlot.e()) { if (canCleanSwap) { action = InventoryAction.HOTBAR_SWAP; } else { @@ -1265,7 +1284,7 @@ public class PlayerConnection extends Connection { action = InventoryAction.NOTHING; // This is not sane! Mojang: You should test for other slots of same type } } - } else if (!clickedSlot.d() && hotbar != null && clickedSlot.isAllowed(hotbar)) { + } else if (!clickedSlot.e() && hotbar != null && clickedSlot.isAllowed(hotbar)) { action = InventoryAction.HOTBAR_SWAP; } else { action = InventoryAction.NOTHING; @@ -1283,7 +1302,7 @@ public class PlayerConnection extends Connection { action = InventoryAction.NOTHING; } else { Slot slot = this.player.activeContainer.getSlot(packet102windowclick.slot); - if (slot != null && slot.d() && player.abilities.canInstantlyBuild && player.inventory.getCarried() == null) { + if (slot != null && slot.e() && player.abilities.canInstantlyBuild && player.inventory.getCarried() == null) { action = InventoryAction.CLONE_STACK; } else { action = InventoryAction.NOTHING; @@ -1298,7 +1317,7 @@ public class PlayerConnection extends Connection { if (packet102windowclick.button == 0) { click = ClickType.DROP; Slot slot = this.player.activeContainer.getSlot(packet102windowclick.slot); - if (slot != null && slot.d() && slot.a(player) && slot.getItem() != null && slot.getItem().id != 0) { + if (slot != null && slot.e() && slot.a(player) && slot.getItem() != null && slot.getItem().id != 0) { action = InventoryAction.DROP_ONE_SLOT; } else { action = InventoryAction.NOTHING; @@ -1306,7 +1325,7 @@ public class PlayerConnection extends Connection { } else if (packet102windowclick.button == 1) { click = ClickType.CONTROL_DROP; Slot slot = this.player.activeContainer.getSlot(packet102windowclick.slot); - if (slot != null && slot.d() && slot.a(player) && slot.getItem() != null && slot.getItem().id != 0) { + if (slot != null && slot.e() && slot.a(player) && slot.getItem() != null && slot.getItem().id != 0) { action = InventoryAction.DROP_ALL_SLOT; } else { action = InventoryAction.NOTHING; @@ -1538,7 +1557,7 @@ public class PlayerConnection extends Connection { TileEntitySign tileentitysign = (TileEntitySign) tileentity; if (!tileentitysign.a()) { - this.minecraftServer.warning("Player " + this.player.name + " just tried to change non-editable sign"); + this.minecraftServer.warning("Player " + this.player.getName() + " just tried to change non-editable sign"); this.sendPacket(new Packet130UpdateSign(packet130updatesign.x, packet130updatesign.y, packet130updatesign.z, tileentitysign.lines)); // CraftBukkit return; } @@ -1626,7 +1645,7 @@ public class PlayerConnection extends Connection { String s; - for (Iterator iterator = this.minecraftServer.a((ICommandListener) this.player, packet203tabcomplete.d()).iterator(); iterator.hasNext(); stringbuilder.append(s)) { + for (Iterator iterator = this.minecraftServer.a(this.player, packet203tabcomplete.d()).iterator(); iterator.hasNext(); stringbuilder.append(s)) { s = (String) iterator.next(); if (stringbuilder.length() > 0) { stringbuilder.append('\0'); // CraftBukkit - fix decompile issue @@ -1665,7 +1684,7 @@ public class PlayerConnection extends Connection { } // CraftBukkit start } catch (Throwable exception) { - this.minecraftServer.getLogger().warning(this.player.name + " sent invalid MC|BEdit data", exception); + this.minecraftServer.getLogger().warning(this.player.getName() + " sent invalid MC|BEdit data", exception); this.disconnect("Invalid book data!"); // CraftBukkit end } @@ -1683,7 +1702,7 @@ public class PlayerConnection extends Connection { } // CraftBukkit start } catch (Throwable exception1) { - this.minecraftServer.getLogger().warning(this.player.name + " sent invalid MC|BSign data", exception1); + this.minecraftServer.getLogger().warning(this.player.getName() + " sent invalid MC|BSign data", exception1); this.disconnect("Invalid book data!"); // CraftBukkit end } @@ -1701,7 +1720,7 @@ public class PlayerConnection extends Connection { } } catch (Exception exception2) { // CraftBukkit start - this.minecraftServer.getLogger().warning(this.player.name + " sent invalid MC|TrSel data", exception2); + this.minecraftServer.getLogger().warning(this.player.getName() + " sent invalid MC|TrSel data", exception2); this.disconnect("Invalid trade data!"); // CraftBukkit end } @@ -1710,29 +1729,29 @@ public class PlayerConnection extends Connection { if ("MC|AdvCdm".equals(packet250custompayload.tag)) { if (!this.minecraftServer.getEnableCommandBlock()) { - this.player.sendMessage(this.player.a("advMode.notEnabled", new Object[0])); + this.player.sendMessage(ChatMessage.e("advMode.notEnabled")); } else if (this.player.a(2, "") && this.player.abilities.canInstantlyBuild) { try { datainputstream = new DataInputStream(new ByteArrayInputStream(packet250custompayload.data)); i = datainputstream.readInt(); j = datainputstream.readInt(); int k = datainputstream.readInt(); - String s = Packet.a(datainputstream, 256); + String s = Packet.a((DataInput) datainputstream, 256); TileEntity tileentity = this.player.world.getTileEntity(i, j, k); if (tileentity != null && tileentity instanceof TileEntityCommand) { - ((TileEntityCommand) tileentity).b(s); + ((TileEntityCommand) tileentity).a(s); this.player.world.notify(i, j, k); - this.player.sendMessage("Command set: " + s); + this.player.sendMessage(ChatMessage.b("advMode.setCommand.success", new Object[] { s})); } } catch (Exception exception3) { // CraftBukkit start - this.minecraftServer.getLogger().warning(this.player.name + " sent invalid MC|AdvCdm data", exception3); + this.minecraftServer.getLogger().warning(this.player.getName() + " sent invalid MC|AdvCdm data", exception3); this.disconnect("Invalid CommandBlock data!"); // CraftBukkit end } } else { - this.player.sendMessage(this.player.a("advMode.notAllowed", new Object[0])); + this.player.sendMessage(ChatMessage.e("advMode.notAllowed")); } } else if ("MC|Beacon".equals(packet250custompayload.tag)) { if (this.player.activeContainer instanceof ContainerBeacon) { @@ -1743,7 +1762,7 @@ public class PlayerConnection extends Connection { ContainerBeacon containerbeacon = (ContainerBeacon) this.player.activeContainer; Slot slot = containerbeacon.getSlot(0); - if (slot.d()) { + if (slot.e()) { slot.a(1); TileEntityBeacon tileentitybeacon = containerbeacon.e(); @@ -1753,7 +1772,7 @@ public class PlayerConnection extends Connection { } } catch (Exception exception4) { // CraftBukkit start - this.minecraftServer.getLogger().warning(this.player.name + " sent invalid MC|Beacon data", exception4); + this.minecraftServer.getLogger().warning(this.player.getName() + " sent invalid MC|Beacon data", exception4); this.disconnect("Invalid beacon data!"); // CraftBukkit end } diff --git a/src/main/java/net/minecraft/server/PlayerInteractManager.java b/src/main/java/net/minecraft/server/PlayerInteractManager.java index 1243d1d0..d77a4cc1 100644 --- a/src/main/java/net/minecraft/server/PlayerInteractManager.java +++ b/src/main/java/net/minecraft/server/PlayerInteractManager.java @@ -107,7 +107,7 @@ public class PlayerInteractManager { // CraftBukkit PlayerInteractEvent event = CraftEventFactory.callPlayerInteractEvent(this.player, Action.LEFT_CLICK_BLOCK, i, j, k, l, this.player.inventory.getItemInHand()); - if (!this.gamemode.isAdventure() || this.player.e(i, j, k)) { + if (!this.gamemode.isAdventure() || this.player.d(i, j, k)) { // CraftBukkit start if (event.isCancelled()) { // Let the client know the block still exists @@ -258,7 +258,10 @@ public class PlayerInteractManager { event = new BlockBreakEvent(block, this.player.getBukkitEntity()); // Adventure mode pre-cancel - event.setCancelled(this.gamemode.isAdventure() && !this.player.e(i, j, k)); + event.setCancelled(this.gamemode.isAdventure() && !this.player.d(i, j, k)); + + // Sword + Creative mode pre-cancel + event.setCancelled(event.isCancelled() || (this.gamemode.d() && this.player.aV() != null && this.player.aV().getItem() instanceof ItemSword)); // Calculate default block experience Block nmsBlock = Block.byId[block.getTypeId()]; @@ -308,13 +311,13 @@ public class PlayerInteractManager { if (this.isCreative()) { this.player.playerConnection.sendPacket(new Packet53BlockChange(i, j, k, this.world)); } else { - ItemStack itemstack = this.player.cd(); + ItemStack itemstack = this.player.bt(); boolean flag1 = this.player.a(Block.byId[l]); if (itemstack != null) { itemstack.a(this.world, l, i, j, k, this.player); if (itemstack.count == 0) { - this.player.ce(); + this.player.bu(); } } @@ -353,7 +356,7 @@ public class PlayerInteractManager { entityhuman.inventory.items[entityhuman.inventory.itemInHandIndex] = null; } - if (!entityhuman.bX()) { + if (!entityhuman.bm()) { ((EntityPlayer) entityhuman).updateInventory(entityhuman.defaultContainer); } diff --git a/src/main/java/net/minecraft/server/PlayerInventory.java b/src/main/java/net/minecraft/server/PlayerInventory.java index 7bf2c6f3..7cf491aa 100644 --- a/src/main/java/net/minecraft/server/PlayerInventory.java +++ b/src/main/java/net/minecraft/server/PlayerInventory.java @@ -13,10 +13,10 @@ public class PlayerInventory implements IInventory { public ItemStack[] items = new ItemStack[36]; public ItemStack[] armor = new ItemStack[4]; - public int itemInHandIndex = 0; + public int itemInHandIndex; public EntityHuman player; private ItemStack g; - public boolean e = false; + public boolean e; // CraftBukkit start public List<HumanEntity> transaction = new java.util.ArrayList<HumanEntity>(); @@ -63,7 +63,7 @@ public class PlayerInventory implements IInventory { return 9; } - private int h(int i) { + private int g(int i) { for (int j = 0; j < this.items.length; ++j) { if (this.items[j] != null && this.items[j].id == i) { return j; @@ -131,6 +131,19 @@ public class PlayerInventory implements IInventory { } } + if (this.g != null) { + if (i > -1 && this.g.id != i) { + return k; + } + + if (j > -1 && this.g.getData() != j) { + return k; + } + + k += this.g.count; + this.setCarried((ItemStack) null); + } + return k; } @@ -181,7 +194,7 @@ public class PlayerInventory implements IInventory { } else { j -= l; this.items[k].count += l; - this.items[k].b = 5; + this.items[k].c = 5; return j; } } @@ -197,7 +210,7 @@ public class PlayerInventory implements IInventory { } public boolean d(int i) { - int j = this.h(i); + int j = this.g(i); if (j < 0) { return false; @@ -211,7 +224,7 @@ public class PlayerInventory implements IInventory { } public boolean e(int i) { - int j = this.h(i); + int j = this.g(i); return j >= 0; } @@ -219,6 +232,8 @@ public class PlayerInventory implements IInventory { public boolean pickup(ItemStack itemstack) { if (itemstack == null) { return false; + } else if (itemstack.count == 0) { + return false; } else { try { int i; @@ -227,7 +242,7 @@ public class PlayerInventory implements IInventory { i = this.j(); if (i >= 0) { this.items[i] = ItemStack.b(itemstack); - this.items[i].b = 5; + this.items[i].c = 5; itemstack.count = 0; return true; } else if (this.player.abilities.canInstantlyBuild) { @@ -401,12 +416,6 @@ public class PlayerInventory implements IInventory { return maxStack; } - public int a(Entity entity) { - ItemStack itemstack = this.getItem(this.itemInHandIndex); - - return itemstack != null ? itemstack.a(entity) : 1; - } - public boolean b(Block block) { if (block.material.isAlwaysDestroyable()) { return true; @@ -435,17 +444,17 @@ public class PlayerInventory implements IInventory { return i; } - public void g(int i) { - i /= 4; - if (i < 1) { - i = 1; + public void a(float f) { + f /= 4.0F; + if (f < 1.0F) { + f = 1.0F; } - for (int j = 0; j < this.armor.length; ++j) { - if (this.armor[j] != null && this.armor[j].getItem() instanceof ItemArmor) { - this.armor[j].damage(i, this.player); - if (this.armor[j].count == 0) { - this.armor[j] = null; + for (int i = 0; i < this.armor.length; ++i) { + if (this.armor[i] != null && this.armor[i].getItem() instanceof ItemArmor) { + this.armor[i].damage((int) f, this.player); + if (this.armor[i].count == 0) { + this.armor[i] = null; } } } diff --git a/src/main/java/net/minecraft/server/PlayerList.java b/src/main/java/net/minecraft/server/PlayerList.java index b7e327bc..b98a0787 100644 --- a/src/main/java/net/minecraft/server/PlayerList.java +++ b/src/main/java/net/minecraft/server/PlayerList.java @@ -46,7 +46,7 @@ public abstract class PlayerList { protected int c; private EnumGamemode l; private boolean m; - private int n = 0; + private int n; // CraftBukkit start private CraftServer cserver; @@ -75,7 +75,7 @@ public abstract class PlayerList { } // CraftBukkit - add world and location to 'logged in' message. - this.server.getLogger().info(entityplayer.name + "[" + s + "] logged in with entity id " + entityplayer.id + " at ([" + entityplayer.world.worldData.getName() + "] " + entityplayer.locX + ", " + entityplayer.locY + ", " + entityplayer.locZ + ")"); + this.server.getLogger().info(entityplayer.getName() + "[" + s + "] logged in with entity id " + entityplayer.id + " at ([" + entityplayer.world.worldData.getName() + "] " + entityplayer.locX + ", " + entityplayer.locY + ", " + entityplayer.locZ + ")"); WorldServer worldserver = this.server.getWorldServer(entityplayer.dimension); ChunkCoordinates chunkcoordinates = worldserver.getSpawn(); @@ -96,13 +96,13 @@ public abstract class PlayerList { playerconnection.sendPacket(new Packet16BlockItemSwitch(entityplayer.inventory.itemInHandIndex)); this.a((ScoreboardServer) worldserver.getScoreboard(), entityplayer); this.b(entityplayer, worldserver); - // this.sendAll(new Packet3Chat(EnumChatFormat.YELLOW + entityplayer.getScoreboardDisplayName() + EnumChatFormat.YELLOW + " joined the game.")); // CraftBukkit - handled in event + // this.sendMessage(ChatMessage.b("multiplayer.player.joined", new Object[] { entityplayer.getScoreboardDisplayName()}).a(EnumChatFormat.YELLOW)); // CraftBukkit - handled in event this.c(entityplayer); playerconnection.a(entityplayer.locX, entityplayer.locY, entityplayer.locZ, entityplayer.yaw, entityplayer.pitch); - this.server.ae().a(playerconnection); - playerconnection.sendPacket(new Packet4UpdateTime(worldserver.getTime(), worldserver.getDayTime())); + this.server.ag().a(playerconnection); + playerconnection.sendPacket(new Packet4UpdateTime(worldserver.getTime(), worldserver.getDayTime(), worldserver.getGameRules().getBoolean("doDaylightCycle"))); if (this.server.getTexturePack().length() > 0) { - entityplayer.a(this.server.getTexturePack(), this.server.S()); + entityplayer.a(this.server.getTexturePack(), this.server.U()); } Iterator iterator = entityplayer.getEffects().iterator(); @@ -160,7 +160,7 @@ public abstract class PlayerList { } public void a(EntityPlayer entityplayer, WorldServer worldserver) { - WorldServer worldserver1 = entityplayer.o(); + WorldServer worldserver1 = entityplayer.p(); if (worldserver != null) { worldserver.getPlayerChunkMap().removePlayer(entityplayer); @@ -178,7 +178,7 @@ public abstract class PlayerList { NBTTagCompound nbttagcompound = this.server.worlds.get(0).getWorldData().i(); // CraftBukkit NBTTagCompound nbttagcompound1; - if (entityplayer.getName().equals(this.server.H()) && nbttagcompound != null) { + if (entityplayer.getName().equals(this.server.J()) && nbttagcompound != null) { entityplayer.f(nbttagcompound); nbttagcompound1 = nbttagcompound; System.out.println("loading single player"); @@ -195,7 +195,7 @@ public abstract class PlayerList { public void c(EntityPlayer entityplayer) { cserver.detectListNameConflict(entityplayer); // CraftBukkit - // this.sendAll(new Packet201PlayerInfo(entityplayer.name, true, 1000)); // CraftBukkit - replaced with loop below + // this.sendAll(new Packet201PlayerInfo(entityplayer.getName(), true, 1000)); // CraftBukkit - replaced with loop below this.players.add(entityplayer); WorldServer worldserver = this.server.getWorldServer(entityplayer.dimension); @@ -206,7 +206,7 @@ public abstract class PlayerList { String joinMessage = playerJoinEvent.getJoinMessage(); if ((joinMessage != null) && (joinMessage.length() > 0)) { - this.server.getPlayerList().sendAll(new Packet3Chat(joinMessage)); + this.server.getPlayerList().sendAll(new Packet3Chat(ChatMessage.d(joinMessage))); } this.cserver.onPlayerJoin(playerJoinEvent.getPlayer()); @@ -243,7 +243,7 @@ public abstract class PlayerList { } public void d(EntityPlayer entityplayer) { - entityplayer.o().getPlayerChunkMap().movePlayer(entityplayer); + entityplayer.p().getPlayerChunkMap().movePlayer(entityplayer); } public String disconnect(EntityPlayer entityplayer) { // CraftBukkit - return string @@ -258,10 +258,10 @@ public abstract class PlayerList { // CraftBukkit end this.b(entityplayer); - WorldServer worldserver = entityplayer.o(); + WorldServer worldserver = entityplayer.p(); if (entityplayer.vehicle != null) { - worldserver.kill(entityplayer.vehicle); + worldserver.removeEntity(entityplayer.vehicle); System.out.println("removing player mount"); } @@ -291,7 +291,7 @@ public abstract class PlayerList { // Instead of kicking then returning, we need to store the kick reason // in the event, check with plugins to see if it's ok, and THEN kick // depending on the outcome. - EntityPlayer entity = new EntityPlayer(this.server, this.server.getWorldServer(0), s, this.server.M() ? new DemoPlayerInteractManager(this.server.getWorldServer(0)) : new PlayerInteractManager(this.server.getWorldServer(0))); + EntityPlayer entity = new EntityPlayer(this.server, this.server.getWorldServer(0), s, this.server.O() ? new DemoPlayerInteractManager(this.server.getWorldServer(0)) : new PlayerInteractManager(this.server.getWorldServer(0))); Player player = entity.getBukkitEntity(); PlayerLoginEvent event = new PlayerLoginEvent(player, hostname, pendingconnection.getSocket().getInetAddress()); @@ -347,7 +347,7 @@ public abstract class PlayerList { for (int i = 0; i < this.players.size(); ++i) { entityplayer = (EntityPlayer) this.players.get(i); - if (entityplayer.name.equalsIgnoreCase(s)) { + if (entityplayer.getName().equalsIgnoreCase(s)) { arraylist.add(entityplayer); } } @@ -362,7 +362,7 @@ public abstract class PlayerList { /* CraftBukkit start Object object; - if (this.server.M()) { + if (this.server.O()) { object = new DemoPlayerInteractManager(this.server.getWorldServer(0)); } else { object = new PlayerInteractManager(this.server.getWorldServer(0)); @@ -381,9 +381,9 @@ public abstract class PlayerList { public EntityPlayer moveToWorld(EntityPlayer entityplayer, int i, boolean flag, Location location, boolean avoidSuffocation) { // CraftBukkit end - entityplayer.o().getTracker().untrackPlayer(entityplayer); - // entityplayer.o().getTracker().untrackEntity(entityplayer); // CraftBukkit - entityplayer.o().getPlayerChunkMap().removePlayer(entityplayer); + entityplayer.p().getTracker().untrackPlayer(entityplayer); + // entityplayer.p().getTracker().untrackEntity(entityplayer); // CraftBukkit + entityplayer.p().getPlayerChunkMap().removePlayer(entityplayer); this.players.remove(entityplayer); this.server.getWorldServer(entityplayer.dimension).removeEntity(entityplayer); ChunkCoordinates chunkcoordinates = entityplayer.getBed(); @@ -714,7 +714,7 @@ public abstract class PlayerList { if (this.n < this.players.size()) { EntityPlayer entityplayer = (EntityPlayer) this.players.get(this.n); - this.sendAll(new Packet201PlayerInfo(entityplayer.name, true, entityplayer.ping)); + this.sendAll(new Packet201PlayerInfo(entityplayer.getName(), true, entityplayer.ping)); } // CraftBukkit end */ } @@ -743,7 +743,7 @@ public abstract class PlayerList { s = s + ", "; } - s = s + ((EntityPlayer) this.players.get(i)).name; + s = s + ((EntityPlayer) this.players.get(i)).getName(); } return s; @@ -753,7 +753,7 @@ public abstract class PlayerList { String[] astring = new String[this.players.size()]; for (int i = 0; i < this.players.size(); ++i) { - astring[i] = ((EntityPlayer) this.players.get(i)).name; + astring[i] = ((EntityPlayer) this.players.get(i)).getName(); } return astring; @@ -796,7 +796,7 @@ public abstract class PlayerList { public boolean isOp(String s) { // CraftBukkit - return this.operators.contains(s.trim().toLowerCase()) || this.server.I() && this.server.worlds.get(0).getWorldData().allowCommands() && this.server.H().equalsIgnoreCase(s) || this.m; + return this.operators.contains(s.trim().toLowerCase()) || this.server.K() && this.server.worlds.get(0).getWorldData().allowCommands() && this.server.J().equalsIgnoreCase(s) || this.m; } public EntityPlayer getPlayer(String s) { @@ -810,62 +810,56 @@ public abstract class PlayerList { } entityplayer = (EntityPlayer) iterator.next(); - } while (!entityplayer.name.equalsIgnoreCase(s)); + } while (!entityplayer.getName().equalsIgnoreCase(s)); return entityplayer; } - public List a(ChunkCoordinates chunkcoordinates, int i, int j, int k, int l, int i1, int j1, Map map, String s, String s1) { + public List a(ChunkCoordinates chunkcoordinates, int i, int j, int k, int l, int i1, int j1, Map map, String s, String s1, World world) { if (this.players.isEmpty()) { return null; } else { Object object = new ArrayList(); boolean flag = k < 0; + boolean flag1 = s != null && s.startsWith("!"); + boolean flag2 = s1 != null && s1.startsWith("!"); int k1 = i * i; int l1 = j * j; k = MathHelper.a(k); + if (flag1) { + s = s.substring(1); + } + + if (flag2) { + s1 = s1.substring(1); + } for (int i2 = 0; i2 < this.players.size(); ++i2) { EntityPlayer entityplayer = (EntityPlayer) this.players.get(i2); - boolean flag1; - if (s != null) { - flag1 = s.startsWith("!"); - if (flag1) { - s = s.substring(1); - } - - if (flag1 == s.equalsIgnoreCase(entityplayer.getLocalizedName())) { - continue; - } - } + if ((world == null || entityplayer.world == world) && (s == null || flag1 != s.equalsIgnoreCase(entityplayer.getLocalizedName()))) { + if (s1 != null) { + ScoreboardTeam scoreboardteam = entityplayer.getScoreboardTeam(); + String s2 = scoreboardteam == null ? "" : scoreboardteam.getName(); - if (s1 != null) { - flag1 = s1.startsWith("!"); - if (flag1) { - s1 = s1.substring(1); + if (flag2 == s1.equalsIgnoreCase(s2)) { + continue; + } } - ScoreboardTeam scoreboardteam = entityplayer.getScoreboardTeam(); - String s2 = scoreboardteam == null ? "" : scoreboardteam.getName(); + if (chunkcoordinates != null && (i > 0 || j > 0)) { + float f = chunkcoordinates.e(entityplayer.b()); - if (flag1 == s1.equalsIgnoreCase(s2)) { - continue; + if (i > 0 && f < (float) k1 || j > 0 && f > (float) l1) { + continue; + } } - } - - if (chunkcoordinates != null && (i > 0 || j > 0)) { - float f = chunkcoordinates.e(entityplayer.b()); - if (i > 0 && f < (float) k1 || j > 0 && f > (float) l1) { - continue; + if (this.a((EntityHuman) entityplayer, map) && (l == EnumGamemode.NONE.a() || l == entityplayer.playerInteractManager.getGameMode().a()) && (i1 <= 0 || entityplayer.expLevel >= i1) && entityplayer.expLevel <= j1) { + ((List) object).add(entityplayer); } } - - if (this.a((EntityHuman) entityplayer, map) && (l == EnumGamemode.NONE.a() || l == entityplayer.playerInteractManager.getGameMode().a()) && (i1 <= 0 || entityplayer.expLevel >= i1) && entityplayer.expLevel <= j1) { - ((List) object).add(entityplayer); - } } if (chunkcoordinates != null) { @@ -977,8 +971,8 @@ public abstract class PlayerList { public void reloadWhitelist() {} public void b(EntityPlayer entityplayer, WorldServer worldserver) { - entityplayer.playerConnection.sendPacket(new Packet4UpdateTime(worldserver.getTime(), worldserver.getDayTime())); - if (worldserver.P()) { + entityplayer.playerConnection.sendPacket(new Packet4UpdateTime(worldserver.getTime(), worldserver.getDayTime(), worldserver.getGameRules().getBoolean("doDaylightCycle"))); + if (worldserver.Q()) { entityplayer.setPlayerWeather(org.bukkit.WeatherType.DOWNFALL, false); // CraftBukkit - handle player specific weather } } @@ -1009,14 +1003,14 @@ public abstract class PlayerList { this.hasWhitelist = flag; } - public List j(String s) { + public List i(String s) { ArrayList arraylist = new ArrayList(); Iterator iterator = this.players.iterator(); while (iterator.hasNext()) { EntityPlayer entityplayer = (EntityPlayer) iterator.next(); - if (entityplayer.p().equals(s)) { + if (entityplayer.q().equals(s)) { arraylist.add(entityplayer); } } @@ -1052,8 +1046,12 @@ public abstract class PlayerList { } } - public void k(String s) { - this.server.info(s); - this.sendAll(new Packet3Chat(s)); + public void sendMessage(ChatMessage chatmessage, boolean flag) { + this.server.sendMessage(chatmessage); + this.sendAll(new Packet3Chat(chatmessage, flag)); + } + + public void sendMessage(ChatMessage chatmessage) { + this.sendMessage(chatmessage, true); } } diff --git a/src/main/java/net/minecraft/server/PortalTravelAgent.java b/src/main/java/net/minecraft/server/PortalTravelAgent.java index 1eea9478..03ad5dcf 100644 --- a/src/main/java/net/minecraft/server/PortalTravelAgent.java +++ b/src/main/java/net/minecraft/server/PortalTravelAgent.java @@ -140,7 +140,7 @@ public class PortalTravelAgent { for (int l1 = i1 - short1; l1 <= i1 + short1; ++l1) { double d6 = (double) l1 + 0.5D - z; // CraftBukkit - for (int i2 = this.a.R() - 1; i2 >= 0; --i2) { + for (int i2 = this.a.S() - 1; i2 >= 0; --i2) { if (this.a.getTypeId(k1, i2, l1) == Block.PORTAL.id) { while (this.a.getTypeId(k1, i2 - 1, l1) == Block.PORTAL.id) { --i2; @@ -215,7 +215,7 @@ public class PortalTravelAgent { j2 = 1; } - int k2 = entity.as(); + int k2 = entity.ar(); if (j2 > -1) { int l2 = Direction.h[j2]; @@ -364,7 +364,7 @@ public class PortalTravelAgent { d2 = (double) j2 + 0.5D - z; // CraftBukkit label274: - for (k2 = this.a.R() - 1; k2 >= 0; --k2) { + for (k2 = this.a.S() - 1; k2 >= 0; --k2) { if (this.a.isEmpty(i2, k2, j2)) { while (k2 > 0 && this.a.isEmpty(i2, k2 - 1, j2)) { --k2; @@ -415,7 +415,7 @@ public class PortalTravelAgent { d2 = (double) j2 + 0.5D - z; // CraftBukkit label222: - for (k2 = this.a.R() - 1; k2 >= 0; --k2) { + for (k2 = this.a.S() - 1; k2 >= 0; --k2) { if (this.a.isEmpty(i2, k2, j2)) { while (k2 > 0 && this.a.isEmpty(i2, k2 - 1, j2)) { --k2; @@ -471,8 +471,8 @@ public class PortalTravelAgent { i1 = 70; } - if (i1 > this.a.R() - 10) { - i1 = this.a.R() - 10; + if (i1 > this.a.S() - 10) { + i1 = this.a.S() - 10; } j5 = i1; diff --git a/src/main/java/net/minecraft/server/RecipeArmorDye.java b/src/main/java/net/minecraft/server/RecipeArmorDye.java index 38a9b461..0663e120 100644 --- a/src/main/java/net/minecraft/server/RecipeArmorDye.java +++ b/src/main/java/net/minecraft/server/RecipeArmorDye.java @@ -81,7 +81,7 @@ public class RecipeArmorDye extends ShapelessRecipes implements IRecipe { // Cra return null; } - float[] afloat = EntitySheep.d[BlockCloth.g_(itemstack1.getData())]; + float[] afloat = EntitySheep.bp[BlockCloth.j_(itemstack1.getData())]; int j1 = (int) (afloat[0] * 255.0F); int k1 = (int) (afloat[1] * 255.0F); diff --git a/src/main/java/net/minecraft/server/RecipesFurnace.java b/src/main/java/net/minecraft/server/RecipesFurnace.java index fe56cde5..47a1a3e9 100644 --- a/src/main/java/net/minecraft/server/RecipesFurnace.java +++ b/src/main/java/net/minecraft/server/RecipesFurnace.java @@ -24,6 +24,7 @@ public class RecipesFurnace { this.registerRecipe(Item.RAW_FISH.id, new ItemStack(Item.COOKED_FISH), 0.35F); this.registerRecipe(Block.COBBLESTONE.id, new ItemStack(Block.STONE), 0.1F); this.registerRecipe(Item.CLAY_BALL.id, new ItemStack(Item.CLAY_BRICK), 0.3F); + this.registerRecipe(Block.CLAY.id, new ItemStack(Block.HARDENED_CLAY), 0.35F); this.registerRecipe(Block.CACTUS.id, new ItemStack(Item.INK_SACK, 1, 2), 0.2F); this.registerRecipe(Block.LOG.id, new ItemStack(Item.COAL, 1, 1), 0.15F); this.registerRecipe(Block.EMERALD_ORE.id, new ItemStack(Item.EMERALD), 1.0F); diff --git a/src/main/java/net/minecraft/server/RegionFile.java b/src/main/java/net/minecraft/server/RegionFile.java index 2a9be3de..e9cb09f9 100644 --- a/src/main/java/net/minecraft/server/RegionFile.java +++ b/src/main/java/net/minecraft/server/RegionFile.java @@ -21,7 +21,7 @@ public class RegionFile { private final int[] e = new int[1024]; private ArrayList f; private int g; - private long h = 0L; + private long h; public RegionFile(File file1) { this.b = file1; @@ -244,7 +244,7 @@ public class RegionFile { } } - this.b(i, j, (int) (System.currentTimeMillis() / 1000L)); + this.b(i, j, (int) (MinecraftServer.aq() / 1000L)); } catch (IOException ioexception) { ioexception.printStackTrace(); } diff --git a/src/main/java/net/minecraft/server/ShapedRecipes.java b/src/main/java/net/minecraft/server/ShapedRecipes.java index a70b8285..8f4246b0 100644 --- a/src/main/java/net/minecraft/server/ShapedRecipes.java +++ b/src/main/java/net/minecraft/server/ShapedRecipes.java @@ -12,7 +12,7 @@ public class ShapedRecipes implements IRecipe { private ItemStack[] items; private ItemStack result; public final int a; - private boolean f = false; + private boolean f; public ShapedRecipes(int i, int j, ItemStack[] aitemstack, ItemStack itemstack) { this.a = itemstack.id; diff --git a/src/main/java/net/minecraft/server/Slot.java b/src/main/java/net/minecraft/server/Slot.java index 079a8270..48d13e42 100644 --- a/src/main/java/net/minecraft/server/Slot.java +++ b/src/main/java/net/minecraft/server/Slot.java @@ -32,7 +32,7 @@ public class Slot { protected void b(ItemStack itemstack) {} public void a(EntityHuman entityhuman, ItemStack itemstack) { - this.e(); + this.f(); } public boolean isAllowed(ItemStack itemstack) { @@ -43,16 +43,16 @@ public class Slot { return this.inventory.getItem(this.index); } - public boolean d() { + public boolean e() { return this.getItem() != null; } public void set(ItemStack itemstack) { this.inventory.setItem(this.index, itemstack); - this.e(); + this.f(); } - public void e() { + public void f() { this.inventory.update(); } diff --git a/src/main/java/net/minecraft/server/SlotFurnaceResult.java b/src/main/java/net/minecraft/server/SlotFurnaceResult.java index c8812336..e0eaec94 100644 --- a/src/main/java/net/minecraft/server/SlotFurnaceResult.java +++ b/src/main/java/net/minecraft/server/SlotFurnaceResult.java @@ -20,7 +20,7 @@ public class SlotFurnaceResult extends Slot { } public ItemStack a(int i) { - if (this.d()) { + if (this.e()) { this.b += Math.min(i, this.getItem().count); } diff --git a/src/main/java/net/minecraft/server/SpawnerCreature.java b/src/main/java/net/minecraft/server/SpawnerCreature.java index 056100f5..aa7698b9 100644 --- a/src/main/java/net/minecraft/server/SpawnerCreature.java +++ b/src/main/java/net/minecraft/server/SpawnerCreature.java @@ -14,23 +14,24 @@ import org.bukkit.event.entity.CreatureSpawnEvent.SpawnReason; public final class SpawnerCreature { - private static LongObjectHashMap<Boolean> b = new LongObjectHashMap<Boolean>(); // CraftBukkit - HashMap -> LongObjectHashMap - protected static final Class[] a = new Class[] { EntitySpider.class, EntityZombie.class, EntitySkeleton.class}; + private LongObjectHashMap<Boolean> a = new LongObjectHashMap<Boolean>(); // CraftBukkit - HashMap -> LongObjectHashMap + + public SpawnerCreature() {} protected static ChunkPosition getRandomPosition(World world, int i, int j) { Chunk chunk = world.getChunkAt(i, j); int k = i * 16 + world.random.nextInt(16); int l = j * 16 + world.random.nextInt(16); - int i1 = world.random.nextInt(chunk == null ? world.R() : chunk.h() + 16 - 1); + int i1 = world.random.nextInt(chunk == null ? world.S() : chunk.h() + 16 - 1); return new ChunkPosition(k, i1, l); } - public static final int spawnEntities(WorldServer worldserver, boolean flag, boolean flag1, boolean flag2) { + public int spawnEntities(WorldServer worldserver, boolean flag, boolean flag1, boolean flag2) { if (!flag && !flag1) { return 0; } else { - b.clear(); + this.a.clear(); int i; int j; @@ -50,9 +51,9 @@ public final class SpawnerCreature { long chunkCoords = LongHash.toLong(l + k, i1 + j); if (!flag3) { - b.put(chunkCoords, false); - } else if (!b.containsKey(chunkCoords)) { - b.put(chunkCoords, true); + this.a.put(chunkCoords, false); + } else if (!this.a.containsKey(chunkCoords)) { + this.a.put(chunkCoords, true); } // CraftBukkit end } @@ -90,15 +91,15 @@ public final class SpawnerCreature { } // CraftBukkit end - if ((!enumcreaturetype.d() || flag1) && (enumcreaturetype.d() || flag) && (!enumcreaturetype.e() || flag2) && worldserver.a(enumcreaturetype.a()) <= limit * b.size() / 256) { // CraftBukkit - use per-world limits - Iterator iterator = b.keySet().iterator(); + if ((!enumcreaturetype.d() || flag1) && (enumcreaturetype.d() || flag) && (!enumcreaturetype.e() || flag2) && worldserver.a(enumcreaturetype.a()) <= limit * this.a.size() / 256) { // CraftBukkit - use per-world limits + Iterator iterator = this.a.keySet().iterator(); label110: while (iterator.hasNext()) { // CraftBukkit start long key = ((Long) iterator.next()).longValue(); - if (!b.get(key)) { + if (!this.a.get(key)) { ChunkPosition chunkposition = getRandomPosition(worldserver, LongHash.msw(key), LongHash.lsw(key)); // CraftBukkit end int k1 = chunkposition.x; @@ -115,6 +116,7 @@ public final class SpawnerCreature { int j3 = i2; byte b1 = 6; BiomeMeta biomemeta = null; + GroupDataEntity groupdataentity = null; int k3 = 0; while (true) { @@ -142,23 +144,23 @@ public final class SpawnerCreature { } } - EntityLiving entityliving; + EntityInsentient entityinsentient; try { - entityliving = (EntityLiving) biomemeta.b.getConstructor(new Class[] { World.class}).newInstance(new Object[] { worldserver}); + entityinsentient = (EntityInsentient) biomemeta.b.getConstructor(new Class[] { World.class}).newInstance(new Object[] { worldserver}); } catch (Exception exception) { exception.printStackTrace(); return i; } - entityliving.setPositionRotation((double) f, (double) f1, (double) f2, worldserver.random.nextFloat() * 360.0F, 0.0F); - if (entityliving.canSpawn()) { + entityinsentient.setPositionRotation((double) f, (double) f1, (double) f2, worldserver.random.nextFloat() * 360.0F, 0.0F); + if (entityinsentient.canSpawn()) { ++j2; - // CraftBukkit start - Added a reason for spawning this creature, moved a(entityliving, world...) up - a(entityliving, worldserver, f, f1, f2); - worldserver.addEntity(entityliving, SpawnReason.NATURAL); + // CraftBukkit start - Added a reason for spawning this creature, moved entityinsentient.a(groupdataentity) up + groupdataentity = entityinsentient.a(groupdataentity); + worldserver.addEntity(entityinsentient, SpawnReason.NATURAL); // CraftBukkit end - if (j2 >= entityliving.by()) { + if (j2 >= entityinsentient.br()) { continue label110; } } @@ -199,16 +201,13 @@ public final class SpawnerCreature { } } - private static void a(EntityLiving entityliving, World world, float f, float f1, float f2) { - entityliving.bJ(); - } - public static void a(World world, BiomeBase biomebase, int i, int j, int k, int l, Random random) { List list = biomebase.getMobs(EnumCreatureType.CREATURE); if (!list.isEmpty()) { while (random.nextFloat() < biomebase.f()) { BiomeMeta biomemeta = (BiomeMeta) WeightedRandom.a(world.random, (Collection) list); + GroupDataEntity groupdataentity = null; int i1 = biomemeta.c + random.nextInt(1 + biomemeta.d - biomemeta.c); int j1 = i + random.nextInt(k); int k1 = j + random.nextInt(l); @@ -226,19 +225,19 @@ public final class SpawnerCreature { float f1 = (float) l2; float f2 = (float) k1 + 0.5F; - EntityLiving entityliving; + EntityInsentient entityinsentient; try { - entityliving = (EntityLiving) biomemeta.b.getConstructor(new Class[] { World.class}).newInstance(new Object[] { world}); + entityinsentient = (EntityInsentient) biomemeta.b.getConstructor(new Class[] { World.class}).newInstance(new Object[] { world}); } catch (Exception exception) { exception.printStackTrace(); continue; } - entityliving.setPositionRotation((double) f, (double) f1, (double) f2, random.nextFloat() * 360.0F, 0.0F); - // CraftBukkit start - Added a reason for spawning this creature, moved a(entity, world...) up - a(entityliving, world, f, f1, f2); - world.addEntity(entityliving, SpawnReason.CHUNK_GEN); + entityinsentient.setPositionRotation((double) f, (double) f1, (double) f2, random.nextFloat() * 360.0F, 0.0F); + // CraftBukkit start - Added a reason for spawning this creature, moved entityinsentient.a(groupdataentity) up + groupdataentity = entityinsentient.a(groupdataentity); + world.addEntity(entityinsentient, SpawnReason.CHUNK_GEN); // CraftBukkit end flag = true; } diff --git a/src/main/java/net/minecraft/server/ThreadLoginVerifier.java b/src/main/java/net/minecraft/server/ThreadLoginVerifier.java index 0686ba0f..2ce2e3af 100644 --- a/src/main/java/net/minecraft/server/ThreadLoginVerifier.java +++ b/src/main/java/net/minecraft/server/ThreadLoginVerifier.java @@ -28,9 +28,9 @@ class ThreadLoginVerifier extends Thread { public void run() { try { - String s = (new BigInteger(MinecraftEncryption.a(PendingConnection.a(this.pendingConnection), PendingConnection.b(this.pendingConnection).F().getPublic(), PendingConnection.c(this.pendingConnection)))).toString(16); + String s = (new BigInteger(MinecraftEncryption.a(PendingConnection.a(this.pendingConnection), PendingConnection.b(this.pendingConnection).H().getPublic(), PendingConnection.c(this.pendingConnection)))).toString(16); URL url = new URL("http://session.minecraft.net/game/checkserver.jsp?user=" + URLEncoder.encode(PendingConnection.d(this.pendingConnection), "UTF-8") + "&serverId=" + URLEncoder.encode(s, "UTF-8")); - BufferedReader bufferedreader = new BufferedReader(new InputStreamReader(url.openStream())); + BufferedReader bufferedreader = new BufferedReader(new InputStreamReader(url.openConnection(PendingConnection.b(this.pendingConnection).ap()).getInputStream())); String s1 = bufferedreader.readLine(); bufferedreader.close(); diff --git a/src/main/java/net/minecraft/server/TileEntity.java b/src/main/java/net/minecraft/server/TileEntity.java index db3fc42e..f4be980b 100644 --- a/src/main/java/net/minecraft/server/TileEntity.java +++ b/src/main/java/net/minecraft/server/TileEntity.java @@ -29,14 +29,14 @@ public class TileEntity { } } - public void b(World world) { - this.world = world; - } - public World getWorld() { return this.world; } + public void b(World world) { + this.world = world; + } + public boolean o() { return this.world != null; } diff --git a/src/main/java/net/minecraft/server/TileEntityBeacon.java b/src/main/java/net/minecraft/server/TileEntityBeacon.java index 36008f28..087b98fe 100644 --- a/src/main/java/net/minecraft/server/TileEntityBeacon.java +++ b/src/main/java/net/minecraft/server/TileEntityBeacon.java @@ -95,7 +95,7 @@ public class TileEntityBeacon extends TileEntity implements IInventory { for (int i = 1; i <= 4; this.e = i++) { int j = this.y - i; - if (j < 1) { + if (j < 0) { break; } diff --git a/src/main/java/net/minecraft/server/TileEntityBrewingStand.java b/src/main/java/net/minecraft/server/TileEntityBrewingStand.java index 2d943bef..f1883f37 100644 --- a/src/main/java/net/minecraft/server/TileEntityBrewingStand.java +++ b/src/main/java/net/minecraft/server/TileEntityBrewingStand.java @@ -103,7 +103,7 @@ public class TileEntityBrewingStand extends TileEntity implements IWorldInventor if (this.items[3] != null && this.items[3].count > 0) { ItemStack itemstack = this.items[3]; - if (!Item.byId[itemstack.id].w()) { + if (!Item.byId[itemstack.id].x()) { return false; } else { boolean flag = false; @@ -121,7 +121,8 @@ public class TileEntityBrewingStand extends TileEntity implements IWorldInventor List list = Item.POTION.c(j); List list1 = Item.POTION.c(k); - if ((j <= 0 || list != list1) && (list == null || !list.equals(list1) && list1 != null) && j != k) { + // CraftBukkit - list != -> !list.equals + if ((j <= 0 || !list.equals(list1)) && (list == null || !list.equals(list1) && list1 != null) && j != k) { flag = true; break; } @@ -166,8 +167,8 @@ public class TileEntityBrewingStand extends TileEntity implements IWorldInventor } } - if (Item.byId[itemstack.id].t()) { - this.items[3] = new ItemStack(Item.byId[itemstack.id].s()); + if (Item.byId[itemstack.id].u()) { + this.items[3] = new ItemStack(Item.byId[itemstack.id].t()); } else { --this.items[3].count; if (this.items[3].count <= 0) { @@ -178,7 +179,7 @@ public class TileEntityBrewingStand extends TileEntity implements IWorldInventor } private int c(int i, ItemStack itemstack) { - return itemstack == null ? i : (Item.byId[itemstack.id].w() ? PotionBrewer.a(i, Item.byId[itemstack.id].v()) : i); + return itemstack == null ? i : (Item.byId[itemstack.id].x() ? PotionBrewer.a(i, Item.byId[itemstack.id].w()) : i); } public void a(NBTTagCompound nbttagcompound) { @@ -268,7 +269,7 @@ public class TileEntityBrewingStand extends TileEntity implements IWorldInventor public void g() {} public boolean b(int i, ItemStack itemstack) { - return i == 3 ? Item.byId[itemstack.id].w() : itemstack.id == Item.POTION.id || itemstack.id == Item.GLASS_BOTTLE.id; + return i == 3 ? Item.byId[itemstack.id].x() : itemstack.id == Item.POTION.id || itemstack.id == Item.GLASS_BOTTLE.id; } public int j() { diff --git a/src/main/java/net/minecraft/server/TileEntityChest.java b/src/main/java/net/minecraft/server/TileEntityChest.java index e529bf47..782913f9 100644 --- a/src/main/java/net/minecraft/server/TileEntityChest.java +++ b/src/main/java/net/minecraft/server/TileEntityChest.java @@ -11,7 +11,7 @@ import org.bukkit.entity.HumanEntity; public class TileEntityChest extends TileEntity implements IInventory { private ItemStack[] items = new ItemStack[27]; // CraftBukkit - 36 -> 27 - public boolean a = false; + public boolean a; public TileEntityChest b; public TileEntityChest c; public TileEntityChest d; diff --git a/src/main/java/net/minecraft/server/TileEntityCommand.java b/src/main/java/net/minecraft/server/TileEntityCommand.java index c9be36ce..e98c080f 100644 --- a/src/main/java/net/minecraft/server/TileEntityCommand.java +++ b/src/main/java/net/minecraft/server/TileEntityCommand.java @@ -7,7 +7,7 @@ import com.google.common.base.Joiner; public class TileEntityCommand extends TileEntity implements ICommandListener { - private int a = 0; + private int a; public String b = ""; // CraftBukkit - private -> public private String c = "@"; // CraftBukkit start @@ -18,7 +18,7 @@ public class TileEntityCommand extends TileEntity implements ICommandListener { } // CraftBukkit end - public void b(String s) { + public void a(String s) { this.b = s; this.update(); } @@ -137,20 +137,16 @@ public class TileEntityCommand extends TileEntity implements ICommandListener { return this.c; } - public void c(String s) { + public void b(String s) { this.c = s; } - public void sendMessage(String s) {} + public void sendMessage(ChatMessage chatmessage) {} public boolean a(int i, String s) { return i <= 2; } - public String a(String s, Object... aobject) { - return s; - } - public void b(NBTTagCompound nbttagcompound) { super.b(nbttagcompound); nbttagcompound.setString("Command", this.b); @@ -171,6 +167,10 @@ public class TileEntityCommand extends TileEntity implements ICommandListener { return new ChunkCoordinates(this.x, this.y, this.z); } + public World f_() { + return this.getWorld(); + } + public Packet getUpdatePacket() { NBTTagCompound nbttagcompound = new NBTTagCompound(); @@ -178,7 +178,7 @@ public class TileEntityCommand extends TileEntity implements ICommandListener { return new Packet132TileEntityData(this.x, this.y, this.z, 2, nbttagcompound); } - public int d() { + public int f() { return this.a; } diff --git a/src/main/java/net/minecraft/server/TileEntityFurnace.java b/src/main/java/net/minecraft/server/TileEntityFurnace.java index e0f6cda3..01293b60 100644 --- a/src/main/java/net/minecraft/server/TileEntityFurnace.java +++ b/src/main/java/net/minecraft/server/TileEntityFurnace.java @@ -16,9 +16,9 @@ public class TileEntityFurnace extends TileEntity implements IWorldInventory { private static final int[] e = new int[] { 2, 1}; private static final int[] f = new int[] { 1}; private ItemStack[] items = new ItemStack[3]; - public int burnTime = 0; - public int ticksForCurrentFuel = 0; - public int cookTime = 0; + public int burnTime; + public int ticksForCurrentFuel; + public int cookTime; private String h; // CraftBukkit start @@ -206,7 +206,7 @@ public class TileEntityFurnace extends TileEntity implements IWorldInventory { if (this.items[1] != null) { --this.items[1].count; if (this.items[1].count == 0) { - Item item = this.items[1].getItem().s(); + Item item = this.items[1].getItem().t(); this.items[1] = item != null ? new ItemStack(item) : null; } @@ -300,9 +300,14 @@ public class TileEntityFurnace extends TileEntity implements IWorldInventory { if (block.material == Material.WOOD) { return 300; } + + if (block == Block.COAL_BLOCK) { + return 16000; + } } - return item instanceof ItemTool && ((ItemTool) item).g().equals("WOOD") ? 200 : (item instanceof ItemSword && ((ItemSword) item).h().equals("WOOD") ? 200 : (item instanceof ItemHoe && ((ItemHoe) item).g().equals("WOOD") ? 200 : (i == Item.STICK.id ? 100 : (i == Item.COAL.id ? 1600 : (i == Item.LAVA_BUCKET.id ? 20000 : (i == Block.SAPLING.id ? 100 : (i == Item.BLAZE_ROD.id ? 2400 : 0))))))); } + return item instanceof ItemTool && ((ItemTool) item).g().equals("WOOD") ? 200 : (item instanceof ItemSword && ((ItemSword) item).i().equals("WOOD") ? 200 : (item instanceof ItemHoe && ((ItemHoe) item).g().equals("WOOD") ? 200 : (i == Item.STICK.id ? 100 : (i == Item.COAL.id ? 1600 : (i == Item.LAVA_BUCKET.id ? 20000 : (i == Block.SAPLING.id ? 100 : (i == Item.BLAZE_ROD.id ? 2400 : 0))))))); + } } public static boolean isFuel(ItemStack itemstack) { diff --git a/src/main/java/net/minecraft/server/TileEntityHopper.java b/src/main/java/net/minecraft/server/TileEntityHopper.java index f6d269d6..054cea49 100644 --- a/src/main/java/net/minecraft/server/TileEntityHopper.java +++ b/src/main/java/net/minecraft/server/TileEntityHopper.java @@ -178,8 +178,9 @@ public class TileEntityHopper extends TileEntity implements IHopper { public boolean j() { if (this.world != null && !this.world.isStatic) { if (!this.l() && BlockHopper.d(this.p())) { - boolean flag = this.u() | suckInItems(this); + boolean flag = this.u(); + flag = suckInItems(this) || flag; if (flag) { this.c(8); this.update(); @@ -265,7 +266,7 @@ public class TileEntityHopper extends TileEntity implements IHopper { } } } else { - EntityItem entityitem = getEntityItemAt(ihopper.getWorld(), ihopper.aA(), ihopper.aB() + 1.0D, ihopper.aC()); + EntityItem entityitem = getEntityItemAt(ihopper.getWorld(), ihopper.az(), ihopper.aA() + 1.0D, ihopper.aB()); if (entityitem != null) { return addEntityItem(ihopper, entityitem); @@ -300,7 +301,7 @@ public class TileEntityHopper extends TileEntity implements IHopper { if (ihopper instanceof TileEntityHopper) { ((TileEntityHopper) ihopper).c(8); // Delay hopper checks } else if (ihopper instanceof EntityMinecartHopper) { - ((EntityMinecartHopper) ihopper).n(4); // Delay hopper minecart checks + ((EntityMinecartHopper) ihopper).l(4); // Delay hopper minecart checks } return false; @@ -405,6 +406,7 @@ public class TileEntityHopper extends TileEntity implements IHopper { if (flag) { if (iinventory instanceof TileEntityHopper) { ((TileEntityHopper) iinventory).c(8); + iinventory.update(); } iinventory.update(); @@ -421,7 +423,7 @@ public class TileEntityHopper extends TileEntity implements IHopper { } public static IInventory getSourceInventory(IHopper ihopper) { - return getInventoryAt(ihopper.getWorld(), ihopper.aA(), ihopper.aB() + 1.0D, ihopper.aC()); + return getInventoryAt(ihopper.getWorld(), ihopper.az(), ihopper.aA() + 1.0D, ihopper.aB()); } public static EntityItem getEntityItemAt(World world, double d0, double d1, double d2) { @@ -464,15 +466,15 @@ public class TileEntityHopper extends TileEntity implements IHopper { return itemstack.id != itemstack1.id ? false : (itemstack.getData() != itemstack1.getData() ? false : (itemstack.count > itemstack.getMaxStackSize() ? false : ItemStack.equals(itemstack, itemstack1))); } - public double aA() { + public double az() { return (double) this.x; } - public double aB() { + public double aA() { return (double) this.y; } - public double aC() { + public double aB() { return (double) this.z; } diff --git a/src/main/java/net/minecraft/server/TileEntityNote.java b/src/main/java/net/minecraft/server/TileEntityNote.java index 121efb87..46bb08d1 100644 --- a/src/main/java/net/minecraft/server/TileEntityNote.java +++ b/src/main/java/net/minecraft/server/TileEntityNote.java @@ -2,8 +2,8 @@ package net.minecraft.server; public class TileEntityNote extends TileEntity { - public byte note = 0; - public boolean b = false; + public byte note; + public boolean b; public TileEntityNote() {} diff --git a/src/main/java/net/minecraft/server/Vec3DPool.java b/src/main/java/net/minecraft/server/Vec3DPool.java index e29889c0..f8e54c23 100644 --- a/src/main/java/net/minecraft/server/Vec3DPool.java +++ b/src/main/java/net/minecraft/server/Vec3DPool.java @@ -15,9 +15,9 @@ public class Vec3DPool { private Vec3D alloclisthead = null; private int total_size = 0; // CraftBukkit end - private int position = 0; - private int largestSize = 0; - private int resizeTime = 0; + private int position; + private int largestSize; + private int resizeTime; public Vec3DPool(int i, int j) { this.a = i; @@ -93,9 +93,9 @@ public class Vec3DPool { this.largestSize = 0; // this.f = 0; // We do not reset to zero; it doubles for a flag } - // CraftBukkit end this.position = 0; + // CraftBukkit end } public int c() { diff --git a/src/main/java/net/minecraft/server/Village.java b/src/main/java/net/minecraft/server/Village.java index 5e9336bc..02bce3d5 100644 --- a/src/main/java/net/minecraft/server/Village.java +++ b/src/main/java/net/minecraft/server/Village.java @@ -11,14 +11,14 @@ public class Village { private final List doors = new ArrayList(); private final ChunkCoordinates c = new ChunkCoordinates(0, 0, 0); private final ChunkCoordinates center = new ChunkCoordinates(0, 0, 0); - private int size = 0; - private int f = 0; - private int time = 0; - private int population = 0; + private int size; + private int f; + private int time; + private int population; private int noBreedTicks; private TreeMap playerStandings = new TreeMap(); private List aggressors = new ArrayList(); - private int ironGolemCount = 0; + private int ironGolemCount; public Village() {} diff --git a/src/main/java/net/minecraft/server/VillageSiege.java b/src/main/java/net/minecraft/server/VillageSiege.java index 18f74641..7affabd9 100644 --- a/src/main/java/net/minecraft/server/VillageSiege.java +++ b/src/main/java/net/minecraft/server/VillageSiege.java @@ -6,7 +6,7 @@ import java.util.List; public class VillageSiege { private World world; - private boolean b = false; + private boolean b; private int c = -1; private int d; private int e; @@ -139,7 +139,7 @@ public class VillageSiege { try { entityzombie = new EntityZombie(this.world); - entityzombie.bJ(); + entityzombie.a((GroupDataEntity) null); entityzombie.setVillager(false); } catch (Exception exception) { exception.printStackTrace(); @@ -162,6 +162,7 @@ public class VillageSiege { int k1 = k + this.world.random.nextInt(16) - 8; if (this.f.a(i1, j1, k1) && SpawnerCreature.a(EnumCreatureType.MONSTER, this.world, i1, j1, k1)) { + // CraftBukkit - add Return return this.world.getVec3DPool().create((double) i1, (double) j1, (double) k1); } } diff --git a/src/main/java/net/minecraft/server/World.java b/src/main/java/net/minecraft/server/World.java index 3a4ddea1..f1348562 100644 --- a/src/main/java/net/minecraft/server/World.java +++ b/src/main/java/net/minecraft/server/World.java @@ -27,7 +27,7 @@ import org.bukkit.event.weather.ThunderChangeEvent; public abstract class World implements IBlockAccess { - public boolean d = false; + public boolean d; public List entityList = new ArrayList(); protected List f = new ArrayList(); public Set tileEntityList = new HashSet(); // CraftBukkit - ArrayList -> HashSet @@ -36,14 +36,14 @@ public abstract class World implements IBlockAccess { public List players = new ArrayList(); public List i = new ArrayList(); private long c = 16777215L; - public int j = 0; + public int j; protected int k = (new Random()).nextInt(); protected final int l = 1013904223; protected float m; protected float n; protected float o; protected float p; - public int q = 0; + public int q; public boolean callingPlaceEvent = false; // CraftBukkit public int difficulty; public Random random = new Random(); @@ -79,15 +79,15 @@ public abstract class World implements IBlockAccess { Chunk chunk = this.getChunkAtWorldCoords(i, j); if (chunk != null) { - return chunk.a(i & 15, j & 15, this.worldProvider.d); + return chunk.a(i & 15, j & 15, this.worldProvider.e); } } - return this.worldProvider.d.getBiome(i, j); + return this.worldProvider.e.getBiome(i, j); } public WorldChunkManager getWorldChunkManager() { - return this.worldProvider.d; + return this.worldProvider.e; } // CraftBukkit start @@ -118,7 +118,6 @@ public abstract class World implements IBlockAccess { this.O = this.random.nextInt(12000); this.H = new int['\u8000']; - this.isStatic = false; this.dataManager = idatamanager; this.methodProfiler = methodprofiler; this.worldMaps = new WorldMapCollection(idatamanager); @@ -168,7 +167,7 @@ public abstract class World implements IBlockAccess { this.villages.a(this); } - this.z(); + this.A(); this.a(); this.getServer().addWorld(this.world); // CraftBukkit @@ -430,7 +429,7 @@ public abstract class World implements IBlockAccess { k = i1; } - if (!this.worldProvider.f) { + if (!this.worldProvider.g) { for (i1 = k; i1 <= l; ++i1) { this.c(EnumSkyBlock.SKY, i, i1, j); } @@ -549,7 +548,7 @@ public abstract class World implements IBlockAccess { if (flag) { int l = this.getTypeId(i, j, k); - if (Block.w[l]) { + if (Block.x[l]) { int i1 = this.b(i, j + 1, k, false); int j1 = this.b(i + 1, j, k, false); int k1 = this.b(i - 1, j, k, false); @@ -672,7 +671,7 @@ public abstract class World implements IBlockAccess { } public float q(int i, int j, int k) { - return this.worldProvider.g[this.getLightLevel(i, j, k)]; + return this.worldProvider.h[this.getLightLevel(i, j, k)]; } public boolean v() { @@ -1036,12 +1035,12 @@ public abstract class World implements IBlockAccess { for (int j2 = 0; j2 < list.size(); ++j2) { AxisAlignedBB axisalignedbb1 = ((Entity) list.get(j2)).D(); - if (axisalignedbb1 != null && axisalignedbb1.a(axisalignedbb)) { + if (axisalignedbb1 != null && axisalignedbb1.b(axisalignedbb)) { this.M.add(axisalignedbb1); } axisalignedbb1 = entity.g((Entity) list.get(j2)); - if (axisalignedbb1 != null && axisalignedbb1.a(axisalignedbb)) { + if (axisalignedbb1 != null && axisalignedbb1.b(axisalignedbb)) { this.M.add(axisalignedbb1); } } @@ -1098,8 +1097,8 @@ public abstract class World implements IBlockAccess { return this.worldProvider.a(this.worldData.getDayTime(), f); } - public int w() { - return this.worldProvider.a(this.worldData.getDayTime()); + public float x() { + return WorldProvider.a[this.worldProvider.a(this.worldData.getDayTime())]; } public float d(float f) { @@ -1550,7 +1549,7 @@ public abstract class World implements IBlockAccess { } } - if (vec3d.b() > 0.0D && entity.aw()) { + if (vec3d.b() > 0.0D && entity.av()) { vec3d = vec3d.a(); double d1 = 0.014D; @@ -1836,7 +1835,7 @@ public abstract class World implements IBlockAccess { } } - public void z() { + public void A() { int i = this.a(1.0F); if (i != this.j) { @@ -1863,7 +1862,7 @@ public abstract class World implements IBlockAccess { } protected void o() { - if (!this.worldProvider.f) { + if (!this.worldProvider.g) { int i = this.worldData.getThunderDuration(); if (i <= 0) { @@ -1941,11 +1940,11 @@ public abstract class World implements IBlockAccess { } } - public void A() { + public void B() { this.worldData.setWeatherDuration(1); } - protected void B() { + protected void C() { // this.chunkTickList.clear(); // CraftBukkit - removed this.methodProfiler.a("buildList"); @@ -2020,7 +2019,7 @@ public abstract class World implements IBlockAccess { } protected void g() { - this.B(); + this.C(); } public boolean x(int i, int j, int k) { @@ -2095,7 +2094,7 @@ public abstract class World implements IBlockAccess { } public void A(int i, int j, int k) { - if (!this.worldProvider.f) { + if (!this.worldProvider.g) { this.c(EnumSkyBlock.SKY, i, j, k); } @@ -2338,9 +2337,9 @@ public abstract class World implements IBlockAccess { Entity entity = (Entity) this.entityList.get(j); // CraftBukkit start - Split out persistent check, don't apply it to special persistent mobs - if (entity instanceof EntityLiving) { - EntityLiving entityliving = (EntityLiving) entity; - if (entityliving.isTypeNotPersistent() && entityliving.bU()) { // Should be isPersistent + if (entity instanceof EntityInsentient) { + EntityInsentient entityinsentient = (EntityInsentient) entity; + if (entityinsentient.isTypeNotPersistent() && entityinsentient.bA()) { // Should be isPersistent continue; } } @@ -2566,7 +2565,7 @@ public abstract class World implements IBlockAccess { } if (entityhuman1.isInvisible()) { - float f = entityhuman1.cc(); + float f = entityhuman1.bs(); if (f < 0.1F) { f = 0.1F; @@ -2587,7 +2586,7 @@ public abstract class World implements IBlockAccess { public EntityHuman a(String s) { for (int i = 0; i < this.players.size(); ++i) { - if (s.equals(((EntityHuman) this.players.get(i)).name)) { + if (s.equals(((EntityHuman) this.players.get(i)).getName())) { return (EntityHuman) this.players.get(i); } } @@ -2595,7 +2594,7 @@ public abstract class World implements IBlockAccess { return null; } - public void F() throws ExceptionWorldConflict { // CraftBukkit - added throws + public void G() throws ExceptionWorldConflict { // CraftBukkit - added throws this.dataManager.checkSession(); } @@ -2625,7 +2624,7 @@ public abstract class World implements IBlockAccess { public void broadcastEntityEffect(Entity entity, byte b0) {} - public IChunkProvider K() { + public IChunkProvider L() { return this.chunkProvider; } @@ -2667,16 +2666,16 @@ public abstract class World implements IBlockAccess { return this.m + (this.n - this.m) * f; } - public boolean O() { + public boolean P() { return (double) this.h(1.0F) > 0.9D; } - public boolean P() { + public boolean Q() { return (double) this.i(1.0F) > 0.2D; } public boolean F(int i, int j, int k) { - if (!this.P()) { + if (!this.Q()) { return false; } else if (!this.l(i, j, k)) { return false; @@ -2738,8 +2737,8 @@ public abstract class World implements IBlockAccess { return 256; } - public int R() { - return this.worldProvider.f ? 128 : 256; + public int S() { + return this.worldProvider.g ? 128 : 256; } public IUpdatePlayerListBox a(EntityMinecartAbstract entityminecartabstract) { @@ -2754,7 +2753,7 @@ public abstract class World implements IBlockAccess { } public ChunkPosition b(String s, int i, int j, int k) { - return this.K().findNearestMapFeature(this, s, i, j, k); + return this.L().findNearestMapFeature(this, s, i, j, k); } public CrashReportSystemDetails a(CrashReport crashreport) { @@ -2785,9 +2784,9 @@ public abstract class World implements IBlockAccess { return this.J; } - public Calendar V() { + public Calendar W() { if (this.getTime() % 600L == 0L) { - this.K.setTimeInMillis(System.currentTimeMillis()); + this.K.setTimeInMillis(MinecraftServer.aq()); } return this.K; @@ -2824,4 +2823,26 @@ public abstract class World implements IBlockAccess { public IConsoleLogManager getLogger() { return this.logAgent; } + + public float b(double d0, double d1, double d2) { + return this.I(MathHelper.floor(d0), MathHelper.floor(d1), MathHelper.floor(d2)); + } + + public float I(int i, int j, int k) { + float f = 0.0F; + boolean flag = this.difficulty == 3; + + if (this.isLoaded(i, j, k)) { + float f1 = this.x(); + + f += MathHelper.a((float) this.getChunkAtWorldCoords(i, k).q / 3600000.0F, 0.0F, 1.0F) * (flag ? 1.0F : 0.75F); + f += f1 * 0.25F; + } + + if (this.difficulty < 2) { + f *= (float) this.difficulty / 2.0F; + } + + return MathHelper.a(f, 0.0F, flag ? 1.5F : 1.0F); + } } diff --git a/src/main/java/net/minecraft/server/WorldGenBigTree.java b/src/main/java/net/minecraft/server/WorldGenBigTree.java index 185ea74d..2404b1d9 100644 --- a/src/main/java/net/minecraft/server/WorldGenBigTree.java +++ b/src/main/java/net/minecraft/server/WorldGenBigTree.java @@ -10,7 +10,7 @@ public class WorldGenBigTree extends WorldGenerator implements BlockSapling.Tree Random b = new Random(); BlockChangeDelegate world; // CraftBukkit int[] d = new int[] { 0, 0, 0}; - int e = 0; + int e; int f; double g = 0.618D; double h = 1.0D; diff --git a/src/main/java/net/minecraft/server/WorldGenGroundBush.java b/src/main/java/net/minecraft/server/WorldGenGroundBush.java index ceb2c9fc..eb0240d5 100644 --- a/src/main/java/net/minecraft/server/WorldGenGroundBush.java +++ b/src/main/java/net/minecraft/server/WorldGenGroundBush.java @@ -43,7 +43,7 @@ public class WorldGenGroundBush extends WorldGenerator implements BlockSapling.T for (int k2 = k - l1; k2 <= k + l1; ++k2) { int l2 = k2 - k; - if ((Math.abs(j2) != l1 || Math.abs(l2) != l1 || random.nextInt(2) != 0) && !Block.s[world.getTypeId(i2, j1, k2)]) { + if ((Math.abs(j2) != l1 || Math.abs(l2) != l1 || random.nextInt(2) != 0) && !Block.t[world.getTypeId(i2, j1, k2)]) { this.setTypeAndData(world, i2, j1, k2, Block.LEAVES.id, this.a); } } diff --git a/src/main/java/net/minecraft/server/WorldGenHugeMushroom.java b/src/main/java/net/minecraft/server/WorldGenHugeMushroom.java index 42b19232..303644f9 100644 --- a/src/main/java/net/minecraft/server/WorldGenHugeMushroom.java +++ b/src/main/java/net/minecraft/server/WorldGenHugeMushroom.java @@ -162,7 +162,7 @@ public class WorldGenHugeMushroom extends WorldGenerator implements BlockSapling l2 = 0; } - if ((l2 != 0 || j >= j + i1 - 1) && !Block.s[world.getTypeId(i2, k1, k2)]) { + if ((l2 != 0 || j >= j + i1 - 1) && !Block.t[world.getTypeId(i2, k1, k2)]) { // CraftBukkit start if (event == null) { this.setTypeAndData(world, i2, k1, k2, Block.BIG_MUSHROOM_1.id + l, l2); @@ -180,7 +180,7 @@ public class WorldGenHugeMushroom extends WorldGenerator implements BlockSapling for (k1 = 0; k1 < i1; ++k1) { l1 = world.getTypeId(i, j + k1, k); - if (!Block.s[l1]) { + if (!Block.t[l1]) { // CraftBukkit start if (event == null) { this.setTypeAndData(world, i, j + k1, k, Block.BIG_MUSHROOM_1.id + l, 10); diff --git a/src/main/java/net/minecraft/server/WorldGenSwampTree.java b/src/main/java/net/minecraft/server/WorldGenSwampTree.java index 853bf99d..7f92b86d 100644 --- a/src/main/java/net/minecraft/server/WorldGenSwampTree.java +++ b/src/main/java/net/minecraft/server/WorldGenSwampTree.java @@ -78,7 +78,7 @@ public class WorldGenSwampTree extends WorldGenerator implements BlockSapling.Tr for (int k2 = k - k1; k2 <= k + k1; ++k2) { int l2 = k2 - k; - if ((Math.abs(i2) != k1 || Math.abs(l2) != k1 || random.nextInt(2) != 0 && j1 != 0) && !Block.s[world.getTypeId(l1, j2, k2)]) { + if ((Math.abs(i2) != k1 || Math.abs(l2) != k1 || random.nextInt(2) != 0 && j1 != 0) && !Block.t[world.getTypeId(l1, j2, k2)]) { this.setType(world, l1, j2, k2, Block.LEAVES.id); } } diff --git a/src/main/java/net/minecraft/server/WorldGenTaiga1.java b/src/main/java/net/minecraft/server/WorldGenTaiga1.java index 65eee4ef..e9a99b7b 100644 --- a/src/main/java/net/minecraft/server/WorldGenTaiga1.java +++ b/src/main/java/net/minecraft/server/WorldGenTaiga1.java @@ -66,7 +66,7 @@ public class WorldGenTaiga1 extends WorldGenerator implements BlockSapling.TreeG for (int i3 = k - l2; i3 <= k + l2; ++i3) { int j3 = i3 - k; - if ((Math.abs(k2) != l2 || Math.abs(j3) != l2 || l2 <= 0) && !Block.s[world.getTypeId(j2, i2, i3)]) { + if ((Math.abs(k2) != l2 || Math.abs(j3) != l2 || l2 <= 0) && !Block.t[world.getTypeId(j2, i2, i3)]) { this.setTypeAndData(world, j2, i2, i3, Block.LEAVES.id, 1); } } diff --git a/src/main/java/net/minecraft/server/WorldGenTaiga2.java b/src/main/java/net/minecraft/server/WorldGenTaiga2.java index 52d5fbb5..8d9ba5e9 100644 --- a/src/main/java/net/minecraft/server/WorldGenTaiga2.java +++ b/src/main/java/net/minecraft/server/WorldGenTaiga2.java @@ -74,7 +74,7 @@ public class WorldGenTaiga2 extends WorldGenerator implements BlockSapling.TreeG for (int l3 = k - k2; l3 <= k + k2; ++l3) { int i4 = l3 - k; - if ((Math.abs(k3) != k2 || Math.abs(i4) != k2 || k2 <= 0) && !Block.s[world.getTypeId(i3, j3, l3)]) { + if ((Math.abs(k3) != k2 || Math.abs(i4) != k2 || k2 <= 0) && !Block.t[world.getTypeId(i3, j3, l3)]) { this.setTypeAndData(world, i3, j3, l3, Block.LEAVES.id, 1); } } diff --git a/src/main/java/net/minecraft/server/WorldGenerator.java b/src/main/java/net/minecraft/server/WorldGenerator.java index 5941f291..ffb18f7f 100644 --- a/src/main/java/net/minecraft/server/WorldGenerator.java +++ b/src/main/java/net/minecraft/server/WorldGenerator.java @@ -28,6 +28,7 @@ public abstract class WorldGenerator { // CraftBukkit - change signature protected void setTypeAndData(BlockChangeDelegate world, int i, int j, int k, int l, int i1) { if (this.a) { + // CraftBukkit - BlockChangeDelegate doesn't have the 6th parameter world.setTypeIdAndData(i, j, k, l, i1); } else { // CraftBukkit start - Layering violation :( diff --git a/src/main/java/net/minecraft/server/WorldMap.java b/src/main/java/net/minecraft/server/WorldMap.java index fd009002..10dff050 100644 --- a/src/main/java/net/minecraft/server/WorldMap.java +++ b/src/main/java/net/minecraft/server/WorldMap.java @@ -147,8 +147,8 @@ public class WorldMap extends WorldMapBase { for (int i = 0; i < this.f.size(); ++i) { WorldMapHumanTracker worldmaphumantracker1 = (WorldMapHumanTracker) this.f.get(i); - if (!worldmaphumantracker1.trackee.dead && (worldmaphumantracker1.trackee.inventory.c(itemstack) || itemstack.z())) { - if (!itemstack.z() && worldmaphumantracker1.trackee.dimension == this.map) { + if (!worldmaphumantracker1.trackee.dead && (worldmaphumantracker1.trackee.inventory.c(itemstack) || itemstack.A())) { + if (!itemstack.A() && worldmaphumantracker1.trackee.dimension == this.map) { this.a(0, worldmaphumantracker1.trackee.world, worldmaphumantracker1.trackee.getName(), worldmaphumantracker1.trackee.locX, worldmaphumantracker1.trackee.locZ, (double) worldmaphumantracker1.trackee.yaw); } } else { @@ -157,8 +157,8 @@ public class WorldMap extends WorldMapBase { } } - if (itemstack.z()) { - this.a(1, entityhuman.world, "frame-" + itemstack.A().id, (double) itemstack.A().x, (double) itemstack.A().z, (double) (itemstack.A().direction * 90)); + if (itemstack.A()) { + this.a(1, entityhuman.world, "frame-" + itemstack.B().id, (double) itemstack.B().x, (double) itemstack.B().z, (double) (itemstack.B().direction * 90)); } } diff --git a/src/main/java/net/minecraft/server/WorldMapHumanTracker.java b/src/main/java/net/minecraft/server/WorldMapHumanTracker.java index bf3e6feb..22d9c7e6 100644 --- a/src/main/java/net/minecraft/server/WorldMapHumanTracker.java +++ b/src/main/java/net/minecraft/server/WorldMapHumanTracker.java @@ -19,9 +19,6 @@ public class WorldMapHumanTracker { this.worldMap = worldmap; this.b = new int[128]; this.c = new int[128]; - this.f = 0; - this.g = 0; - this.i = false; this.trackee = entityhuman; for (int i = 0; i < this.b.length; ++i) { @@ -60,7 +57,7 @@ public class WorldMapHumanTracker { } // CraftBukkit end - boolean flag = !itemstack.z(); + boolean flag = !itemstack.A(); if (this.h != null && this.h.length == abyte.length) { for (j = 0; j < abyte.length; ++j) { diff --git a/src/main/java/net/minecraft/server/WorldNBTStorage.java b/src/main/java/net/minecraft/server/WorldNBTStorage.java index e0ae71a8..e9134b32 100644 --- a/src/main/java/net/minecraft/server/WorldNBTStorage.java +++ b/src/main/java/net/minecraft/server/WorldNBTStorage.java @@ -21,7 +21,7 @@ public class WorldNBTStorage implements IDataManager, IPlayerFileData { private final File baseDir; private final File playerDir; private final File dataDir; - private final long sessionId = System.currentTimeMillis(); + private final long sessionId = MinecraftServer.aq(); private final String e; private UUID uuid = null; // CraftBukkit @@ -174,8 +174,8 @@ public class WorldNBTStorage implements IDataManager, IPlayerFileData { NBTTagCompound nbttagcompound = new NBTTagCompound(); entityhuman.e(nbttagcompound); - File file1 = new File(this.playerDir, entityhuman.name + ".dat.tmp"); - File file2 = new File(this.playerDir, entityhuman.name + ".dat"); + File file1 = new File(this.playerDir, entityhuman.getName() + ".dat.tmp"); + File file2 = new File(this.playerDir, entityhuman.getName() + ".dat"); NBTCompressedStreamTools.a(nbttagcompound, (OutputStream) (new FileOutputStream(file1))); if (file2.exists()) { @@ -184,12 +184,12 @@ public class WorldNBTStorage implements IDataManager, IPlayerFileData { file1.renameTo(file2); } catch (Exception exception) { - MinecraftServer.getServer().getLogger().warning("Failed to save player data for " + entityhuman.name); + MinecraftServer.getServer().getLogger().warning("Failed to save player data for " + entityhuman.getName()); } } public NBTTagCompound load(EntityHuman entityhuman) { - NBTTagCompound nbttagcompound = this.getPlayerData(entityhuman.name); + NBTTagCompound nbttagcompound = this.getPlayerData(entityhuman.getName()); if (nbttagcompound != null) { // CraftBukkit start diff --git a/src/main/java/net/minecraft/server/WorldServer.java b/src/main/java/net/minecraft/server/WorldServer.java index 49360c13..e787fb1b 100644 --- a/src/main/java/net/minecraft/server/WorldServer.java +++ b/src/main/java/net/minecraft/server/WorldServer.java @@ -30,12 +30,13 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate public ChunkProviderServer chunkProviderServer; public boolean savingDisabled; private boolean N; - private int emptyTime = 0; + private int emptyTime; private final PortalTravelAgent P; - private NoteDataList[] Q = new NoteDataList[] { new NoteDataList((EmptyClass2) null), new NoteDataList((EmptyClass2) null)}; - private int R = 0; - private static final StructurePieceTreasure[] S = new StructurePieceTreasure[] { new StructurePieceTreasure(Item.STICK.id, 0, 1, 3, 10), new StructurePieceTreasure(Block.WOOD.id, 0, 1, 3, 10), new StructurePieceTreasure(Block.LOG.id, 0, 1, 3, 10), new StructurePieceTreasure(Item.STONE_AXE.id, 0, 1, 1, 3), new StructurePieceTreasure(Item.WOOD_AXE.id, 0, 1, 1, 5), new StructurePieceTreasure(Item.STONE_PICKAXE.id, 0, 1, 1, 3), new StructurePieceTreasure(Item.WOOD_PICKAXE.id, 0, 1, 1, 5), new StructurePieceTreasure(Item.APPLE.id, 0, 2, 3, 5), new StructurePieceTreasure(Item.BREAD.id, 0, 2, 3, 3)}; - private ArrayList T = new ArrayList(); + private final SpawnerCreature Q = new SpawnerCreature(); + private NoteDataList[] R = new NoteDataList[] { new NoteDataList((EmptyClass2) null), new NoteDataList((EmptyClass2) null)}; + private int S; + private static final StructurePieceTreasure[] T = new StructurePieceTreasure[] { new StructurePieceTreasure(Item.STICK.id, 0, 1, 3, 10), new StructurePieceTreasure(Block.WOOD.id, 0, 1, 3, 10), new StructurePieceTreasure(Block.LOG.id, 0, 1, 3, 10), new StructurePieceTreasure(Item.STONE_AXE.id, 0, 1, 1, 3), new StructurePieceTreasure(Item.WOOD_AXE.id, 0, 1, 1, 5), new StructurePieceTreasure(Item.STONE_PICKAXE.id, 0, 1, 1, 3), new StructurePieceTreasure(Item.WOOD_PICKAXE.id, 0, 1, 1, 5), new StructurePieceTreasure(Item.APPLE.id, 0, 2, 3, 5), new StructurePieceTreasure(Item.BREAD.id, 0, 2, 3, 3)}; + private List U = new ArrayList(); private IntHashMap entitiesById; // CraftBukkit start @@ -163,27 +164,22 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate this.difficulty = 3; } - this.worldProvider.d.b(); + this.worldProvider.e.b(); if (this.everyoneDeeplySleeping()) { - boolean flag = false; - - if (this.allowMonsters && this.difficulty >= 1) { - ; - } - - if (!flag) { + if (this.getGameRules().getBoolean("doDaylightCycle")) { long i = this.worldData.getDayTime() + 24000L; this.worldData.setDayTime(i - i % 24000L); - this.d(); } + + this.d(); } this.methodProfiler.a("mobSpawner"); // CraftBukkit start - Only call spawner if we have players online and the world allows for mobs or animals long time = this.worldData.getTime(); if (this.getGameRules().getBoolean("doMobSpawning") && (this.allowMonsters || this.allowAnimals) && (this instanceof WorldServer && this.players.size() > 0)) { - SpawnerCreature.spawnEntities(this, this.allowMonsters && (this.ticksPerMonsterSpawns != 0 && time % this.ticksPerMonsterSpawns == 0L), this.allowAnimals && (this.ticksPerAnimalSpawns != 0 && time % this.ticksPerAnimalSpawns == 0L), this.worldData.getTime() % 400L == 0L); + this.Q.spawnEntities(this, this.allowMonsters && (this.ticksPerMonsterSpawns != 0 && time % this.ticksPerMonsterSpawns == 0L), this.allowAnimals && (this.ticksPerAnimalSpawns != 0 && time % this.ticksPerAnimalSpawns == 0L), this.worldData.getTime() % 400L == 0L); } // CraftBukkit end this.methodProfiler.c("chunkSource"); @@ -195,7 +191,10 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate } this.worldData.setTime(this.worldData.getTime() + 1L); - this.worldData.setDayTime(this.worldData.getDayTime() + 1L); + if (this.getGameRules().getBoolean("doDaylightCycle")) { + this.worldData.setDayTime(this.worldData.getDayTime() + 1L); + } + this.methodProfiler.c("tickPending"); this.a(false); this.methodProfiler.c("tickTiles"); @@ -208,13 +207,13 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate this.methodProfiler.c("portalForcer"); this.P.a(this.getTime()); this.methodProfiler.b(); - this.Z(); + this.aa(); this.getWorld().processChunkGC(); // CraftBukkit } public BiomeMeta a(EnumCreatureType enumcreaturetype, int i, int j, int k) { - List list = this.K().getMobsFor(enumcreaturetype, i, j, k); + List list = this.L().getMobsFor(enumcreaturetype, i, j, k); return list != null && !list.isEmpty() ? (BiomeMeta) WeightedRandom.a(this.random, (Collection) list) : null; } @@ -245,10 +244,10 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate } } - this.Y(); + this.Z(); } - private void Y() { + private void Z() { // CraftBukkit start WeatherChangeEvent weather = new WeatherChangeEvent(this.getWorld(), false); this.getServer().getPluginManager().callEvent(weather); @@ -321,7 +320,7 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate int k1; int l1; - if (this.random.nextInt(100000) == 0 && this.P() && this.O()) { + if (this.random.nextInt(100000) == 0 && this.Q() && this.P()) { this.k = this.k * 3 + 1013904223; i1 = this.k >> 2; j1 = k + (i1 & 15); @@ -354,7 +353,7 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate // CraftBukkit end } - if (this.P() && this.z(j1 + k, l1, k1 + l)) { + if (this.Q() && this.z(j1 + k, l1, k1 + l)) { // CraftBukkit start BlockState blockState = this.getWorld().getBlockAt(j1 + k, l1, k1 + l).getState(); blockState.setTypeId(Block.SNOW.id); @@ -367,7 +366,7 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate // CraftBukkit end } - if (this.P()) { + if (this.Q()) { BiomeBase biomebase = this.getBiome(j1 + k, k1 + l); if (biomebase.d()) { @@ -414,7 +413,7 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate public boolean a(int i, int j, int k, int l) { NextTickListEntry nextticklistentry = new NextTickListEntry(i, j, k, l); - return this.T.contains(nextticklistentry); + return this.U.contains(nextticklistentry); } public void a(int i, int j, int k, int l, int i1) { @@ -427,6 +426,7 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate if (this.d && l > 0) { if (Block.byId[l].l()) { + b0 = 8; if (this.e(nextticklistentry.a - b0, nextticklistentry.b - b0, nextticklistentry.c - b0, nextticklistentry.a + b0, nextticklistentry.b + b0, nextticklistentry.c + b0)) { int k1 = this.getTypeId(nextticklistentry.a, nextticklistentry.b, nextticklistentry.c); @@ -512,12 +512,12 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate this.M.remove(nextticklistentry); this.L.remove(nextticklistentry); - this.T.add(nextticklistentry); + this.U.add(nextticklistentry); } this.methodProfiler.b(); this.methodProfiler.a("ticking"); - Iterator iterator = this.T.iterator(); + Iterator iterator = this.U.iterator(); while (iterator.hasNext()) { nextticklistentry = (NextTickListEntry) iterator.next(); @@ -552,7 +552,7 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate } this.methodProfiler.b(); - this.T.clear(); + this.U.clear(); return !this.M.isEmpty(); } } @@ -571,10 +571,10 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate if (i1 == 0) { iterator = this.M.iterator(); } else { - iterator = this.T.iterator(); + iterator = this.U.iterator(); /* CraftBukkit start - Comment out debug spam - if (!this.T.isEmpty()) { - System.out.println(this.T.size()); + if (!this.U.isEmpty()) { + System.out.println(this.U.size()); } // CraftBukkit end */ } @@ -600,12 +600,12 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate return arraylist; } + /* CraftBukkit start - We prevent spawning in general, so this butchering is not needed public void entityJoinedWorld(Entity entity, boolean flag) { - /* CraftBukkit start - We prevent spawning in general, so this butchering is not needed if (!this.server.getSpawnAnimals() && (entity instanceof EntityAnimal || entity instanceof EntityWaterAnimal)) { entity.die(); } - // CraftBukkit end */ + if (!this.server.getSpawnNPCs() && entity instanceof NPC) { entity.die(); } @@ -614,9 +614,18 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate super.entityJoinedWorld(entity, flag); } } + // CraftBukkit end */ public void vehicleEnteredWorld(Entity entity, boolean flag) { - super.entityJoinedWorld(entity, flag); + try { + super.entityJoinedWorld(entity, flag); + } catch (Throwable throwable) { + CrashReport crashreport = CrashReport.a(throwable, "Forcefully ticking entity"); + CrashReportSystemDetails crashreportsystemdetails = crashreport.a("Entity being force ticked"); + + entity.a(crashreportsystemdetails); + throw new ReportedException(crashreport); + } } protected IChunkProvider j() { @@ -691,7 +700,7 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate this.worldData.setSpawn(0, this.worldProvider.getSeaLevel(), 0); } else { this.isLoading = true; - WorldChunkManager worldchunkmanager = this.worldProvider.d; + WorldChunkManager worldchunkmanager = this.worldProvider.e; List list = worldchunkmanager.a(); Random random = new Random(this.getSeed()); ChunkPosition chunkposition = worldchunkmanager.a(0, 0, 256, list, random); @@ -743,7 +752,7 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate } protected void k() { - WorldGenBonusChest worldgenbonuschest = new WorldGenBonusChest(S, 10); + WorldGenBonusChest worldgenbonuschest = new WorldGenBonusChest(T, 10); for (int i = 0; i < 10; ++i) { int j = this.worldData.c() + this.random.nextInt(6) - this.random.nextInt(6); @@ -782,7 +791,7 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate } protected void a() throws ExceptionWorldConflict { // CraftBukkit - added throws - this.F(); + this.G(); this.dataManager.saveWorldData(this.worldData, this.server.getPlayerList().q()); this.worldMaps.a(); } @@ -790,7 +799,7 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate protected void a(Entity entity) { super.a(entity); this.entitiesById.a(entity.id, entity); - Entity[] aentity = entity.an(); + Entity[] aentity = entity.am(); if (aentity != null) { for (int i = 0; i < aentity.length; ++i) { @@ -802,7 +811,7 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate protected void b(Entity entity) { super.b(entity); this.entitiesById.d(entity.id); - Entity[] aentity = entity.an(); + Entity[] aentity = entity.am(); if (aentity != null) { for (int i = 0; i < aentity.length; ++i) { @@ -874,13 +883,13 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate public void playNote(int i, int j, int k, int l, int i1, int j1) { NoteBlockData noteblockdata = new NoteBlockData(i, j, k, l, i1, j1); - Iterator iterator = this.Q[this.R].iterator(); + Iterator iterator = this.R[this.S].iterator(); NoteBlockData noteblockdata1; do { if (!iterator.hasNext()) { - this.Q[this.R].add(noteblockdata); + this.R[this.S].add(noteblockdata); return; } @@ -889,12 +898,12 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate } - private void Z() { - while (!this.Q[this.R].isEmpty()) { - int i = this.R; + private void aa() { + while (!this.R[this.S].isEmpty()) { + int i = this.S; - this.R ^= 1; - Iterator iterator = this.Q[i].iterator(); + this.S ^= 1; + Iterator iterator = this.R[i].iterator(); while (iterator.hasNext()) { NoteBlockData noteblockdata = (NoteBlockData) iterator.next(); @@ -905,7 +914,7 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate } } - this.Q[i].clear(); + this.R[i].clear(); } } @@ -920,10 +929,10 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate } protected void o() { - boolean flag = this.P(); + boolean flag = this.Q(); super.o(); - if (flag != this.P()) { + if (flag != this.Q()) { // CraftBukkit start - Only send weather packets to those affected for (int i = 0; i < this.players.size(); ++i) { if (((EntityPlayer) this.players.get(i)).world == this) { diff --git a/src/main/java/org/bukkit/craftbukkit/CraftOfflinePlayer.java b/src/main/java/org/bukkit/craftbukkit/CraftOfflinePlayer.java index c43773df..dd6bcf90 100644 --- a/src/main/java/org/bukkit/craftbukkit/CraftOfflinePlayer.java +++ b/src/main/java/org/bukkit/craftbukkit/CraftOfflinePlayer.java @@ -105,7 +105,7 @@ public class CraftOfflinePlayer implements OfflinePlayer, ConfigurationSerializa public Player getPlayer() { for (Object obj : server.getHandle().players) { EntityPlayer player = (EntityPlayer) obj; - if (player.name.equalsIgnoreCase(getName())) { + if (player.getName().equalsIgnoreCase(getName())) { return (player.playerConnection != null) ? player.playerConnection.getPlayer() : null; } } diff --git a/src/main/java/org/bukkit/craftbukkit/CraftWorld.java b/src/main/java/org/bukkit/craftbukkit/CraftWorld.java index 6c7f5709..e06e23b4 100644 --- a/src/main/java/org/bukkit/craftbukkit/CraftWorld.java +++ b/src/main/java/org/bukkit/craftbukkit/CraftWorld.java @@ -443,7 +443,7 @@ public class CraftWorld implements World { CraftPlayer cp = (CraftPlayer) p; if (cp.getHandle().playerConnection == null) continue; - cp.getHandle().playerConnection.sendPacket(new Packet4UpdateTime(cp.getHandle().world.getTime(), cp.getHandle().getPlayerTime())); + cp.getHandle().playerConnection.sendPacket(new Packet4UpdateTime(cp.getHandle().world.getTime(), cp.getHandle().getPlayerTime(), cp.getHandle().world.getGameRules().getBoolean("doDaylightCycle"))); } } diff --git a/src/main/java/org/bukkit/craftbukkit/block/CraftCommandBlock.java b/src/main/java/org/bukkit/craftbukkit/block/CraftCommandBlock.java index c68e27ca..a7adb22c 100644 --- a/src/main/java/org/bukkit/craftbukkit/block/CraftCommandBlock.java +++ b/src/main/java/org/bukkit/craftbukkit/block/CraftCommandBlock.java @@ -39,8 +39,8 @@ public class CraftCommandBlock extends CraftBlockState implements CommandBlock { boolean result = super.update(force, applyPhysics);
if (result) {
- commandBlock.b(command);
- commandBlock.c(name);
+ commandBlock.a(command);
+ commandBlock.b(name);
}
return result;
diff --git a/src/main/java/org/bukkit/craftbukkit/command/CraftRemoteConsoleCommandSender.java b/src/main/java/org/bukkit/craftbukkit/command/CraftRemoteConsoleCommandSender.java index fec7feeb..c269e4de 100644 --- a/src/main/java/org/bukkit/craftbukkit/command/CraftRemoteConsoleCommandSender.java +++ b/src/main/java/org/bukkit/craftbukkit/command/CraftRemoteConsoleCommandSender.java @@ -1,5 +1,6 @@ package org.bukkit.craftbukkit.command; +import net.minecraft.server.ChatMessage; import net.minecraft.server.RemoteControlCommandListener; import org.bukkit.command.RemoteConsoleCommandSender; @@ -9,7 +10,7 @@ public class CraftRemoteConsoleCommandSender extends ServerCommandSender impleme } public void sendMessage(String message) { - RemoteControlCommandListener.instance.sendMessage(message + "\n"); // Send a newline after each message, to preserve formatting. + RemoteControlCommandListener.instance.sendMessage(ChatMessage.d(message + "\n")); // Send a newline after each message, to preserve formatting. } public void sendMessage(String[] messages) { diff --git a/src/main/java/org/bukkit/craftbukkit/command/ServerCommandListener.java b/src/main/java/org/bukkit/craftbukkit/command/ServerCommandListener.java index 47c059c0..08a07c11 100644 --- a/src/main/java/org/bukkit/craftbukkit/command/ServerCommandListener.java +++ b/src/main/java/org/bukkit/craftbukkit/command/ServerCommandListener.java @@ -2,9 +2,11 @@ package org.bukkit.craftbukkit.command; import java.lang.reflect.Method; +import net.minecraft.server.ChatMessage; import net.minecraft.server.ChunkCoordinates; import net.minecraft.server.ICommandListener; import net.minecraft.server.LocaleLanguage; +import net.minecraft.server.World; import org.bukkit.command.CommandSender; @@ -18,8 +20,8 @@ public class ServerCommandListener implements ICommandListener { this.prefix = parts[parts.length - 1]; } - public void sendMessage(String msg) { - this.commandSender.sendMessage(msg); + public void sendMessage(ChatMessage chatmessage) { + this.commandSender.sendMessage(chatmessage.toString()); } public CommandSender getSender() { @@ -36,10 +38,6 @@ public class ServerCommandListener implements ICommandListener { return this.prefix; } - public String a(String s, Object... aobject) { - return LocaleLanguage.a().a(s, aobject); - } - public boolean a(int i, String s) { return true; } @@ -47,4 +45,8 @@ public class ServerCommandListener implements ICommandListener { public ChunkCoordinates b() { return new ChunkCoordinates(0, 0, 0); } + + public World f_() { + return null; + } } diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftEnderDragon.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftEnderDragon.java index fa0d63ae..70f53fbb 100644 --- a/src/main/java/org/bukkit/craftbukkit/entity/CraftEnderDragon.java +++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftEnderDragon.java @@ -11,6 +11,7 @@ import net.minecraft.server.EntityEnderDragon; import org.bukkit.craftbukkit.CraftServer; import org.bukkit.entity.ComplexEntityPart; import org.bukkit.entity.EnderDragon; +import org.bukkit.entity.Entity; import org.bukkit.entity.EntityType; public class CraftEnderDragon extends CraftComplexLivingEntity implements EnderDragon { diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftEnderDragonPart.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftEnderDragonPart.java index ce4a87c9..736a4602 100644 --- a/src/main/java/org/bukkit/craftbukkit/entity/CraftEnderDragonPart.java +++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftEnderDragonPart.java @@ -5,6 +5,7 @@ import org.bukkit.craftbukkit.CraftServer; import org.bukkit.entity.EnderDragon; import org.bukkit.entity.EnderDragonPart; import org.bukkit.entity.Entity; +import org.bukkit.util.NumberConversions; public class CraftEnderDragonPart extends CraftComplexPart implements EnderDragonPart { public CraftEnderDragonPart(CraftServer server, EntityComplexPart entity) { @@ -26,31 +27,61 @@ public class CraftEnderDragonPart extends CraftComplexPart implements EnderDrago return "CraftEnderDragonPart"; } - public void damage(int amount) { + public void damage(double amount) { getParent().damage(amount); } - public void damage(int amount, Entity source) { + public void damage(double amount, Entity source) { getParent().damage(amount, source); } - public int getHealth() { + public double getHealth() { return getParent().getHealth(); } - public void setHealth(int health) { + public void setHealth(double health) { getParent().setHealth(health); } - public int getMaxHealth() { + public double getMaxHealth() { return getParent().getMaxHealth(); } - public void setMaxHealth(int health) { + public void setMaxHealth(double health) { getParent().setMaxHealth(health); } public void resetMaxHealth() { getParent().resetMaxHealth(); } + + @Deprecated + public void _INVALID_damage(int amount) { + damage(amount); + } + + @Deprecated + public void _INVALID_damage(int amount, Entity source) { + damage(amount, source); + } + + @Deprecated + public int _INVALID_getHealth() { + return NumberConversions.ceil(getHealth()); + } + + @Deprecated + public void _INVALID_setHealth(int health) { + setHealth(health); + } + + @Deprecated + public int _INVALID_getMaxHealth() { + return NumberConversions.ceil(getMaxHealth()); + } + + @Deprecated + public void _INVALID_setMaxHealth(int health) { + setMaxHealth(health); + } } diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftHorse.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftHorse.java new file mode 100644 index 00000000..4dd77126 --- /dev/null +++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftHorse.java @@ -0,0 +1,23 @@ +package org.bukkit.craftbukkit.entity;
+
+import net.minecraft.server.EntityAnimal;
+
+import org.bukkit.craftbukkit.CraftServer;
+import org.bukkit.entity.EntityType;
+import org.bukkit.entity.Horse;
+
+public class CraftHorse extends CraftAnimals implements Horse {
+
+ public CraftHorse(CraftServer server, EntityAnimal entity) {
+ super(server, entity);
+ }
+
+ @Override
+ public String toString() {
+ return "CraftHorse";
+ }
+
+ public EntityType getType() {
+ return EntityType.HORSE;
+ }
+}
diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftHumanEntity.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftHumanEntity.java index aca2e62e..2b1040b7 100644 --- a/src/main/java/org/bukkit/craftbukkit/entity/CraftHumanEntity.java +++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftHumanEntity.java @@ -52,7 +52,7 @@ public class CraftHumanEntity extends CraftLivingEntity implements HumanEntity { } public String getName() { - return getHandle().name; + return getHandle().getName(); } public PlayerInventory getInventory() { diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftIronGolem.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftIronGolem.java index 08655eba..aa5b40e7 100644 --- a/src/main/java/org/bukkit/craftbukkit/entity/CraftIronGolem.java +++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftIronGolem.java @@ -21,7 +21,7 @@ public class CraftIronGolem extends CraftGolem implements IronGolem { } public boolean isPlayerCreated() { - return getHandle().p(); + return getHandle().bS(); } public void setPlayerCreated(boolean playerCreated) { diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftItemFrame.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftItemFrame.java index 037ba207..ba8afa31 100644 --- a/src/main/java/org/bukkit/craftbukkit/entity/CraftItemFrame.java +++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftItemFrame.java @@ -25,11 +25,11 @@ public class CraftItemFrame extends CraftHanging implements ItemFrame { } public org.bukkit.inventory.ItemStack getItem() { - return CraftItemStack.asBukkitCopy(getHandle().i()); + return CraftItemStack.asBukkitCopy(getHandle().h()); } public Rotation getRotation() { - return toBukkitRotation(getHandle().j()); + return toBukkitRotation(getHandle().i()); } Rotation toBukkitRotation(int value) { @@ -44,7 +44,7 @@ public class CraftItemFrame extends CraftHanging implements ItemFrame { case 3: return Rotation.COUNTER_CLOCKWISE; default: - throw new AssertionError("Unknown rotation " + getHandle().j() + " for " + getHandle()); + throw new AssertionError("Unknown rotation " + getHandle().i() + " for " + getHandle()); } } diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftLivingEntity.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftLivingEntity.java index 666d8e09..bd00911b 100644 --- a/src/main/java/org/bukkit/craftbukkit/entity/CraftLivingEntity.java +++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftLivingEntity.java @@ -11,6 +11,7 @@ import net.minecraft.server.EntityArrow; import net.minecraft.server.EntityEgg; import net.minecraft.server.EntityEnderDragon; import net.minecraft.server.EntityEnderPearl; +import net.minecraft.server.EntityInsentient; import net.minecraft.server.EntityLargeFireball; import net.minecraft.server.EntityLiving; import net.minecraft.server.EntitySmallFireball; @@ -51,6 +52,7 @@ import org.bukkit.inventory.ItemStack; import org.bukkit.potion.PotionEffect; import org.bukkit.potion.PotionEffectType; import org.bukkit.util.BlockIterator; +import org.bukkit.util.NumberConversions; import org.bukkit.util.Vector; public class CraftLivingEntity extends CraftEntity implements LivingEntity { @@ -59,16 +61,16 @@ public class CraftLivingEntity extends CraftEntity implements LivingEntity { public CraftLivingEntity(final CraftServer server, final EntityLiving entity) { super(server, entity); - if (!(this instanceof HumanEntity)) { + if (entity instanceof EntityInsentient) { equipment = new CraftEntityEquipment(this); } } - public int getHealth() { + public double getHealth() { return Math.min(Math.max(0, getHandle().getHealth()), getMaxHealth()); } - public void setHealth(int health) { + public void setHealth(double health) { if ((health < 0) || (health > getMaxHealth())) { throw new IllegalArgumentException("Health must be between 0 and " + getMaxHealth()); } @@ -77,17 +79,17 @@ public class CraftLivingEntity extends CraftEntity implements LivingEntity { ((EntityPlayer) entity).die(DamageSource.GENERIC); } - getHandle().setHealth(health); + getHandle().setHealth((float) health); } - public int getMaxHealth() { + public double getMaxHealth() { return getHandle().maxHealth; } - public void setMaxHealth(int amount) { + public void setMaxHealth(double amount) { Validate.isTrue(amount > 0, "Max health must be greater than 0"); - getHandle().maxHealth = amount; + getHandle().maxHealth = (float) amount; if (getHealth() > amount) { setHealth(amount); @@ -176,11 +178,11 @@ public class CraftLivingEntity extends CraftEntity implements LivingEntity { getHandle().maxAirTicks = ticks; } - public void damage(int amount) { + public void damage(double amount) { damage(amount, null); } - public void damage(int amount, org.bukkit.entity.Entity source) { + public void damage(double amount, org.bukkit.entity.Entity source) { DamageSource reason = DamageSource.GENERIC; if (source instanceof HumanEntity) { @@ -190,9 +192,9 @@ public class CraftLivingEntity extends CraftEntity implements LivingEntity { } if (entity instanceof EntityEnderDragon) { - ((EntityEnderDragon) entity).dealDamage(reason, amount); + ((EntityEnderDragon) entity).dealDamage(reason, (float) amount); } else { - entity.damageEntity(reason, amount); + entity.damageEntity(reason, (float) amount); } } @@ -210,12 +212,12 @@ public class CraftLivingEntity extends CraftEntity implements LivingEntity { getHandle().maxNoDamageTicks = ticks; } - public int getLastDamage() { + public double getLastDamage() { return getHandle().lastDamage; } - public void setLastDamage(int damage) { - getHandle().lastDamage = damage; + public void setLastDamage(double damage) { + getHandle().lastDamage = (float) damage; } public int getNoDamageTicks() { @@ -332,15 +334,17 @@ public class CraftLivingEntity extends CraftEntity implements LivingEntity { } public boolean hasLineOfSight(Entity other) { - return getHandle().getEntitySenses().canSee(((CraftEntity) other).getHandle()); + return getHandle() instanceof EntityInsentient && ((EntityInsentient) getHandle()).getEntitySenses().canSee(((CraftEntity) other).getHandle()); } public boolean getRemoveWhenFarAway() { - return !getHandle().persistent; + return getHandle() instanceof EntityInsentient && !((EntityInsentient) getHandle()).persistent; } public void setRemoveWhenFarAway(boolean remove) { - getHandle().persistent = !remove; + if (getHandle() instanceof EntityInsentient) { + ((EntityInsentient) getHandle()).persistent = !remove; + } } public EntityEquipment getEquipment() { @@ -348,11 +352,13 @@ public class CraftLivingEntity extends CraftEntity implements LivingEntity { } public void setCanPickupItems(boolean pickup) { - getHandle().canPickUpLoot = pickup; + if (getHandle() instanceof EntityInsentient) { + ((EntityInsentient) getHandle()).canPickUpLoot = pickup; + } } public boolean getCanPickupItems() { - return getHandle().canPickUpLoot; + return getHandle() instanceof EntityInsentient && ((EntityInsentient) getHandle()).canPickUpLoot; } @Override @@ -365,6 +371,10 @@ public class CraftLivingEntity extends CraftEntity implements LivingEntity { } public void setCustomName(String name) { + if (!(getHandle() instanceof EntityInsentient)) { + return; + } + if (name == null) { name = ""; } @@ -374,11 +384,15 @@ public class CraftLivingEntity extends CraftEntity implements LivingEntity { name = name.substring(0, 64); } - getHandle().setCustomName(name); + ((EntityInsentient) getHandle()).setCustomName(name); } public String getCustomName() { - String name = getHandle().getCustomName(); + if (!(getHandle() instanceof EntityInsentient)) { + return null; + } + + String name = ((EntityInsentient) getHandle()).getCustomName(); if (name == null || name.length() == 0) { return null; @@ -388,10 +402,52 @@ public class CraftLivingEntity extends CraftEntity implements LivingEntity { } public void setCustomNameVisible(boolean flag) { - getHandle().setCustomNameVisible(flag); + if (getHandle() instanceof EntityInsentient) { + ((EntityInsentient) getHandle()).setCustomNameVisible(flag); + } } public boolean isCustomNameVisible() { - return getHandle().getCustomNameVisible(); + return getHandle() instanceof EntityInsentient && ((EntityInsentient) getHandle()).getCustomNameVisible(); + } + + @Deprecated + public int _INVALID_getLastDamage() { + return NumberConversions.ceil(getLastDamage()); + } + + @Deprecated + public void _INVALID_setLastDamage(int damage) { + setLastDamage(damage); + } + + @Deprecated + public void _INVALID_damage(int amount) { + damage(amount); + } + + @Deprecated + public void _INVALID_damage(int amount, Entity source) { + damage(amount, source); + } + + @Deprecated + public int _INVALID_getHealth() { + return NumberConversions.ceil(getHealth()); + } + + @Deprecated + public void _INVALID_setHealth(int health) { + setHealth(health); + } + + @Deprecated + public int _INVALID_getMaxHealth() { + return NumberConversions.ceil(getMaxHealth()); + } + + @Deprecated + public void _INVALID_setMaxHealth(int health) { + setMaxHealth(health); } } diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftMinecart.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftMinecart.java index acbad192..daf6bb42 100644 --- a/src/main/java/org/bukkit/craftbukkit/entity/CraftMinecart.java +++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftMinecart.java @@ -4,6 +4,7 @@ import net.minecraft.server.EntityMinecartAbstract; import org.bukkit.craftbukkit.CraftServer; import org.bukkit.entity.Minecart; +import org.bukkit.util.NumberConversions; import org.bukkit.util.Vector; public abstract class CraftMinecart extends CraftVehicle implements Minecart { @@ -11,11 +12,11 @@ public abstract class CraftMinecart extends CraftVehicle implements Minecart { super(server, entity); } - public void setDamage(int damage) { - getHandle().setDamage(damage); + public void setDamage(double damage) { + getHandle().setDamage((float) damage); } - public int getDamage() { + public double getDamage() { return getHandle().getDamage(); } @@ -57,4 +58,14 @@ public abstract class CraftMinecart extends CraftVehicle implements Minecart { public EntityMinecartAbstract getHandle() { return (EntityMinecartAbstract) entity; } + + @Deprecated + public void _INVALID_setDamage(int damage) { + setDamage(damage); + } + + @Deprecated + public int _INVALID_getDamage() { + return NumberConversions.ceil(getDamage()); + } } diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java index 8c30bf5a..583b99c9 100644 --- a/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java +++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java @@ -89,7 +89,7 @@ public class CraftPlayer extends CraftHumanEntity implements Player { public boolean isOnline() { for (Object obj : server.getHandle().players) { EntityPlayer player = (EntityPlayer) obj; - if (player.name.equalsIgnoreCase(getName())) { + if (player.getName().equalsIgnoreCase(getName())) { return true; } } @@ -128,7 +128,7 @@ public class CraftPlayer extends CraftHumanEntity implements Player { public void sendRawMessage(String message) { if (getHandle().playerConnection == null) return; - getHandle().playerConnection.sendPacket(new Packet3Chat(message)); + getHandle().playerConnection.sendPacket(new Packet3Chat(ChatMessage.d(message))); } public void sendMessage(String message) { @@ -859,10 +859,12 @@ public class CraftPlayer extends CraftHumanEntity implements Player { } } + @Override public EntityType getType() { return EntityType.PLAYER; } + @Override public void setMetadata(String metadataKey, MetadataValue newMetadataValue) { server.getPlayerMetadata().setMetadata(this, metadataKey, newMetadataValue); } @@ -967,11 +969,13 @@ public class CraftPlayer extends CraftHumanEntity implements Player { } } - public void setMaxHealth(int amount) { + @Override + public void setMaxHealth(double amount) { super.setMaxHealth(amount); getHandle().triggerHealthUpdate(); } + @Override public void resetMaxHealth() { super.resetMaxHealth(); getHandle().triggerHealthUpdate(); diff --git a/src/main/java/org/bukkit/craftbukkit/event/CraftEventFactory.java b/src/main/java/org/bukkit/craftbukkit/event/CraftEventFactory.java index 2b56c75f..9986b7ac 100644 --- a/src/main/java/org/bukkit/craftbukkit/event/CraftEventFactory.java +++ b/src/main/java/org/bukkit/craftbukkit/event/CraftEventFactory.java @@ -13,6 +13,7 @@ import net.minecraft.server.EntityArrow; import net.minecraft.server.EntityDamageSource; import net.minecraft.server.EntityDamageSourceIndirect; import net.minecraft.server.EntityHuman; +import net.minecraft.server.EntityInsentient; import net.minecraft.server.EntityItem; import net.minecraft.server.EntityLiving; import net.minecraft.server.EntityPlayer; @@ -243,7 +244,7 @@ public class CraftEventFactory { /** * EntityTameEvent */ - public static EntityTameEvent callEntityTameEvent(EntityLiving entity, EntityHuman tamer) { + public static EntityTameEvent callEntityTameEvent(EntityInsentient entity, EntityHuman tamer) { org.bukkit.entity.Entity bukkitEntity = entity.getBukkitEntity(); org.bukkit.entity.AnimalTamer bukkitTamer = (tamer != null ? tamer.getBukkitEntity() : null); CraftServer craftServer = (CraftServer) bukkitEntity.getServer(); @@ -370,7 +371,7 @@ public class CraftEventFactory { /** * EntityDamage(ByEntityEvent) */ - public static EntityDamageEvent callEntityDamageEvent(Entity damager, Entity damagee, DamageCause cause, int damage) { + public static EntityDamageEvent callEntityDamageEvent(Entity damager, Entity damagee, DamageCause cause, double damage) { EntityDamageEvent event; if (damager != null) { event = new EntityDamageByEntityEvent(damager.getBukkitEntity(), damagee.getBukkitEntity(), cause, damage); @@ -387,7 +388,7 @@ public class CraftEventFactory { return event; } - public static EntityDamageEvent handleEntityDamageEvent(Entity entity, DamageSource source, int damage) { + public static EntityDamageEvent handleEntityDamageEvent(Entity entity, DamageSource source, float damage) { if (source instanceof EntityDamageSource) { Entity damager = source.getEntity(); DamageCause cause = DamageCause.ENTITY_ATTACK; @@ -443,7 +444,7 @@ public class CraftEventFactory { } // Non-Living Entities such as EntityEnderCrystal need to call this - public static boolean handleNonLivingEntityDamageEvent(Entity entity, DamageSource source, int damage) { + public static boolean handleNonLivingEntityDamageEvent(Entity entity, DamageSource source, float damage) { if (!(source instanceof EntityDamageSource)) { return false; } diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftEntityEquipment.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftEntityEquipment.java index 6e9f69ff..22134820 100644 --- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftEntityEquipment.java +++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftEntityEquipment.java @@ -1,5 +1,7 @@ package org.bukkit.craftbukkit.inventory; +import net.minecraft.server.EntityInsentient; + import org.bukkit.craftbukkit.entity.CraftLivingEntity; import org.bukkit.entity.Entity; import org.bukkit.inventory.EntityEquipment; @@ -133,10 +135,10 @@ public class CraftEntityEquipment implements EntityEquipment { } private void setDropChance(int slot, float chance) { - entity.getHandle().dropChances[slot] = chance - 0.1F; + ((EntityInsentient) entity.getHandle()).dropChances[slot] = chance - 0.1F; } private float getDropChance(int slot) { - return entity.getHandle().dropChances[slot] + 0.1F; + return ((EntityInsentient) entity.getHandle()).dropChances[slot] + 0.1F; } } diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftInventoryHorse.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftInventoryHorse.java new file mode 100644 index 00000000..bb5222eb --- /dev/null +++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftInventoryHorse.java @@ -0,0 +1,25 @@ +package org.bukkit.craftbukkit.inventory; + +import net.minecraft.server.IInventory; + +public class CraftInventoryHorse extends CraftInventory { + private final IInventory resultInventory = null; + + public CraftInventoryHorse(IInventory inventory) { + super(inventory); + } + + public IInventory getResultInventory() { + return resultInventory; + } + + public IInventory getIngredientsInventory() { + return inventory; + } + + @Override + public int getSize() { + //return getResultInventory().getSize() + getIngredientsInventory().getSize(); + return getIngredientsInventory().getSize(); + } +} diff --git a/src/test/java/org/bukkit/DyeColorsTest.java b/src/test/java/org/bukkit/DyeColorsTest.java index 8e252c0d..0e3a7c75 100644 --- a/src/test/java/org/bukkit/DyeColorsTest.java +++ b/src/test/java/org/bukkit/DyeColorsTest.java @@ -33,7 +33,7 @@ public class DyeColorsTest extends AbstractTestingBase { @Test public void checkColor() { Color color = dye.getColor(); - float[] nmsColorArray = EntitySheep.d[dye.getWoolData()]; + float[] nmsColorArray = EntitySheep.bp[dye.getWoolData()]; Color nmsColor = Color.fromRGB((int) (nmsColorArray[0] * 255), (int) (nmsColorArray[1] * 255), (int) (nmsColorArray[2] * 255)); assertThat(color, is(nmsColor)); } |