diff --git a/pom.xml b/pom.xml index d697ca1e6c..5a74ee9b7e 100644 --- a/pom.xml +++ b/pom.xml @@ -4,7 +4,7 @@ org.bukkit craftbukkit jar - 1.4.7-R1.1-SNAPSHOT + 1.5-R0.1-SNAPSHOT CraftBukkit http://www.bukkit.org @@ -12,8 +12,8 @@ UTF-8 unknown 4.11 - 1.4.7 - 1_4_R1 + 1.5 + 1_5_R1 diff --git a/src/main/java/net/minecraft/server/Block.java b/src/main/java/net/minecraft/server/Block.java index f29eace661..4392cb2dbc 100644 --- a/src/main/java/net/minecraft/server/Block.java +++ b/src/main/java/net/minecraft/server/Block.java @@ -6,177 +6,188 @@ import java.util.Random; public class Block { private CreativeModeTab creativeTab; - public static final StepSound d = new StepSound("stone", 1.0F, 1.0F); - public static final StepSound e = new StepSound("wood", 1.0F, 1.0F); - public static final StepSound f = new StepSound("gravel", 1.0F, 1.0F); - public static final StepSound g = new StepSound("grass", 1.0F, 1.0F); - public static final StepSound h = new StepSound("stone", 1.0F, 1.0F); - public static final StepSound i = new StepSound("stone", 1.0F, 1.5F); - public static final StepSound j = new StepSoundStone("stone", 1.0F, 1.0F); - public static final StepSound k = new StepSound("cloth", 1.0F, 1.0F); - public static final StepSound l = new StepSound("sand", 1.0F, 1.0F); - public static final StepSound m = new StepSound("snow", 1.0F, 1.0F); - public static final StepSound n = new StepSoundLadder("ladder", 1.0F, 1.0F); - public static final StepSound o = new StepSoundAnvil("anvil", 0.3F, 1.0F); + 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); public static final Block[] byId = new Block[4096]; - public static final boolean[] q = new boolean[4096]; - public static final int[] lightBlock = new int[4096]; public static final boolean[] s = new boolean[4096]; - public static final int[] lightEmission = new int[4096]; + public static final int[] lightBlock = new int[4096]; public static final boolean[] u = new boolean[4096]; - public static boolean[] v = new boolean[4096]; - public static final Block STONE = (new BlockStone(1, 1)).c(1.5F).b(10.0F).a(h).b("stone"); - public static final BlockGrass GRASS = (BlockGrass) (new BlockGrass(2)).c(0.6F).a(g).b("grass"); - public static final Block DIRT = (new BlockDirt(3, 2)).c(0.5F).a(f).b("dirt"); - public static final Block COBBLESTONE = (new Block(4, 16, Material.STONE)).c(2.0F).b(10.0F).a(h).b("stonebrick").a(CreativeModeTab.b); - public static final Block WOOD = (new BlockWood(5)).c(2.0F).b(5.0F).a(e).b("wood").r(); - public static final Block SAPLING = (new BlockSapling(6, 15)).c(0.0F).a(g).b("sapling").r(); - public static final Block BEDROCK = (new Block(7, 17, Material.STONE)).s().b(6000000.0F).a(h).b("bedrock").D().a(CreativeModeTab.b); - public static final Block WATER = (new BlockFlowing(8, Material.WATER)).c(100.0F).h(3).b("water").D().r(); - public static final Block STATIONARY_WATER = (new BlockStationary(9, Material.WATER)).c(100.0F).h(3).b("water").D().r(); - public static final Block LAVA = (new BlockFlowing(10, Material.LAVA)).c(0.0F).a(1.0F).h(255).b("lava").D().r(); - public static final Block STATIONARY_LAVA = (new BlockStationary(11, Material.LAVA)).c(100.0F).a(1.0F).h(255).b("lava").D().r(); - public static final Block SAND = (new BlockSand(12, 18)).c(0.5F).a(l).b("sand"); - public static final Block GRAVEL = (new BlockGravel(13, 19)).c(0.6F).a(f).b("gravel"); - public static final Block GOLD_ORE = (new BlockOre(14, 32)).c(3.0F).b(5.0F).a(h).b("oreGold"); - public static final Block IRON_ORE = (new BlockOre(15, 33)).c(3.0F).b(5.0F).a(h).b("oreIron"); - public static final Block COAL_ORE = (new BlockOre(16, 34)).c(3.0F).b(5.0F).a(h).b("oreCoal"); - public static final Block LOG = (new BlockLog(17)).c(2.0F).a(e).b("log").r(); - public static final BlockLeaves LEAVES = (BlockLeaves) (new BlockLeaves(18, 52)).c(0.2F).h(1).a(g).b("leaves").r(); - public static final Block SPONGE = (new BlockSponge(19)).c(0.6F).a(g).b("sponge"); - public static final Block GLASS = (new BlockGlass(20, 49, Material.SHATTERABLE, false)).c(0.3F).a(j).b("glass"); - public static final Block LAPIS_ORE = (new BlockOre(21, 160)).c(3.0F).b(5.0F).a(h).b("oreLapis"); - public static final Block LAPIS_BLOCK = (new Block(22, 144, Material.STONE)).c(3.0F).b(5.0F).a(h).b("blockLapis").a(CreativeModeTab.b); - public static final Block DISPENSER = (new BlockDispenser(23)).c(3.5F).a(h).b("dispenser").r(); - public static final Block SANDSTONE = (new BlockSandStone(24)).a(h).c(0.8F).b("sandStone").r(); - public static final Block NOTE_BLOCK = (new BlockNote(25)).c(0.8F).b("musicBlock").r(); - public static final Block BED = (new BlockBed(26)).c(0.2F).b("bed").D().r(); - public static final Block GOLDEN_RAIL = (new BlockMinecartTrack(27, 179, true)).c(0.7F).a(i).b("goldenRail").r(); - public static final Block DETECTOR_RAIL = (new BlockMinecartDetector(28, 195)).c(0.7F).a(i).b("detectorRail").r(); - public static final Block PISTON_STICKY = (new BlockPiston(29, 106, true)).b("pistonStickyBase").r(); - public static final Block WEB = (new BlockWeb(30, 11)).h(1).c(4.0F).b("web"); - public static final BlockLongGrass LONG_GRASS = (BlockLongGrass) (new BlockLongGrass(31, 39)).c(0.0F).a(g).b("tallgrass"); - public static final BlockDeadBush DEAD_BUSH = (BlockDeadBush) (new BlockDeadBush(32, 55)).c(0.0F).a(g).b("deadbush"); - public static final Block PISTON = (new BlockPiston(33, 107, false)).b("pistonBase").r(); - public static final BlockPistonExtension PISTON_EXTENSION = (BlockPistonExtension) (new BlockPistonExtension(34, 107)).r(); - public static final Block WOOL = (new BlockCloth()).c(0.8F).a(k).b("cloth").r(); + 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 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 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 BlockPistonMoving PISTON_MOVING = new BlockPistonMoving(36); - public static final BlockFlower YELLOW_FLOWER = (BlockFlower) (new BlockFlower(37, 13)).c(0.0F).a(g).b("flower"); - public static final BlockFlower RED_ROSE = (BlockFlower) (new BlockFlower(38, 12)).c(0.0F).a(g).b("rose"); - public static final BlockFlower BROWN_MUSHROOM = (BlockFlower) (new BlockMushroom(39, 29)).c(0.0F).a(g).a(0.125F).b("mushroom"); - public static final BlockFlower RED_MUSHROOM = (BlockFlower) (new BlockMushroom(40, 28)).c(0.0F).a(g).b("mushroom"); - public static final Block GOLD_BLOCK = (new BlockOreBlock(41, 23)).c(3.0F).b(10.0F).a(i).b("blockGold"); - public static final Block IRON_BLOCK = (new BlockOreBlock(42, 22)).c(5.0F).b(10.0F).a(i).b("blockIron"); - public static final BlockStepAbstract DOUBLE_STEP = (BlockStepAbstract) (new BlockStep(43, true)).c(2.0F).b(10.0F).a(h).b("stoneSlab"); - public static final BlockStepAbstract STEP = (BlockStepAbstract) (new BlockStep(44, false)).c(2.0F).b(10.0F).a(h).b("stoneSlab"); - public static final Block BRICK = (new Block(45, 7, Material.STONE)).c(2.0F).b(10.0F).a(h).b("brick").a(CreativeModeTab.b); - public static final Block TNT = (new BlockTNT(46, 8)).c(0.0F).a(g).b("tnt"); - public static final Block BOOKSHELF = (new BlockBookshelf(47, 35)).c(1.5F).a(e).b("bookshelf"); - public static final Block MOSSY_COBBLESTONE = (new Block(48, 36, Material.STONE)).c(2.0F).b(10.0F).a(h).b("stoneMoss").a(CreativeModeTab.b); - public static final Block OBSIDIAN = (new BlockObsidian(49, 37)).c(50.0F).b(2000.0F).a(h).b("obsidian"); - public static final Block TORCH = (new BlockTorch(50, 80)).c(0.0F).a(0.9375F).a(e).b("torch").r(); - public static final BlockFire FIRE = (BlockFire) (new BlockFire(51, 31)).c(0.0F).a(1.0F).a(e).b("fire").D(); - public static final Block MOB_SPAWNER = (new BlockMobSpawner(52, 65)).c(5.0F).a(i).b("mobSpawner").D(); - public static final Block WOOD_STAIRS = (new BlockStairs(53, WOOD, 0)).b("stairsWood").r(); - public static final Block CHEST = (new BlockChest(54)).c(2.5F).a(e).b("chest").r(); - public static final Block REDSTONE_WIRE = (new BlockRedstoneWire(55, 164)).c(0.0F).a(d).b("redstoneDust").D().r(); - public static final Block DIAMOND_ORE = (new BlockOre(56, 50)).c(3.0F).b(5.0F).a(h).b("oreDiamond"); - public static final Block DIAMOND_BLOCK = (new BlockOreBlock(57, 24)).c(5.0F).b(10.0F).a(i).b("blockDiamond"); - public static final Block WORKBENCH = (new BlockWorkbench(58)).c(2.5F).a(e).b("workbench"); - public static final Block CROPS = (new BlockCrops(59, 88)).b("crops"); - public static final Block SOIL = (new BlockSoil(60)).c(0.6F).a(f).b("farmland").r(); - public static final Block FURNACE = (new BlockFurnace(61, false)).c(3.5F).a(h).b("furnace").r().a(CreativeModeTab.c); - public static final Block BURNING_FURNACE = (new BlockFurnace(62, true)).c(3.5F).a(h).a(0.875F).b("furnace").r(); - public static final Block SIGN_POST = (new BlockSign(63, TileEntitySign.class, true)).c(1.0F).a(e).b("sign").D().r(); - public static final Block WOODEN_DOOR = (new BlockDoor(64, Material.WOOD)).c(3.0F).a(e).b("doorWood").D().r(); - public static final Block LADDER = (new BlockLadder(65, 83)).c(0.4F).a(n).b("ladder").r(); - public static final Block RAILS = (new BlockMinecartTrack(66, 128, false)).c(0.7F).a(i).b("rail").r(); - public static final Block COBBLESTONE_STAIRS = (new BlockStairs(67, COBBLESTONE, 0)).b("stairsStone").r(); - public static final Block WALL_SIGN = (new BlockSign(68, TileEntitySign.class, false)).c(1.0F).a(e).b("sign").D().r(); - public static final Block LEVER = (new BlockLever(69, 96)).c(0.5F).a(e).b("lever").r(); - public static final Block STONE_PLATE = (new BlockPressurePlate(70, STONE.textureId, EnumMobType.MOBS, Material.STONE)).c(0.5F).a(h).b("pressurePlate").r(); - public static final Block IRON_DOOR_BLOCK = (new BlockDoor(71, Material.ORE)).c(5.0F).a(i).b("doorIron").D().r(); - public static final Block WOOD_PLATE = (new BlockPressurePlate(72, WOOD.textureId, EnumMobType.EVERYTHING, Material.WOOD)).c(0.5F).a(e).b("pressurePlate").r(); - public static final Block REDSTONE_ORE = (new BlockRedstoneOre(73, 51, false)).c(3.0F).b(5.0F).a(h).b("oreRedstone").r().a(CreativeModeTab.b); - public static final Block GLOWING_REDSTONE_ORE = (new BlockRedstoneOre(74, 51, true)).a(0.625F).c(3.0F).b(5.0F).a(h).b("oreRedstone").r(); - public static final Block REDSTONE_TORCH_OFF = (new BlockRedstoneTorch(75, 115, false)).c(0.0F).a(e).b("notGate").r(); - public static final Block REDSTONE_TORCH_ON = (new BlockRedstoneTorch(76, 99, true)).c(0.0F).a(0.5F).a(e).b("notGate").r().a(CreativeModeTab.d); - public static final Block STONE_BUTTON = (new BlockButton(77, STONE.textureId, false)).c(0.5F).a(h).b("button").r(); - public static final Block SNOW = (new BlockSnow(78, 66)).c(0.1F).a(m).b("snow").r().h(0); - public static final Block ICE = (new BlockIce(79, 67)).c(0.5F).h(3).a(j).b("ice"); - public static final Block SNOW_BLOCK = (new BlockSnowBlock(80, 66)).c(0.2F).a(m).b("snow"); - public static final Block CACTUS = (new BlockCactus(81, 70)).c(0.4F).a(k).b("cactus"); - public static final Block CLAY = (new BlockClay(82, 72)).c(0.6F).a(f).b("clay"); - public static final Block SUGAR_CANE_BLOCK = (new BlockReed(83, 73)).c(0.0F).a(g).b("reeds").D(); - public static final Block JUKEBOX = (new BlockJukeBox(84, 74)).c(2.0F).b(10.0F).a(h).b("jukebox").r(); - public static final Block FENCE = (new BlockFence(85, 4)).c(2.0F).b(5.0F).a(e).b("fence"); - public static final Block PUMPKIN = (new BlockPumpkin(86, 102, false)).c(1.0F).a(e).b("pumpkin").r(); - public static final Block NETHERRACK = (new BlockBloodStone(87, 103)).c(0.4F).a(h).b("hellrock"); - public static final Block SOUL_SAND = (new BlockSlowSand(88, 104)).c(0.5F).a(l).b("hellsand"); - public static final Block GLOWSTONE = (new BlockLightStone(89, 105, Material.SHATTERABLE)).c(0.3F).a(j).a(1.0F).b("lightgem"); - public static final BlockPortal PORTAL = (BlockPortal) (new BlockPortal(90, 14)).c(-1.0F).a(j).a(0.75F).b("portal"); - public static final Block JACK_O_LANTERN = (new BlockPumpkin(91, 102, true)).c(1.0F).a(e).a(1.0F).b("litpumpkin").r(); - public static final Block CAKE_BLOCK = (new BlockCake(92, 121)).c(0.5F).a(k).b("cake").D().r(); - public static final Block DIODE_OFF = (new BlockDiode(93, false)).c(0.0F).a(e).b("diode").D().r(); - public static final Block DIODE_ON = (new BlockDiode(94, true)).c(0.0F).a(0.625F).a(e).b("diode").D().r(); - public static final Block LOCKED_CHEST = (new BlockLockedChest(95)).c(0.0F).a(1.0F).a(e).b("lockedchest").b(true).r(); - public static final Block TRAP_DOOR = (new BlockTrapdoor(96, Material.WOOD)).c(3.0F).a(e).b("trapdoor").D().r(); - public static final Block MONSTER_EGGS = (new BlockMonsterEggs(97)).c(0.75F).b("monsterStoneEgg"); - public static final Block SMOOTH_BRICK = (new BlockSmoothBrick(98)).c(1.5F).b(10.0F).a(h).b("stonebricksmooth"); - public static final Block BIG_MUSHROOM_1 = (new BlockHugeMushroom(99, Material.WOOD, 142, 0)).c(0.2F).a(e).b("mushroom").r(); - public static final Block BIG_MUSHROOM_2 = (new BlockHugeMushroom(100, Material.WOOD, 142, 1)).c(0.2F).a(e).b("mushroom").r(); - public static final Block IRON_FENCE = (new BlockThinFence(101, 85, 85, Material.ORE, true)).c(5.0F).b(10.0F).a(i).b("fenceIron"); - public static final Block THIN_GLASS = (new BlockThinFence(102, 49, 148, Material.SHATTERABLE, false)).c(0.3F).a(j).b("thinGlass"); - public static final Block MELON = (new BlockMelon(103)).c(1.0F).a(e).b("melon"); - public static final Block PUMPKIN_STEM = (new BlockStem(104, PUMPKIN)).c(0.0F).a(e).b("pumpkinStem").r(); - public static final Block MELON_STEM = (new BlockStem(105, MELON)).c(0.0F).a(e).b("pumpkinStem").r(); - public static final Block VINE = (new BlockVine(106)).c(0.2F).a(g).b("vine").r(); - public static final Block FENCE_GATE = (new BlockFenceGate(107, 4)).c(2.0F).b(5.0F).a(e).b("fenceGate").r(); - public static final Block BRICK_STAIRS = (new BlockStairs(108, BRICK, 0)).b("stairsBrick").r(); - public static final Block STONE_STAIRS = (new BlockStairs(109, SMOOTH_BRICK, 0)).b("stairsStoneBrickSmooth").r(); - public static final BlockMycel MYCEL = (BlockMycel) (new BlockMycel(110)).c(0.6F).a(g).b("mycel"); - public static final Block WATER_LILY = (new BlockWaterLily(111, 76)).c(0.0F).a(g).b("waterlily"); - public static final Block NETHER_BRICK = (new Block(112, 224, Material.STONE)).c(2.0F).b(10.0F).a(h).b("netherBrick").a(CreativeModeTab.b); - public static final Block NETHER_FENCE = (new BlockFence(113, 224, Material.STONE)).c(2.0F).b(10.0F).a(h).b("netherFence"); - public static final Block NETHER_BRICK_STAIRS = (new BlockStairs(114, NETHER_BRICK, 0)).b("stairsNetherBrick").r(); - public static final Block NETHER_WART = (new BlockNetherWart(115)).b("netherStalk").r(); - public static final Block ENCHANTMENT_TABLE = (new BlockEnchantmentTable(116)).c(5.0F).b(2000.0F).b("enchantmentTable"); - public static final Block BREWING_STAND = (new BlockBrewingStand(117)).c(0.5F).a(0.125F).b("brewingStand").r(); - public static final Block CAULDRON = (new BlockCauldron(118)).c(2.0F).b("cauldron").r(); + 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 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 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 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 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 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 ENDER_PORTAL = (new BlockEnderPortal(119, Material.PORTAL)).c(-1.0F).b(6000000.0F); - public static final Block ENDER_PORTAL_FRAME = (new BlockEnderPortalFrame(120)).a(j).a(0.125F).c(-1.0F).b("endPortalFrame").r().b(6000000.0F).a(CreativeModeTab.c); - public static final Block WHITESTONE = (new Block(121, 175, Material.STONE)).c(3.0F).b(15.0F).a(h).b("whiteStone").a(CreativeModeTab.b); - public static final Block DRAGON_EGG = (new BlockDragonEgg(122, 167)).c(3.0F).b(15.0F).a(h).a(0.125F).b("dragonEgg"); - public static final Block REDSTONE_LAMP_OFF = (new BlockRedstoneLamp(123, false)).c(0.3F).a(j).b("redstoneLight").a(CreativeModeTab.d); - public static final Block REDSTONE_LAMP_ON = (new BlockRedstoneLamp(124, true)).c(0.3F).a(j).b("redstoneLight"); - public static final BlockStepAbstract WOOD_DOUBLE_STEP = (BlockStepAbstract) (new BlockWoodStep(125, true)).c(2.0F).b(5.0F).a(e).b("woodSlab"); - public static final BlockStepAbstract WOOD_STEP = (BlockStepAbstract) (new BlockWoodStep(126, false)).c(2.0F).b(5.0F).a(e).b("woodSlab"); - public static final Block COCOA = (new BlockCocoa(127)).c(0.2F).b(5.0F).a(e).b("cocoa").r(); - public static final Block SANDSTONE_STAIRS = (new BlockStairs(128, SANDSTONE, 0)).b("stairsSandStone").r(); - public static final Block EMERALD_ORE = (new BlockOre(129, 171)).c(3.0F).b(5.0F).a(h).b("oreEmerald"); - public static final Block ENDER_CHEST = (new BlockEnderChest(130)).c(22.5F).b(1000.0F).a(h).b("enderChest").r().a(0.5F); - public static final BlockTripwireHook TRIPWIRE_SOURCE = (BlockTripwireHook) (new BlockTripwireHook(131)).b("tripWireSource").r(); - public static final Block TRIPWIRE = (new BlockTripwire(132)).b("tripWire").r(); - public static final Block EMERALD_BLOCK = (new BlockOreBlock(133, 25)).c(5.0F).b(10.0F).a(i).b("blockEmerald"); - public static final Block SPRUCE_WOOD_STAIRS = (new BlockStairs(134, WOOD, 1)).b("stairsWoodSpruce").r(); - public static final Block BIRCH_WOOD_STAIRS = (new BlockStairs(135, WOOD, 2)).b("stairsWoodBirch").r(); - public static final Block JUNGLE_WOOD_STAIRS = (new BlockStairs(136, WOOD, 3)).b("stairsWoodJungle").r(); - public static final Block COMMAND = (new BlockCommand(137)).b("commandBlock"); - public static final Block BEACON = (new BlockBeacon(138)).b("beacon").a(1.0F); - public static final Block COBBLE_WALL = (new BlockCobbleWall(139, COBBLESTONE)).b("cobbleWall"); - public static final Block FLOWER_POT = (new BlockFlowerPot(140)).c(0.0F).a(d).b("flowerPot"); - public static final Block CARROTS = (new BlockCarrots(141)).b("carrots"); - public static final Block POTATOES = (new BlockPotatoes(142)).b("potatoes"); - public static final Block WOOD_BUTTON = (new BlockButton(143, WOOD.textureId, true)).c(0.5F).a(e).b("button").r(); - public static final Block SKULL = (new BlockSkull(144)).c(1.0F).a(h).b("skull").r(); - public static final Block ANVIL = (new BlockAnvil(145)).c(5.0F).a(o).b(2000.0F).b("anvil").r(); - public int textureId; + 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 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 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 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 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 final int id; protected float strength; protected float durability; - protected boolean cp; - protected boolean cq; - protected boolean cr; + protected boolean cC = true; + protected boolean cD = true; + protected boolean cE; protected boolean isTileEntity; protected double minX; protected double minY; @@ -185,16 +196,14 @@ public class Block { protected double maxY; protected double maxZ; public StepSound stepSound; - public float cA; + public float cN; public final Material material; public float frictionFactor; private String name; protected Block(int i, Material material) { - this.cp = true; - this.cq = true; - this.stepSound = d; - this.cA = 1.0F; + this.stepSound = f; + this.cN = 1.0F; this.frictionFactor = 0.6F; if (byId[i] != null) { throw new IllegalArgumentException("Slot " + i + " is already occupied by " + byId[i] + " when adding " + this); @@ -203,30 +212,20 @@ public class Block { byId[i] = this; this.id = i; this.a(0.0F, 0.0F, 0.0F, 1.0F, 1.0F, 1.0F); - q[i] = this.c(); + s[i] = this.c(); lightBlock[i] = this.c() ? 255 : 0; - s[i] = !material.blocksLight(); + u[i] = !material.blocksLight(); } } - protected Block r() { - u[this.id] = true; - return this; - } - - protected void t_() {} - - protected Block(int i, int j, Material material) { - this(i, material); - this.textureId = j; - } + protected void s_() {} protected Block a(StepSound stepsound) { this.stepSound = stepsound; return this; } - protected Block h(int i) { + protected Block k(int i) { lightBlock[this.id] = i; return this; } @@ -241,17 +240,17 @@ public class Block { return this; } - public static boolean i(int i) { + public static boolean l(int i) { Block block = byId[i]; - return block == null ? false : block.material.k() && block.b(); + return block == null ? false : block.material.k() && block.b() && !block.isPowerSource(); } public boolean b() { return true; } - public boolean c(IBlockAccess iblockaccess, int i, int j, int k) { + public boolean b(IBlockAccess iblockaccess, int i, int j, int k) { return !this.material.isSolid(); } @@ -268,25 +267,25 @@ public class Block { return this; } - protected Block s() { + protected Block r() { this.c(-1.0F); return this; } - public float m(World world, int i, int j, int k) { + public float l(World world, int i, int j, int k) { return this.strength; } protected Block b(boolean flag) { - this.cr = flag; + this.cE = flag; return this; } public boolean isTicking() { - return this.cr; + return this.cE; } - public boolean u() { + public boolean t() { return this.isTileEntity; } @@ -303,23 +302,15 @@ public class Block { return iblockaccess.getMaterial(i, j, k).isBuildable(); } - public int a(int i, int j) { - return this.a(i); - } - - public int a(int i) { - return this.textureId; - } - public void a(World world, int i, int j, int k, AxisAlignedBB axisalignedbb, List list, Entity entity) { - AxisAlignedBB axisalignedbb1 = this.e(world, i, j, k); + AxisAlignedBB axisalignedbb1 = this.b(world, i, j, k); if (axisalignedbb1 != null && axisalignedbb.a(axisalignedbb1)) { list.add(axisalignedbb1); } } - public AxisAlignedBB e(World world, int i, int j, int k) { + public AxisAlignedBB b(World world, int i, int j, int k) { return AxisAlignedBB.a().a((double) i + this.minX, (double) j + this.minY, (double) k + this.minZ, (double) i + this.maxX, (double) j + this.maxY, (double) k + this.maxZ); } @@ -335,13 +326,13 @@ public class Block { return true; } - public void b(World world, int i, int j, int k, Random random) {} + public void a(World world, int i, int j, int k, Random random) {} public void postBreak(World world, int i, int j, int k, int l) {} public void doPhysics(World world, int i, int j, int k, int l) {} - public int r_() { + public int a(World world) { return 10; } @@ -358,9 +349,9 @@ public class Block { } public float getDamage(EntityHuman entityhuman, World world, int i, int j, int k) { - float f = this.m(world, i, j, k); + float f = this.l(world, i, j, k); - return f < 0.0F ? 0.0F : (!entityhuman.b(this) ? 1.0F / f / 100.0F : entityhuman.a(this) / f / 30.0F); + return f < 0.0F ? 0.0F : (!entityhuman.a(this) ? entityhuman.a(this, false) / f / 100.0F : entityhuman.a(this, true) / f / 30.0F); } public final void c(World world, int i, int j, int k, int l, int i1) { @@ -397,7 +388,7 @@ public class Block { } } - protected void f(World world, int i, int j, int k, int l) { + protected void j(World world, int i, int j, int k, int l) { if (!world.isStatic) { while (l > 0) { int i1 = EntityExperienceOrb.getOrbValue(l); @@ -522,7 +513,11 @@ public class Block { return vec3d == null ? false : vec3d.c >= this.minX && vec3d.c <= this.maxX && vec3d.d >= this.minY && vec3d.d <= this.maxY; } - public void wasExploded(World world, int i, int j, int k) {} + public void wasExploded(World world, int i, int j, int k, Explosion explosion) {} + + public boolean canPlace(World world, int i, int j, int k, int l, ItemStack itemstack) { + return this.canPlace(world, i, j, k, l); + } public boolean canPlace(World world, int i, int j, int k, int l) { return this.canPlace(world, i, j, k); @@ -550,32 +545,32 @@ public class Block { public void updateShape(IBlockAccess iblockaccess, int i, int j, int k) {} - public final double v() { + public final double u() { return this.minX; } - public final double w() { + public final double v() { return this.maxX; } - public final double x() { + public final double w() { return this.minY; } - public final double y() { + public final double x() { return this.maxY; } - public final double z() { + public final double y() { return this.minZ; } - public final double A() { + public final double z() { return this.maxZ; } - public boolean b(IBlockAccess iblockaccess, int i, int j, int k, int l) { - return false; + public int b(IBlockAccess iblockaccess, int i, int j, int k, int l) { + return 0; } public boolean isPowerSource() { @@ -584,17 +579,17 @@ public class Block { public void a(World world, int i, int j, int k, Entity entity) {} - public boolean c(IBlockAccess iblockaccess, int i, int j, int k, int l) { - return false; + public int c(IBlockAccess iblockaccess, int i, int j, int k, int l) { + return 0; } - public void f() {} + public void g() {} 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); - if (this.s_() && EnchantmentManager.hasSilkTouchEnchantment(entityhuman)) { - ItemStack itemstack = this.f_(l); + if (this.r_() && EnchantmentManager.hasSilkTouchEnchantment(entityhuman)) { + ItemStack itemstack = this.c_(l); if (itemstack != null) { this.b(world, i, j, k, itemstack); @@ -606,14 +601,14 @@ public class Block { } } - protected boolean s_() { + protected boolean r_() { return this.b() && !this.isTileEntity; } - protected ItemStack f_(int i) { + protected ItemStack c_(int i) { int j = 0; - if (this.id >= 0 && this.id < Item.byId.length && Item.byId[this.id].l()) { + if (this.id >= 0 && this.id < Item.byId.length && Item.byId[this.id].m()) { j = i; } @@ -624,16 +619,16 @@ public class Block { return this.a(random); } - public boolean d(World world, int i, int j, int k) { + public boolean f(World world, int i, int j, int k) { return true; } - public void postPlace(World world, int i, int j, int k, EntityLiving entityliving) {} + public void postPlace(World world, int i, int j, int k, EntityLiving entityliving, ItemStack itemstack) {} public void postPlace(World world, int i, int j, int k, int l) {} - public Block b(String s) { - this.name = "tile." + s; + public Block c(String s) { + this.name = s; return this; } @@ -642,21 +637,23 @@ public class Block { } public String a() { - return this.name; + return "tile." + this.name; } - public void b(World world, int i, int j, int k, int l, int i1) {} + public boolean b(World world, int i, int j, int k, int l, int i1) { + return false; + } public boolean C() { - return this.cq; + return this.cD; } protected Block D() { - this.cq = false; + this.cD = false; return this; } - public int q_() { + public int h() { return this.material.getPushReaction(); } @@ -673,9 +670,9 @@ public class Block { public void a(World world, int i, int j, int k, int l, EntityHuman entityhuman) {} - public void h(World world, int i, int j, int k, int l) {} + public void l(World world, int i, int j, int k, int l) {} - public void f(World world, int i, int j, int k) {} + public void g(World world, int i, int j, int k) {} public boolean l() { return true; @@ -685,6 +682,22 @@ public class Block { return true; } + public boolean i(int i) { + return this.id == i; + } + + public static boolean b(int i, int j) { + return i == j ? true : (i != 0 && j != 0 && byId[i] != null && byId[j] != null ? byId[i].i(j) : false); + } + + public boolean q_() { + return false; + } + + public int b_(World world, int i, int j, int k, int l) { + return 0; + } + 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"); @@ -692,6 +705,7 @@ public class Block { 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"); Item.byId[SANDSTONE.id] = (new ItemMultiTexture(SANDSTONE.id - 256, SANDSTONE, BlockSandStone.a)).b("sandStone"); + Item.byId[QUARTZ_BLOCK.id] = (new ItemMultiTexture(QUARTZ_BLOCK.id - 256, QUARTZ_BLOCK, BlockQuartz.a)).b("quartzBlock"); Item.byId[STEP.id] = (new ItemStep(STEP.id - 256, STEP, DOUBLE_STEP, false)).b("stoneSlab"); Item.byId[DOUBLE_STEP.id] = (new ItemStep(DOUBLE_STEP.id - 256, STEP, DOUBLE_STEP, true)).b("stoneSlab"); Item.byId[WOOD_STEP.id] = (new ItemStep(WOOD_STEP.id - 256, WOOD_STEP, WOOD_DOUBLE_STEP, false)).b("woodSlab"); @@ -700,6 +714,7 @@ public class Block { Item.byId[LEAVES.id] = (new ItemLeaves(LEAVES.id - 256)).b("leaves"); Item.byId[VINE.id] = new ItemWithAuxData(VINE.id - 256, false); Item.byId[LONG_GRASS.id] = (new ItemWithAuxData(LONG_GRASS.id - 256, true)).a(new String[] { "shrub", "grass", "fern"}); + Item.byId[SNOW.id] = new ItemSnow(SNOW.id - 256, SNOW); Item.byId[WATER_LILY.id] = new ItemWaterLily(WATER_LILY.id - 256); Item.byId[PISTON.id] = new ItemPiston(PISTON.id - 256); Item.byId[PISTON_STICKY.id] = new ItemPiston(PISTON_STICKY.id - 256); @@ -715,7 +730,7 @@ public class Block { if (byId[i] != null) { if (Item.byId[i] == null) { Item.byId[i] = new ItemBlock(i - 256); - byId[i].t_(); + byId[i].s_(); } boolean flag = false; @@ -732,7 +747,7 @@ public class Block { flag = true; } - if (s[i]) { + if (u[i]) { flag = true; } @@ -740,11 +755,11 @@ public class Block { flag = true; } - v[i] = flag; + w[i] = flag; } } - s[0] = true; + u[0] = true; StatisticList.b(); } diff --git a/src/main/java/net/minecraft/server/BlockBloodStone.java b/src/main/java/net/minecraft/server/BlockBloodStone.java index fb891933e6..91be87e1bf 100644 --- a/src/main/java/net/minecraft/server/BlockBloodStone.java +++ b/src/main/java/net/minecraft/server/BlockBloodStone.java @@ -4,8 +4,8 @@ import org.bukkit.event.block.BlockRedstoneEvent; // CraftBukkit public class BlockBloodStone extends Block { - public BlockBloodStone(int i, int j) { - super(i, j, Material.STONE); + public BlockBloodStone(int i) { + super(i, Material.STONE); this.a(CreativeModeTab.b); } diff --git a/src/main/java/net/minecraft/server/BlockButton.java b/src/main/java/net/minecraft/server/BlockButtonAbstract.java similarity index 72% rename from src/main/java/net/minecraft/server/BlockButton.java rename to src/main/java/net/minecraft/server/BlockButtonAbstract.java index ab8bc44f50..b8f62e5b9f 100644 --- a/src/main/java/net/minecraft/server/BlockButton.java +++ b/src/main/java/net/minecraft/server/BlockButtonAbstract.java @@ -8,22 +8,22 @@ import org.bukkit.event.block.BlockRedstoneEvent; import org.bukkit.event.entity.EntityInteractEvent; // CraftBukkit end -public class BlockButton extends Block { +public abstract class BlockButtonAbstract extends Block { private final boolean a; - protected BlockButton(int i, int j, boolean flag) { - super(i, j, Material.ORIENTABLE); + protected BlockButtonAbstract(int i, boolean flag) { + super(i, Material.ORIENTABLE); this.b(true); this.a(CreativeModeTab.d); this.a = flag; } - public AxisAlignedBB e(World world, int i, int j, int k) { + public AxisAlignedBB b(World world, int i, int j, int k) { return null; } - public int r_() { + public int a(World world) { return this.a ? 30 : 20; } @@ -36,11 +36,11 @@ public class BlockButton extends Block { } public boolean canPlace(World world, int i, int j, int k, int l) { - return l == 2 && world.t(i, j, k + 1) ? true : (l == 3 && world.t(i, j, k - 1) ? true : (l == 4 && world.t(i + 1, j, k) ? true : l == 5 && world.t(i - 1, j, k))); + return l == 2 && world.u(i, j, k + 1) ? true : (l == 3 && world.u(i, j, k - 1) ? true : (l == 4 && world.u(i + 1, j, k) ? true : l == 5 && world.u(i - 1, j, k))); } public boolean canPlace(World world, int i, int j, int k) { - return world.t(i - 1, j, k) ? true : (world.t(i + 1, j, k) ? true : (world.t(i, j, k - 1) ? true : world.t(i, j, k + 1))); + return world.u(i - 1, j, k) ? true : (world.u(i + 1, j, k) ? true : (world.u(i, j, k - 1) ? true : world.u(i, j, k + 1))); } public int getPlacedData(World world, int i, int j, int k, int l, float f, float f1, float f2, int i1) { @@ -48,57 +48,57 @@ public class BlockButton extends Block { int k1 = j1 & 8; j1 &= 7; - if (l == 2 && world.t(i, j, k + 1)) { + if (l == 2 && world.u(i, j, k + 1)) { j1 = 4; - } else if (l == 3 && world.t(i, j, k - 1)) { + } else if (l == 3 && world.u(i, j, k - 1)) { j1 = 3; - } else if (l == 4 && world.t(i + 1, j, k)) { + } else if (l == 4 && world.u(i + 1, j, k)) { j1 = 2; - } else if (l == 5 && world.t(i - 1, j, k)) { + } else if (l == 5 && world.u(i - 1, j, k)) { j1 = 1; } else { - j1 = this.l(world, i, j, k); + j1 = this.k(world, i, j, k); } return j1 + k1; } - private int l(World world, int i, int j, int k) { - return world.t(i - 1, j, k) ? 1 : (world.t(i + 1, j, k) ? 2 : (world.t(i, j, k - 1) ? 3 : (world.t(i, j, k + 1) ? 4 : 1))); + private int k(World world, int i, int j, int k) { + return world.u(i - 1, j, k) ? 1 : (world.u(i + 1, j, k) ? 2 : (world.u(i, j, k - 1) ? 3 : (world.u(i, j, k + 1) ? 4 : 1))); } public void doPhysics(World world, int i, int j, int k, int l) { - if (this.n(world, i, j, k)) { + if (this.m(world, i, j, k)) { int i1 = world.getData(i, j, k) & 7; boolean flag = false; - if (!world.t(i - 1, j, k) && i1 == 1) { + if (!world.u(i - 1, j, k) && i1 == 1) { flag = true; } - if (!world.t(i + 1, j, k) && i1 == 2) { + if (!world.u(i + 1, j, k) && i1 == 2) { flag = true; } - if (!world.t(i, j, k - 1) && i1 == 3) { + if (!world.u(i, j, k - 1) && i1 == 3) { flag = true; } - if (!world.t(i, j, k + 1) && i1 == 4) { + if (!world.u(i, j, k + 1) && i1 == 4) { flag = true; } if (flag) { this.c(world, i, j, k, world.getData(i, j, k), 0); - world.setTypeId(i, j, k, 0); + world.setAir(i, j, k); } } } - private boolean n(World world, int i, int j, int k) { + private boolean m(World world, int i, int j, int k) { if (!this.canPlace(world, i, j, k)) { this.c(world, i, j, k, world.getData(i, j, k), 0); - world.setTypeId(i, j, k, 0); + world.setAir(i, j, k); return false; } else { return true; @@ -108,10 +108,10 @@ public class BlockButton extends Block { public void updateShape(IBlockAccess iblockaccess, int i, int j, int k) { int l = iblockaccess.getData(i, j, k); - this.e(l); + this.d(l); } - private void e(int i) { + private void d(int i) { int j = i & 7; boolean flag = (i & 8) > 0; float f = 0.375F; @@ -146,8 +146,8 @@ public class BlockButton extends Block { } else { // CraftBukkit start org.bukkit.block.Block block = world.getWorld().getBlockAt(i, j, k); - int old = (k1 != 8) ? 1 : 0; - int current = (k1 == 8) ? 1 : 0; + int old = (k1 != 8) ? 15 : 0; + int current = (k1 == 8) ? 15 : 0; BlockRedstoneEvent eventRedstone = new BlockRedstoneEvent(block, old, current); world.getServer().getPluginManager().callEvent(eventRedstone); @@ -157,11 +157,11 @@ public class BlockButton extends Block { } // CraftBukkit end - world.setData(i, j, k, j1 + k1); - world.e(i, j, k, i, j, k); + world.setData(i, j, k, j1 + k1, 3); + world.g(i, j, k, i, j, k); world.makeSound((double) i + 0.5D, (double) j + 0.5D, (double) k + 0.5D, "random.click", 0.3F, 0.6F); this.d(world, i, j, k, j1); - world.a(i, j, k, this.id, this.r_()); + world.a(i, j, k, this.id, this.a(world)); return true; } } @@ -176,19 +176,19 @@ public class BlockButton extends Block { super.remove(world, i, j, k, l, i1); } - public boolean b(IBlockAccess iblockaccess, int i, int j, int k, int l) { - return (iblockaccess.getData(i, j, k) & 8) > 0; + public int b(IBlockAccess iblockaccess, int i, int j, int k, int l) { + return (iblockaccess.getData(i, j, k) & 8) > 0 ? 15 : 0; } - public boolean c(IBlockAccess iblockaccess, int i, int j, int k, int l) { + public int c(IBlockAccess iblockaccess, int i, int j, int k, int l) { int i1 = iblockaccess.getData(i, j, k); if ((i1 & 8) == 0) { - return false; + return 0; } else { int j1 = i1 & 7; - return j1 == 5 && l == 1 ? true : (j1 == 4 && l == 2 ? true : (j1 == 3 && l == 3 ? true : (j1 == 2 && l == 4 ? true : j1 == 1 && l == 5))); + return j1 == 5 && l == 1 ? 15 : (j1 == 4 && l == 2 ? 15 : (j1 == 3 && l == 3 ? 15 : (j1 == 2 && l == 4 ? 15 : (j1 == 1 && l == 5 ? 15 : 0)))); } } @@ -196,7 +196,7 @@ public class BlockButton extends Block { return true; } - public void b(World world, int i, int j, int k, Random random) { + public void a(World world, int i, int j, int k, Random random) { if (!world.isStatic) { int l = world.getData(i, j, k); @@ -204,7 +204,7 @@ public class BlockButton extends Block { // CraftBukkit start org.bukkit.block.Block block = world.getWorld().getBlockAt(i, j, k); - BlockRedstoneEvent eventRedstone = new BlockRedstoneEvent(block, 1, 0); + BlockRedstoneEvent eventRedstone = new BlockRedstoneEvent(block, 15, 0); world.getServer().getPluginManager().callEvent(eventRedstone); if (eventRedstone.getNewCurrent() > 0) { @@ -213,20 +213,20 @@ public class BlockButton extends Block { // CraftBukkit end if (this.a) { - this.o(world, i, j, k); + this.n(world, i, j, k); } else { - world.setData(i, j, k, l & 7); + world.setData(i, j, k, l & 7, 3); int i1 = l & 7; this.d(world, i, j, k, i1); world.makeSound((double) i + 0.5D, (double) j + 0.5D, (double) k + 0.5D, "random.click", 0.3F, 0.5F); - world.e(i, j, k, i, j, k); + world.g(i, j, k, i, j, k); } } } } - public void f() { + public void g() { float f = 0.1875F; float f1 = 0.125F; float f2 = 0.125F; @@ -246,37 +246,38 @@ public class BlockButton extends Block { return; } // CraftBukkit end - this.o(world, i, j, k); + + this.n(world, i, j, k); } } } } - private void o(World world, int i, int j, int k) { + private void n(World world, int i, int j, int k) { int l = world.getData(i, j, k); int i1 = l & 7; boolean flag = (l & 8) != 0; - this.e(l); + this.d(l); List list = world.a(EntityArrow.class, AxisAlignedBB.a().a((double) i + this.minX, (double) j + this.minY, (double) k + this.minZ, (double) i + this.maxX, (double) j + this.maxY, (double) k + this.maxZ)); boolean flag1 = !list.isEmpty(); if (flag1 && !flag) { - world.setData(i, j, k, i1 | 8); + world.setData(i, j, k, i1 | 8, 3); this.d(world, i, j, k, i1); - world.e(i, j, k, i, j, k); + world.g(i, j, k, i, j, k); world.makeSound((double) i + 0.5D, (double) j + 0.5D, (double) k + 0.5D, "random.click", 0.3F, 0.6F); } if (!flag1 && flag) { - world.setData(i, j, k, i1); + world.setData(i, j, k, i1, 3); this.d(world, i, j, k, i1); - world.e(i, j, k, i, j, k); + world.g(i, j, k, i, j, k); world.makeSound((double) i + 0.5D, (double) j + 0.5D, (double) k + 0.5D, "random.click", 0.3F, 0.5F); } if (flag1) { - world.a(i, j, k, this.id, this.r_()); + world.a(i, j, k, this.id, this.a(world)); } } diff --git a/src/main/java/net/minecraft/server/BlockCactus.java b/src/main/java/net/minecraft/server/BlockCactus.java index dd680201bf..83cc09da80 100644 --- a/src/main/java/net/minecraft/server/BlockCactus.java +++ b/src/main/java/net/minecraft/server/BlockCactus.java @@ -6,13 +6,13 @@ import org.bukkit.event.entity.EntityDamageByBlockEvent; // CraftBukkit public class BlockCactus extends Block { - protected BlockCactus(int i, int j) { - super(i, j, Material.CACTUS); + protected BlockCactus(int i) { + super(i, Material.CACTUS); this.b(true); this.a(CreativeModeTab.c); } - public void b(World world, int i, int j, int k, Random random) { + public void a(World world, int i, int j, int k, Random random) { if (world.isEmpty(i, j + 1, k)) { int l; @@ -25,24 +25,21 @@ public class BlockCactus extends Block { if (i1 == 15) { org.bukkit.craftbukkit.event.CraftEventFactory.handleBlockGrowEvent(world, i, j + 1, k, this.id, 0); // CraftBukkit - world.setData(i, j, k, 0); + world.setData(i, j, k, 0, 4); + this.doPhysics(world, i, j + 1, k, this.id); } else { - world.setData(i, j, k, i1 + 1); + world.setData(i, j, k, i1 + 1, 4); } } } } - public AxisAlignedBB e(World world, int i, int j, int k) { + public AxisAlignedBB b(World world, int i, int j, int k) { float f = 0.0625F; return AxisAlignedBB.a().a((double) ((float) i + f), (double) j, (double) ((float) k + f), (double) ((float) (i + 1) - f), (double) ((float) (j + 1) - f), (double) ((float) (k + 1) - f)); } - public int a(int i) { - return i == 1 ? this.textureId - 1 : (i == 0 ? this.textureId + 1 : this.textureId); - } - public boolean b() { return false; } @@ -56,17 +53,16 @@ public class BlockCactus extends Block { } public boolean canPlace(World world, int i, int j, int k) { - return !super.canPlace(world, i, j, k) ? false : this.d(world, i, j, k); + return !super.canPlace(world, i, j, k) ? false : this.f(world, i, j, k); } public void doPhysics(World world, int i, int j, int k, int l) { - if (!this.d(world, i, j, k)) { - this.c(world, i, j, k, world.getData(i, j, k), 0); - world.setTypeId(i, j, k, 0); + if (!this.f(world, i, j, k)) { + world.setAir(i, j, k, true); } } - public boolean d(World world, int i, int j, int k) { + public boolean f(World world, int i, int j, int k) { if (world.getMaterial(i - 1, j, k).isBuildable()) { return false; } else if (world.getMaterial(i + 1, j, k).isBuildable()) { diff --git a/src/main/java/net/minecraft/server/BlockCocoa.java b/src/main/java/net/minecraft/server/BlockCocoa.java index ae97d4ad8b..b7007d94ac 100644 --- a/src/main/java/net/minecraft/server/BlockCocoa.java +++ b/src/main/java/net/minecraft/server/BlockCocoa.java @@ -4,34 +4,36 @@ import java.util.Random; public class BlockCocoa extends BlockDirectional { + public static final String[] a = new String[] { "cocoa_0", "cocoa_1", "cocoa_2"}; + public BlockCocoa(int i) { - super(i, 168, Material.PLANT); + super(i, Material.PLANT); this.b(true); } - public void b(World world, int i, int j, int k, Random random) { - if (!this.d(world, i, j, k)) { + 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.setTypeId(i, j, k, 0); + world.setAir(i, j, k); } else if (world.random.nextInt(5) == 0) { int l = world.getData(i, j, k); int i1 = c(l); if (i1 < 2) { ++i1; - org.bukkit.craftbukkit.event.CraftEventFactory.handleBlockGrowEvent(world, i, j, k, this.id, i1 << 2 | e(l)); // CraftBukkit + org.bukkit.craftbukkit.event.CraftEventFactory.handleBlockGrowEvent(world, i, j, k, this.id, i1 << 2 | j(l)); // CraftBukkit } } } - public boolean d(World world, int i, int j, int k) { - int l = e(world.getData(i, j, k)); + public boolean f(World world, int i, int j, int k) { + int l = j(world.getData(i, j, k)); i += Direction.a[l]; k += Direction.b[l]; int i1 = world.getTypeId(i, j, k); - return i1 == Block.LOG.id && BlockLog.e(world.getData(i, j, k)) == 3; + return i1 == Block.LOG.id && BlockLog.d(world.getData(i, j, k)) == 3; } public int d() { @@ -46,14 +48,14 @@ public class BlockCocoa extends BlockDirectional { return false; } - public AxisAlignedBB e(World world, int i, int j, int k) { + public AxisAlignedBB b(World world, int i, int j, int k) { this.updateShape(world, i, j, k); - return super.e(world, i, j, k); + return super.b(world, i, j, k); } public void updateShape(IBlockAccess iblockaccess, int i, int j, int k) { int l = iblockaccess.getData(i, j, k); - int i1 = e(l); + int i1 = j(l); int j1 = c(l); int k1 = 4 + j1 * 2; int l1 = 5 + j1 * 2; @@ -77,10 +79,10 @@ public class BlockCocoa extends BlockDirectional { } } - public void postPlace(World world, int i, int j, int k, EntityLiving entityliving) { + public void postPlace(World world, int i, int j, int k, EntityLiving entityliving, ItemStack itemstack) { int l = ((MathHelper.floor((double) (entityliving.yaw * 4.0F / 360.0F) + 0.5D) & 3) + 0) % 4; - world.setData(i, j, k, l); + world.setData(i, j, k, l, 2); } public int getPlacedData(World world, int i, int j, int k, int l, float f, float f1, float f2, int i1) { @@ -92,9 +94,9 @@ public class BlockCocoa extends BlockDirectional { } public void doPhysics(World world, int i, int j, int k, int l) { - if (!this.d(world, i, j, k)) { + if (!this.f(world, i, j, k)) { this.c(world, i, j, k, world.getData(i, j, k), 0); - world.setTypeId(i, j, k, 0); + world.setAir(i, j, k); } } diff --git a/src/main/java/net/minecraft/server/BlockCommand.java b/src/main/java/net/minecraft/server/BlockCommand.java index 34f50ca433..c464beb94b 100644 --- a/src/main/java/net/minecraft/server/BlockCommand.java +++ b/src/main/java/net/minecraft/server/BlockCommand.java @@ -7,10 +7,10 @@ import org.bukkit.event.block.BlockRedstoneEvent; // CraftBukkit public class BlockCommand extends BlockContainer { public BlockCommand(int i) { - super(i, 184, Material.ORE); + super(i, Material.ORE); } - public TileEntity a(World world) { + public TileEntity b(World world) { return new TileEntityCommand(); } @@ -22,31 +22,34 @@ public class BlockCommand extends BlockContainer { // CraftBukkit start org.bukkit.block.Block block = world.getWorld().getBlockAt(i, j, k); - int old = flag1 ? 1 : 0; - int current = flag ? 1 : 0; + int old = flag1 ? 15 : 0; + int current = flag ? 15 : 0; BlockRedstoneEvent eventRedstone = new BlockRedstoneEvent(block, old, current); world.getServer().getPluginManager().callEvent(eventRedstone); // CraftBukkit end if (eventRedstone.getNewCurrent() > 0 && !(eventRedstone.getOldCurrent() > 0)) { // CraftBukkit - world.setRawData(i, j, k, i1 | 1); - world.a(i, j, k, this.id, this.r_()); + world.setData(i, j, k, i1 | 1, 4); + world.a(i, j, k, this.id, this.a(world)); } else if (!(eventRedstone.getNewCurrent() > 0) && eventRedstone.getOldCurrent() > 0) { // CraftBukkit - world.setRawData(i, j, k, i1 & -2); + world.setData(i, j, k, i1 & -2, 4); } } } - public void b(World world, int i, int j, int k, Random random) { + public void a(World world, int i, int j, int k, Random random) { TileEntity tileentity = world.getTileEntity(i, j, k); if (tileentity != null && tileentity instanceof TileEntityCommand) { - ((TileEntityCommand) tileentity).a(world); + TileEntityCommand tileentitycommand = (TileEntityCommand) tileentity; + + tileentitycommand.a(tileentitycommand.a(world)); + world.m(i, j, k, this.id); } } - public int r_() { + public int a(World world) { return 1; } @@ -59,4 +62,22 @@ public class BlockCommand extends BlockContainer { return true; } + + public boolean q_() { + return true; + } + + 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; + } + + 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()); + } + } } diff --git a/src/main/java/net/minecraft/server/BlockCrops.java b/src/main/java/net/minecraft/server/BlockCrops.java index a2ce8f94a9..14a1c3bde1 100644 --- a/src/main/java/net/minecraft/server/BlockCrops.java +++ b/src/main/java/net/minecraft/server/BlockCrops.java @@ -4,31 +4,29 @@ import java.util.Random; public class BlockCrops extends BlockFlower { - protected BlockCrops(int i, int j) { - super(i, j); - this.textureId = j; + protected BlockCrops(int i) { + super(i); this.b(true); float f = 0.5F; 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(g); + this.a(Block.i); // CraftBukkit - i -> Block.i, decompile error this.D(); - this.r(); } - protected boolean d_(int i) { + protected boolean f_(int i) { return i == Block.SOIL.id; } - public void b(World world, int i, int j, int k, Random random) { - super.b(world, i, j, k, random); + public void a(World world, int i, int j, int k, Random random) { + super.a(world, i, j, k, random); if (world.getLightLevel(i, j + 1, k) >= 9) { int l = world.getData(i, j, k); if (l < 7) { - float f = this.l(world, i, j, k); + float f = this.k(world, i, j, k); if (random.nextInt((int) (25.0F / f) + 1) == 0) { org.bukkit.craftbukkit.event.CraftEventFactory.handleBlockGrowEvent(world, i, j, k, this.id, ++l); // CraftBukkit @@ -37,11 +35,17 @@ public class BlockCrops extends BlockFlower { } } - public void c_(World world, int i, int j, int k) { - world.setData(i, j, k, 7); + public void e_(World world, int i, int j, int k) { + int l = world.getData(i, j, k) + MathHelper.nextInt(world.random, 2, 5); + + if (l > 7) { + l = 7; + } + + world.setData(i, j, k, l, 2); } - private float l(World world, int i, int j, int k) { + private float k(World world, int i, int j, int k) { float f = 1.0F; int l = world.getTypeId(i, j, k - 1); int i1 = world.getTypeId(i, j, k + 1); @@ -82,23 +86,15 @@ public class BlockCrops extends BlockFlower { return f; } - public int a(int i, int j) { - if (j < 0) { - j = 7; - } - - return this.textureId + j; - } - public int d() { return 6; } - protected int h() { + protected int j() { return Item.SEEDS.id; } - protected int j() { + protected int k() { return Item.WHEAT.id; } @@ -110,7 +106,7 @@ public class BlockCrops extends BlockFlower { for (int k1 = 0; k1 < j1; ++k1) { if (world.random.nextInt(15) <= l) { - this.b(world, i, j, k, new ItemStack(this.h(), 1, 0)); + this.b(world, i, j, k, new ItemStack(this.j(), 1, 0)); } } } @@ -118,7 +114,7 @@ public class BlockCrops extends BlockFlower { } public int getDropType(int i, Random random, int j) { - return i == 7 ? this.j() : this.h(); + return i == 7 ? this.k() : this.j(); } public int a(Random random) { diff --git a/src/main/java/net/minecraft/server/BlockDiode.java b/src/main/java/net/minecraft/server/BlockDiode.java deleted file mode 100644 index 2e06725d31..0000000000 --- a/src/main/java/net/minecraft/server/BlockDiode.java +++ /dev/null @@ -1,228 +0,0 @@ -package net.minecraft.server; - -import java.util.Random; - -import org.bukkit.craftbukkit.event.CraftEventFactory; // CraftBukkit - -public class BlockDiode extends BlockDirectional { - - public static final double[] a = new double[] { -0.0625D, 0.0625D, 0.1875D, 0.3125D}; - private static final int[] b = new int[] { 1, 2, 3, 4}; - private final boolean c; - - protected BlockDiode(int i, boolean flag) { - super(i, 6, Material.ORIENTABLE); - this.c = flag; - this.a(0.0F, 0.0F, 0.0F, 1.0F, 0.125F, 1.0F); - } - - public boolean b() { - return false; - } - - public boolean canPlace(World world, int i, int j, int k) { - return !world.v(i, j - 1, k) ? false : super.canPlace(world, i, j, k); - } - - public boolean d(World world, int i, int j, int k) { - return !world.v(i, j - 1, k) ? false : super.d(world, i, j, k); - } - - public void b(World world, int i, int j, int k, Random random) { - int l = world.getData(i, j, k); - boolean flag = this.e(world, i, j, k, l); - - if (!flag) { - boolean flag1 = this.i(world, i, j, k, l); - - if (this.c && !flag1) { - // CraftBukkit start - if (CraftEventFactory.callRedstoneChange(world, i, j, k, 15, 0).getNewCurrent() != 0) { - return; - } - // CraftBukkit end - - world.setTypeIdAndData(i, j, k, Block.DIODE_OFF.id, l); - } else if (!this.c) { - // CraftBukkit start - if (CraftEventFactory.callRedstoneChange(world, i, j, k, 0, 15).getNewCurrent() != 15) { - return; - } - // CraftBukkit end - - world.setTypeIdAndData(i, j, k, Block.DIODE_ON.id, l); - if (!flag1) { - int i1 = (l & 12) >> 2; - - world.a(i, j, k, Block.DIODE_ON.id, b[i1] * 2); - } - } - } - } - - public int a(int i, int j) { - return i == 0 ? (this.c ? 99 : 115) : (i == 1 ? (this.c ? 147 : 131) : 5); - } - - public int d() { - return 15; - } - - public int a(int i) { - return this.a(i, 0); - } - - public boolean c(IBlockAccess iblockaccess, int i, int j, int k, int l) { - return this.b(iblockaccess, i, j, k, l); - } - - public boolean b(IBlockAccess iblockaccess, int i, int j, int k, int l) { - if (!this.c) { - return false; - } else { - int i1 = e(iblockaccess.getData(i, j, k)); - - return i1 == 0 && l == 3 ? true : (i1 == 1 && l == 4 ? true : (i1 == 2 && l == 2 ? true : i1 == 3 && l == 5)); - } - } - - public void doPhysics(World world, int i, int j, int k, int l) { - if (!this.d(world, i, j, k)) { - this.c(world, i, j, k, world.getData(i, j, k), 0); - world.setTypeId(i, j, k, 0); - world.applyPhysics(i + 1, j, k, this.id); - world.applyPhysics(i - 1, j, k, this.id); - world.applyPhysics(i, j, k + 1, this.id); - world.applyPhysics(i, j, k - 1, this.id); - world.applyPhysics(i, j - 1, k, this.id); - world.applyPhysics(i, j + 1, k, this.id); - } else { - int i1 = world.getData(i, j, k); - boolean flag = this.e(world, i, j, k, i1); - - if (!flag) { - boolean flag1 = this.i(world, i, j, k, i1); - int j1 = (i1 & 12) >> 2; - - if (this.c && !flag1 || !this.c && flag1) { - byte b0 = 0; - - if (this.d(world, i, j, k, i1)) { - b0 = -1; - } - - world.a(i, j, k, this.id, b[j1] * 2, b0); - } - } - } - } - - private boolean i(World world, int i, int j, int k, int l) { - int i1 = e(l); - - switch (i1) { - case 0: - return world.isBlockFaceIndirectlyPowered(i, j, k + 1, 3) || world.getTypeId(i, j, k + 1) == Block.REDSTONE_WIRE.id && world.getData(i, j, k + 1) > 0; - - case 1: - return world.isBlockFaceIndirectlyPowered(i - 1, j, k, 4) || world.getTypeId(i - 1, j, k) == Block.REDSTONE_WIRE.id && world.getData(i - 1, j, k) > 0; - - case 2: - return world.isBlockFaceIndirectlyPowered(i, j, k - 1, 2) || world.getTypeId(i, j, k - 1) == Block.REDSTONE_WIRE.id && world.getData(i, j, k - 1) > 0; - - case 3: - return world.isBlockFaceIndirectlyPowered(i + 1, j, k, 5) || world.getTypeId(i + 1, j, k) == Block.REDSTONE_WIRE.id && world.getData(i + 1, j, k) > 0; - - default: - return false; - } - } - - public boolean e(IBlockAccess iblockaccess, int i, int j, int k, int l) { - int i1 = e(l); - - switch (i1) { - case 0: - case 2: - return iblockaccess.isBlockFacePowered(i - 1, j, k, 4) && c(iblockaccess.getTypeId(i - 1, j, k)) || iblockaccess.isBlockFacePowered(i + 1, j, k, 5) && c(iblockaccess.getTypeId(i + 1, j, k)); - - case 1: - case 3: - return iblockaccess.isBlockFacePowered(i, j, k + 1, 3) && c(iblockaccess.getTypeId(i, j, k + 1)) || iblockaccess.isBlockFacePowered(i, j, k - 1, 2) && c(iblockaccess.getTypeId(i, j, k - 1)); - - default: - return false; - } - } - - public boolean interact(World world, int i, int j, int k, EntityHuman entityhuman, int l, float f, float f1, float f2) { - int i1 = world.getData(i, j, k); - int j1 = (i1 & 12) >> 2; - - j1 = j1 + 1 << 2 & 12; - world.setData(i, j, k, j1 | i1 & 3); - return true; - } - - public boolean isPowerSource() { - return true; - } - - public void postPlace(World world, int i, int j, int k, EntityLiving entityliving) { - int l = ((MathHelper.floor((double) (entityliving.yaw * 4.0F / 360.0F) + 0.5D) & 3) + 2) % 4; - - world.setData(i, j, k, l); - boolean flag = this.i(world, i, j, k, l); - - if (flag) { - world.a(i, j, k, this.id, 1); - } - } - - public void onPlace(World world, int i, int j, int k) { - world.applyPhysics(i + 1, j, k, this.id); - world.applyPhysics(i - 1, j, k, this.id); - world.applyPhysics(i, j, k + 1, this.id); - world.applyPhysics(i, j, k - 1, this.id); - world.applyPhysics(i, j - 1, k, this.id); - world.applyPhysics(i, j + 1, k, this.id); - } - - public void postBreak(World world, int i, int j, int k, int l) { - if (this.c) { - world.applyPhysics(i + 1, j, k, this.id); - world.applyPhysics(i - 1, j, k, this.id); - world.applyPhysics(i, j, k + 1, this.id); - world.applyPhysics(i, j, k - 1, this.id); - world.applyPhysics(i, j - 1, k, this.id); - world.applyPhysics(i, j + 1, k, this.id); - } - - super.postBreak(world, i, j, k, l); - } - - public boolean c() { - return false; - } - - public int getDropType(int i, Random random, int j) { - return Item.DIODE.id; - } - - public static boolean c(int i) { - return i == Block.DIODE_ON.id || i == Block.DIODE_OFF.id; - } - - public boolean d(World world, int i, int j, int k, int l) { - int i1 = e(l); - - if (c(world.getTypeId(i - Direction.a[i1], j, k - Direction.b[i1]))) { - int j1 = world.getData(i - Direction.a[i1], j, k - Direction.b[i1]); - int k1 = e(j1); - - return k1 != i1; - } else { - return false; - } - } -} diff --git a/src/main/java/net/minecraft/server/BlockDiodeAbstract.java b/src/main/java/net/minecraft/server/BlockDiodeAbstract.java new file mode 100644 index 0000000000..1ef8144d9b --- /dev/null +++ b/src/main/java/net/minecraft/server/BlockDiodeAbstract.java @@ -0,0 +1,261 @@ +package net.minecraft.server; + +import java.util.Random; + +import org.bukkit.craftbukkit.event.CraftEventFactory; // CraftBukkit + +public abstract class BlockDiodeAbstract extends BlockDirectional { + + protected final boolean a; + + protected BlockDiodeAbstract(int i, boolean flag) { + super(i, Material.ORIENTABLE); + this.a = flag; + this.a(0.0F, 0.0F, 0.0F, 1.0F, 0.125F, 1.0F); + } + + public boolean b() { + return false; + } + + public boolean canPlace(World world, int i, int j, int k) { + return !world.w(i, j - 1, k) ? false : super.canPlace(world, i, j, k); + } + + public boolean f(World world, int i, int j, int k) { + return !world.w(i, j - 1, k) ? false : super.f(world, i, j, k); + } + + public void a(World world, int i, int j, int k, Random random) { + int l = world.getData(i, j, k); + + if (!this.e((IBlockAccess) world, i, j, k, l)) { + boolean flag = this.d(world, i, j, k, l); + + if (this.a && !flag) { + // CraftBukkit start + if (CraftEventFactory.callRedstoneChange(world, i, j, k, 15, 0).getNewCurrent() != 0) { + return; + } + // CraftBukkit end + + world.setTypeIdAndData(i, j, k, this.j().id, l, 2); + } else if (!this.a) { + // CraftBukkit start + if (CraftEventFactory.callRedstoneChange(world, i, j, k, 0, 15).getNewCurrent() != 15) { + return; + } + // CraftBukkit end + + world.setTypeIdAndData(i, j, k, this.i().id, l, 2); + if (!flag) { + world.a(i, j, k, this.i().id, this.h(l), -1); + } + } + } + } + + public int d() { + return 36; + } + + protected boolean c(int i) { + return this.a; + } + + public int c(IBlockAccess iblockaccess, int i, int j, int k, int l) { + return this.b(iblockaccess, i, j, k, l); + } + + public int b(IBlockAccess iblockaccess, int i, int j, int k, int l) { + int i1 = iblockaccess.getData(i, j, k); + + if (!this.c(i1)) { + return 0; + } else { + int j1 = j(i1); + + return j1 == 0 && l == 3 ? this.d(iblockaccess, i, j, k, i1) : (j1 == 1 && l == 4 ? this.d(iblockaccess, i, j, k, i1) : (j1 == 2 && l == 2 ? this.d(iblockaccess, i, j, k, i1) : (j1 == 3 && l == 5 ? this.d(iblockaccess, i, j, k, i1) : 0))); + } + } + + 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.applyPhysics(i + 1, j, k, this.id); + world.applyPhysics(i - 1, j, k, this.id); + world.applyPhysics(i, j, k + 1, this.id); + world.applyPhysics(i, j, k - 1, this.id); + world.applyPhysics(i, j - 1, k, this.id); + world.applyPhysics(i, j + 1, k, this.id); + } else { + this.f(world, i, j, k, l); + } + } + + protected void f(World world, int i, int j, int k, int l) { + int i1 = world.getData(i, j, k); + + if (!this.e((IBlockAccess) world, i, j, k, i1)) { + boolean flag = this.d(world, i, j, k, i1); + + if ((this.a && !flag || !this.a && flag) && !world.a(i, j, k, this.id)) { + byte b0 = -1; + + if (this.h(world, i, j, k, i1)) { + b0 = -3; + } else if (this.a) { + b0 = -2; + } + + world.a(i, j, k, this.id, this.i_(i1), b0); + } + } + } + + public boolean e(IBlockAccess iblockaccess, int i, int j, int k, int l) { + return false; + } + + protected boolean d(World world, int i, int j, int k, int l) { + return this.e(world, i, j, k, l) > 0; + } + + protected int e(World world, int i, int j, int k, int l) { + int i1 = j(l); + int j1 = i + Direction.a[i1]; + int k1 = k + Direction.b[i1]; + int l1 = world.getBlockFacePower(j1, j, k1, Direction.d[i1]); + + return l1 >= 15 ? l1 : Math.max(l1, world.getTypeId(j1, j, k1) == Block.REDSTONE_WIRE.id ? world.getData(j1, j, k1) : 0); + } + + protected int f(IBlockAccess iblockaccess, int i, int j, int k, int l) { + int i1 = j(l); + + switch (i1) { + case 0: + case 2: + return Math.max(this.g(iblockaccess, i - 1, j, k, 4), this.g(iblockaccess, i + 1, j, k, 5)); + + case 1: + case 3: + return Math.max(this.g(iblockaccess, i, j, k + 1, 3), this.g(iblockaccess, i, j, k - 1, 2)); + + default: + return 0; + } + } + + protected int g(IBlockAccess iblockaccess, int i, int j, int k, int l) { + int i1 = iblockaccess.getTypeId(i, j, k); + + return this.e(i1) ? (i1 == Block.REDSTONE_WIRE.id ? iblockaccess.getData(i, j, k) : iblockaccess.getBlockPower(i, j, k, l)) : 0; + } + + public boolean isPowerSource() { + return true; + } + + public void postPlace(World world, int i, int j, int k, EntityLiving entityliving, ItemStack itemstack) { + int l = ((MathHelper.floor((double) (entityliving.yaw * 4.0F / 360.0F) + 0.5D) & 3) + 2) % 4; + + world.setData(i, j, k, l, 3); + boolean flag = this.d(world, i, j, k, l); + + if (flag) { + world.a(i, j, k, this.id, 1); + } + } + + public void onPlace(World world, int i, int j, int k) { + this.h_(world, i, j, k); + } + + protected void h_(World world, int i, int j, int k) { + int l = j(world.getData(i, j, k)); + + if (l == 1) { + world.g(i + 1, j, k, this.id); + world.c(i + 1, j, k, this.id, 4); + } + + if (l == 3) { + world.g(i - 1, j, k, this.id); + world.c(i - 1, j, k, this.id, 5); + } + + if (l == 2) { + world.g(i, j, k + 1, this.id); + world.c(i, j, k + 1, this.id, 2); + } + + if (l == 0) { + world.g(i, j, k - 1, this.id); + world.c(i, j, k - 1, this.id, 3); + } + } + + public void postBreak(World world, int i, int j, int k, int l) { + if (this.a) { + world.applyPhysics(i + 1, j, k, this.id); + world.applyPhysics(i - 1, j, k, this.id); + world.applyPhysics(i, j, k + 1, this.id); + world.applyPhysics(i, j, k - 1, this.id); + world.applyPhysics(i, j - 1, k, this.id); + world.applyPhysics(i, j + 1, k, this.id); + } + + super.postBreak(world, i, j, k, l); + } + + public boolean c() { + return false; + } + + protected boolean e(int i) { + Block block = Block.byId[i]; + + return block != null && block.isPowerSource(); + } + + protected int d(IBlockAccess iblockaccess, int i, int j, int k, int l) { + return 15; + } + + public static boolean f(int i) { + return Block.DIODE_OFF.g(i) || Block.REDSTONE_COMPARATOR_OFF.g(i); + } + + public boolean g(int i) { + return i == this.i().id || i == this.j().id; + } + + public boolean h(World world, int i, int j, int k, int l) { + int i1 = j(l); + + if (f(world.getTypeId(i - Direction.a[i1], j, k - Direction.b[i1]))) { + int j1 = world.getData(i - Direction.a[i1], j, k - Direction.b[i1]); + int k1 = j(j1); + + return k1 != i1; + } else { + return false; + } + } + + protected int h(int i) { + return this.i_(i); + } + + protected abstract int i_(int i); + + protected abstract BlockDiodeAbstract i(); + + protected abstract BlockDiodeAbstract j(); + + public boolean i(int i) { + return this.g(i); + } +} diff --git a/src/main/java/net/minecraft/server/BlockDispenser.java b/src/main/java/net/minecraft/server/BlockDispenser.java index 5cb21c8354..b3fed06dcf 100644 --- a/src/main/java/net/minecraft/server/BlockDispenser.java +++ b/src/main/java/net/minecraft/server/BlockDispenser.java @@ -5,29 +5,24 @@ import java.util.Random; public class BlockDispenser extends BlockContainer { public static final IRegistry a = new RegistryDefault(new DispenseBehaviorItem()); + protected Random b = new Random(); public static boolean eventFired = false; // CraftBukkit - private Random b = new Random(); protected BlockDispenser(int i) { super(i, Material.STONE); - this.textureId = 45; this.a(CreativeModeTab.d); } - public int r_() { + public int a(World world) { return 4; } - public int getDropType(int i, Random random, int j) { - return Block.DISPENSER.id; - } - public void onPlace(World world, int i, int j, int k) { super.onPlace(world, i, j, k); - this.l(world, i, j, k); + this.k(world, i, j, k); } - private void l(World world, int i, int j, int k) { + private void k(World world, int i, int j, int k) { if (!world.isStatic) { int l = world.getTypeId(i, j, k - 1); int i1 = world.getTypeId(i, j, k + 1); @@ -35,30 +30,26 @@ public class BlockDispenser extends BlockContainer { int k1 = world.getTypeId(i + 1, j, k); byte b0 = 3; - if (Block.q[l] && !Block.q[i1]) { + if (Block.s[l] && !Block.s[i1]) { b0 = 3; } - if (Block.q[i1] && !Block.q[l]) { + if (Block.s[i1] && !Block.s[l]) { b0 = 2; } - if (Block.q[j1] && !Block.q[k1]) { + if (Block.s[j1] && !Block.s[k1]) { b0 = 5; } - if (Block.q[k1] && !Block.q[j1]) { + if (Block.s[k1] && !Block.s[j1]) { b0 = 4; } - world.setData(i, j, k, b0); + world.setData(i, j, k, b0, 2); } } - public int a(int i) { - return i == 1 ? this.textureId + 17 : (i == 0 ? this.textureId + 17 : (i == 3 ? this.textureId + 1 : this.textureId)); - } - public boolean interact(World world, int i, int j, int k, EntityHuman entityhuman, int l, float f, float f1, float f2) { if (world.isStatic) { return true; @@ -79,13 +70,13 @@ public class BlockDispenser extends BlockContainer { TileEntityDispenser tileentitydispenser = (TileEntityDispenser) sourceblock.getTileEntity(); if (tileentitydispenser != null) { - int l = tileentitydispenser.i(); + int l = tileentitydispenser.j(); if (l < 0) { world.triggerEffect(1001, i, j, k, 0); } else { ItemStack itemstack = tileentitydispenser.getItem(l); - IDispenseBehavior idispensebehavior = (IDispenseBehavior) a.a(itemstack.getItem()); + IDispenseBehavior idispensebehavior = this.a(itemstack); if (idispensebehavior != IDispenseBehavior.a) { ItemStack itemstack1 = idispensebehavior.a(sourceblock, itemstack); @@ -97,43 +88,39 @@ public class BlockDispenser extends BlockContainer { } } - public void doPhysics(World world, int i, int j, int k, int l) { - if (l > 0 && Block.byId[l].isPowerSource()) { - boolean flag = world.isBlockIndirectlyPowered(i, j, k) || world.isBlockIndirectlyPowered(i, j + 1, k); + protected IDispenseBehavior a(ItemStack itemstack) { + return (IDispenseBehavior) a.a(itemstack.getItem()); + } - if (flag) { - world.a(i, j, k, this.id, this.r_()); - } + public void doPhysics(World world, int i, int j, int k, int l) { + boolean flag = world.isBlockIndirectlyPowered(i, j, k) || world.isBlockIndirectlyPowered(i, j + 1, k); + int i1 = world.getData(i, j, k); + boolean flag1 = (i1 & 8) != 0; + + if (flag && !flag1) { + world.a(i, j, k, this.id, this.a(world)); + world.setData(i, j, k, i1 | 8, 4); + } else if (!flag && flag1) { + world.setData(i, j, k, i1 & -9, 4); } } - public void b(World world, int i, int j, int k, Random random) { - if (!world.isStatic && (world.isBlockIndirectlyPowered(i, j, k) || world.isBlockIndirectlyPowered(i, j + 1, k))) { + public void a(World world, int i, int j, int k, Random random) { + if (!world.isStatic) { this.dispense(world, i, j, k); } } - public TileEntity a(World world) { + public TileEntity b(World world) { return new TileEntityDispenser(); } - public void postPlace(World world, int i, int j, int k, EntityLiving entityliving) { - int l = MathHelper.floor((double) (entityliving.yaw * 4.0F / 360.0F) + 0.5D) & 3; + public void postPlace(World world, int i, int j, int k, EntityLiving entityliving, ItemStack itemstack) { + int l = BlockPiston.a(world, i, j, k, entityliving); - if (l == 0) { - world.setData(i, j, k, 2); - } - - if (l == 1) { - world.setData(i, j, k, 5); - } - - if (l == 2) { - world.setData(i, j, k, 3); - } - - if (l == 3) { - world.setData(i, j, k, 4); + world.setData(i, j, k, l, 2); + if (itemstack.hasName()) { + ((TileEntityDispenser) world.getTileEntity(i, j, k)).a(itemstack.getName()); } } @@ -178,11 +165,23 @@ public class BlockDispenser extends BlockContainer { } public static IPosition a(ISourceBlock isourceblock) { - EnumFacing enumfacing = EnumFacing.a(isourceblock.h()); + EnumFacing enumfacing = j_(isourceblock.h()); double d0 = isourceblock.getX() + 0.7D * (double) enumfacing.c(); - double d1 = isourceblock.getY(); + double d1 = isourceblock.getY() + 0.7D * (double) enumfacing.d(); double d2 = isourceblock.getZ() + 0.7D * (double) enumfacing.e(); return new Position(d0, d1, d2); } + + public static EnumFacing j_(int i) { + return EnumFacing.a(i & 7); + } + + public boolean q_() { + return true; + } + + public int b_(World world, int i, int j, int k, int l) { + return Container.b((IInventory) world.getTileEntity(i, j, k)); + } } diff --git a/src/main/java/net/minecraft/server/BlockDoor.java b/src/main/java/net/minecraft/server/BlockDoor.java index 946fa36ae5..fd28fa02e2 100644 --- a/src/main/java/net/minecraft/server/BlockDoor.java +++ b/src/main/java/net/minecraft/server/BlockDoor.java @@ -6,11 +6,15 @@ 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); - this.textureId = 97; if (material == Material.ORE) { - ++this.textureId; + this.b = 2; + } else { + this.b = 0; } float f = 0.5F; @@ -23,8 +27,8 @@ public class BlockDoor extends Block { return false; } - public boolean c(IBlockAccess iblockaccess, int i, int j, int k) { - int l = this.b_(iblockaccess, i, j, k); + public boolean b(IBlockAccess iblockaccess, int i, int j, int k) { + int l = this.c_(iblockaccess, i, j, k); return (l & 4) != 0; } @@ -37,24 +41,24 @@ public class BlockDoor extends Block { return 7; } - public AxisAlignedBB e(World world, int i, int j, int k) { + public AxisAlignedBB b(World world, int i, int j, int k) { this.updateShape(world, i, j, k); - return super.e(world, i, j, k); + return super.b(world, i, j, k); } public void updateShape(IBlockAccess iblockaccess, int i, int j, int k) { - this.e(this.b_(iblockaccess, i, j, k)); + this.d(this.c_(iblockaccess, i, j, k)); } public int d(IBlockAccess iblockaccess, int i, int j, int k) { - return this.b_(iblockaccess, i, j, k) & 3; + return this.c_(iblockaccess, i, j, k) & 3; } - public boolean a_(IBlockAccess iblockaccess, int i, int j, int k) { - return (this.b_(iblockaccess, i, j, k) & 4) != 0; + public boolean b_(IBlockAccess iblockaccess, int i, int j, int k) { + return (this.c_(iblockaccess, i, j, k) & 4) != 0; } - private void e(int i) { + private void d(int i) { float f = 0.1875F; this.a(0.0F, 0.0F, 0.0F, 1.0F, 2.0F, 1.0F); @@ -111,16 +115,16 @@ public class BlockDoor extends Block { if (this.material == Material.ORE) { return true; } else { - int i1 = this.b_(world, i, j, k); + int i1 = this.c_(world, i, j, k); int j1 = i1 & 7; j1 ^= 4; if ((i1 & 8) == 0) { - world.setData(i, j, k, j1); - world.e(i, j, k, i, j, k); + world.setData(i, j, k, j1, 2); + world.g(i, j, k, i, j, k); } else { - world.setData(i, j - 1, k, j1); - world.e(i, j - 1, k, i, j, k); + world.setData(i, j - 1, k, j1, 2); + world.g(i, j - 1, k, i, j, k); } world.a(entityhuman, 1003, i, j, k, 0); @@ -129,7 +133,7 @@ public class BlockDoor extends Block { } public void setDoor(World world, int i, int j, int k, boolean flag) { - int l = this.b_(world, i, j, k); + int l = this.c_(world, i, j, k); boolean flag1 = (l & 4) != 0; if (flag1 != flag) { @@ -137,11 +141,11 @@ public class BlockDoor extends Block { i1 ^= 4; if ((l & 8) == 0) { - world.setData(i, j, k, i1); - world.e(i, j, k, i, j, k); + world.setData(i, j, k, i1, 2); + world.g(i, j, k, i, j, k); } else { - world.setData(i, j - 1, k, i1); - world.e(i, j - 1, k, i, j, k); + world.setData(i, j - 1, k, i1, 2); + world.g(i, j - 1, k, i, j, k); } world.a((EntityHuman) null, 1003, i, j, k, 0); @@ -155,15 +159,15 @@ public class BlockDoor extends Block { boolean flag = false; if (world.getTypeId(i, j + 1, k) != this.id) { - world.setTypeId(i, j, k, 0); + world.setAir(i, j, k); flag = true; } - if (!world.v(i, j - 1, k)) { - world.setTypeId(i, j, k, 0); + if (!world.w(i, j - 1, k)) { + world.setAir(i, j, k); flag = true; if (world.getTypeId(i, j + 1, k) == this.id) { - world.setTypeId(i, j + 1, k, 0); + world.setAir(i, j + 1, k); } } @@ -192,8 +196,9 @@ public class BlockDoor extends Block { } } else { if (world.getTypeId(i, j - 1, k) != this.id) { - world.setTypeId(i, j, k, 0); + world.setAir(i, j, k); } + else if (l > 0 && l != this.id) { // CraftBukkit this.doPhysics(world, i, j - 1, k, l); } @@ -210,14 +215,14 @@ public class BlockDoor extends Block { } public boolean canPlace(World world, int i, int j, int k) { - return j >= 255 ? false : world.v(i, j - 1, k) && super.canPlace(world, i, j, k) && super.canPlace(world, i, j + 1, k); + return j >= 255 ? false : world.w(i, j - 1, k) && super.canPlace(world, i, j, k) && super.canPlace(world, i, j + 1, k); } - public int q_() { + public int h() { return 1; } - public int b_(IBlockAccess iblockaccess, int i, int j, int k) { + public int c_(IBlockAccess iblockaccess, int i, int j, int k) { int l = iblockaccess.getData(i, j, k); boolean flag = (l & 8) != 0; int i1; @@ -238,7 +243,7 @@ public class BlockDoor extends Block { public void a(World world, int i, int j, int k, int l, EntityHuman entityhuman) { if (entityhuman.abilities.canInstantlyBuild && (l & 8) != 0 && world.getTypeId(i, j - 1, k) == this.id) { - world.setTypeId(i, j - 1, k, 0); + world.setAir(i, j - 1, k); } } } diff --git a/src/main/java/net/minecraft/server/BlockDragonEgg.java b/src/main/java/net/minecraft/server/BlockDragonEgg.java index 2c46125354..a27a6c07d3 100644 --- a/src/main/java/net/minecraft/server/BlockDragonEgg.java +++ b/src/main/java/net/minecraft/server/BlockDragonEgg.java @@ -6,56 +6,56 @@ import org.bukkit.event.block.BlockFromToEvent; // CraftBukkit public class BlockDragonEgg extends Block { - public BlockDragonEgg(int i, int j) { - super(i, j, Material.DRAGON_EGG); + public BlockDragonEgg(int i) { + super(i, Material.DRAGON_EGG); this.a(0.0625F, 0.0F, 0.0625F, 0.9375F, 1.0F, 0.9375F); } public void onPlace(World world, int i, int j, int k) { - world.a(i, j, k, this.id, this.r_()); + world.a(i, j, k, this.id, this.a(world)); } public void doPhysics(World world, int i, int j, int k, int l) { - world.a(i, j, k, this.id, this.r_()); + world.a(i, j, k, this.id, this.a(world)); } - public void b(World world, int i, int j, int k, Random random) { - this.l(world, i, j, k); + public void a(World world, int i, int j, int k, Random random) { + this.k(world, i, j, k); } - private void l(World world, int i, int j, int k) { + private void k(World world, int i, int j, int k) { if (BlockSand.canFall(world, i, j - 1, k) && j >= 0) { byte b0 = 32; - if (!BlockSand.instaFall && world.d(i - b0, j - b0, k - b0, i + b0, j + b0, k + b0)) { + if (!BlockSand.instaFall && world.e(i - b0, j - b0, k - b0, i + b0, j + b0, k + b0)) { // CraftBukkit - added data EntityFallingBlock entityfallingblock = new EntityFallingBlock(world, (double) ((float) i + 0.5F), (double) ((float) j + 0.5F), (double) ((float) k + 0.5F), this.id, world.getData(i, j, k)); world.addEntity(entityfallingblock); } else { - world.setTypeId(i, j, k, 0); + world.setAir(i, j, k); while (BlockSand.canFall(world, i, j - 1, k) && j > 0) { --j; } if (j > 0) { - world.setTypeId(i, j, k, this.id); + world.setTypeIdAndData(i, j, k, this.id, 0, 2); } } } } public boolean interact(World world, int i, int j, int k, EntityHuman entityhuman, int l, float f, float f1, float f2) { - this.n(world, i, j, k); + this.m(world, i, j, k); return true; } public void attack(World world, int i, int j, int k, EntityHuman entityhuman) { - this.n(world, i, j, k); + this.m(world, i, j, k); } - private void n(World world, int i, int j, int k) { + private void m(World world, int i, int j, int k) { if (world.getTypeId(i, j, k) == this.id) { for (int l = 0; l < 1000; ++l) { int i1 = i + world.random.nextInt(16) - world.random.nextInt(16); @@ -79,8 +79,8 @@ public class BlockDragonEgg extends Block { // CraftBukkit end if (!world.isStatic) { - world.setTypeIdAndData(i1, j1, k1, this.id, world.getData(i, j, k)); - world.setTypeId(i, j, k, 0); + world.setTypeIdAndData(i1, j1, k1, this.id, world.getData(i, j, k), 2); + world.setAir(i, j, k); } else { short short1 = 128; @@ -103,7 +103,7 @@ public class BlockDragonEgg extends Block { } } - public int r_() { + public int a(World world) { return 5; } diff --git a/src/main/java/net/minecraft/server/BlockEnderPortal.java b/src/main/java/net/minecraft/server/BlockEnderPortal.java index 6a5b27488c..2b40023634 100644 --- a/src/main/java/net/minecraft/server/BlockEnderPortal.java +++ b/src/main/java/net/minecraft/server/BlockEnderPortal.java @@ -10,11 +10,11 @@ public class BlockEnderPortal extends BlockContainer { public static boolean a = false; protected BlockEnderPortal(int i, Material material) { - super(i, 0, material); + super(i, material); this.a(1.0F); } - public TileEntity a(World world) { + public TileEntity b(World world) { return new TileEntityEnderPortal(); } @@ -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.b(1); + entity.c(1); } } @@ -55,7 +55,7 @@ public class BlockEnderPortal extends BlockContainer { public void onPlace(World world, int i, int j, int k) { if (!a) { if (world.worldProvider.dimension != 0) { - world.setTypeId(i, j, k, 0); + world.setAir(i, j, k); } } } diff --git a/src/main/java/net/minecraft/server/BlockFire.java b/src/main/java/net/minecraft/server/BlockFire.java index 6d249f133a..eb33c84f4b 100644 --- a/src/main/java/net/minecraft/server/BlockFire.java +++ b/src/main/java/net/minecraft/server/BlockFire.java @@ -13,12 +13,12 @@ public class BlockFire extends Block { private int[] a = new int[256]; private int[] b = new int[256]; - protected BlockFire(int i, int j) { - super(i, j, Material.FIRE); + protected BlockFire(int i) { + super(i, Material.FIRE); this.b(true); } - public void t_() { + public void s_() { this.a(Block.WOOD.id, 5, 20); this.a(Block.WOOD_DOUBLE_STEP.id, 5, 20); this.a(Block.WOOD_STEP.id, 5, 20); @@ -41,7 +41,7 @@ public class BlockFire extends Block { this.b[i] = k; } - public AxisAlignedBB e(World world, int i, int j, int k) { + public AxisAlignedBB b(World world, int i, int j, int k) { return null; } @@ -61,11 +61,11 @@ public class BlockFire extends Block { return 0; } - public int r_() { + public int a(World world) { return 30; } - public void b(World world, int i, int j, int k, Random random) { + public void a(World world, int i, int j, int k, Random random) { if (world.getGameRules().getBoolean("doFireTick")) { boolean flag = world.getTypeId(i, j - 1, k) == Block.NETHERRACK.id; @@ -77,24 +77,24 @@ public class BlockFire extends Block { fireExtinguished(world, i, j, k); // CraftBukkit - invalid place location } - if (!flag && world.N() && (world.D(i, j, k) || world.D(i - 1, j, k) || world.D(i + 1, j, k) || world.D(i, j, k - 1) || world.D(i, j, k + 1))) { + if (!flag && world.O() && (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); if (l < 15) { - world.setRawData(i, j, k, l + random.nextInt(3) / 2); + world.setData(i, j, k, l + random.nextInt(3) / 2, 4); } - world.a(i, j, k, this.id, this.r_() + random.nextInt(10)); - if (!flag && !this.l(world, i, j, k)) { - if (!world.v(i, j - 1, k) || l > 3) { - world.setTypeId(i, j, k, 0); + world.a(i, j, k, this.id, this.a(world) + random.nextInt(10)); + if (!flag && !this.k(world, i, j, k)) { + if (!world.w(i, j - 1, k) || l > 3) { + world.setAir(i, j, k); } } else if (!flag && !this.d((IBlockAccess) world, i, j - 1, k) && l == 15 && random.nextInt(4) == 0) { fireExtinguished(world, i, j, k); // CraftBukkit - burn out } else { - boolean flag1 = world.E(i, j, k); + boolean flag1 = world.G(i, j, k); byte b0 = 0; if (flag1) { @@ -126,7 +126,7 @@ public class BlockFire extends Block { l1 += (k1 - (j + 1)) * 100; } - int i2 = this.n(world, i1, k1, j1); + int i2 = this.m(world, i1, k1, j1); if (i2 > 0) { int j2 = (i2 + 40 + world.difficulty * 7) / (l + 30); @@ -135,7 +135,7 @@ public class BlockFire extends Block { j2 /= 2; } - if (j2 > 0 && random.nextInt(l1) <= j2 && (!world.N() || !world.D(i1, k1, j1)) && !world.D(i1 - 1, k1, k) && !world.D(i1 + 1, k1, j1) && !world.D(i1, k1, j1 - 1) && !world.D(i1, k1, j1 + 1)) { + if (j2 > 0 && random.nextInt(l1) <= j2 && (!world.O() || !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) { @@ -197,16 +197,16 @@ public class BlockFire extends Block { } // CraftBukkit end - if (random.nextInt(i1 + 10) < 5 && !world.D(i, j, k)) { + if (random.nextInt(i1 + 10) < 5 && !world.F(i, j, k)) { int k1 = i1 + random.nextInt(5) / 4; if (k1 > 15) { k1 = 15; } - world.setTypeIdAndData(i, j, k, this.id, k1); + world.setTypeIdAndData(i, j, k, this.id, k1, 3); } else { - world.setTypeId(i, j, k, 0); + world.setAir(i, j, k); } if (flag) { @@ -215,11 +215,11 @@ public class BlockFire extends Block { } } - private boolean l(World world, int i, int j, int k) { + private boolean k(World world, int i, int j, int k) { return this.d((IBlockAccess) world, i + 1, j, k) ? true : (this.d((IBlockAccess) world, i - 1, j, k) ? true : (this.d((IBlockAccess) world, i, j - 1, k) ? true : (this.d((IBlockAccess) world, i, j + 1, k) ? true : (this.d((IBlockAccess) world, i, j, k - 1) ? true : this.d((IBlockAccess) world, i, j, k + 1))))); } - private int n(World world, int i, int j, int k) { + private int m(World world, int i, int j, int k) { byte b0 = 0; if (!world.isEmpty(i, j, k)) { @@ -251,21 +251,21 @@ public class BlockFire extends Block { } public boolean canPlace(World world, int i, int j, int k) { - return world.v(i, j - 1, k) || this.l(world, i, j, k); + return world.w(i, j - 1, k) || this.k(world, i, j, k); } public void doPhysics(World world, int i, int j, int k, int l) { - if (!world.v(i, j - 1, k) && !this.l(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 gone } } 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.i_(world, i, j, k)) { - if (!world.v(i, j - 1, k) && !this.l(world, i, j, k)) { + if (world.worldProvider.dimension > 0 || world.getTypeId(i, j - 1, k) != Block.OBSIDIAN.id || !Block.PORTAL.n_(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 { - world.a(i, j, k, this.id, this.r_() + world.random.nextInt(10)); + world.a(i, j, k, this.id, this.a(world) + world.random.nextInt(10)); } } } @@ -273,7 +273,7 @@ public class BlockFire extends Block { // CraftBukkit start private void fireExtinguished(World world, int x, int y, int z) { if (org.bukkit.craftbukkit.event.CraftEventFactory.callBlockFadeEvent(world.getWorld().getBlockAt(x, y, z), 0).isCancelled() == false) { - world.setTypeId(x, y, z, 0); + world.setAir(x, y, z); } } // CraftBukkit end diff --git a/src/main/java/net/minecraft/server/BlockFlowing.java b/src/main/java/net/minecraft/server/BlockFlowing.java index 643422a3c4..2b5d1f3932 100644 --- a/src/main/java/net/minecraft/server/BlockFlowing.java +++ b/src/main/java/net/minecraft/server/BlockFlowing.java @@ -17,25 +17,24 @@ public class BlockFlowing extends BlockFluids { super(i, material); } - private void l(World world, int i, int j, int k) { + private void k(World world, int i, int j, int k) { int l = world.getData(i, j, k); - world.setRawTypeIdAndData(i, j, k, this.id + 1, l); - world.e(i, j, k, i, j, k); + world.setTypeIdAndData(i, j, k, this.id + 1, l, 2); } - public boolean c(IBlockAccess iblockaccess, int i, int j, int k) { + public boolean b(IBlockAccess iblockaccess, int i, int j, int k) { return this.material != Material.LAVA; } - public void b(World world, int i, int j, int k, Random random) { + public void a(World world, int i, int j, int k, Random random) { // CraftBukkit start org.bukkit.World bworld = world.getWorld(); org.bukkit.Server server = world.getServer(); org.bukkit.block.Block source = bworld == null ? null : bworld.getBlockAt(i, j, k); // CraftBukkit end - int l = this.f_(world, i, j, k); + int l = this.k_(world, i, j, k); byte b0 = 1; if (this.material == Material.LAVA && !world.worldProvider.e) { @@ -59,8 +58,8 @@ public class BlockFlowing extends BlockFluids { i1 = -1; } - if (this.f_(world, i, j + 1, k) >= 0) { - int k1 = this.f_(world, i, j + 1, k); + if (this.k_(world, i, j + 1, k) >= 0) { + int k1 = this.k_(world, i, j + 1, k); if (k1 >= 8) { i1 = k1; @@ -72,7 +71,7 @@ public class BlockFlowing extends BlockFluids { if (this.a >= 2 && this.material == Material.WATER) { if (world.getMaterial(i, j - 1, k).isBuildable()) { i1 = 0; - } else if (world.getMaterial(i, j - 1, k) == this.material && world.getData(i, j, k) == 0) { + } else if (world.getMaterial(i, j - 1, k) == this.material && world.getData(i, j - 1, k) == 0) { i1 = 0; } } @@ -84,23 +83,23 @@ public class BlockFlowing extends BlockFluids { if (i1 == l) { if (flag) { - this.l(world, i, j, k); + this.k(world, i, j, k); } } else { l = i1; if (i1 < 0) { - world.setTypeId(i, j, k, 0); + world.setAir(i, j, k); } else { - world.setData(i, j, k, i1); - world.a(i, j, k, this.id, this.r_()); + world.setData(i, j, k, i1, 2); + world.a(i, j, k, this.id, this.a(world)); world.applyPhysics(i, j, k, this.id); } } } else { - this.l(world, i, j, k); + this.k(world, i, j, k); } - if (this.p(world, i, j - 1, k)) { + if (this.o(world, i, j - 1, k)) { // CraftBukkit start - send "down" to the server BlockFromToEvent event = new BlockFromToEvent(source, BlockFace.DOWN); if (server != null) { @@ -109,7 +108,7 @@ public class BlockFlowing extends BlockFluids { if (!event.isCancelled()) { if (this.material == Material.LAVA && world.getMaterial(i, j - 1, k) == Material.WATER) { - world.setTypeId(i, j - 1, k, Block.STONE.id); + world.setTypeIdUpdate(i, j - 1, k, Block.STONE.id); this.fizz(world, i, j - 1, k); return; } @@ -121,8 +120,8 @@ public class BlockFlowing extends BlockFluids { } } // CraftBukkit end - } else if (l >= 0 && (l == 0 || this.o(world, i, j - 1, k))) { - boolean[] aboolean = this.n(world, i, j, k); + } else if (l >= 0 && (l == 0 || this.n(world, i, j - 1, k))) { + boolean[] aboolean = this.m(world, i, j, k); i1 = l + b0; if (l >= 8) { @@ -156,7 +155,7 @@ public class BlockFlowing extends BlockFluids { } private void flow(World world, int i, int j, int k, int l) { - if (this.p(world, i, j, k)) { + if (this.o(world, i, j, k)) { int i1 = world.getTypeId(i, j, k); if (i1 > 0) { @@ -167,7 +166,7 @@ public class BlockFlowing extends BlockFluids { } } - world.setTypeIdAndData(i, j, k, this.id, l); + world.setTypeIdAndData(i, j, k, this.id, l, 3); } } @@ -195,8 +194,8 @@ public class BlockFlowing extends BlockFluids { ++i2; } - if (!this.o(world, l1, j, i2) && (world.getMaterial(l1, j, i2) != this.material || world.getData(l1, j, i2) != 0)) { - if (!this.o(world, l1, j - 1, i2)) { + if (!this.n(world, l1, j, i2) && (world.getMaterial(l1, j, i2) != this.material || world.getData(l1, j, i2) != 0)) { + if (!this.n(world, l1, j - 1, i2)) { return l; } @@ -214,7 +213,7 @@ public class BlockFlowing extends BlockFluids { return j1; } - private boolean[] n(World world, int i, int j, int k) { + private boolean[] m(World world, int i, int j, int k) { int l; int i1; @@ -239,8 +238,8 @@ public class BlockFlowing extends BlockFluids { ++j1; } - if (!this.o(world, i1, j, j1) && (world.getMaterial(i1, j, j1) != this.material || world.getData(i1, j, j1) != 0)) { - if (this.o(world, i1, j - 1, j1)) { + if (!this.n(world, i1, j, j1) && (world.getMaterial(i1, j, j1) != this.material || world.getData(i1, j, j1) != 0)) { + if (this.n(world, i1, j - 1, j1)) { this.c[l] = this.d(world, i1, j, j1, 1, l); } else { this.c[l] = 0; @@ -263,7 +262,7 @@ public class BlockFlowing extends BlockFluids { return this.b; } - private boolean o(World world, int i, int j, int k) { + private boolean n(World world, int i, int j, int k) { int l = world.getTypeId(i, j, k); if (l != Block.WOODEN_DOOR.id && l != Block.IRON_DOOR_BLOCK.id && l != Block.SIGN_POST.id && l != Block.LADDER.id && l != Block.SUGAR_CANE_BLOCK.id) { @@ -280,7 +279,7 @@ public class BlockFlowing extends BlockFluids { } protected int d(World world, int i, int j, int k, int l) { - int i1 = this.f_(world, i, j, k); + int i1 = this.k_(world, i, j, k); if (i1 < 0) { return l; @@ -297,16 +296,16 @@ public class BlockFlowing extends BlockFluids { } } - private boolean p(World world, int i, int j, int k) { + private boolean o(World world, int i, int j, int k) { Material material = world.getMaterial(i, j, k); - return material == this.material ? false : (material == Material.LAVA ? false : !this.o(world, i, j, k)); + return material == this.material ? false : (material == Material.LAVA ? false : !this.n(world, i, j, k)); } public void onPlace(World world, int i, int j, int k) { super.onPlace(world, i, j, k); if (world.getTypeId(i, j, k) == this.id) { - world.a(i, j, k, this.id, this.r_()); + world.a(i, j, k, this.id, this.a(world)); } } diff --git a/src/main/java/net/minecraft/server/BlockGrass.java b/src/main/java/net/minecraft/server/BlockGrass.java index 79a007c856..6f9301de78 100644 --- a/src/main/java/net/minecraft/server/BlockGrass.java +++ b/src/main/java/net/minecraft/server/BlockGrass.java @@ -12,16 +12,11 @@ public class BlockGrass extends Block { protected BlockGrass(int i) { super(i, Material.GRASS); - this.textureId = 3; this.b(true); this.a(CreativeModeTab.b); } - public int a(int i, int j) { - return i == 1 ? 0 : (i == 0 ? 2 : 3); - } - - public void b(World world, int i, int j, int k, Random random) { + public void a(World world, int i, int j, int k, Random random) { if (!world.isStatic) { if (world.getLightLevel(i, j + 1, k) < 4 && Block.lightBlock[world.getTypeId(i, j + 1, k)] > 2) { // CraftBukkit start diff --git a/src/main/java/net/minecraft/server/BlockIce.java b/src/main/java/net/minecraft/server/BlockIce.java index b7215376f0..e2259706d8 100644 --- a/src/main/java/net/minecraft/server/BlockIce.java +++ b/src/main/java/net/minecraft/server/BlockIce.java @@ -4,8 +4,8 @@ import java.util.Random; public class BlockIce extends BlockHalfTransparant { - public BlockIce(int i, int j) { - super(i, j, Material.ICE, false); + public BlockIce(int i) { + super(i, "ice", Material.ICE, false); this.frictionFactor = 0.98F; this.b(true); this.a(CreativeModeTab.b); @@ -14,15 +14,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); - if (this.s_() && EnchantmentManager.hasSilkTouchEnchantment(entityhuman)) { - ItemStack itemstack = this.f_(l); + if (this.r_() && EnchantmentManager.hasSilkTouchEnchantment(entityhuman)) { + ItemStack itemstack = this.c_(l); if (itemstack != null) { this.b(world, i, j, k, itemstack); } } else { if (world.worldProvider.e) { - world.setTypeId(i, j, k, 0); + world.setAir(i, j, k); return; } @@ -32,7 +32,7 @@ public class BlockIce extends BlockHalfTransparant { Material material = world.getMaterial(i, j - 1, k); if (material.isSolid() || material.isLiquid()) { - world.setTypeId(i, j, k, Block.WATER.id); + world.setTypeIdUpdate(i, j, k, Block.WATER.id); } } } @@ -41,7 +41,7 @@ public class BlockIce extends BlockHalfTransparant { return 0; } - public void b(World world, int i, int j, int k, Random random) { + public void a(World world, int i, int j, int k, Random random) { if (world.b(EnumSkyBlock.BLOCK, i, j, k) > 11 - Block.lightBlock[this.id]) { // CraftBukkit start if (org.bukkit.craftbukkit.event.CraftEventFactory.callBlockFadeEvent(world.getWorld().getBlockAt(i, j, k), Block.STATIONARY_WATER.id).isCancelled()) { @@ -50,16 +50,16 @@ public class BlockIce extends BlockHalfTransparant { // CraftBukkit end if (world.worldProvider.e) { - world.setTypeId(i, j, k, 0); + world.setAir(i, j, k); return; } this.c(world, i, j, k, world.getData(i, j, k), 0); - world.setTypeId(i, j, k, Block.STATIONARY_WATER.id); + world.setTypeIdUpdate(i, j, k, Block.STATIONARY_WATER.id); } } - public int q_() { + public int h() { return 0; } } diff --git a/src/main/java/net/minecraft/server/BlockJukeBox.java b/src/main/java/net/minecraft/server/BlockJukeBox.java deleted file mode 100644 index b675141cbf..0000000000 --- a/src/main/java/net/minecraft/server/BlockJukeBox.java +++ /dev/null @@ -1,77 +0,0 @@ -package net.minecraft.server; - -public class BlockJukeBox extends BlockContainer { - - protected BlockJukeBox(int i, int j) { - super(i, j, Material.WOOD); - this.a(CreativeModeTab.c); - } - - public int a(int i) { - return this.textureId + (i == 1 ? 1 : 0); - } - - public boolean interact(World world, int i, int j, int k, EntityHuman entityhuman, int l, float f, float f1, float f2) { - if (world.getData(i, j, k) == 0) { - return false; - } else { - this.dropRecord(world, i, j, k); - return true; - } - } - - public void a(World world, int i, int j, int k, ItemStack itemstack) { - if (!world.isStatic) { - TileEntityRecordPlayer tileentityrecordplayer = (TileEntityRecordPlayer) world.getTileEntity(i, j, k); - - if (tileentityrecordplayer != null) { - tileentityrecordplayer.record = itemstack.cloneItemStack(); - tileentityrecordplayer.record.count = 1; // CraftBukkit - There can be only one - tileentityrecordplayer.update(); - world.setData(i, j, k, 1); - } - } - } - - public void dropRecord(World world, int i, int j, int k) { - if (!world.isStatic) { - TileEntityRecordPlayer tileentityrecordplayer = (TileEntityRecordPlayer) world.getTileEntity(i, j, k); - - if (tileentityrecordplayer != null) { - ItemStack itemstack = tileentityrecordplayer.record; - - if (itemstack != null) { - world.triggerEffect(1005, i, j, k, 0); - world.a((String) null, i, j, k); - tileentityrecordplayer.record = null; - tileentityrecordplayer.update(); - world.setData(i, j, k, 0); - float f = 0.7F; - double d0 = (double) (world.random.nextFloat() * f) + (double) (1.0F - f) * 0.5D; - double d1 = (double) (world.random.nextFloat() * f) + (double) (1.0F - f) * 0.2D + 0.6D; - double d2 = (double) (world.random.nextFloat() * f) + (double) (1.0F - f) * 0.5D; - ItemStack itemstack1 = itemstack.cloneItemStack(); - EntityItem entityitem = new EntityItem(world, (double) i + d0, (double) j + d1, (double) k + d2, itemstack1); - - entityitem.pickupDelay = 10; - world.addEntity(entityitem); - } - } - } - } - - public void remove(World world, int i, int j, int k, int l, int i1) { - this.dropRecord(world, i, j, k); - super.remove(world, i, j, k, l, i1); - } - - public void dropNaturally(World world, int i, int j, int k, int l, float f, int i1) { - if (!world.isStatic) { - super.dropNaturally(world, i, j, k, l, f, 0); - } - } - - public TileEntity a(World world) { - return new TileEntityRecordPlayer(); - } -} diff --git a/src/main/java/net/minecraft/server/BlockLeaves.java b/src/main/java/net/minecraft/server/BlockLeaves.java index e06e0675f6..318c304d98 100644 --- a/src/main/java/net/minecraft/server/BlockLeaves.java +++ b/src/main/java/net/minecraft/server/BlockLeaves.java @@ -6,13 +6,13 @@ import org.bukkit.event.block.LeavesDecayEvent; // CraftBukkit public class BlockLeaves extends BlockTransparant { - private int cD; public static final String[] a = new String[] { "oak", "spruce", "birch", "jungle"}; - int[] b; + 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][]; + int[] c; - protected BlockLeaves(int i, int j) { - super(i, j, Material.LEAVES, false); - this.cD = j; + protected BlockLeaves(int i) { + super(i, Material.LEAVES, false); this.b(true); this.a(CreativeModeTab.c); } @@ -21,7 +21,7 @@ public class BlockLeaves extends BlockTransparant { byte b0 = 1; int j1 = b0 + 1; - if (world.d(i - j1, j - j1, k - j1, i + j1, j + j1, k + j1)) { + if (world.e(i - j1, j - j1, k - j1, i + j1, j + j1, k + j1)) { for (int k1 = -b0; k1 <= b0; ++k1) { for (int l1 = -b0; l1 <= b0; ++l1) { for (int i2 = -b0; i2 <= b0; ++i2) { @@ -30,7 +30,7 @@ public class BlockLeaves extends BlockTransparant { if (j2 == Block.LEAVES.id) { int k2 = world.getData(i + k1, j + l1, k + i2); - world.setRawData(i + k1, j + l1, k + i2, k2 | 8); + world.setData(i + k1, j + l1, k + i2, k2 | 8, 4); } } } @@ -38,7 +38,7 @@ public class BlockLeaves extends BlockTransparant { } } - public void b(World world, int i, int j, int k, Random random) { + public void a(World world, int i, int j, int k, Random random) { if (!world.isStatic) { int l = world.getData(i, j, k); @@ -49,13 +49,13 @@ public class BlockLeaves extends BlockTransparant { int j1 = b1 * b1; int k1 = b1 / 2; - if (this.b == null) { - this.b = new int[b1 * b1 * b1]; + if (this.c == null) { + this.c = new int[b1 * b1 * b1]; } int l1; - if (world.d(i - i1, j - i1, k - i1, i + i1, j + i1, k + i1)) { + if (world.e(i - i1, j - i1, k - i1, i + i1, j + i1, k + i1)) { int i2; int j2; int k2; @@ -65,11 +65,11 @@ public class BlockLeaves extends BlockTransparant { for (j2 = -b0; j2 <= b0; ++j2) { k2 = world.getTypeId(i + l1, j + i2, k + j2); if (k2 == Block.LOG.id) { - this.b[(l1 + k1) * j1 + (i2 + k1) * b1 + j2 + k1] = 0; + this.c[(l1 + k1) * j1 + (i2 + k1) * b1 + j2 + k1] = 0; } else if (k2 == Block.LEAVES.id) { - this.b[(l1 + k1) * j1 + (i2 + k1) * b1 + j2 + k1] = -2; + this.c[(l1 + k1) * j1 + (i2 + k1) * b1 + j2 + k1] = -2; } else { - this.b[(l1 + k1) * j1 + (i2 + k1) * b1 + j2 + k1] = -1; + this.c[(l1 + k1) * j1 + (i2 + k1) * b1 + j2 + k1] = -1; } } } @@ -79,29 +79,29 @@ public class BlockLeaves extends BlockTransparant { for (i2 = -b0; i2 <= b0; ++i2) { for (j2 = -b0; j2 <= b0; ++j2) { for (k2 = -b0; k2 <= b0; ++k2) { - if (this.b[(i2 + k1) * j1 + (j2 + k1) * b1 + k2 + k1] == l1 - 1) { - if (this.b[(i2 + k1 - 1) * j1 + (j2 + k1) * b1 + k2 + k1] == -2) { - this.b[(i2 + k1 - 1) * j1 + (j2 + k1) * b1 + k2 + k1] = l1; + if (this.c[(i2 + k1) * j1 + (j2 + k1) * b1 + k2 + k1] == l1 - 1) { + if (this.c[(i2 + k1 - 1) * j1 + (j2 + k1) * b1 + k2 + k1] == -2) { + this.c[(i2 + k1 - 1) * j1 + (j2 + k1) * b1 + k2 + k1] = l1; } - if (this.b[(i2 + k1 + 1) * j1 + (j2 + k1) * b1 + k2 + k1] == -2) { - this.b[(i2 + k1 + 1) * j1 + (j2 + k1) * b1 + k2 + k1] = l1; + if (this.c[(i2 + k1 + 1) * j1 + (j2 + k1) * b1 + k2 + k1] == -2) { + this.c[(i2 + k1 + 1) * j1 + (j2 + k1) * b1 + k2 + k1] = l1; } - if (this.b[(i2 + k1) * j1 + (j2 + k1 - 1) * b1 + k2 + k1] == -2) { - this.b[(i2 + k1) * j1 + (j2 + k1 - 1) * b1 + k2 + k1] = l1; + if (this.c[(i2 + k1) * j1 + (j2 + k1 - 1) * b1 + k2 + k1] == -2) { + this.c[(i2 + k1) * j1 + (j2 + k1 - 1) * b1 + k2 + k1] = l1; } - if (this.b[(i2 + k1) * j1 + (j2 + k1 + 1) * b1 + k2 + k1] == -2) { - this.b[(i2 + k1) * j1 + (j2 + k1 + 1) * b1 + k2 + k1] = l1; + if (this.c[(i2 + k1) * j1 + (j2 + k1 + 1) * b1 + k2 + k1] == -2) { + this.c[(i2 + k1) * j1 + (j2 + k1 + 1) * b1 + k2 + k1] = l1; } - if (this.b[(i2 + k1) * j1 + (j2 + k1) * b1 + (k2 + k1 - 1)] == -2) { - this.b[(i2 + k1) * j1 + (j2 + k1) * b1 + (k2 + k1 - 1)] = l1; + if (this.c[(i2 + k1) * j1 + (j2 + k1) * b1 + (k2 + k1 - 1)] == -2) { + this.c[(i2 + k1) * j1 + (j2 + k1) * b1 + (k2 + k1 - 1)] = l1; } - if (this.b[(i2 + k1) * j1 + (j2 + k1) * b1 + k2 + k1 + 1] == -2) { - this.b[(i2 + k1) * j1 + (j2 + k1) * b1 + k2 + k1 + 1] = l1; + if (this.c[(i2 + k1) * j1 + (j2 + k1) * b1 + k2 + k1 + 1] == -2) { + this.c[(i2 + k1) * j1 + (j2 + k1) * b1 + k2 + k1 + 1] = l1; } } } @@ -110,17 +110,17 @@ public class BlockLeaves extends BlockTransparant { } } - l1 = this.b[k1 * j1 + k1 * b1 + k1]; + l1 = this.c[k1 * j1 + k1 * b1 + k1]; if (l1 >= 0) { - world.setRawData(i, j, k, l & -9); + world.setData(i, j, k, l & -9, 4); } else { - this.l(world, i, j, k); + this.k(world, i, j, k); } } } } - private void l(World world, int i, int j, int k) { + private void k(World world, int i, int j, int k) { // CraftBukkit start LeavesDecayEvent event = new LeavesDecayEvent(world.getWorld().getBlockAt(i, j, k)); world.getServer().getPluginManager().callEvent(event); @@ -131,7 +131,7 @@ public class BlockLeaves extends BlockTransparant { // CraftBukkit end this.c(world, i, j, k, world.getData(i, j, k), 0); - world.setTypeId(i, j, k, 0); + world.setAir(i, j, k); } public int a(Random random) { @@ -144,26 +144,41 @@ public class BlockLeaves extends BlockTransparant { public void dropNaturally(World world, int i, int j, int k, int l, float f, int i1) { if (!world.isStatic) { - byte b0 = 20; + int j1 = 20; if ((l & 3) == 3) { - b0 = 40; + j1 = 40; } - if (world.random.nextInt(b0) == 0) { - int j1 = this.getDropType(l, world.random, i1); - - this.b(world, i, j, k, new ItemStack(j1, 1, this.getDropData(l))); + if (i1 > 0) { + j1 -= 2 << i1; + if (j1 < 10) { + j1 = 10; + } } - if ((l & 3) == 0 && world.random.nextInt(200) == 0) { + if (world.random.nextInt(j1) == 0) { + int k1 = this.getDropType(l, world.random, i1); + + this.b(world, i, j, k, new ItemStack(k1, 1, this.getDropData(l))); + } + + j1 = 200; + if (i1 > 0) { + j1 -= 10 << i1; + if (j1 < 40) { + j1 = 40; + } + } + + if ((l & 3) == 0 && world.random.nextInt(j1) == 0) { this.b(world, i, j, k, new ItemStack(Item.APPLE, 1, 0)); } } } public void a(World world, EntityHuman entityhuman, int i, int j, int k, int l) { - if (!world.isStatic && entityhuman.bS() != null && entityhuman.bS().id == Item.SHEARS.id) { + if (!world.isStatic && entityhuman.cb() != null && entityhuman.cb().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 { @@ -176,14 +191,10 @@ public class BlockLeaves extends BlockTransparant { } public boolean c() { - return !this.c; + return !this.d; } - public int a(int i, int j) { - return (j & 3) == 1 ? this.textureId + 80 : ((j & 3) == 3 ? this.textureId + 144 : this.textureId); - } - - protected ItemStack f_(int i) { + protected ItemStack c_(int i) { return new ItemStack(this.id, 1, i & 3); } } diff --git a/src/main/java/net/minecraft/server/BlockLever.java b/src/main/java/net/minecraft/server/BlockLever.java index 11489b14e5..a225d28386 100644 --- a/src/main/java/net/minecraft/server/BlockLever.java +++ b/src/main/java/net/minecraft/server/BlockLever.java @@ -4,12 +4,12 @@ import org.bukkit.event.block.BlockRedstoneEvent; // CraftBukkit public class BlockLever extends Block { - protected BlockLever(int i, int j) { - super(i, j, Material.ORIENTABLE); + protected BlockLever(int i) { + super(i, Material.ORIENTABLE); this.a(CreativeModeTab.d); } - public AxisAlignedBB e(World world, int i, int j, int k) { + public AxisAlignedBB b(World world, int i, int j, int k) { return null; } @@ -26,46 +26,66 @@ public class BlockLever extends Block { } public boolean canPlace(World world, int i, int j, int k, int l) { - return l == 0 && world.t(i, j + 1, k) ? true : (l == 1 && world.v(i, j - 1, k) ? true : (l == 2 && world.t(i, j, k + 1) ? true : (l == 3 && world.t(i, j, k - 1) ? true : (l == 4 && world.t(i + 1, j, k) ? true : l == 5 && world.t(i - 1, j, k))))); + return l == 0 && world.u(i, j + 1, k) ? true : (l == 1 && world.w(i, j - 1, k) ? true : (l == 2 && world.u(i, j, k + 1) ? true : (l == 3 && world.u(i, j, k - 1) ? true : (l == 4 && world.u(i + 1, j, k) ? true : l == 5 && world.u(i - 1, j, k))))); } public boolean canPlace(World world, int i, int j, int k) { - return world.t(i - 1, j, k) ? true : (world.t(i + 1, j, k) ? true : (world.t(i, j, k - 1) ? true : (world.t(i, j, k + 1) ? true : (world.v(i, j - 1, k) ? true : world.t(i, j + 1, k))))); + return world.u(i - 1, j, k) ? true : (world.u(i + 1, j, k) ? true : (world.u(i, j, k - 1) ? true : (world.u(i, j, k + 1) ? true : (world.w(i, j - 1, k) ? true : world.u(i, j + 1, k))))); } public int getPlacedData(World world, int i, int j, int k, int l, float f, float f1, float f2, int i1) { int j1 = i1 & 8; int k1 = i1 & 7; + byte b0 = -1; - k1 = -1; - if (l == 0 && world.t(i, j + 1, k)) { - k1 = world.random.nextBoolean() ? 0 : 7; + if (l == 0 && world.u(i, j + 1, k)) { + b0 = 0; } - if (l == 1 && world.v(i, j - 1, k)) { - k1 = 5 + world.random.nextInt(2); + if (l == 1 && world.w(i, j - 1, k)) { + b0 = 5; } - if (l == 2 && world.t(i, j, k + 1)) { - k1 = 4; + if (l == 2 && world.u(i, j, k + 1)) { + b0 = 4; } - if (l == 3 && world.t(i, j, k - 1)) { - k1 = 3; + if (l == 3 && world.u(i, j, k - 1)) { + b0 = 3; } - if (l == 4 && world.t(i + 1, j, k)) { - k1 = 2; + if (l == 4 && world.u(i + 1, j, k)) { + b0 = 2; } - if (l == 5 && world.t(i - 1, j, k)) { - k1 = 1; + if (l == 5 && world.u(i - 1, j, k)) { + b0 = 1; } - return k1 + j1; + return b0 + j1; } - public static int e(int i) { + public void postPlace(World world, int i, int j, int k, EntityLiving entityliving, ItemStack itemstack) { + int l = world.getData(i, j, k); + int i1 = l & 7; + int j1 = l & 8; + + if (i1 == d(1)) { + if ((MathHelper.floor((double) (entityliving.yaw * 4.0F / 360.0F) + 0.5D) & 1) == 0) { + world.setData(i, j, k, 5 | j1, 2); + } else { + world.setData(i, j, k, 6 | j1, 2); + } + } else if (i1 == d(0)) { + if ((MathHelper.floor((double) (entityliving.yaw * 4.0F / 360.0F) + 0.5D) & 1) == 0) { + world.setData(i, j, k, 7 | j1, 2); + } else { + world.setData(i, j, k, 0 | j1, 2); + } + } + } + + public static int d(int i) { switch (i) { case 0: return 0; @@ -91,53 +111,53 @@ public class BlockLever extends Block { } public void doPhysics(World world, int i, int j, int k, int l) { - if (this.l(world, i, j, k)) { + if (this.k(world, i, j, k)) { int i1 = world.getData(i, j, k) & 7; boolean flag = false; - if (!world.t(i - 1, j, k) && i1 == 1) { + if (!world.u(i - 1, j, k) && i1 == 1) { flag = true; } - if (!world.t(i + 1, j, k) && i1 == 2) { + if (!world.u(i + 1, j, k) && i1 == 2) { flag = true; } - if (!world.t(i, j, k - 1) && i1 == 3) { + if (!world.u(i, j, k - 1) && i1 == 3) { flag = true; } - if (!world.t(i, j, k + 1) && i1 == 4) { + if (!world.u(i, j, k + 1) && i1 == 4) { flag = true; } - if (!world.v(i, j - 1, k) && i1 == 5) { + if (!world.w(i, j - 1, k) && i1 == 5) { flag = true; } - if (!world.v(i, j - 1, k) && i1 == 6) { + if (!world.w(i, j - 1, k) && i1 == 6) { flag = true; } - if (!world.t(i, j + 1, k) && i1 == 0) { + if (!world.u(i, j + 1, k) && i1 == 0) { flag = true; } - if (!world.t(i, j + 1, k) && i1 == 7) { + if (!world.u(i, j + 1, k) && i1 == 7) { flag = true; } if (flag) { this.c(world, i, j, k, world.getData(i, j, k), 0); - world.setTypeId(i, j, k, 0); + world.setAir(i, j, k); } } } - private boolean l(World world, int i, int j, int k) { + private boolean k(World world, int i, int j, int k) { if (!this.canPlace(world, i, j, k)) { this.c(world, i, j, k, world.getData(i, j, k), 0); - world.setTypeId(i, j, k, 0); + world.setAir(i, j, k); return false; } else { return true; @@ -167,8 +187,6 @@ public class BlockLever extends Block { } } - public void attack(World world, int i, int j, int k, EntityHuman entityhuman) {} - public boolean interact(World world, int i, int j, int k, EntityHuman entityhuman, int l, float f, float f1, float f2) { if (world.isStatic) { return true; @@ -179,8 +197,8 @@ public class BlockLever extends Block { // CraftBukkit start - Interact Lever org.bukkit.block.Block block = world.getWorld().getBlockAt(i, j, k); - int old = (k1 != 8) ? 1 : 0; - int current = (k1 == 8) ? 1 : 0; + int old = (k1 != 8) ? 15 : 0; + int current = (k1 == 8) ? 15 : 0; BlockRedstoneEvent eventRedstone = new BlockRedstoneEvent(block, old, current); world.getServer().getPluginManager().callEvent(eventRedstone); @@ -190,8 +208,7 @@ public class BlockLever extends Block { } // CraftBukkit end - world.setData(i, j, k, j1 + k1); - world.e(i, j, k, i, j, k); + world.setData(i, j, k, j1 + k1, 3); world.makeSound((double) i + 0.5D, (double) j + 0.5D, (double) k + 0.5D, "random.click", 0.3F, k1 > 0 ? 0.6F : 0.5F); world.applyPhysics(i, j, k, this.id); if (j1 == 1) { @@ -239,19 +256,19 @@ public class BlockLever extends Block { super.remove(world, i, j, k, l, i1); } - public boolean b(IBlockAccess iblockaccess, int i, int j, int k, int l) { - return (iblockaccess.getData(i, j, k) & 8) > 0; + public int b(IBlockAccess iblockaccess, int i, int j, int k, int l) { + return (iblockaccess.getData(i, j, k) & 8) > 0 ? 15 : 0; } - public boolean c(IBlockAccess iblockaccess, int i, int j, int k, int l) { + public int c(IBlockAccess iblockaccess, int i, int j, int k, int l) { int i1 = iblockaccess.getData(i, j, k); if ((i1 & 8) == 0) { - return false; + return 0; } else { int j1 = i1 & 7; - return j1 == 0 && l == 0 ? true : (j1 == 7 && l == 0 ? true : (j1 == 6 && l == 1 ? true : (j1 == 5 && l == 1 ? true : (j1 == 4 && l == 2 ? true : (j1 == 3 && l == 3 ? true : (j1 == 2 && l == 4 ? true : j1 == 1 && l == 5)))))); + return j1 == 0 && l == 0 ? 15 : (j1 == 7 && l == 0 ? 15 : (j1 == 6 && l == 1 ? 15 : (j1 == 5 && l == 1 ? 15 : (j1 == 4 && l == 2 ? 15 : (j1 == 3 && l == 3 ? 15 : (j1 == 2 && l == 4 ? 15 : (j1 == 1 && l == 5 ? 15 : 0))))))); } } diff --git a/src/main/java/net/minecraft/server/BlockMinecartDetector.java b/src/main/java/net/minecraft/server/BlockMinecartDetector.java index 93d13625c3..3469207eb6 100644 --- a/src/main/java/net/minecraft/server/BlockMinecartDetector.java +++ b/src/main/java/net/minecraft/server/BlockMinecartDetector.java @@ -5,14 +5,14 @@ import java.util.Random; import org.bukkit.event.block.BlockRedstoneEvent; // CraftBukkit -public class BlockMinecartDetector extends BlockMinecartTrack { +public class BlockMinecartDetector extends BlockMinecartTrackAbstract { - public BlockMinecartDetector(int i, int j) { - super(i, j, true); + public BlockMinecartDetector(int i) { + super(i, true); this.b(true); } - public int r_() { + public int a(World world) { return 20; } @@ -30,7 +30,7 @@ public class BlockMinecartDetector extends BlockMinecartTrack { } } - public void b(World world, int i, int j, int k, Random random) { + public void a(World world, int i, int j, int k, Random random) { if (!world.isStatic) { int l = world.getData(i, j, k); @@ -40,19 +40,19 @@ public class BlockMinecartDetector extends BlockMinecartTrack { } } - public boolean b(IBlockAccess iblockaccess, int i, int j, int k, int l) { - return (iblockaccess.getData(i, j, k) & 8) != 0; + public int b(IBlockAccess iblockaccess, int i, int j, int k, int l) { + return (iblockaccess.getData(i, j, k) & 8) != 0 ? 15 : 0; } - public boolean c(IBlockAccess iblockaccess, int i, int j, int k, int l) { - return (iblockaccess.getData(i, j, k) & 8) == 0 ? false : l == 1; + public int c(IBlockAccess iblockaccess, int i, int j, int k, int l) { + return (iblockaccess.getData(i, j, k) & 8) == 0 ? 0 : (l == 1 ? 15 : 0); } private void d(World world, int i, int j, int k, int l) { boolean flag = (l & 8) != 0; boolean flag1 = false; float f = 0.125F; - List list = world.a(EntityMinecart.class, AxisAlignedBB.a().a((double) ((float) i + f), (double) j, (double) ((float) k + f), (double) ((float) (i + 1) - f), (double) ((float) (j + 1) - f), (double) ((float) (k + 1) - f))); + List list = world.a(EntityMinecartAbstract.class, AxisAlignedBB.a().a((double) ((float) i + f), (double) j, (double) ((float) k + f), (double) ((float) (i + 1) - f), (double) ((float) (j + 1) - f), (double) ((float) (k + 1) - f))); if (!list.isEmpty()) { flag1 = true; @@ -62,7 +62,7 @@ public class BlockMinecartDetector extends BlockMinecartTrack { if (flag != flag1) { org.bukkit.block.Block block = world.getWorld().getBlockAt(i, j, k); - BlockRedstoneEvent eventRedstone = new BlockRedstoneEvent(block, flag ? 1 : 0, flag1 ? 1 : 0); + BlockRedstoneEvent eventRedstone = new BlockRedstoneEvent(block, flag ? 15 : 0, flag1 ? 15 : 0); world.getServer().getPluginManager().callEvent(eventRedstone); flag1 = eventRedstone.getNewCurrent() > 0; @@ -70,21 +70,45 @@ public class BlockMinecartDetector extends BlockMinecartTrack { // CraftBukkit end if (flag1 && !flag) { - world.setData(i, j, k, l | 8); + world.setData(i, j, k, l | 8, 3); world.applyPhysics(i, j, k, this.id); world.applyPhysics(i, j - 1, k, this.id); - world.e(i, j, k, i, j, k); + world.g(i, j, k, i, j, k); } if (!flag1 && flag) { - world.setData(i, j, k, l & 7); + world.setData(i, j, k, l & 7, 3); world.applyPhysics(i, j, k, this.id); world.applyPhysics(i, j - 1, k, this.id); - world.e(i, j, k, i, j, k); + world.g(i, j, k, i, j, k); } if (flag1) { - world.a(i, j, k, this.id, this.r_()); + world.a(i, j, k, this.id, this.a(world)); } + + world.m(i, j, k, this.id); + } + + public void onPlace(World world, int i, int j, int k) { + super.onPlace(world, i, j, k); + this.d(world, i, j, k, world.getData(i, j, k)); + } + + public boolean q_() { + return true; + } + + public int b_(World world, int i, int j, int k, int l) { + if ((world.getData(i, j, k) & 8) > 0) { + float f = 0.125F; + List list = world.a(EntityMinecartAbstract.class, AxisAlignedBB.a().a((double) ((float) i + f), (double) j, (double) ((float) k + f), (double) ((float) (i + 1) - f), (double) ((float) (j + 1) - f), (double) ((float) (k + 1) - f)), IEntitySelector.b); + + if (list.size() > 0) { + return Container.b((IInventory) list.get(0)); + } + } + + return 0; } } diff --git a/src/main/java/net/minecraft/server/BlockMobSpawner.java b/src/main/java/net/minecraft/server/BlockMobSpawner.java index fdedbad910..614a3d16a4 100644 --- a/src/main/java/net/minecraft/server/BlockMobSpawner.java +++ b/src/main/java/net/minecraft/server/BlockMobSpawner.java @@ -4,11 +4,11 @@ import java.util.Random; public class BlockMobSpawner extends BlockContainer { - protected BlockMobSpawner(int i, int j) { - super(i, j, Material.STONE); + protected BlockMobSpawner(int i) { + super(i, Material.STONE); } - public TileEntity a(World world) { + public TileEntity b(World world) { return new TileEntityMobSpawner(); } @@ -25,7 +25,7 @@ public class BlockMobSpawner extends BlockContainer { /* CraftBukkit start - delegate to getExpDrop int j1 = 15 + world.random.nextInt(15) + world.random.nextInt(15); - this.f(world, i, j, k, j1);*/ + this.j(world, i, j, k, j1);*/ } public int getExpDrop(World world, int data, int enchantmentLevel) { diff --git a/src/main/java/net/minecraft/server/BlockMushroom.java b/src/main/java/net/minecraft/server/BlockMushroom.java index db9087492c..872ad00322 100644 --- a/src/main/java/net/minecraft/server/BlockMushroom.java +++ b/src/main/java/net/minecraft/server/BlockMushroom.java @@ -14,15 +14,18 @@ import org.bukkit.event.world.StructureGrowEvent; public class BlockMushroom extends BlockFlower { - protected BlockMushroom(int i, int j) { - super(i, j); + private final String a; + + protected BlockMushroom(int i, String s) { + 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); this.b(true); } - public void b(World world, int i, int j, int k, Random random) { + public void a(World world, int i, int j, int k, Random random) { final int sourceX = i, sourceY = j, sourceZ = k; // CraftBukkit if (random.nextInt(25) == 0) { byte b0 = 4; @@ -50,7 +53,7 @@ public class BlockMushroom extends BlockFlower { k1 = k + random.nextInt(3) - 1; for (int l1 = 0; l1 < 4; ++l1) { - if (world.isEmpty(i1, j1, k1) && this.d(world, i1, j1, k1)) { + if (world.isEmpty(i1, j1, k1) && this.f(world, i1, j1, k1)) { i = i1; j = j1; k = k1; @@ -61,7 +64,7 @@ public class BlockMushroom extends BlockFlower { k1 = k + random.nextInt(3) - 1; } - if (world.isEmpty(i1, j1, k1) && this.d(world, i1, j1, k1)) { + if (world.isEmpty(i1, j1, k1) && this.f(world, i1, j1, k1)) { // CraftBukkit start org.bukkit.World bworld = world.getWorld(); BlockState blockState = bworld.getBlockAt(i1, j1, k1).getState(); @@ -79,18 +82,18 @@ public class BlockMushroom extends BlockFlower { } public boolean canPlace(World world, int i, int j, int k) { - return super.canPlace(world, i, j, k) && this.d(world, i, j, k); + return super.canPlace(world, i, j, k) && this.f(world, i, j, k); } - protected boolean d_(int i) { - return Block.q[i]; + protected boolean f_(int i) { + return Block.s[i]; } - public boolean d(World world, int i, int j, int k) { + 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.l(i, j, k) < 13 && this.d_(l); + return l == Block.MYCEL.id || world.m(i, j, k) < 13 && this.f_(l); } else { return false; } @@ -100,7 +103,7 @@ public class BlockMushroom extends BlockFlower { public boolean grow(World world, int i, int j, int k, Random random, boolean bonemeal, org.bukkit.entity.Player player, ItemStack itemstack) { int l = world.getData(i, j, k); - world.setRawTypeId(i, j, k, 0); + world.setAir(i, j, k); // CraftBukkit start boolean grown = false; StructureGrowEvent event = null; @@ -122,7 +125,7 @@ public class BlockMushroom extends BlockFlower { } } if (!grown || event.isCancelled()) { - world.setRawTypeIdAndData(i, j, k, this.id, l); + world.setTypeIdAndData(i, j, k, this.id, l, 3); return false; } return true; diff --git a/src/main/java/net/minecraft/server/BlockMycel.java b/src/main/java/net/minecraft/server/BlockMycel.java index 6dbf49f70f..1de8c83e75 100644 --- a/src/main/java/net/minecraft/server/BlockMycel.java +++ b/src/main/java/net/minecraft/server/BlockMycel.java @@ -12,16 +12,11 @@ public class BlockMycel extends Block { protected BlockMycel(int i) { super(i, Material.GRASS); - this.textureId = 77; this.b(true); this.a(CreativeModeTab.b); } - public int a(int i, int j) { - return i == 1 ? 78 : (i == 0 ? 2 : 77); - } - - public void b(World world, int i, int j, int k, Random random) { + public void a(World world, int i, int j, int k, Random random) { if (!world.isStatic) { if (world.getLightLevel(i, j + 1, k) < 4 && Block.lightBlock[world.getTypeId(i, j + 1, k)] > 2) { // CraftBukkit start diff --git a/src/main/java/net/minecraft/server/BlockNetherWart.java b/src/main/java/net/minecraft/server/BlockNetherWart.java index 22b8d19142..1a87122e29 100644 --- a/src/main/java/net/minecraft/server/BlockNetherWart.java +++ b/src/main/java/net/minecraft/server/BlockNetherWart.java @@ -4,8 +4,10 @@ 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, 226); + super(i); this.b(true); float f = 0.5F; @@ -13,26 +15,22 @@ public class BlockNetherWart extends BlockFlower { this.a((CreativeModeTab) null); } - protected boolean d_(int i) { + protected boolean f_(int i) { return i == Block.SOUL_SAND.id; } - public boolean d(World world, int i, int j, int k) { - return this.d_(world.getTypeId(i, j - 1, k)); + public boolean f(World world, int i, int j, int k) { + return this.f_(world.getTypeId(i, j - 1, k)); } - public void b(World world, int i, int j, int k, Random random) { + public void a(World world, int i, int j, int k, Random random) { int l = world.getData(i, j, k); if (l < 3 && random.nextInt(10) == 0) { org.bukkit.craftbukkit.event.CraftEventFactory.handleBlockGrowEvent(world, i, j, k, this.id, ++l); // CraftBukkit } - super.b(world, i, j, k, random); - } - - public int a(int i, int j) { - return j >= 3 ? this.textureId + 2 : (j > 0 ? this.textureId + 1 : this.textureId); + super.a(world, i, j, k, random); } public int d() { diff --git a/src/main/java/net/minecraft/server/BlockOre.java b/src/main/java/net/minecraft/server/BlockOre.java index 7448d16653..fb1a142714 100644 --- a/src/main/java/net/minecraft/server/BlockOre.java +++ b/src/main/java/net/minecraft/server/BlockOre.java @@ -4,13 +4,13 @@ import java.util.Random; public class BlockOre extends Block { - public BlockOre(int i, int j) { - super(i, j, Material.STONE); + public BlockOre(int i) { + super(i, Material.STONE); this.a(CreativeModeTab.b); } public int getDropType(int i, Random random, int j) { - return this.id == Block.COAL_ORE.id ? Item.COAL.id : (this.id == Block.DIAMOND_ORE.id ? Item.DIAMOND.id : (this.id == Block.LAPIS_ORE.id ? Item.INK_SACK.id : (this.id == Block.EMERALD_ORE.id ? Item.EMERALD.id : this.id))); + return this.id == Block.COAL_ORE.id ? Item.COAL.id : (this.id == Block.DIAMOND_ORE.id ? Item.DIAMOND.id : (this.id == Block.LAPIS_ORE.id ? Item.INK_SACK.id : (this.id == Block.EMERALD_ORE.id ? Item.EMERALD.id : (this.id == Block.QUARTZ_ORE.id ? Item.QUARTZ.id : this.id)))); } public int a(Random random) { @@ -45,9 +45,11 @@ public class BlockOre extends Block { j1 = MathHelper.nextInt(world.random, 3, 7); } else if (this.id == Block.LAPIS_ORE.id) { j1 = MathHelper.nextInt(world.random, 2, 5); + } else if (this.id == Block.QUARTZ_ORE.id) { + j1 = MathHelper.nextInt(world.random, 2, 5); } - this.f(world, i, j, k, j1); + this.j(world, i, j, k, j1); } */ } @@ -63,6 +65,8 @@ public class BlockOre extends Block { j1 = MathHelper.nextInt(world.random, 3, 7); } else if (this.id == Block.LAPIS_ORE.id) { j1 = MathHelper.nextInt(world.random, 2, 5); + } else if (this.id == Block.QUARTZ_ORE.id) { + j1 = MathHelper.nextInt(world.random, 2, 5); } return j1; diff --git a/src/main/java/net/minecraft/server/BlockPiston.java b/src/main/java/net/minecraft/server/BlockPiston.java index 0f1b5e584e..cbafd17c34 100644 --- a/src/main/java/net/minecraft/server/BlockPiston.java +++ b/src/main/java/net/minecraft/server/BlockPiston.java @@ -10,22 +10,16 @@ import org.bukkit.event.block.BlockPistonExtendEvent; public class BlockPiston extends Block { - private boolean a; + private final boolean a; - public BlockPiston(int i, int j, boolean flag) { - super(i, j, Material.PISTON); + public BlockPiston(int i, boolean flag) { + super(i, Material.PISTON); this.a = flag; - this.a(h); + this.a(j); this.c(0.5F); this.a(CreativeModeTab.d); } - public int a(int i, int j) { - int k = e(j); - - return k > 5 ? this.textureId : (i == k ? (!f(j) && this.minX <= 0.0D && this.minY <= 0.0D && this.minZ <= 0.0D && this.maxX >= 1.0D && this.maxY >= 1.0D && this.maxZ >= 1.0D ? this.textureId : 110) : (i == Facing.OPPOSITE_FACING[k] ? 109 : 108)); - } - public int d() { return 16; } @@ -38,37 +32,37 @@ public class BlockPiston extends Block { return false; } - public void postPlace(World world, int i, int j, int k, EntityLiving entityliving) { - int l = b(world, i, j, k, (EntityHuman) entityliving); + public void postPlace(World world, int i, int j, int k, EntityLiving entityliving, ItemStack itemstack) { + int l = a(world, i, j, k, entityliving); - world.setData(i, j, k, l); + world.setData(i, j, k, l, 2); if (!world.isStatic) { - this.l(world, i, j, k); + this.k(world, i, j, k); } } public void doPhysics(World world, int i, int j, int k, int l) { if (!world.isStatic) { - this.l(world, i, j, k); + this.k(world, i, j, k); } } public void onPlace(World world, int i, int j, int k) { if (!world.isStatic && world.getTileEntity(i, j, k) == null) { - this.l(world, i, j, k); + this.k(world, i, j, k); } } - private void l(World world, int i, int j, int k) { + private void k(World world, int i, int j, int k) { int l = world.getData(i, j, k); - int i1 = e(l); + int i1 = d(l); if (i1 != 7) { boolean flag = this.d(world, i, j, k, i1); - if (flag && !f(l)) { + if (flag && !e(l)) { // CraftBukkit start - int length = i(world, i, j, k, i1); + int length = e(world, i, j, k, i1); if (length >= 0) { org.bukkit.block.Block block = world.getWorld().getBlockAt(i, j, k); BlockPistonExtendEvent event = new BlockPistonExtendEvent(block, length, CraftBlock.notchToBlockFace(i1)); @@ -81,7 +75,7 @@ public class BlockPiston extends Block { world.playNote(i, j, k, this.id, 0, i1); } - } else if (!flag && f(l)) { + } else if (!flag && e(l)) { // CraftBukkit start org.bukkit.block.Block block = world.getWorld().getBlockAt(i, j, k); BlockPistonRetractEvent event = new BlockPistonRetractEvent(block, CraftBlock.notchToBlockFace(i1)); @@ -92,29 +86,37 @@ public class BlockPiston extends Block { } // CraftBukkit end + world.setData(i, j, k, i1, 2); world.playNote(i, j, k, this.id, 1, i1); } } } private boolean d(World world, int i, int j, int k, int l) { - return l != 0 && world.isBlockFaceIndirectlyPowered(i, j - 1, k, 0) ? true : (l != 1 && world.isBlockFaceIndirectlyPowered(i, j + 1, k, 1) ? true : (l != 2 && world.isBlockFaceIndirectlyPowered(i, j, k - 1, 2) ? true : (l != 3 && world.isBlockFaceIndirectlyPowered(i, j, k + 1, 3) ? true : (l != 5 && world.isBlockFaceIndirectlyPowered(i + 1, j, k, 5) ? true : (l != 4 && world.isBlockFaceIndirectlyPowered(i - 1, j, k, 4) ? true : (world.isBlockFaceIndirectlyPowered(i, j, k, 0) ? true : (world.isBlockFaceIndirectlyPowered(i, j + 2, k, 1) ? true : (world.isBlockFaceIndirectlyPowered(i, j + 1, k - 1, 2) ? true : (world.isBlockFaceIndirectlyPowered(i, j + 1, k + 1, 3) ? true : (world.isBlockFaceIndirectlyPowered(i - 1, j + 1, k, 4) ? true : world.isBlockFaceIndirectlyPowered(i + 1, j + 1, k, 5))))))))))); + return l != 0 && world.isBlockFacePowered(i, j - 1, k, 0) ? true : (l != 1 && world.isBlockFacePowered(i, j + 1, k, 1) ? true : (l != 2 && world.isBlockFacePowered(i, j, k - 1, 2) ? true : (l != 3 && world.isBlockFacePowered(i, j, k + 1, 3) ? true : (l != 5 && world.isBlockFacePowered(i + 1, j, k, 5) ? true : (l != 4 && world.isBlockFacePowered(i - 1, j, k, 4) ? true : (world.isBlockFacePowered(i, j, k, 0) ? true : (world.isBlockFacePowered(i, j + 2, k, 1) ? true : (world.isBlockFacePowered(i, j + 1, k - 1, 2) ? true : (world.isBlockFacePowered(i, j + 1, k + 1, 3) ? true : (world.isBlockFacePowered(i - 1, j + 1, k, 4) ? true : world.isBlockFacePowered(i + 1, j + 1, k, 5))))))))))); } - public void b(World world, int i, int j, int k, int l, int i1) { - if (l == 0) { - world.setRawData(i, j, k, i1 | 8); - } else { - world.setRawData(i, j, k, i1); + public boolean b(World world, int i, int j, int k, int l, int i1) { + if (!world.isStatic) { + boolean flag = this.d(world, i, j, k, i1); + + if (flag && l == 1) { + world.setData(i, j, k, i1 | 8, 2); + return false; + } + + if (!flag && l == 0) { + return false; + } } if (l == 0) { - if (this.j(world, i, j, k, i1)) { - world.setData(i, j, k, i1 | 8); - world.makeSound((double) i + 0.5D, (double) j + 0.5D, (double) k + 0.5D, "tile.piston.out", 0.5F, world.random.nextFloat() * 0.25F + 0.6F); - } else { - world.setRawData(i, j, k, i1); + if (!this.f(world, i, j, k, i1)) { + return false; } + + world.setData(i, j, k, i1 | 8, 2); + world.makeSound((double) i + 0.5D, (double) j + 0.5D, (double) k + 0.5D, "tile.piston.out", 0.5F, world.random.nextFloat() * 0.25F + 0.6F); } else if (l == 1) { TileEntity tileentity = world.getTileEntity(i + Facing.b[i1], j + Facing.c[i1], k + Facing.d[i1]); @@ -122,7 +124,7 @@ public class BlockPiston extends Block { ((TileEntityPiston) tileentity).f(); } - world.setRawTypeIdAndData(i, j, k, Block.PISTON_MOVING.id, i1); + world.setTypeIdAndData(i, j, k, Block.PISTON_MOVING.id, i1, 3); world.setTileEntity(i, j, k, BlockPistonMoving.a(this.id, i1, i1, false, true)); if (this.a) { int j1 = i + Facing.b[i1] * 2; @@ -130,7 +132,7 @@ public class BlockPiston extends Block { int l1 = k + Facing.d[i1] * 2; int i2 = world.getTypeId(j1, k1, l1); int j2 = world.getData(j1, k1, l1); - boolean flag = false; + boolean flag1 = false; if (i2 == Block.PISTON_MOVING.id) { TileEntity tileentity1 = world.getTileEntity(j1, k1, l1); @@ -142,34 +144,36 @@ public class BlockPiston extends Block { tileentitypiston.f(); i2 = tileentitypiston.a(); j2 = tileentitypiston.p(); - flag = true; + flag1 = true; } } } - if (!flag && i2 > 0 && a(i2, world, j1, k1, l1, false) && (Block.byId[i2].q_() == 0 || i2 == Block.PISTON.id || i2 == Block.PISTON_STICKY.id)) { + if (!flag1 && i2 > 0 && a(i2, world, j1, k1, l1, false) && (Block.byId[i2].h() == 0 || i2 == Block.PISTON.id || i2 == Block.PISTON_STICKY.id)) { i += Facing.b[i1]; j += Facing.c[i1]; k += Facing.d[i1]; - world.setRawTypeIdAndData(i, j, k, Block.PISTON_MOVING.id, j2); + world.setTypeIdAndData(i, j, k, Block.PISTON_MOVING.id, j2, 3); world.setTileEntity(i, j, k, BlockPistonMoving.a(i2, j2, i1, false, false)); - world.setTypeId(j1, k1, l1, 0); - } else if (!flag) { - world.setTypeId(i + Facing.b[i1], j + Facing.c[i1], k + Facing.d[i1], 0); + world.setAir(j1, k1, l1); + } else if (!flag1) { + world.setAir(i + Facing.b[i1], j + Facing.c[i1], k + Facing.d[i1]); } } else { - world.setTypeId(i + Facing.b[i1], j + Facing.c[i1], k + Facing.d[i1], 0); + world.setAir(i + Facing.b[i1], j + Facing.c[i1], k + Facing.d[i1]); } world.makeSound((double) i + 0.5D, (double) j + 0.5D, (double) k + 0.5D, "tile.piston.in", 0.5F, world.random.nextFloat() * 0.15F + 0.6F); } + + return true; } public void updateShape(IBlockAccess iblockaccess, int i, int j, int k) { int l = iblockaccess.getData(i, j, k); - if (f(l)) { - switch (e(l)) { + if (e(l)) { + switch (d(l)) { case 0: this.a(0.0F, 0.25F, 0.0F, 1.0F, 1.0F, 1.0F); break; @@ -198,7 +202,7 @@ public class BlockPiston extends Block { } } - public void f() { + public void g() { this.a(0.0F, 0.0F, 0.0F, 1.0F, 1.0F, 1.0F); } @@ -207,27 +211,27 @@ public class BlockPiston extends Block { super.a(world, i, j, k, axisalignedbb, list, entity); } - public AxisAlignedBB e(World world, int i, int j, int k) { + public AxisAlignedBB b(World world, int i, int j, int k) { this.updateShape(world, i, j, k); - return super.e(world, i, j, k); + return super.b(world, i, j, k); } public boolean b() { return false; } - public static int e(int i) { + public static int d(int i) { if ((i & 7) >= Facing.OPPOSITE_FACING.length) return 7; // CraftBukkit - check for AIOOB on piston data return i & 7; } - public static boolean f(int i) { + public static boolean e(int i) { return (i & 8) != 0; } - public static int b(World world, int i, int j, int k, EntityHuman entityhuman) { - if (MathHelper.abs((float) entityhuman.locX - (float) i) < 2.0F && MathHelper.abs((float) entityhuman.locZ - (float) k) < 2.0F) { - double d0 = entityhuman.locY + 1.82D - (double) entityhuman.height; + public static int a(World world, int i, int j, int k, EntityLiving entityliving) { + if (MathHelper.abs((float) entityliving.locX - (float) i) < 2.0F && MathHelper.abs((float) entityliving.locZ - (float) k) < 2.0F) { + double d0 = entityliving.locY + 1.82D - (double) entityliving.height; if (d0 - (double) j > 2.0D) { return 1; @@ -238,7 +242,7 @@ public class BlockPiston extends Block { } } - int l = MathHelper.floor((double) (entityhuman.yaw * 4.0F / 360.0F) + 0.5D) & 3; + int l = MathHelper.floor((double) (entityliving.yaw * 4.0F / 360.0F) + 0.5D) & 3; return l == 0 ? 2 : (l == 1 ? 5 : (l == 2 ? 3 : (l == 3 ? 4 : 0))); } @@ -248,27 +252,31 @@ public class BlockPiston extends Block { return false; } else { if (i != Block.PISTON.id && i != Block.PISTON_STICKY.id) { - if (Block.byId[i].m(world, j, k, l) == -1.0F) { + if (Block.byId[i].l(world, j, k, l) == -1.0F) { return false; } - if (Block.byId[i].q_() == 2) { + if (Block.byId[i].h() == 2) { return false; } - if (!flag && Block.byId[i].q_() == 1) { - return false; + if (Block.byId[i].h() == 1) { + if (!flag) { + return false; + } + + return true; } - } else if (f(world.getData(j, k, l))) { + } else if (e(world.getData(j, k, l))) { return false; } - return !(Block.byId[i] instanceof BlockContainer); + return !(Block.byId[i] instanceof IContainer); } } // CraftBukkit - boolean -> int return - private static int i(World world, int i, int j, int k, int l) { + private static int e(World world, int i, int j, int k, int l) { int i1 = i + Facing.b[l]; int j1 = j + Facing.c[l]; int k1 = k + Facing.d[l]; @@ -287,7 +295,7 @@ public class BlockPiston extends Block { return -1; // CraftBukkit } - if (Block.byId[i2].q_() != 1) { + if (Block.byId[i2].h() != 1) { if (l1 == 12) { return -1; // CraftBukkit } @@ -305,7 +313,7 @@ public class BlockPiston extends Block { } } - private boolean j(World world, int i, int j, int k, int l) { + private boolean f(World world, int i, int j, int k, int l) { int i1 = i + Facing.b[l]; int j1 = j + Facing.c[l]; int k1 = k + Facing.d[l]; @@ -325,7 +333,7 @@ public class BlockPiston extends Block { return false; } - if (Block.byId[i2].q_() != 1) { + if (Block.byId[i2].h() != 1) { if (l1 == 12) { return false; } @@ -338,28 +346,51 @@ public class BlockPiston extends Block { } Block.byId[i2].c(world, i1, j1, k1, world.getData(i1, j1, k1), 0); - world.setTypeId(i1, j1, k1, 0); + world.setAir(i1, j1, k1); } } - while (i1 != i || j1 != j || k1 != k) { - l1 = i1 - Facing.b[l]; - i2 = j1 - Facing.c[l]; - int j2 = k1 - Facing.d[l]; - int k2 = world.getTypeId(l1, i2, j2); - int l2 = world.getData(l1, i2, j2); + l1 = i1; + i2 = j1; + int j2 = k1; + int k2 = 0; - if (k2 == this.id && l1 == i && i2 == j && j2 == k) { - world.setRawTypeIdAndData(i1, j1, k1, Block.PISTON_MOVING.id, l | (this.a ? 8 : 0), false); + int[] aint; + int l2; + int i3; + int j3; + + for (aint = new int[13]; i1 != i || j1 != j || k1 != k; k1 = j3) { + l2 = i1 - Facing.b[l]; + i3 = j1 - Facing.c[l]; + j3 = k1 - Facing.d[l]; + int k3 = world.getTypeId(l2, i3, j3); + int l3 = world.getData(l2, i3, j3); + + if (k3 == this.id && l2 == i && i3 == j && j3 == k) { + world.setTypeIdAndData(i1, j1, k1, Block.PISTON_MOVING.id, l | (this.a ? 8 : 0), 4); world.setTileEntity(i1, j1, k1, BlockPistonMoving.a(Block.PISTON_EXTENSION.id, l | (this.a ? 8 : 0), l, true, false)); } else { - world.setRawTypeIdAndData(i1, j1, k1, Block.PISTON_MOVING.id, l2, false); - world.setTileEntity(i1, j1, k1, BlockPistonMoving.a(k2, l2, l, true, false)); + world.setTypeIdAndData(i1, j1, k1, Block.PISTON_MOVING.id, l3, 4); + world.setTileEntity(i1, j1, k1, BlockPistonMoving.a(k3, l3, l, true, false)); } - i1 = l1; - j1 = i2; - k1 = j2; + aint[k2++] = k3; + i1 = l2; + j1 = i3; + } + + i1 = l1; + j1 = i2; + k1 = j2; + + for (k2 = 0; i1 != i || j1 != j || k1 != k; k1 = j3) { + l2 = i1 - Facing.b[l]; + i3 = j1 - Facing.c[l]; + j3 = k1 - Facing.d[l]; + world.applyPhysics(l2, i3, j3, aint[k2++]); + i1 = l2; + j1 = i3; } return true; diff --git a/src/main/java/net/minecraft/server/BlockPistonExtension.java b/src/main/java/net/minecraft/server/BlockPistonExtension.java index b14548a28b..b6475f724b 100644 --- a/src/main/java/net/minecraft/server/BlockPistonExtension.java +++ b/src/main/java/net/minecraft/server/BlockPistonExtension.java @@ -5,18 +5,18 @@ import java.util.Random; public class BlockPistonExtension extends Block { - private int a = -1; + private IIcon a = null; - public BlockPistonExtension(int i, int j) { - super(i, j, Material.PISTON); - this.a(h); + public BlockPistonExtension(int i) { + super(i, Material.PISTON); + this.a(j); this.c(0.5F); } public void remove(World world, int i, int j, int k, int l, int i1) { super.remove(world, i, j, k, l, i1); if ((i1 & 7) >= Facing.OPPOSITE_FACING.length) return; // CraftBukkit - fix a piston AIOOBE issue - int j1 = Facing.OPPOSITE_FACING[f(i1)]; + int j1 = Facing.OPPOSITE_FACING[d(i1)]; i += Facing.b[j1]; j += Facing.c[j1]; @@ -25,19 +25,13 @@ public class BlockPistonExtension extends Block { if (k1 == Block.PISTON.id || k1 == Block.PISTON_STICKY.id) { i1 = world.getData(i, j, k); - if (BlockPiston.f(i1)) { + if (BlockPiston.e(i1)) { Block.byId[k1].c(world, i, j, k, i1, 0); - world.setTypeId(i, j, k, 0); + world.setAir(i, j, k); } } } - public int a(int i, int j) { - int k = f(j); - - return i == k ? (this.a >= 0 ? this.a : ((j & 8) != 0 ? this.textureId - 1 : this.textureId)) : (k < 6 && i == Facing.OPPOSITE_FACING[k] ? 107 : 108); - } - public int d() { return 17; } @@ -65,7 +59,7 @@ 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); - switch (f(l)) { + switch (d(l)) { case 0: this.a(0.0F, 0.0F, 0.0F, 1.0F, 0.25F, 1.0F); super.a(world, i, j, k, axisalignedbb, list, entity); @@ -114,7 +108,7 @@ public class BlockPistonExtension extends Block { public void updateShape(IBlockAccess iblockaccess, int i, int j, int k) { int l = iblockaccess.getData(i, j, k); - switch (f(l)) { + switch (d(l)) { case 0: this.a(0.0F, 0.0F, 0.0F, 1.0F, 0.25F, 1.0F); break; @@ -141,18 +135,18 @@ public class BlockPistonExtension extends Block { } public void doPhysics(World world, int i, int j, int k, int l) { - int i1 = f(world.getData(i, j, k)); + int i1 = d(world.getData(i, j, k)); if ((i1 & 7) >= Facing.OPPOSITE_FACING.length) return; // CraftBukkit - fix a piston AIOOBE issue int j1 = world.getTypeId(i - Facing.b[i1], j - Facing.c[i1], k - Facing.d[i1]); if (j1 != Block.PISTON.id && j1 != Block.PISTON_STICKY.id) { - world.setTypeId(i, j, k, 0); + world.setAir(i, j, k); } else { Block.byId[j1].doPhysics(world, i - Facing.b[i1], j - Facing.c[i1], k - Facing.d[i1], l); } } - public static int f(int i) { + public static int d(int i) { return i & 7; } } diff --git a/src/main/java/net/minecraft/server/BlockPortal.java b/src/main/java/net/minecraft/server/BlockPortal.java index 29d1308393..e1a91e7440 100644 --- a/src/main/java/net/minecraft/server/BlockPortal.java +++ b/src/main/java/net/minecraft/server/BlockPortal.java @@ -9,31 +9,31 @@ import org.bukkit.event.world.PortalCreateEvent; public class BlockPortal extends BlockHalfTransparant { - public BlockPortal(int i, int j) { - super(i, j, Material.PORTAL, false); + public BlockPortal(int i) { + super(i, "portal", Material.PORTAL, false); this.b(true); } - public void b(World world, int i, int j, int k, Random random) { - super.b(world, i, j, k, random); + public void a(World world, int i, int j, int k, Random random) { + super.a(world, i, j, k, random); if (world.worldProvider.d() && random.nextInt(2000) < world.difficulty) { int l; - for (l = j; !world.v(i, l, k) && l > 0; --l) { + for (l = j; !world.w(i, l, k) && l > 0; --l) { ; } - if (l > 0 && !world.t(i, l + 1, k)) { + if (l > 0 && !world.u(i, l + 1, k)) { Entity entity = ItemMonsterEgg.a(world, 57, (double) i + 0.5D, (double) l + 1.1D, (double) k + 0.5D); if (entity != null) { - entity.portalCooldown = entity.ab(); + entity.portalCooldown = entity.aa(); } } } } - public AxisAlignedBB e(World world, int i, int j, int k) { + public AxisAlignedBB b(World world, int i, int j, int k) { return null; } @@ -60,7 +60,7 @@ public class BlockPortal extends BlockHalfTransparant { return false; } - public boolean i_(World world, int i, int j, int k) { + public boolean n_(World world, int i, int j, int k) { byte b0 = 0; byte b1 = 0; @@ -123,15 +123,12 @@ public class BlockPortal extends BlockHalfTransparant { } // CraftBukkit end - world.suppressPhysics = true; - for (l = 0; l < 2; ++l) { for (i1 = 0; i1 < 3; ++i1) { - world.setTypeId(i + b0 * l, j + i1, k + b1 * l, Block.PORTAL.id); + world.setTypeIdAndData(i + b0 * l, j + i1, k + b1 * l, Block.PORTAL.id, 0, 2); } } - world.suppressPhysics = false; return true; } } @@ -152,7 +149,7 @@ public class BlockPortal extends BlockHalfTransparant { } if (world.getTypeId(i, i1 - 1, k) != Block.OBSIDIAN.id) { - world.setTypeId(i, j, k, 0); + world.setAir(i, j, k); } else { int j1; @@ -165,14 +162,14 @@ public class BlockPortal extends BlockHalfTransparant { boolean flag1 = world.getTypeId(i, j, k - 1) == this.id || world.getTypeId(i, j, k + 1) == this.id; if (flag && flag1) { - world.setTypeId(i, j, k, 0); + world.setAir(i, j, k); } else { if ((world.getTypeId(i + b0, j, k + b1) != Block.OBSIDIAN.id || world.getTypeId(i - b0, j, k - b1) != this.id) && (world.getTypeId(i - b0, j, k - b1) != Block.OBSIDIAN.id || world.getTypeId(i + b0, j, k + b1) != this.id)) { - world.setTypeId(i, j, k, 0); + world.setAir(i, j, k); } } } else { - world.setTypeId(i, j, k, 0); + world.setAir(i, j, k); } } } @@ -188,7 +185,7 @@ public class BlockPortal extends BlockHalfTransparant { world.getServer().getPluginManager().callEvent(event); // CraftBukkit end - entity.aa(); + entity.Z(); } } } diff --git a/src/main/java/net/minecraft/server/BlockPressurePlate.java b/src/main/java/net/minecraft/server/BlockPressurePlate.java deleted file mode 100644 index e4dc875426..0000000000 --- a/src/main/java/net/minecraft/server/BlockPressurePlate.java +++ /dev/null @@ -1,207 +0,0 @@ -package net.minecraft.server; - -import java.util.Iterator; -import java.util.List; -import java.util.Random; - -// CraftBukkit start -import org.bukkit.event.block.BlockRedstoneEvent; -import org.bukkit.event.entity.EntityInteractEvent; -// CraftBukkit end - -public class BlockPressurePlate extends Block { - - private EnumMobType a; - - protected BlockPressurePlate(int i, int j, EnumMobType enummobtype, Material material) { - super(i, j, material); - this.a = enummobtype; - this.a(CreativeModeTab.d); - this.b(true); - float f = 0.0625F; - - this.a(f, 0.0F, f, 1.0F - f, 0.03125F, 1.0F - f); - } - - public int r_() { - return 20; - } - - public AxisAlignedBB e(World world, int i, int j, int k) { - return null; - } - - public boolean c() { - return false; - } - - public boolean b() { - return false; - } - - public boolean c(IBlockAccess iblockaccess, int i, int j, int k) { - return true; - } - - public boolean canPlace(World world, int i, int j, int k) { - return world.v(i, j - 1, k) || BlockFence.c(world.getTypeId(i, j - 1, k)); - } - - public void doPhysics(World world, int i, int j, int k, int l) { - boolean flag = false; - - if (!world.v(i, j - 1, k) && !BlockFence.c(world.getTypeId(i, j - 1, k))) { - flag = true; - } - - if (flag) { - this.c(world, i, j, k, world.getData(i, j, k), 0); - world.setTypeId(i, j, k, 0); - } - } - - public void b(World world, int i, int j, int k, Random random) { - if (!world.isStatic) { - if (world.getData(i, j, k) != 0) { - this.l(world, i, j, k); - } - } - } - - public void a(World world, int i, int j, int k, Entity entity) { - if (!world.isStatic) { - if (world.getData(i, j, k) != 1) { - this.l(world, i, j, k); - } - } - } - - private void l(World world, int i, int j, int k) { - boolean flag = world.getData(i, j, k) == 1; - boolean flag1 = false; - float f = 0.125F; - List list = null; - - if (this.a == EnumMobType.EVERYTHING) { - list = world.getEntities((Entity) null, AxisAlignedBB.a().a((double) ((float) i + f), (double) j, (double) ((float) k + f), (double) ((float) (i + 1) - f), (double) j + 0.25D, (double) ((float) (k + 1) - f))); - } - - if (this.a == EnumMobType.MOBS) { - list = world.a(EntityLiving.class, AxisAlignedBB.a().a((double) ((float) i + f), (double) j, (double) ((float) k + f), (double) ((float) (i + 1) - f), (double) j + 0.25D, (double) ((float) (k + 1) - f))); - } - - if (this.a == EnumMobType.PLAYERS) { - list = world.a(EntityHuman.class, AxisAlignedBB.a().a((double) ((float) i + f), (double) j, (double) ((float) k + f), (double) ((float) (i + 1) - f), (double) j + 0.25D, (double) ((float) (k + 1) - f))); - } - - if (!list.isEmpty()) { - Iterator iterator = list.iterator(); - - while (iterator.hasNext()) { - Entity entity = (Entity) iterator.next(); - - if (!entity.au()) { - flag1 = true; - break; - } - } - } - - // CraftBukkit start - Interact Pressure Plate - org.bukkit.World bworld = world.getWorld(); - org.bukkit.plugin.PluginManager manager = world.getServer().getPluginManager(); - - if (flag != flag1) { - if (flag1) { - for (Object object : list) { - if (object != null) { - org.bukkit.event.Cancellable cancellable; - - if (object instanceof EntityHuman) { - cancellable = org.bukkit.craftbukkit.event.CraftEventFactory.callPlayerInteractEvent((EntityHuman) object, org.bukkit.event.block.Action.PHYSICAL, i, j, k, -1, null); - } else if (object instanceof Entity) { - cancellable = new EntityInteractEvent(((Entity) object).getBukkitEntity(), bworld.getBlockAt(i, j, k)); - manager.callEvent((EntityInteractEvent) cancellable); - } else { - continue; - } - - if (cancellable.isCancelled()) { - return; - } - } - } - } - - BlockRedstoneEvent eventRedstone = new BlockRedstoneEvent(bworld.getBlockAt(i, j, k), flag ? 1 : 0, flag1 ? 1 : 0); - manager.callEvent(eventRedstone); - - flag1 = eventRedstone.getNewCurrent() > 0; - } - // CraftBukkit end - - if (flag1 && !flag) { - world.setData(i, j, k, 1); - world.applyPhysics(i, j, k, this.id); - world.applyPhysics(i, j - 1, k, this.id); - world.e(i, j, k, i, j, k); - world.makeSound((double) i + 0.5D, (double) j + 0.1D, (double) k + 0.5D, "random.click", 0.3F, 0.6F); - } - - if (!flag1 && flag) { - world.setData(i, j, k, 0); - world.applyPhysics(i, j, k, this.id); - world.applyPhysics(i, j - 1, k, this.id); - world.e(i, j, k, i, j, k); - world.makeSound((double) i + 0.5D, (double) j + 0.1D, (double) k + 0.5D, "random.click", 0.3F, 0.5F); - } - - if (flag1) { - world.a(i, j, k, this.id, this.r_()); - } - } - - public void remove(World world, int i, int j, int k, int l, int i1) { - if (i1 > 0) { - world.applyPhysics(i, j, k, this.id); - world.applyPhysics(i, j - 1, k, this.id); - } - - super.remove(world, i, j, k, l, i1); - } - - public void updateShape(IBlockAccess iblockaccess, int i, int j, int k) { - boolean flag = iblockaccess.getData(i, j, k) == 1; - float f = 0.0625F; - - if (flag) { - this.a(f, 0.0F, f, 1.0F - f, 0.03125F, 1.0F - f); - } else { - this.a(f, 0.0F, f, 1.0F - f, 0.0625F, 1.0F - f); - } - } - - public boolean b(IBlockAccess iblockaccess, int i, int j, int k, int l) { - return iblockaccess.getData(i, j, k) > 0; - } - - public boolean c(IBlockAccess iblockaccess, int i, int j, int k, int l) { - return iblockaccess.getData(i, j, k) == 0 ? false : l == 1; - } - - public boolean isPowerSource() { - return true; - } - - public void f() { - float f = 0.5F; - float f1 = 0.125F; - float f2 = 0.5F; - - this.a(0.5F - f, 0.5F - f1, 0.5F - f2, 0.5F + f, 0.5F + f1, 0.5F + f2); - } - - public int q_() { - return 1; - } -} diff --git a/src/main/java/net/minecraft/server/BlockPressurePlateAbstract.java b/src/main/java/net/minecraft/server/BlockPressurePlateAbstract.java new file mode 100644 index 0000000000..23fb187989 --- /dev/null +++ b/src/main/java/net/minecraft/server/BlockPressurePlateAbstract.java @@ -0,0 +1,174 @@ +package net.minecraft.server; + +import java.util.Random; + +import org.bukkit.event.block.BlockRedstoneEvent; // CraftBukkit + +public abstract class BlockPressurePlateAbstract extends Block { + + private String a; + + protected BlockPressurePlateAbstract(int i, String s, Material material) { + super(i, material); + this.a = s; + this.a(CreativeModeTab.d); + this.b(true); + this.b_(this.d(15)); + } + + public void updateShape(IBlockAccess iblockaccess, int i, int j, int k) { + this.b_(iblockaccess.getData(i, j, k)); + } + + protected void b_(int i) { + boolean flag = this.c(i) > 0; + float f = 0.0625F; + + if (flag) { + this.a(f, 0.0F, f, 1.0F - f, 0.03125F, 1.0F - f); + } else { + this.a(f, 0.0F, f, 1.0F - f, 0.0625F, 1.0F - f); + } + } + + public int a(World world) { + return 20; + } + + public AxisAlignedBB b(World world, int i, int j, int k) { + return null; + } + + public boolean c() { + return false; + } + + public boolean b() { + return false; + } + + public boolean b(IBlockAccess iblockaccess, int i, int j, int k) { + return true; + } + + 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)); + } + + 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))) { + flag = true; + } + + if (flag) { + this.c(world, i, j, k, world.getData(i, j, k), 0); + world.setAir(i, j, k); + } + } + + public void a(World world, int i, int j, int k, Random random) { + if (!world.isStatic) { + int l = this.c(world.getData(i, j, k)); + + if (l > 0) { + this.b(world, i, j, k, l); + } + } + } + + public void a(World world, int i, int j, int k, Entity entity) { + if (!world.isStatic) { + int l = this.c(world.getData(i, j, k)); + + if (l == 0) { + this.b(world, i, j, k, l); + } + } + } + + protected void b(World world, int i, int j, int k, int l) { + int i1 = this.e(world, i, j, k); + boolean flag = l > 0; + boolean flag1 = i1 > 0; + + // CraftBukkit start - Interact Pressure Plate + org.bukkit.World bworld = world.getWorld(); + org.bukkit.plugin.PluginManager manager = world.getServer().getPluginManager(); + + if (flag != flag1) { + BlockRedstoneEvent eventRedstone = new BlockRedstoneEvent(bworld.getBlockAt(i, j, k), l, i1); + manager.callEvent(eventRedstone); + + flag1 = eventRedstone.getNewCurrent() > 0; + i1 = eventRedstone.getNewCurrent(); + } + // CraftBukkit end + + if (l != i1) { + world.setData(i, j, k, this.d(i1), 2); + this.b_(world, i, j, k); + world.g(i, j, k, i, j, k); + } + + if (!flag1 && flag) { + world.makeSound((double) i + 0.5D, (double) j + 0.1D, (double) k + 0.5D, "random.click", 0.3F, 0.5F); + } else if (flag1 && !flag) { + world.makeSound((double) i + 0.5D, (double) j + 0.1D, (double) k + 0.5D, "random.click", 0.3F, 0.6F); + } + + if (flag1) { + world.a(i, j, k, this.id, this.a(world)); + } + } + + protected AxisAlignedBB a(int i, int j, int k) { + float f = 0.125F; + + return AxisAlignedBB.a().a((double) ((float) i + f), (double) j, (double) ((float) k + f), (double) ((float) (i + 1) - f), (double) j + 0.25D, (double) ((float) (k + 1) - f)); + } + + public void remove(World world, int i, int j, int k, int l, int i1) { + if (this.c(i1) > 0) { + this.b_(world, i, j, k); + } + + super.remove(world, i, j, k, l, i1); + } + + protected void b_(World world, int i, int j, int k) { + world.applyPhysics(i, j, k, this.id); + world.applyPhysics(i, j - 1, k, this.id); + } + + public int b(IBlockAccess iblockaccess, int i, int j, int k, int l) { + return this.c(iblockaccess.getData(i, j, k)); + } + + public int c(IBlockAccess iblockaccess, int i, int j, int k, int l) { + return l == 1 ? this.c(iblockaccess.getData(i, j, k)) : 0; + } + + public boolean isPowerSource() { + return true; + } + + public void g() { + float f = 0.5F; + float f1 = 0.125F; + float f2 = 0.5F; + + this.a(0.5F - f, 0.5F - f1, 0.5F - f2, 0.5F + f, 0.5F + f1, 0.5F + f2); + } + + public int h() { + return 1; + } + + protected abstract int e(World world, int i, int j, int k); + + protected abstract int c(int i); + + protected abstract int d(int i); +} diff --git a/src/main/java/net/minecraft/server/BlockPressurePlateBinary.java b/src/main/java/net/minecraft/server/BlockPressurePlateBinary.java new file mode 100644 index 0000000000..ba7b66053b --- /dev/null +++ b/src/main/java/net/minecraft/server/BlockPressurePlateBinary.java @@ -0,0 +1,71 @@ +package net.minecraft.server; + +import java.util.Iterator; +import java.util.List; + +import org.bukkit.event.entity.EntityInteractEvent; // CraftBukkit + +public class BlockPressurePlateBinary extends BlockPressurePlateAbstract { + + private EnumMobType a; + + protected BlockPressurePlateBinary(int i, String s, Material material, EnumMobType enummobtype) { + super(i, s, material); + this.a = enummobtype; + } + + protected int d(int i) { + return i > 0 ? 1 : 0; + } + + protected int c(int i) { + return i == 1 ? 15 : 0; + } + + protected int e(World world, int i, int j, int k) { + List list = null; + + if (this.a == EnumMobType.EVERYTHING) { + list = world.getEntities((Entity) null, this.a(i, j, k)); + } + + if (this.a == EnumMobType.MOBS) { + list = world.a(EntityLiving.class, this.a(i, j, k)); + } + + if (this.a == EnumMobType.PLAYERS) { + list = world.a(EntityHuman.class, this.a(i, j, k)); + } + + if (!list.isEmpty()) { + Iterator iterator = list.iterator(); + + while (iterator.hasNext()) { + Entity entity = (Entity) iterator.next(); + + // CraftBukkit start + org.bukkit.World bworld = world.getWorld(); + org.bukkit.plugin.PluginManager manager = world.getServer().getPluginManager(); + org.bukkit.event.Cancellable cancellable; + + if (entity instanceof EntityHuman) { + cancellable = org.bukkit.craftbukkit.event.CraftEventFactory.callPlayerInteractEvent((EntityHuman) entity, org.bukkit.event.block.Action.PHYSICAL, i, j, k, -1, null); + } else { + cancellable = new EntityInteractEvent(entity.getBukkitEntity(), bworld.getBlockAt(i, j, k)); + manager.callEvent((EntityInteractEvent) cancellable); + } + + if (cancellable.isCancelled()) { + return 0; + } + // CraftBukkit end + + if (!entity.at()) { + return 15; + } + } + } + + return 0; + } +} diff --git a/src/main/java/net/minecraft/server/BlockPumpkin.java b/src/main/java/net/minecraft/server/BlockPumpkin.java index f848a07955..6f7788c4e2 100644 --- a/src/main/java/net/minecraft/server/BlockPumpkin.java +++ b/src/main/java/net/minecraft/server/BlockPumpkin.java @@ -10,34 +10,13 @@ public class BlockPumpkin extends BlockDirectional { private boolean a; - protected BlockPumpkin(int i, int j, boolean flag) { + protected BlockPumpkin(int i, boolean flag) { super(i, Material.PUMPKIN); - this.textureId = j; this.b(true); this.a = flag; this.a(CreativeModeTab.b); } - public int a(int i, int j) { - if (i == 1) { - return this.textureId; - } else if (i == 0) { - return this.textureId; - } else { - int k = this.textureId + 1 + 16; - - if (this.a) { - ++k; - } - - return j == 2 && i == 2 ? k : (j == 3 && i == 5 ? k : (j == 0 && i == 3 ? k : (j == 1 && i == 4 ? k : this.textureId + 16))); - } - } - - public int a(int i) { - return i == 1 ? this.textureId : (i == 0 ? this.textureId : (i == 3 ? this.textureId + 1 + 16 : this.textureId + 16)); - } - public void onPlace(World world, int i, int j, int k) { super.onPlace(world, i, j, k); if (world.getTypeId(i, j - 1, k) == Block.SNOW_BLOCK.id && world.getTypeId(i, j - 2, k) == Block.SNOW_BLOCK.id) { @@ -100,13 +79,13 @@ public class BlockPumpkin extends BlockDirectional { public boolean canPlace(World world, int i, int j, int k) { int l = world.getTypeId(i, j, k); - return (l == 0 || Block.byId[l].material.isReplaceable()) && world.v(i, j - 1, k); + return (l == 0 || Block.byId[l].material.isReplaceable()) && world.w(i, j - 1, k); } - public void postPlace(World world, int i, int j, int k, EntityLiving entityliving) { + public void postPlace(World world, int i, int j, int k, EntityLiving entityliving, ItemStack itemstack) { int l = MathHelper.floor((double) (entityliving.yaw * 4.0F / 360.0F) + 2.5D) & 3; - world.setData(i, j, k, l); + world.setData(i, j, k, l, 2); } // CraftBukkit start diff --git a/src/main/java/net/minecraft/server/BlockRedstoneLamp.java b/src/main/java/net/minecraft/server/BlockRedstoneLamp.java index 6bdd14aad2..e527e7fa17 100644 --- a/src/main/java/net/minecraft/server/BlockRedstoneLamp.java +++ b/src/main/java/net/minecraft/server/BlockRedstoneLamp.java @@ -9,11 +9,10 @@ public class BlockRedstoneLamp extends Block { private final boolean a; public BlockRedstoneLamp(int i, boolean flag) { - super(i, 211, Material.BUILDABLE_GLASS); + super(i, Material.BUILDABLE_GLASS); this.a = flag; if (flag) { this.a(1.0F); - ++this.textureId; } } @@ -28,7 +27,7 @@ public class BlockRedstoneLamp extends Block { } // CraftBukkit end - world.setTypeId(i, j, k, Block.REDSTONE_LAMP_ON.id); + world.setTypeIdAndData(i, j, k, Block.REDSTONE_LAMP_ON.id, 0, 2); } } } @@ -44,12 +43,12 @@ public class BlockRedstoneLamp extends Block { } // CraftBukkit end - world.setTypeId(i, j, k, Block.REDSTONE_LAMP_ON.id); + world.setTypeIdAndData(i, j, k, Block.REDSTONE_LAMP_ON.id, 0, 2); } } } - public void b(World world, int i, int j, int k, Random random) { + public void a(World world, int i, int j, int k, Random random) { if (!world.isStatic && this.a && !world.isBlockIndirectlyPowered(i, j, k)) { // CraftBukkit start if (CraftEventFactory.callRedstoneChange(world, i, j, k, 15, 0).getNewCurrent() != 0) { @@ -57,7 +56,7 @@ public class BlockRedstoneLamp extends Block { } // CraftBukkit end - world.setTypeId(i, j, k, Block.REDSTONE_LAMP_OFF.id); + world.setTypeIdAndData(i, j, k, Block.REDSTONE_LAMP_OFF.id, 0, 2); } } diff --git a/src/main/java/net/minecraft/server/BlockRedstoneOre.java b/src/main/java/net/minecraft/server/BlockRedstoneOre.java index 2bb9436695..4f059d2425 100644 --- a/src/main/java/net/minecraft/server/BlockRedstoneOre.java +++ b/src/main/java/net/minecraft/server/BlockRedstoneOre.java @@ -8,8 +8,8 @@ public class BlockRedstoneOre extends Block { private boolean a; - public BlockRedstoneOre(int i, int j, boolean flag) { - super(i, j, Material.STONE); + public BlockRedstoneOre(int i, boolean flag) { + super(i, Material.STONE); if (flag) { this.b(true); } @@ -17,12 +17,12 @@ public class BlockRedstoneOre extends Block { this.a = flag; } - public int r_() { + public int a(World world) { return 30; } public void attack(World world, int i, int j, int k, EntityHuman entityhuman) { - this.l(world, i, j, k); + this.k(world, i, j, k); super.attack(world, i, j, k, entityhuman); } @@ -31,14 +31,14 @@ public class BlockRedstoneOre extends Block { if (entity instanceof EntityHuman) { org.bukkit.event.player.PlayerInteractEvent event = org.bukkit.craftbukkit.event.CraftEventFactory.callPlayerInteractEvent((EntityHuman) entity, org.bukkit.event.block.Action.PHYSICAL, i, j, k, -1, null); if (!event.isCancelled()) { - this.l(world, i, j, k); + this.k(world, i, j, k); super.b(world, i, j, k, entity); } } else { EntityInteractEvent event = new EntityInteractEvent(entity.getBukkitEntity(), world.getWorld().getBlockAt(i, j, k)); world.getServer().getPluginManager().callEvent(event); if (!event.isCancelled()) { - this.l(world, i, j, k); + this.k(world, i, j, k); super.b(world, i, j, k, entity); } } @@ -46,20 +46,20 @@ public class BlockRedstoneOre extends Block { } public boolean interact(World world, int i, int j, int k, EntityHuman entityhuman, int l, float f, float f1, float f2) { - this.l(world, i, j, k); + this.k(world, i, j, k); return super.interact(world, i, j, k, entityhuman, l, f, f1, f2); } - private void l(World world, int i, int j, int k) { - this.n(world, i, j, k); + private void k(World world, int i, int j, int k) { + this.m(world, i, j, k); if (this.id == Block.REDSTONE_ORE.id) { - world.setTypeId(i, j, k, Block.GLOWING_REDSTONE_ORE.id); + world.setTypeIdUpdate(i, j, k, Block.GLOWING_REDSTONE_ORE.id); } } - public void b(World world, int i, int j, int k, Random random) { + public void a(World world, int i, int j, int k, Random random) { if (this.id == Block.GLOWING_REDSTONE_ORE.id) { - world.setTypeId(i, j, k, Block.REDSTONE_ORE.id); + world.setTypeIdUpdate(i, j, k, Block.REDSTONE_ORE.id); } } @@ -81,7 +81,7 @@ public class BlockRedstoneOre extends Block { if (this.getDropType(l, world.random, i1) != this.id) { int j1 = 1 + world.random.nextInt(5); - this.f(world, i, j, k, j1); + this.j(world, i, j, k, j1); } */ } @@ -96,7 +96,7 @@ public class BlockRedstoneOre extends Block { // CraftBukkit end } - private void n(World world, int i, int j, int k) { + private void m(World world, int i, int j, int k) { Random random = world.random; double d0 = 0.0625D; @@ -105,27 +105,27 @@ public class BlockRedstoneOre extends Block { double d2 = (double) ((float) j + random.nextFloat()); double d3 = (double) ((float) k + random.nextFloat()); - if (l == 0 && !world.s(i, j + 1, k)) { + if (l == 0 && !world.t(i, j + 1, k)) { d2 = (double) (j + 1) + d0; } - if (l == 1 && !world.s(i, j - 1, k)) { + if (l == 1 && !world.t(i, j - 1, k)) { d2 = (double) (j + 0) - d0; } - if (l == 2 && !world.s(i, j, k + 1)) { + if (l == 2 && !world.t(i, j, k + 1)) { d3 = (double) (k + 1) + d0; } - if (l == 3 && !world.s(i, j, k - 1)) { + if (l == 3 && !world.t(i, j, k - 1)) { d3 = (double) (k + 0) - d0; } - if (l == 4 && !world.s(i + 1, j, k)) { + if (l == 4 && !world.t(i + 1, j, k)) { d1 = (double) (i + 1) + d0; } - if (l == 5 && !world.s(i - 1, j, k)) { + if (l == 5 && !world.t(i - 1, j, k)) { d1 = (double) (i + 0) - d0; } @@ -135,7 +135,7 @@ public class BlockRedstoneOre extends Block { } } - protected ItemStack f_(int i) { + protected ItemStack c_(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 4240ade9fd..3a560e22ec 100644 --- a/src/main/java/net/minecraft/server/BlockRedstoneTorch.java +++ b/src/main/java/net/minecraft/server/BlockRedstoneTorch.java @@ -13,10 +13,6 @@ public class BlockRedstoneTorch extends BlockTorch { private boolean isOn = false; private static Map b = new HashMap(); - public int a(int i, int j) { - return i == 1 ? Block.REDSTONE_WIRE.a(i, j) : super.a(i, j); - } - private boolean a(World world, int i, int j, int k, boolean flag) { if (!b.containsKey(world)) { b.put(world, new ArrayList()); @@ -44,14 +40,14 @@ public class BlockRedstoneTorch extends BlockTorch { return false; } - protected BlockRedstoneTorch(int i, int j, boolean flag) { - super(i, j); + protected BlockRedstoneTorch(int i, boolean flag) { + super(i); this.isOn = flag; this.b(true); this.a((CreativeModeTab) null); } - public int r_() { + public int a(World world) { return 2; } @@ -81,24 +77,24 @@ public class BlockRedstoneTorch extends BlockTorch { } } - public boolean b(IBlockAccess iblockaccess, int i, int j, int k, int l) { + public int b(IBlockAccess iblockaccess, int i, int j, int k, int l) { if (!this.isOn) { - return false; + return 0; } else { int i1 = iblockaccess.getData(i, j, k); - return i1 == 5 && l == 1 ? false : (i1 == 3 && l == 3 ? false : (i1 == 4 && l == 2 ? false : (i1 == 1 && l == 5 ? false : i1 != 2 || l != 4))); + return i1 == 5 && l == 1 ? 0 : (i1 == 3 && l == 3 ? 0 : (i1 == 4 && l == 2 ? 0 : (i1 == 1 && l == 5 ? 0 : (i1 == 2 && l == 4 ? 0 : 15)))); } } - private boolean l(World world, int i, int j, int k) { + private boolean m(World world, int i, int j, int k) { int l = world.getData(i, j, k); - return l == 5 && world.isBlockFaceIndirectlyPowered(i, j - 1, k, 0) ? true : (l == 3 && world.isBlockFaceIndirectlyPowered(i, j, k - 1, 2) ? true : (l == 4 && world.isBlockFaceIndirectlyPowered(i, j, k + 1, 3) ? true : (l == 1 && world.isBlockFaceIndirectlyPowered(i - 1, j, k, 4) ? true : l == 2 && world.isBlockFaceIndirectlyPowered(i + 1, j, k, 5)))); + return l == 5 && world.isBlockFacePowered(i, j - 1, k, 0) ? true : (l == 3 && world.isBlockFacePowered(i, j, k - 1, 2) ? true : (l == 4 && world.isBlockFacePowered(i, j, k + 1, 3) ? true : (l == 1 && world.isBlockFacePowered(i - 1, j, k, 4) ? true : l == 2 && world.isBlockFacePowered(i + 1, j, k, 5)))); } - public void b(World world, int i, int j, int k, Random random) { - boolean flag = this.l(world, i, j, k); + public void a(World world, int i, int j, int k, Random random) { + boolean flag = this.m(world, i, j, k); List list = (List) b.get(world); while (list != null && !list.isEmpty() && world.getTime() - ((RedstoneUpdateInfo) list.get(0)).d > 60L) { @@ -125,7 +121,7 @@ public class BlockRedstoneTorch extends BlockTorch { } // CraftBukkit end - world.setTypeIdAndData(i, j, k, Block.REDSTONE_TORCH_OFF.id, world.getData(i, j, k)); + world.setTypeIdAndData(i, j, k, Block.REDSTONE_TORCH_OFF.id, world.getData(i, j, k), 3); if (this.a(world, i, j, k, true)) { 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); @@ -149,17 +145,22 @@ public class BlockRedstoneTorch extends BlockTorch { } // CraftBukkit end - world.setTypeIdAndData(i, j, k, Block.REDSTONE_TORCH_ON.id, world.getData(i, j, k)); + world.setTypeIdAndData(i, j, k, Block.REDSTONE_TORCH_ON.id, world.getData(i, j, k), 3); } } public void doPhysics(World world, int i, int j, int k, int l) { - super.doPhysics(world, i, j, k, l); - world.a(i, j, k, this.id, this.r_()); + if (!this.d(world, i, j, k, l)) { + boolean flag = this.m(world, i, j, k); + + if (this.isOn && flag || !this.isOn && !flag) { + world.a(i, j, k, this.id, this.a(world)); + } + } } - public boolean c(IBlockAccess iblockaccess, int i, int j, int k, int l) { - return l == 0 ? this.b(iblockaccess, i, j, k, l) : false; + public int c(IBlockAccess iblockaccess, int i, int j, int k, int l) { + return l == 0 ? this.b(iblockaccess, i, j, k, l) : 0; } public int getDropType(int i, Random random, int j) { @@ -169,4 +170,8 @@ public class BlockRedstoneTorch extends BlockTorch { public boolean isPowerSource() { return true; } + + public boolean i(int i) { + return i == Block.REDSTONE_TORCH_OFF.id || i == Block.REDSTONE_TORCH_ON.id; + } } diff --git a/src/main/java/net/minecraft/server/BlockRedstoneWire.java b/src/main/java/net/minecraft/server/BlockRedstoneWire.java index 024be8bece..856df909f8 100644 --- a/src/main/java/net/minecraft/server/BlockRedstoneWire.java +++ b/src/main/java/net/minecraft/server/BlockRedstoneWire.java @@ -10,18 +10,14 @@ import org.bukkit.event.block.BlockRedstoneEvent; // CraftBukkit public class BlockRedstoneWire extends Block { private boolean a = true; - private Set b = new java.util.LinkedHashSet(); // CraftBukkit - HashSet -> LinkedHashSet + private Set b = new HashSet(); - public BlockRedstoneWire(int i, int j) { - super(i, j, Material.ORIENTABLE); + public BlockRedstoneWire(int i) { + super(i, Material.ORIENTABLE); this.a(0.0F, 0.0F, 0.0F, 1.0F, 0.0625F, 1.0F); } - public int a(int i, int j) { - return this.textureId; - } - - public AxisAlignedBB e(World world, int i, int j, int k) { + public AxisAlignedBB b(World world, int i, int j, int k) { return null; } @@ -38,10 +34,10 @@ public class BlockRedstoneWire extends Block { } public boolean canPlace(World world, int i, int j, int k) { - return world.v(i, j - 1, k) || world.getTypeId(i, j - 1, k) == Block.GLOWSTONE.id; + return world.w(i, j - 1, k) || world.getTypeId(i, j - 1, k) == Block.GLOWSTONE.id; } - private void l(World world, int i, int j, int k) { + private void k(World world, int i, int j, int k) { this.a(world, i, j, k, i, j, k); ArrayList arraylist = new ArrayList(this.b); @@ -56,56 +52,62 @@ public class BlockRedstoneWire extends Block { private void a(World world, int i, int j, int k, int l, int i1, int j1) { int k1 = world.getData(i, j, k); - int l1 = 0; + byte b0 = 0; + int l1 = this.getPower(world, l, i1, j1, b0); this.a = false; - boolean flag = world.isBlockIndirectlyPowered(i, j, k); + int i2 = world.getHighestNeighborSignal(i, j, k); this.a = true; - int i2; - int j2; - int k2; + if (i2 > 0 && i2 > l1 - 1) { + l1 = i2; + } - if (flag) { - l1 = 15; + int j2 = 0; + + for (int k2 = 0; k2 < 4; ++k2) { + int l2 = i; + int i3 = k; + + if (k2 == 0) { + l2 = i - 1; + } + + if (k2 == 1) { + ++l2; + } + + if (k2 == 2) { + i3 = k - 1; + } + + if (k2 == 3) { + ++i3; + } + + if (l2 != l || i3 != j1) { + j2 = this.getPower(world, l2, j, i3, j2); + } + + if (world.u(l2, j, i3) && !world.u(i, j + 1, k)) { + if ((l2 != l || i3 != j1) && j >= i1) { + j2 = this.getPower(world, l2, j + 1, i3, j2); + } + } else if (!world.u(l2, j, i3) && (l2 != l || i3 != j1) && j <= i1) { + j2 = this.getPower(world, l2, j - 1, i3, j2); + } + } + + if (j2 > l1) { + l1 = j2 - 1; + } else if (l1 > 0) { + --l1; } else { - for (i2 = 0; i2 < 4; ++i2) { - j2 = i; - k2 = k; - if (i2 == 0) { - j2 = i - 1; - } + l1 = 0; + } - if (i2 == 1) { - ++j2; - } - - if (i2 == 2) { - k2 = k - 1; - } - - if (i2 == 3) { - ++k2; - } - - if (j2 != l || j != i1 || k2 != j1) { - l1 = this.getPower(world, j2, j, k2, l1); - } - - if (world.t(j2, j, k2) && !world.t(i, j + 1, k)) { - if (j2 != l || j + 1 != i1 || k2 != j1) { - l1 = this.getPower(world, j2, j + 1, k2, l1); - } - } else if (!world.t(j2, j, k2) && (j2 != l || j - 1 != i1 || k2 != j1)) { - l1 = this.getPower(world, j2, j - 1, k2, l1); - } - } - - if (l1 > 0) { - --l1; - } else { - l1 = 0; - } + if (i2 > l1 - 1) { + l1 = i2; } // CraftBukkit start @@ -118,72 +120,18 @@ public class BlockRedstoneWire extends Block { // CraftBukkit end if (k1 != l1) { - world.suppressPhysics = true; - world.setData(i, j, k, l1); - world.e(i, j, k, i, j, k); - world.suppressPhysics = false; - - for (i2 = 0; i2 < 4; ++i2) { - j2 = i; - k2 = k; - int l2 = j - 1; - - if (i2 == 0) { - j2 = i - 1; - } - - if (i2 == 1) { - ++j2; - } - - if (i2 == 2) { - k2 = k - 1; - } - - if (i2 == 3) { - ++k2; - } - - if (world.t(j2, j, k2)) { - l2 += 2; - } - - boolean flag1 = false; - int i3 = this.getPower(world, j2, j, k2, -1); - - l1 = world.getData(i, j, k); - if (l1 > 0) { - --l1; - } - - if (i3 >= 0 && i3 != l1) { - this.a(world, j2, j, k2, i, j, k); - } - - i3 = this.getPower(world, j2, l2, k2, -1); - l1 = world.getData(i, j, k); - if (l1 > 0) { - --l1; - } - - if (i3 >= 0 && i3 != l1) { - this.a(world, j2, l2, k2, i, j, k); - } - } - - if (k1 < l1 || l1 == 0) { - this.b.add(new ChunkPosition(i, j, k)); - this.b.add(new ChunkPosition(i - 1, j, k)); - this.b.add(new ChunkPosition(i + 1, j, k)); - this.b.add(new ChunkPosition(i, j - 1, k)); - this.b.add(new ChunkPosition(i, j + 1, k)); - this.b.add(new ChunkPosition(i, j, k - 1)); - this.b.add(new ChunkPosition(i, j, k + 1)); - } + world.setData(i, j, k, l1, 2); + this.b.add(new ChunkPosition(i, j, k)); + this.b.add(new ChunkPosition(i - 1, j, k)); + this.b.add(new ChunkPosition(i + 1, j, k)); + this.b.add(new ChunkPosition(i, j - 1, k)); + this.b.add(new ChunkPosition(i, j + 1, k)); + this.b.add(new ChunkPosition(i, j, k - 1)); + this.b.add(new ChunkPosition(i, j, k + 1)); } } - private void n(World world, int i, int j, int k) { + private void m(World world, int i, int j, int k) { if (world.getTypeId(i, j, k) == this.id) { world.applyPhysics(i, j, k, this.id); world.applyPhysics(i - 1, j, k, this.id); @@ -198,35 +146,35 @@ public class BlockRedstoneWire extends Block { public void onPlace(World world, int i, int j, int k) { super.onPlace(world, i, j, k); if (!world.isStatic) { - this.l(world, i, j, k); + this.k(world, i, j, k); world.applyPhysics(i, j + 1, k, this.id); world.applyPhysics(i, j - 1, k, this.id); - this.n(world, i - 1, j, k); - this.n(world, i + 1, j, k); - this.n(world, i, j, k - 1); - this.n(world, i, j, k + 1); - if (world.t(i - 1, j, k)) { - this.n(world, i - 1, j + 1, k); + this.m(world, i - 1, j, k); + this.m(world, i + 1, j, k); + this.m(world, i, j, k - 1); + this.m(world, i, j, k + 1); + if (world.u(i - 1, j, k)) { + this.m(world, i - 1, j + 1, k); } else { - this.n(world, i - 1, j - 1, k); + this.m(world, i - 1, j - 1, k); } - if (world.t(i + 1, j, k)) { - this.n(world, i + 1, j + 1, k); + if (world.u(i + 1, j, k)) { + this.m(world, i + 1, j + 1, k); } else { - this.n(world, i + 1, j - 1, k); + this.m(world, i + 1, j - 1, k); } - if (world.t(i, j, k - 1)) { - this.n(world, i, j + 1, k - 1); + if (world.u(i, j, k - 1)) { + this.m(world, i, j + 1, k - 1); } else { - this.n(world, i, j - 1, k - 1); + this.m(world, i, j - 1, k - 1); } - if (world.t(i, j, k + 1)) { - this.n(world, i, j + 1, k + 1); + if (world.u(i, j, k + 1)) { + this.m(world, i, j + 1, k + 1); } else { - this.n(world, i, j - 1, k + 1); + this.m(world, i, j - 1, k + 1); } } } @@ -240,33 +188,33 @@ public class BlockRedstoneWire extends Block { world.applyPhysics(i - 1, j, k, this.id); world.applyPhysics(i, j, k + 1, this.id); world.applyPhysics(i, j, k - 1, this.id); - this.l(world, i, j, k); - this.n(world, i - 1, j, k); - this.n(world, i + 1, j, k); - this.n(world, i, j, k - 1); - this.n(world, i, j, k + 1); - if (world.t(i - 1, j, k)) { - this.n(world, i - 1, j + 1, k); + this.k(world, i, j, k); + this.m(world, i - 1, j, k); + this.m(world, i + 1, j, k); + this.m(world, i, j, k - 1); + this.m(world, i, j, k + 1); + if (world.u(i - 1, j, k)) { + this.m(world, i - 1, j + 1, k); } else { - this.n(world, i - 1, j - 1, k); + this.m(world, i - 1, j - 1, k); } - if (world.t(i + 1, j, k)) { - this.n(world, i + 1, j + 1, k); + if (world.u(i + 1, j, k)) { + this.m(world, i + 1, j + 1, k); } else { - this.n(world, i + 1, j - 1, k); + this.m(world, i + 1, j - 1, k); } - if (world.t(i, j, k - 1)) { - this.n(world, i, j + 1, k - 1); + if (world.u(i, j, k - 1)) { + this.m(world, i, j + 1, k - 1); } else { - this.n(world, i, j - 1, k - 1); + this.m(world, i, j - 1, k - 1); } - if (world.t(i, j, k + 1)) { - this.n(world, i, j + 1, k + 1); + if (world.u(i, j, k + 1)) { + this.m(world, i, j + 1, k + 1); } else { - this.n(world, i, j - 1, k + 1); + this.m(world, i, j - 1, k + 1); } } } @@ -284,14 +232,13 @@ public class BlockRedstoneWire extends Block { public void doPhysics(World world, int i, int j, int k, int l) { if (!world.isStatic) { - int i1 = world.getData(i, j, k); boolean flag = this.canPlace(world, i, j, k); if (flag) { - this.l(world, i, j, k); + this.k(world, i, j, k); } else { - this.c(world, i, j, k, i1, 0); - world.setTypeId(i, j, k, 0); + this.c(world, i, j, k, 0, 0); + world.setAir(i, j, k); } super.doPhysics(world, i, j, k, l); @@ -302,42 +249,46 @@ public class BlockRedstoneWire extends Block { return Item.REDSTONE.id; } - public boolean c(IBlockAccess iblockaccess, int i, int j, int k, int l) { - return !this.a ? false : this.b(iblockaccess, i, j, k, l); + public int c(IBlockAccess iblockaccess, int i, int j, int k, int l) { + return !this.a ? 0 : this.b(iblockaccess, i, j, k, l); } - public boolean b(IBlockAccess iblockaccess, int i, int j, int k, int l) { + public int b(IBlockAccess iblockaccess, int i, int j, int k, int l) { if (!this.a) { - return false; - } else if (iblockaccess.getData(i, j, k) == 0) { - return false; - } else if (l == 1) { - return true; + return 0; } else { - boolean flag = g(iblockaccess, i - 1, j, k, 1) || !iblockaccess.t(i - 1, j, k) && g(iblockaccess, i - 1, j - 1, k, -1); - boolean flag1 = g(iblockaccess, i + 1, j, k, 3) || !iblockaccess.t(i + 1, j, k) && g(iblockaccess, i + 1, j - 1, k, -1); - boolean flag2 = g(iblockaccess, i, j, k - 1, 2) || !iblockaccess.t(i, j, k - 1) && g(iblockaccess, i, j - 1, k - 1, -1); - boolean flag3 = g(iblockaccess, i, j, k + 1, 0) || !iblockaccess.t(i, j, k + 1) && g(iblockaccess, i, j - 1, k + 1, -1); + int i1 = iblockaccess.getData(i, j, k); - if (!iblockaccess.t(i, j + 1, k)) { - if (iblockaccess.t(i - 1, j, k) && g(iblockaccess, i - 1, j + 1, k, -1)) { - flag = true; + if (i1 == 0) { + return 0; + } else if (l == 1) { + return i1; + } else { + boolean flag = g(iblockaccess, i - 1, j, k, 1) || !iblockaccess.u(i - 1, j, k) && g(iblockaccess, i - 1, j - 1, k, -1); + boolean flag1 = g(iblockaccess, i + 1, j, k, 3) || !iblockaccess.u(i + 1, j, k) && g(iblockaccess, i + 1, j - 1, k, -1); + boolean flag2 = g(iblockaccess, i, j, k - 1, 2) || !iblockaccess.u(i, j, k - 1) && g(iblockaccess, i, j - 1, k - 1, -1); + boolean flag3 = g(iblockaccess, i, j, k + 1, 0) || !iblockaccess.u(i, j, k + 1) && g(iblockaccess, i, j - 1, k + 1, -1); + + if (!iblockaccess.u(i, j + 1, k)) { + if (iblockaccess.u(i - 1, j, k) && g(iblockaccess, i - 1, j + 1, k, -1)) { + flag = true; + } + + if (iblockaccess.u(i + 1, j, k) && g(iblockaccess, i + 1, j + 1, k, -1)) { + flag1 = true; + } + + if (iblockaccess.u(i, j, k - 1) && g(iblockaccess, i, j + 1, k - 1, -1)) { + flag2 = true; + } + + if (iblockaccess.u(i, j, k + 1) && g(iblockaccess, i, j + 1, k + 1, -1)) { + flag3 = true; + } } - if (iblockaccess.t(i + 1, j, k) && g(iblockaccess, i + 1, j + 1, k, -1)) { - flag1 = true; - } - - if (iblockaccess.t(i, j, k - 1) && g(iblockaccess, i, j + 1, k - 1, -1)) { - flag2 = true; - } - - if (iblockaccess.t(i, j, k + 1) && g(iblockaccess, i, j + 1, k + 1, -1)) { - flag3 = true; - } + return !flag2 && !flag1 && !flag && !flag3 && l >= 2 && l <= 5 ? i1 : (l == 2 && flag2 && !flag && !flag1 ? i1 : (l == 3 && flag3 && !flag && !flag1 ? i1 : (l == 4 && flag && !flag2 && !flag3 ? i1 : (l == 5 && flag1 && !flag2 && !flag3 ? i1 : 0)))); } - - return !flag2 && !flag1 && !flag && !flag3 && l >= 2 && l <= 5 ? true : (l == 2 && flag2 && !flag && !flag1 ? true : (l == 3 && flag3 && !flag && !flag1 ? true : (l == 4 && flag && !flag2 && !flag3 ? true : l == 5 && flag1 && !flag2 && !flag3))); } } @@ -352,7 +303,7 @@ public class BlockRedstoneWire extends Block { return true; } else if (i1 == 0) { return false; - } else if (i1 != Block.DIODE_OFF.id && i1 != Block.DIODE_ON.id) { + } else if (!Block.DIODE_OFF.g(i1)) { return Block.byId[i1].isPowerSource() && l != -1; } else { int j1 = iblockaccess.getData(i, j, k); diff --git a/src/main/java/net/minecraft/server/BlockReed.java b/src/main/java/net/minecraft/server/BlockReed.java index 399050abf0..8657860125 100644 --- a/src/main/java/net/minecraft/server/BlockReed.java +++ b/src/main/java/net/minecraft/server/BlockReed.java @@ -4,16 +4,15 @@ import java.util.Random; public class BlockReed extends Block { - protected BlockReed(int i, int j) { + protected BlockReed(int i) { super(i, Material.PLANT); - this.textureId = j; float f = 0.375F; this.a(0.5F - f, 0.0F, 0.5F - f, 0.5F + f, 1.0F, 0.5F + f); this.b(true); } - public void b(World world, int i, int j, int k, Random random) { + public void a(World world, int i, int j, int k, Random random) { if (world.isEmpty(i, j + 1, k)) { int l; @@ -26,9 +25,9 @@ public class BlockReed extends Block { if (i1 == 15) { org.bukkit.craftbukkit.event.CraftEventFactory.handleBlockGrowEvent(world, i, j + 1, k, this.id, 0); // CraftBukkit - world.setData(i, j, k, 0); + world.setData(i, j, k, 0, 4); } else { - world.setData(i, j, k, i1 + 1); + world.setData(i, j, k, i1 + 1, 4); } } } @@ -41,21 +40,21 @@ public class BlockReed extends Block { } public void doPhysics(World world, int i, int j, int k, int l) { - this.k_(world, i, j, k); + this.p_(world, i, j, k); } - protected final void k_(World world, int i, int j, int k) { - if (!this.d(world, i, j, k)) { + protected final void p_(World world, int i, int j, int k) { + if (!this.f(world, i, j, k)) { this.c(world, i, j, k, world.getData(i, j, k), 0); - world.setTypeId(i, j, k, 0); + world.setAir(i, j, k); } } - public boolean d(World world, int i, int j, int k) { + public boolean f(World world, int i, int j, int k) { return this.canPlace(world, i, j, k); } - public AxisAlignedBB e(World world, int i, int j, int k) { + public AxisAlignedBB b(World world, int i, int j, int k) { return null; } diff --git a/src/main/java/net/minecraft/server/BlockSand.java b/src/main/java/net/minecraft/server/BlockSand.java deleted file mode 100644 index 44c114846c..0000000000 --- a/src/main/java/net/minecraft/server/BlockSand.java +++ /dev/null @@ -1,78 +0,0 @@ -package net.minecraft.server; - -import java.util.Random; - -public class BlockSand extends Block { - - public static boolean instaFall = false; - - public BlockSand(int i, int j) { - super(i, j, Material.SAND); - this.a(CreativeModeTab.b); - } - - public BlockSand(int i, int j, Material material) { - super(i, j, material); - } - - public void onPlace(World world, int i, int j, int k) { - world.a(i, j, k, this.id, this.r_()); - } - - public void doPhysics(World world, int i, int j, int k, int l) { - world.a(i, j, k, this.id, this.r_()); - } - - public void b(World world, int i, int j, int k, Random random) { - if (!world.isStatic) { - this.l(world, i, j, k); - } - } - - private void l(World world, int i, int j, int k) { - if (canFall(world, i, j - 1, k) && j >= 0) { - byte b0 = 32; - - if (!instaFall && world.d(i - b0, j - b0, k - b0, i + b0, j + b0, k + b0)) { - if (!world.isStatic) { - EntityFallingBlock entityfallingblock = new EntityFallingBlock(world, (double) ((float) i + 0.5F), (double) ((float) j + 0.5F), (double) ((float) k + 0.5F), this.id, world.getData(i, j, k)); - - this.a(entityfallingblock); - world.addEntity(entityfallingblock); - } - } else { - world.setTypeId(i, j, k, 0); - - while (canFall(world, i, j - 1, k) && j > 0) { - --j; - } - - if (j > 0) { - world.setTypeId(i, j, k, this.id); - } - } - } - } - - protected void a(EntityFallingBlock entityfallingblock) {} - - public int r_() { - return 5; - } - - public static boolean canFall(World world, int i, int j, int k) { - int l = world.getTypeId(i, j, k); - - if (l == 0) { - return true; - } else if (l == Block.FIRE.id) { - return true; - } else { - Material material = Block.byId[l].material; - - return material == Material.WATER ? true : material == Material.LAVA; - } - } - - public void a_(World world, int i, int j, int k, int l) {} -} diff --git a/src/main/java/net/minecraft/server/BlockSapling.java b/src/main/java/net/minecraft/server/BlockSapling.java index 9c94399e10..4264630047 100644 --- a/src/main/java/net/minecraft/server/BlockSapling.java +++ b/src/main/java/net/minecraft/server/BlockSapling.java @@ -12,38 +12,40 @@ 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, int j) { - super(i, j); + protected BlockSapling(int i) { + super(i); float f = 0.4F; this.a(0.5F - f, 0.0F, 0.5F - f, 0.5F + f, f * 2.0F, 0.5F + f); this.a(CreativeModeTab.c); } - public void b(World world, int i, int j, int k, Random random) { + public void a(World world, int i, int j, int k, Random random) { if (!world.isStatic) { - super.b(world, i, j, k, random); + super.a(world, i, j, k, random); if (world.getLightLevel(i, j + 1, k) >= 9 && random.nextInt(7) == 0) { - int l = world.getData(i, j, k); - - if ((l & 8) == 0) { - world.setData(i, j, k, l | 8); - } else { - this.grow(world, i, j, k, random, false, null, null); // CraftBukkit - added bonemeal, player and itemstack - } + this.grow(world, i, j, k, random, false, null, null); // CraftBukkit - added bonemeal, player and itemstack } } } - public int a(int i, int j) { - j &= 3; - return j == 1 ? 63 : (j == 2 ? 79 : (j == 3 ? 30 : super.a(i, j))); + // CraftBukkit - added bonemeal, player and itemstack + public void grow(World world, int i, int j, int k, Random random, boolean bonemeal, org.bukkit.entity.Player player, ItemStack itemstack) { + int l = world.getData(i, j, k); + + if ((l & 8) == 0) { + world.setData(i, j, k, l | 8, 4); + } else { + this.d(world, i, j, k, random, bonemeal, player, itemstack); // CraftBukkit + } } // CraftBukkit - added bonemeal, player and itemstack - public void grow(World world, int i, int j, int k, Random random, boolean bonemeal, org.bukkit.entity.Player player, ItemStack itemstack) { + public void d(World world, int i, int j, int k, Random random, boolean bonemeal, org.bukkit.entity.Player player, ItemStack itemstack) { int l = world.getData(i, j, k) & 3; + Object object = null; int i1 = 0; int j1 = 0; boolean flag = false; @@ -91,12 +93,12 @@ public class BlockSapling extends BlockFlower { } if (flag) { - world.setRawTypeId(i + i1, j, k + j1, 0); - world.setRawTypeId(i + i1 + 1, j, k + j1, 0); - world.setRawTypeId(i + i1, j, k + j1 + 1, 0); - world.setRawTypeId(i + i1 + 1, j, k + j1 + 1, 0); + world.setTypeIdAndData(i + i1, j, k + j1, 0, 0, 4); + world.setTypeIdAndData(i + i1 + 1, j, k + j1, 0, 0, 4); + world.setTypeIdAndData(i + i1, j, k + j1 + 1, 0, 0, 4); + world.setTypeIdAndData(i + i1 + 1, j, k + j1 + 1, 0, 0, 4); } else { - world.setRawTypeId(i, j, k, 0); + world.setTypeIdAndData(i, j, k, 0, 0, 4); } grownTree = gen.generate(delegate, random, i + i1, j, k + j1); @@ -117,12 +119,12 @@ public class BlockSapling extends BlockFlower { } if (!grownTree) { if (flag) { - world.setRawTypeIdAndData(i + i1, j, k + j1, this.id, l); - world.setRawTypeIdAndData(i + i1 + 1, j, k + j1, this.id, l); - world.setRawTypeIdAndData(i + i1, j, k + j1 + 1, this.id, l); - world.setRawTypeIdAndData(i + i1 + 1, j, k + j1 + 1, this.id, l); + world.setTypeIdAndData(i + i1, j, k + j1, this.id, l, 4); + world.setTypeIdAndData(i + i1 + 1, j, k + j1, this.id, l, 4); + world.setTypeIdAndData(i + i1, j, k + j1 + 1, this.id, l, 4); + world.setTypeIdAndData(i + i1 + 1, j, k + j1 + 1, this.id, l, 4); } else { - world.setRawTypeIdAndData(i, j, k, this.id, l); + world.setTypeIdAndData(i, j, k, this.id, l, 4); } } // CraftBukkit end diff --git a/src/main/java/net/minecraft/server/BlockSign.java b/src/main/java/net/minecraft/server/BlockSign.java index 5e6ce37eb9..33dd19c13c 100644 --- a/src/main/java/net/minecraft/server/BlockSign.java +++ b/src/main/java/net/minecraft/server/BlockSign.java @@ -12,7 +12,6 @@ public class BlockSign extends BlockContainer { protected BlockSign(int i, Class oclass, boolean flag) { super(i, Material.WOOD); this.b = flag; - this.textureId = 4; this.a = oclass; float f = 0.25F; float f1 = 1.0F; @@ -20,7 +19,7 @@ public class BlockSign extends BlockContainer { this.a(0.5F - f, 0.0F, 0.5F - f, 0.5F + f, f1, 0.5F + f); } - public AxisAlignedBB e(World world, int i, int j, int k) { + public AxisAlignedBB b(World world, int i, int j, int k) { return null; } @@ -60,7 +59,7 @@ public class BlockSign extends BlockContainer { return false; } - public boolean c(IBlockAccess iblockaccess, int i, int j, int k) { + public boolean b(IBlockAccess iblockaccess, int i, int j, int k) { return true; } @@ -68,7 +67,7 @@ public class BlockSign extends BlockContainer { return false; } - public TileEntity a(World world) { + public TileEntity b(World world) { try { return (TileEntity) this.a.newInstance(); } catch (Exception exception) { @@ -110,7 +109,7 @@ public class BlockSign extends BlockContainer { if (flag) { this.c(world, i, j, k, world.getData(i, j, k), 0); - world.setTypeId(i, j, k, 0); + world.setAir(i, j, k); } super.doPhysics(world, i, j, k, l); diff --git a/src/main/java/net/minecraft/server/BlockSkull.java b/src/main/java/net/minecraft/server/BlockSkull.java index de166a1b9b..933f49aeca 100644 --- a/src/main/java/net/minecraft/server/BlockSkull.java +++ b/src/main/java/net/minecraft/server/BlockSkull.java @@ -11,7 +11,6 @@ public class BlockSkull extends BlockContainer { protected BlockSkull(int i) { super(i, Material.ORIENTABLE); - this.textureId = 104; this.a(0.25F, 0.0F, 0.25F, 0.75F, 0.5F, 0.75F); } @@ -53,18 +52,18 @@ public class BlockSkull extends BlockContainer { } } - public AxisAlignedBB e(World world, int i, int j, int k) { + public AxisAlignedBB b(World world, int i, int j, int k) { this.updateShape(world, i, j, k); - return super.e(world, i, j, k); + return super.b(world, i, j, k); } - public void postPlace(World world, int i, int j, int k, EntityLiving entityliving) { + public void postPlace(World world, int i, int j, int k, EntityLiving entityliving, ItemStack itemstack) { int l = MathHelper.floor((double) (entityliving.yaw * 4.0F / 360.0F) + 2.5D) & 3; - world.setData(i, j, k, l); + world.setData(i, j, k, l, 2); } - public TileEntity a(World world) { + public TileEntity b(World world) { return new TileEntitySkull(); } @@ -97,7 +96,7 @@ public class BlockSkull extends BlockContainer { public void a(World world, int i, int j, int k, int l, EntityHuman entityhuman) { if (entityhuman.abilities.canInstantlyBuild) { l |= 8; - world.setData(i, j, k, l); + world.setData(i, j, k, l, 4); } super.a(world, i, j, k, l, entityhuman); @@ -128,7 +127,7 @@ public class BlockSkull extends BlockContainer { } public void a(World world, int i, int j, int k, TileEntitySkull tileentityskull) { - if (tileentityskull.getSkullType() == 1 && j >= 2 && world.difficulty > 0) { + if (tileentityskull.getSkullType() == 1 && j >= 2 && world.difficulty > 0 && !world.isStatic) { int l = Block.SOUL_SAND.id; int i1; @@ -140,9 +139,9 @@ public class BlockSkull extends BlockContainer { // CraftBukkit start - use BlockStateListPopulator BlockStateListPopulator blockList = new BlockStateListPopulator(world.getWorld()); - world.setRawData(i, j, k + i1, 8); - world.setRawData(i, j, k + i1 + 1, 8); - world.setRawData(i, j, k + i1 + 2, 8); + world.setData(i, j, k + i1, 8, 2); + world.setData(i, j, k + i1 + 1, 8, 2); + world.setData(i, j, k + i1 + 2, 8, 2); blockList.setTypeId(i, j, k + i1, 0); blockList.setTypeId(i, j, k + i1 + 1, 0); @@ -155,7 +154,7 @@ 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.ax = 90.0F; + entitywither.ay = 90.0F; entitywither.m(); if (world.addEntity(entitywither, SpawnReason.BUILD_WITHER)) { @@ -177,9 +176,9 @@ public class BlockSkull extends BlockContainer { // CraftBukkit start - use BlockStateListPopulator BlockStateListPopulator blockList = new BlockStateListPopulator(world.getWorld()); - world.setRawData(i + i1, j, k, 8); - world.setRawData(i + i1 + 1, j, k, 8); - world.setRawData(i + i1 + 2, j, k, 8); + world.setData(i + i1, j, k, 8, 2); + world.setData(i + i1 + 1, j, k, 8, 2); + world.setData(i + i1 + 2, j, k, 8, 2); blockList.setTypeId(i + i1, j, k, 0); blockList.setTypeId(i + i1 + 1, j, k, 0); diff --git a/src/main/java/net/minecraft/server/BlockSnow.java b/src/main/java/net/minecraft/server/BlockSnow.java index eacb148593..5b913cb246 100644 --- a/src/main/java/net/minecraft/server/BlockSnow.java +++ b/src/main/java/net/minecraft/server/BlockSnow.java @@ -4,17 +4,19 @@ import java.util.Random; public class BlockSnow extends Block { - protected BlockSnow(int i, int j) { - super(i, j, Material.SNOW_LAYER); + protected BlockSnow(int i) { + super(i, Material.SNOW_LAYER); this.a(0.0F, 0.0F, 0.0F, 1.0F, 0.125F, 1.0F); this.b(true); this.a(CreativeModeTab.c); + this.d(0); } - public AxisAlignedBB e(World world, int i, int j, int k) { + public AxisAlignedBB b(World world, int i, int j, int k) { int l = world.getData(i, j, k) & 7; + float f = 0.125F; - return l >= 3 ? AxisAlignedBB.a().a((double) i + this.minX, (double) j + this.minY, (double) k + this.minZ, (double) i + this.maxX, (double) ((float) j + 0.5F), (double) k + this.maxZ) : null; + return AxisAlignedBB.a().a((double) i + this.minX, (double) j + this.minY, (double) k + this.minZ, (double) i + this.maxX, (double) ((float) j + (float) l * f), (double) k + this.maxZ); } public boolean c() { @@ -25,9 +27,17 @@ public class BlockSnow extends Block { return false; } + public void g() { + this.d(0); + } + public void updateShape(IBlockAccess iblockaccess, int i, int j, int k) { - int l = iblockaccess.getData(i, j, k) & 7; - float f = (float) (2 * (1 + l)) / 16.0F; + this.d(iblockaccess.getData(i, j, k)); + } + + protected void d(int i) { + int j = i & 7; + float f = (float) (2 * (1 + j)) / 16.0F; this.a(0.0F, 0.0F, 0.0F, 1.0F, f, 1.0F); } @@ -35,18 +45,17 @@ public class BlockSnow extends Block { public boolean canPlace(World world, int i, int j, int k) { int l = world.getTypeId(i, j - 1, k); - return l != 0 && (l == Block.LEAVES.id || Block.byId[l].c()) ? world.getMaterial(i, j - 1, k).isSolid() : false; + return l == 0 ? false : (l == this.id && (world.getData(i, j - 1, k) & 7) == 7 ? true : (l != Block.LEAVES.id && !Block.byId[l].c() ? false : world.getMaterial(i, j - 1, k).isSolid())); } public void doPhysics(World world, int i, int j, int k, int l) { - this.n(world, i, j, k); + this.m(world, i, j, k); } - private boolean n(World world, int i, int j, int k) { + private boolean m(World world, int i, int j, int k) { if (!this.canPlace(world, i, j, k)) { this.c(world, i, j, k, world.getData(i, j, k), 0); - world.setRawTypeId(i, j, k, 0); // CraftBukkit - world.notify(i, j, k); // CraftBukkit - Notify clients of the reversion + world.setAir(i, j, k); return false; } else { return true; @@ -55,9 +64,10 @@ public class BlockSnow extends Block { public void a(World world, EntityHuman entityhuman, int i, int j, int k, int l) { int i1 = Item.SNOW_BALL.id; + int j1 = l & 7; - this.b(world, i, j, k, new ItemStack(i1, 1, 0)); - world.setTypeId(i, j, k, 0); + this.b(world, i, j, k, new ItemStack(i1, j1 + 1, 0)); + world.setAir(i, j, k); entityhuman.a(StatisticList.C[this.id], 1); } @@ -69,7 +79,7 @@ public class BlockSnow extends Block { return 0; } - public void b(World world, int i, int j, int k, Random random) { + public void a(World world, int i, int j, int k, Random random) { if (world.b(EnumSkyBlock.BLOCK, i, j, k) > 11) { // CraftBukkit start if (org.bukkit.craftbukkit.event.CraftEventFactory.callBlockFadeEvent(world.getWorld().getBlockAt(i, j, k), 0).isCancelled()) { @@ -78,7 +88,7 @@ public class BlockSnow extends Block { // CraftBukkit end this.c(world, i, j, k, world.getData(i, j, k), 0); - world.setTypeId(i, j, k, 0); + world.setAir(i, j, k); } } } diff --git a/src/main/java/net/minecraft/server/BlockSoil.java b/src/main/java/net/minecraft/server/BlockSoil.java index 21641570bd..8da8e11279 100644 --- a/src/main/java/net/minecraft/server/BlockSoil.java +++ b/src/main/java/net/minecraft/server/BlockSoil.java @@ -11,13 +11,12 @@ public class BlockSoil extends Block { protected BlockSoil(int i) { super(i, Material.EARTH); - this.textureId = 87; this.b(true); this.a(0.0F, 0.0F, 0.0F, 1.0F, 0.9375F, 1.0F); - this.h(255); + this.k(255); } - public AxisAlignedBB e(World world, int i, int j, int k) { + public AxisAlignedBB b(World world, int i, int j, int k) { return AxisAlignedBB.a().a((double) (i + 0), (double) (j + 0), (double) (k + 0), (double) (i + 1), (double) (j + 1), (double) (k + 1)); } @@ -29,17 +28,13 @@ public class BlockSoil extends Block { return false; } - public int a(int i, int j) { - return i == 1 && j > 0 ? this.textureId - 1 : (i == 1 ? this.textureId : 2); - } - - public void b(World world, int i, int j, int k, Random random) { - if (!this.n(world, i, j, k) && !world.D(i, j + 1, k)) { + public void a(World world, int i, int j, int k, Random random) { + if (!this.m(world, i, j, k) && !world.F(i, j + 1, k)) { int l = world.getData(i, j, k); if (l > 0) { - world.setData(i, j, k, l - 1); - } else if (!this.l(world, i, j, k)) { + world.setData(i, j, k, l - 1, 2); + } else if (!this.k(world, i, j, k)) { // CraftBukkit start org.bukkit.block.Block block = world.getWorld().getBlockAt(i, j, k); if (CraftEventFactory.callBlockFadeEvent(block, Block.DIRT.id).isCancelled()) { @@ -47,10 +42,10 @@ public class BlockSoil extends Block { } // CraftBukkit end - world.setTypeId(i, j, k, Block.DIRT.id); + world.setTypeIdUpdate(i, j, k, Block.DIRT.id); } } else { - world.setData(i, j, k, 7); + world.setData(i, j, k, 7, 2); } } @@ -74,11 +69,11 @@ public class BlockSoil extends Block { } // CraftBukkit end - world.setTypeId(i, j, k, Block.DIRT.id); + world.setTypeIdUpdate(i, j, k, Block.DIRT.id); } } - private boolean l(World world, int i, int j, int k) { + private boolean k(World world, int i, int j, int k) { byte b0 = 0; for (int l = i - b0; l <= i + b0; ++l) { @@ -94,7 +89,7 @@ public class BlockSoil extends Block { return false; } - private boolean n(World world, int i, int j, int k) { + private boolean m(World world, int i, int j, int k) { for (int l = i - 4; l <= i + 4; ++l) { for (int i1 = j; i1 <= j + 1; ++i1) { for (int j1 = k - 4; j1 <= k + 4; ++j1) { @@ -113,7 +108,7 @@ public class BlockSoil extends Block { Material material = world.getMaterial(i, j + 1, k); if (material.isBuildable()) { - world.setTypeId(i, j, k, Block.DIRT.id); + world.setTypeIdUpdate(i, j, k, Block.DIRT.id); } } diff --git a/src/main/java/net/minecraft/server/BlockStationary.java b/src/main/java/net/minecraft/server/BlockStationary.java index 25695d3fe9..cf44468011 100644 --- a/src/main/java/net/minecraft/server/BlockStationary.java +++ b/src/main/java/net/minecraft/server/BlockStationary.java @@ -17,28 +17,25 @@ public class BlockStationary extends BlockFluids { } } - public boolean c(IBlockAccess iblockaccess, int i, int j, int k) { + public boolean b(IBlockAccess iblockaccess, int i, int j, int k) { return this.material != Material.LAVA; } public void doPhysics(World world, int i, int j, int k, int l) { super.doPhysics(world, i, j, k, l); if (world.getTypeId(i, j, k) == this.id) { - this.l(world, i, j, k); + this.k(world, i, j, k); } } - private void l(World world, int i, int j, int k) { + private void k(World world, int i, int j, int k) { int l = world.getData(i, j, k); - world.suppressPhysics = true; - world.setRawTypeIdAndData(i, j, k, this.id - 1, l); - world.e(i, j, k, i, j, k); - world.a(i, j, k, this.id - 1, this.r_()); - world.suppressPhysics = false; + world.setTypeIdAndData(i, j, k, this.id - 1, l, 2); + world.a(i, j, k, this.id - 1, this.a(world)); } - public void b(World world, int i, int j, int k, Random random) { + public void a(World world, int i, int j, int k, Random random) { if (this.material == Material.LAVA) { int l = random.nextInt(3); @@ -56,7 +53,7 @@ public class BlockStationary extends BlockFluids { k += random.nextInt(3) - 1; j1 = world.getTypeId(i, j, k); if (j1 == 0) { - if (this.n(world, i - 1, j, k) || this.n(world, i + 1, j, k) || this.n(world, i, j, k - 1) || this.n(world, i, j, k + 1) || this.n(world, i, j - 1, k) || this.n(world, i, j + 1, k)) { + if (this.m(world, i - 1, j, k) || this.m(world, i + 1, j, k) || this.m(world, i, j, k - 1) || this.m(world, i, j, k + 1) || this.m(world, i, j - 1, k) || this.m(world, i, j + 1, k)) { // CraftBukkit start - prevent lava putting something on fire org.bukkit.block.Block block = bworld.getBlockAt(i, j, k); if (block.getTypeId() != Block.FIRE.id) { @@ -66,7 +63,7 @@ public class BlockStationary extends BlockFluids { } // CraftBukkit end - world.setTypeId(i, j, k, Block.FIRE.id); + world.setTypeIdUpdate(i, j, k, Block.FIRE.id); return; } } else if (Block.byId[j1].material.isSolid()) { @@ -81,7 +78,7 @@ public class BlockStationary extends BlockFluids { for (int k1 = 0; k1 < 3; ++k1) { i = i1 + random.nextInt(3) - 1; k = j1 + random.nextInt(3) - 1; - if (world.isEmpty(i, j + 1, k) && this.n(world, i, j, k)) { + if (world.isEmpty(i, j + 1, k) && this.m(world, i, j, k)) { // CraftBukkit start - prevent lava putting something on fire org.bukkit.block.Block block = bworld.getBlockAt(i, j + 1, k); if (block.getTypeId() != Block.FIRE.id) { @@ -91,14 +88,14 @@ public class BlockStationary extends BlockFluids { } // CraftBukkit end - world.setTypeId(i, j + 1, k, Block.FIRE.id); + world.setTypeIdUpdate(i, j + 1, k, Block.FIRE.id); } } } } } - private boolean n(World world, int i, int j, int k) { + private boolean m(World world, int i, int j, int k) { return world.getMaterial(i, j, k).isBurnable(); } } diff --git a/src/main/java/net/minecraft/server/BlockStem.java b/src/main/java/net/minecraft/server/BlockStem.java index ff1b89fa5a..8339a352ab 100644 --- a/src/main/java/net/minecraft/server/BlockStem.java +++ b/src/main/java/net/minecraft/server/BlockStem.java @@ -6,10 +6,10 @@ import org.bukkit.craftbukkit.event.CraftEventFactory; // CraftBukkit public class BlockStem extends BlockFlower { - private Block blockFruit; + private final Block blockFruit; protected BlockStem(int i, Block block) { - super(i, 111); + super(i); this.blockFruit = block; this.b(true); float f = 0.125F; @@ -18,21 +18,20 @@ public class BlockStem extends BlockFlower { this.a((CreativeModeTab) null); } - protected boolean d_(int i) { + protected boolean f_(int i) { return i == Block.SOIL.id; } - public void b(World world, int i, int j, int k, Random random) { - super.b(world, i, j, k, random); + public void a(World world, int i, int j, int k, Random random) { + super.a(world, i, j, k, random); if (world.getLightLevel(i, j + 1, k) >= 9) { - float f = this.n(world, i, j, k); + float f = this.m(world, i, j, k); if (random.nextInt((int) (25.0F / f) + 1) == 0) { int l = world.getData(i, j, k); if (l < 7) { - ++l; - CraftEventFactory.handleBlockGrowEvent(world, i, j, k, this.id, l); // CraftBukkit + CraftEventFactory.handleBlockGrowEvent(world, i, j, k, this.id, ++l); // CraftBukkit } else { if (world.getTypeId(i - 1, j, k) == this.blockFruit.id) { return; @@ -80,11 +79,17 @@ public class BlockStem extends BlockFlower { } } - public void l(World world, int i, int j, int k) { - world.setData(i, j, k, 7); + public void k(World world, int i, int j, int k) { + int l = world.getData(i, j, k) + MathHelper.nextInt(world.random, 2, 5); + + if (l > 7) { + l = 7; + } + + world.setData(i, j, k, l, 2); } - private float n(World world, int i, int j, int k) { + private float m(World world, int i, int j, int k) { float f = 1.0F; int l = world.getTypeId(i, j, k - 1); int i1 = world.getTypeId(i, j, k + 1); @@ -125,11 +130,7 @@ public class BlockStem extends BlockFlower { return f; } - public int a(int i, int j) { - return this.textureId; - } - - public void f() { + public void g() { float f = 0.125F; this.a(0.5F - f, 0.0F, 0.5F - f, 0.5F + f, 0.25F, 0.5F + f); diff --git a/src/main/java/net/minecraft/server/BlockTNT.java b/src/main/java/net/minecraft/server/BlockTNT.java deleted file mode 100644 index c9c0ec0f8d..0000000000 --- a/src/main/java/net/minecraft/server/BlockTNT.java +++ /dev/null @@ -1,79 +0,0 @@ -package net.minecraft.server; - -import java.util.Random; - -public class BlockTNT extends Block { - - public BlockTNT(int i, int j) { - super(i, j, Material.TNT); - this.a(CreativeModeTab.d); - } - - public int a(int i) { - return i == 0 ? this.textureId + 2 : (i == 1 ? this.textureId + 1 : this.textureId); - } - - public void onPlace(World world, int i, int j, int k) { - super.onPlace(world, i, j, k); - if (!world.suppressPhysics && world.isBlockIndirectlyPowered(i, j, k)) { // CraftBukkit - this.postBreak(world, i, j, k, 1); - world.setTypeId(i, j, k, 0); - } - } - - public void doPhysics(World world, int i, int j, int k, int l) { - if (l > 0 && Block.byId[l].isPowerSource() && world.isBlockIndirectlyPowered(i, j, k)) { - this.postBreak(world, i, j, k, 1); - world.setTypeId(i, j, k, 0); - } - } - - public int a(Random random) { - return 1; - } - - public void wasExploded(World world, int i, int j, int k) { - if (!world.isStatic) { - EntityTNTPrimed entitytntprimed = new EntityTNTPrimed(world, (double) ((float) i + 0.5F), (double) ((float) j + 0.5F), (double) ((float) k + 0.5F)); - - entitytntprimed.fuseTicks = world.random.nextInt(entitytntprimed.fuseTicks / 4) + entitytntprimed.fuseTicks / 8; - world.addEntity(entitytntprimed); - } - } - - public void postBreak(World world, int i, int j, int k, int l) { - if (!world.isStatic) { - if ((l & 1) == 1) { - EntityTNTPrimed entitytntprimed = new EntityTNTPrimed(world, (double) ((float) i + 0.5F), (double) ((float) j + 0.5F), (double) ((float) k + 0.5F)); - - world.addEntity(entitytntprimed); - world.makeSound(entitytntprimed, "random.fuse", 1.0F, 1.0F); - } - } - } - - public boolean interact(World world, int i, int j, int k, EntityHuman entityhuman, int l, float f, float f1, float f2) { - if (entityhuman.bS() != null && entityhuman.bS().id == Item.FLINT_AND_STEEL.id) { - this.postBreak(world, i, j, k, 1); - world.setTypeId(i, j, k, 0); - return true; - } else { - return super.interact(world, i, j, k, entityhuman, l, f, f1, f2); - } - } - - public void a(World world, int i, int j, int k, Entity entity) { - if (entity instanceof EntityArrow && !world.isStatic) { - EntityArrow entityarrow = (EntityArrow) entity; - - if (entityarrow.isBurning()) { - this.postBreak(world, i, j, k, 1); - world.setTypeId(i, j, k, 0); - } - } - } - - public boolean a(Explosion explosion) { - return false; - } -} diff --git a/src/main/java/net/minecraft/server/BlockTrapdoor.java b/src/main/java/net/minecraft/server/BlockTrapdoor.java index 7739df087b..37e321d5a2 100644 --- a/src/main/java/net/minecraft/server/BlockTrapdoor.java +++ b/src/main/java/net/minecraft/server/BlockTrapdoor.java @@ -6,11 +6,6 @@ public class BlockTrapdoor extends Block { protected BlockTrapdoor(int i, Material material) { super(i, material); - this.textureId = 84; - if (material == Material.ORE) { - ++this.textureId; - } - float f = 0.5F; float f1 = 1.0F; @@ -26,30 +21,30 @@ public class BlockTrapdoor extends Block { return false; } - public boolean c(IBlockAccess iblockaccess, int i, int j, int k) { - return !g(iblockaccess.getData(i, j, k)); + public boolean b(IBlockAccess iblockaccess, int i, int j, int k) { + return !f(iblockaccess.getData(i, j, k)); } public int d() { return 0; } - public AxisAlignedBB e(World world, int i, int j, int k) { + public AxisAlignedBB b(World world, int i, int j, int k) { this.updateShape(world, i, j, k); - return super.e(world, i, j, k); + return super.b(world, i, j, k); } public void updateShape(IBlockAccess iblockaccess, int i, int j, int k) { - this.e(iblockaccess.getData(i, j, k)); + this.d(iblockaccess.getData(i, j, k)); } - public void f() { + public void g() { float f = 0.1875F; this.a(0.0F, 0.5F - f / 2.0F, 0.0F, 1.0F, 0.5F + f / 2.0F, 1.0F); } - public void e(int i) { + public void d(int i) { float f = 0.1875F; if ((i & 8) != 0) { @@ -58,7 +53,7 @@ public class BlockTrapdoor extends Block { this.a(0.0F, 0.0F, 0.0F, 1.0F, f, 1.0F); } - if (g(i)) { + if (f(i)) { if ((i & 3) == 0) { this.a(0.0F, 0.0F, 1.0F - f, 1.0F, 1.0F, 1.0F); } @@ -85,7 +80,7 @@ public class BlockTrapdoor extends Block { } else { int i1 = world.getData(i, j, k); - world.setData(i, j, k, i1 ^ 4); + world.setData(i, j, k, i1 ^ 4, 2); world.a(entityhuman, 1003, i, j, k, 0); return true; } @@ -96,7 +91,7 @@ public class BlockTrapdoor extends Block { boolean flag1 = (l & 4) > 0; if (flag1 != flag) { - world.setData(i, j, k, l ^ 4); + world.setData(i, j, k, l ^ 4, 2); world.a((EntityHuman) null, 1003, i, j, k, 0); } } @@ -123,8 +118,8 @@ public class BlockTrapdoor extends Block { --j1; } - if (!j(world.getTypeId(j1, j, k1))) { - world.setTypeId(i, j, k, 0); + if (!g(world.getTypeId(j1, j, k1))) { + world.setAir(i, j, k); this.c(world, i, j, k, i1, 0); } @@ -200,15 +195,15 @@ public class BlockTrapdoor extends Block { --i; } - return j(world.getTypeId(i, j, k)); + return g(world.getTypeId(i, j, k)); } } - public static boolean g(int i) { + public static boolean f(int i) { return (i & 4) != 0; } - private static boolean j(int i) { + private static boolean g(int i) { if (i <= 0) { return false; } else { diff --git a/src/main/java/net/minecraft/server/BlockTripwire.java b/src/main/java/net/minecraft/server/BlockTripwire.java index dc31e0c25b..520b4e3efa 100644 --- a/src/main/java/net/minecraft/server/BlockTripwire.java +++ b/src/main/java/net/minecraft/server/BlockTripwire.java @@ -9,16 +9,16 @@ import org.bukkit.event.entity.EntityInteractEvent; // CraftBukkit public class BlockTripwire extends Block { public BlockTripwire(int i) { - super(i, 173, Material.ORIENTABLE); + super(i, Material.ORIENTABLE); this.a(0.0F, 0.0F, 0.0F, 1.0F, 0.15625F, 1.0F); this.b(true); } - public int r_() { + public int a(World world) { return 10; } - public AxisAlignedBB e(World world, int i, int j, int k) { + public AxisAlignedBB b(World world, int i, int j, int k) { return null; } @@ -41,11 +41,11 @@ public class BlockTripwire extends Block { public void doPhysics(World world, int i, int j, int k, int l) { int i1 = world.getData(i, j, k); boolean flag = (i1 & 2) == 2; - boolean flag1 = !world.v(i, j - 1, k); + boolean flag1 = !world.w(i, j - 1, k); if (flag != flag1) { this.c(world, i, j, k, i1, 0); - world.setTypeId(i, j, k, 0); + world.setAir(i, j, k); } } @@ -64,9 +64,9 @@ public class BlockTripwire extends Block { } public void onPlace(World world, int i, int j, int k) { - int l = world.v(i, j - 1, k) ? 0 : 2; + int l = world.w(i, j - 1, k) ? 0 : 2; - world.setData(i, j, k, l); + world.setData(i, j, k, l, 3); this.d(world, i, j, k, l); } @@ -76,8 +76,8 @@ 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.bS() != null && entityhuman.bS().id == Item.SHEARS.id) { - world.setData(i, j, k, l | 8); + if (entityhuman.cb() != null && entityhuman.cb().id == Item.SHEARS.id) { + world.setData(i, j, k, l | 8, 4); } } } @@ -115,20 +115,20 @@ public class BlockTripwire extends Block { public void a(World world, int i, int j, int k, Entity entity) { if (!world.isStatic) { if ((world.getData(i, j, k) & 1) != 1) { - this.l(world, i, j, k); + this.k(world, i, j, k); } } } - public void b(World world, int i, int j, int k, Random random) { + public void a(World world, int i, int j, int k, Random random) { if (!world.isStatic) { if ((world.getData(i, j, k) & 1) == 1) { - this.l(world, i, j, k); + this.k(world, i, j, k); } } } - private void l(World world, int i, int j, int k) { + private void k(World world, int i, int j, int k) { int l = world.getData(i, j, k); boolean flag = (l & 1) == 1; boolean flag1 = false; @@ -140,7 +140,7 @@ public class BlockTripwire extends Block { while (iterator.hasNext()) { Entity entity = (Entity) iterator.next(); - if (!entity.au()) { + if (!entity.at()) { flag1 = true; break; } @@ -184,12 +184,12 @@ public class BlockTripwire extends Block { } if (flag1 != flag) { - world.setData(i, j, k, l); + world.setData(i, j, k, l, 3); this.d(world, i, j, k, l); } if (flag1) { - world.a(i, j, k, this.id, this.r_()); + world.a(i, j, k, this.id, this.a(world)); } } } diff --git a/src/main/java/net/minecraft/server/BlockTripwireHook.java b/src/main/java/net/minecraft/server/BlockTripwireHook.java index e18bf43b26..5f70c3897b 100644 --- a/src/main/java/net/minecraft/server/BlockTripwireHook.java +++ b/src/main/java/net/minecraft/server/BlockTripwireHook.java @@ -7,12 +7,12 @@ import org.bukkit.event.block.BlockRedstoneEvent; // CraftBukkit public class BlockTripwireHook extends Block { public BlockTripwireHook(int i) { - super(i, 172, Material.ORIENTABLE); + super(i, Material.ORIENTABLE); this.a(CreativeModeTab.d); this.b(true); } - public AxisAlignedBB e(World world, int i, int j, int k) { + public AxisAlignedBB b(World world, int i, int j, int k) { return null; } @@ -28,34 +28,34 @@ public class BlockTripwireHook extends Block { return 29; } - public int r_() { + public int a(World world) { return 10; } public boolean canPlace(World world, int i, int j, int k, int l) { - return l == 2 && world.t(i, j, k + 1) ? true : (l == 3 && world.t(i, j, k - 1) ? true : (l == 4 && world.t(i + 1, j, k) ? true : l == 5 && world.t(i - 1, j, k))); + return l == 2 && world.u(i, j, k + 1) ? true : (l == 3 && world.u(i, j, k - 1) ? true : (l == 4 && world.u(i + 1, j, k) ? true : l == 5 && world.u(i - 1, j, k))); } public boolean canPlace(World world, int i, int j, int k) { - return world.t(i - 1, j, k) ? true : (world.t(i + 1, j, k) ? true : (world.t(i, j, k - 1) ? true : world.t(i, j, k + 1))); + return world.u(i - 1, j, k) ? true : (world.u(i + 1, j, k) ? true : (world.u(i, j, k - 1) ? true : world.u(i, j, k + 1))); } public int getPlacedData(World world, int i, int j, int k, int l, float f, float f1, float f2, int i1) { byte b0 = 0; - if (l == 2 && world.b(i, j, k + 1, true)) { + if (l == 2 && world.c(i, j, k + 1, true)) { b0 = 2; } - if (l == 3 && world.b(i, j, k - 1, true)) { + if (l == 3 && world.c(i, j, k - 1, true)) { b0 = 0; } - if (l == 4 && world.b(i + 1, j, k, true)) { + if (l == 4 && world.c(i + 1, j, k, true)) { b0 = 1; } - if (l == 5 && world.b(i - 1, j, k, true)) { + if (l == 5 && world.c(i - 1, j, k, true)) { b0 = 3; } @@ -68,30 +68,30 @@ public class BlockTripwireHook extends Block { public void doPhysics(World world, int i, int j, int k, int l) { if (l != this.id) { - if (this.l(world, i, j, k)) { + if (this.k(world, i, j, k)) { int i1 = world.getData(i, j, k); int j1 = i1 & 3; boolean flag = false; - if (!world.t(i - 1, j, k) && j1 == 3) { + if (!world.u(i - 1, j, k) && j1 == 3) { flag = true; } - if (!world.t(i + 1, j, k) && j1 == 1) { + if (!world.u(i + 1, j, k) && j1 == 1) { flag = true; } - if (!world.t(i, j, k - 1) && j1 == 0) { + if (!world.u(i, j, k - 1) && j1 == 0) { flag = true; } - if (!world.t(i, j, k + 1) && j1 == 2) { + if (!world.u(i, j, k + 1) && j1 == 2) { flag = true; } if (flag) { this.c(world, i, j, k, i1, 0); - world.setTypeId(i, j, k, 0); + world.setAir(i, j, k); } } } @@ -103,7 +103,7 @@ public class BlockTripwireHook extends Block { boolean flag2 = (i1 & 8) == 8; boolean flag3 = l == Block.TRIPWIRE_SOURCE.id; boolean flag4 = false; - boolean flag5 = !world.v(i, j - 1, k); + boolean flag5 = !world.w(i, j - 1, k); int i2 = Direction.a[l1]; int j2 = Direction.b[l1]; int k2 = 0; @@ -140,7 +140,7 @@ public class BlockTripwireHook extends Block { flag4 |= flag6 && flag7; aint[i3] = l3; if (i3 == j1) { - world.a(i, j, k, l, this.r_()); + world.a(i, j, k, l, this.a(world)); flag3 &= flag6; } } @@ -154,7 +154,7 @@ public class BlockTripwireHook extends Block { l2 = i + i2 * k2; k3 = k + j2 * k2; j3 = Direction.f[l1]; - world.setData(l2, j, k3, j3 | i3); + world.setData(l2, j, k3, j3 | i3, 3); this.d(world, l2, j, k3, j3); this.a(world, l2, j, k3, flag3, flag4, flag1, flag2); } @@ -162,7 +162,7 @@ public class BlockTripwireHook extends Block { // CraftBukkit start org.bukkit.block.Block block = world.getWorld().getBlockAt(i, j, k); - BlockRedstoneEvent eventRedstone = new BlockRedstoneEvent(block, 1, 0); + BlockRedstoneEvent eventRedstone = new BlockRedstoneEvent(block, 15, 0); world.getServer().getPluginManager().callEvent(eventRedstone); if (eventRedstone.getNewCurrent() > 0) { @@ -172,7 +172,7 @@ public class BlockTripwireHook extends Block { this.a(world, i, j, k, flag3, flag4, flag1, flag2); if (l > 0) { - world.setData(i, j, k, i1); + world.setData(i, j, k, i1, 3); if (flag) { this.d(world, i, j, k, l1); } @@ -190,13 +190,13 @@ public class BlockTripwireHook extends Block { l3 &= -5; } - world.setData(k3, j, j3, l3); + world.setData(k3, j, j3, l3, 3); } } } } - public void b(World world, int i, int j, int k, Random random) { + public void a(World world, int i, int j, int k, Random random) { this.a(world, i, j, k, this.id, world.getData(i, j, k), true, -1, 0); } @@ -225,10 +225,10 @@ public class BlockTripwireHook extends Block { } } - private boolean l(World world, int i, int j, int k) { + private boolean k(World world, int i, int j, int k) { if (!this.canPlace(world, i, j, k)) { this.c(world, i, j, k, world.getData(i, j, k), 0); - world.setTypeId(i, j, k, 0); + world.setAir(i, j, k); return false; } else { return true; @@ -276,19 +276,19 @@ public class BlockTripwireHook extends Block { super.remove(world, i, j, k, l, i1); } - public boolean b(IBlockAccess iblockaccess, int i, int j, int k, int l) { - return (iblockaccess.getData(i, j, k) & 8) == 8; + public int b(IBlockAccess iblockaccess, int i, int j, int k, int l) { + return (iblockaccess.getData(i, j, k) & 8) == 8 ? 15 : 0; } - public boolean c(IBlockAccess iblockaccess, int i, int j, int k, int l) { + public int c(IBlockAccess iblockaccess, int i, int j, int k, int l) { int i1 = iblockaccess.getData(i, j, k); if ((i1 & 8) != 8) { - return false; + return 0; } else { int j1 = i1 & 3; - return j1 == 2 && l == 2 ? true : (j1 == 0 && l == 3 ? true : (j1 == 1 && l == 4 ? true : j1 == 3 && l == 5)); + return j1 == 2 && l == 2 ? 15 : (j1 == 0 && l == 3 ? 15 : (j1 == 1 && l == 4 ? 15 : (j1 == 3 && l == 5 ? 15 : 0))); } } diff --git a/src/main/java/net/minecraft/server/BlockVine.java b/src/main/java/net/minecraft/server/BlockVine.java index 03064defa8..6dc99f6673 100644 --- a/src/main/java/net/minecraft/server/BlockVine.java +++ b/src/main/java/net/minecraft/server/BlockVine.java @@ -7,12 +7,12 @@ import org.bukkit.craftbukkit.event.CraftEventFactory; // CraftBukkit public class BlockVine extends Block { public BlockVine(int i) { - super(i, 143, Material.REPLACEABLE_PLANT); + super(i, Material.REPLACEABLE_PLANT); this.b(true); this.a(CreativeModeTab.c); } - public void f() { + public void g() { this.a(0.0F, 0.0F, 0.0F, 1.0F, 1.0F, 1.0F); } @@ -78,7 +78,7 @@ public class BlockVine extends Block { flag = true; } - if (!flag && this.e(iblockaccess.getTypeId(i, j + 1, k))) { + if (!flag && this.d(iblockaccess.getTypeId(i, j + 1, k))) { f1 = Math.min(f1, 0.9375F); f4 = 1.0F; f = 0.0F; @@ -90,33 +90,33 @@ public class BlockVine extends Block { this.a(f, f1, f2, f3, f4, f5); } - public AxisAlignedBB e(World world, int i, int j, int k) { + public AxisAlignedBB b(World world, int i, int j, int k) { return null; } public boolean canPlace(World world, int i, int j, int k, int l) { switch (l) { case 1: - return this.e(world.getTypeId(i, j + 1, k)); + return this.d(world.getTypeId(i, j + 1, k)); case 2: - return this.e(world.getTypeId(i, j, k + 1)); + return this.d(world.getTypeId(i, j, k + 1)); case 3: - return this.e(world.getTypeId(i, j, k - 1)); + return this.d(world.getTypeId(i, j, k - 1)); case 4: - return this.e(world.getTypeId(i + 1, j, k)); + return this.d(world.getTypeId(i + 1, j, k)); case 5: - return this.e(world.getTypeId(i - 1, j, k)); + return this.d(world.getTypeId(i - 1, j, k)); default: return false; } } - private boolean e(int i) { + private boolean d(int i) { if (i == 0) { return false; } else { @@ -126,7 +126,7 @@ public class BlockVine extends Block { } } - private boolean l(World world, int i, int j, int k) { + private boolean k(World world, int i, int j, int k) { int l = world.getData(i, j, k); int i1 = l; @@ -134,17 +134,17 @@ public class BlockVine extends Block { for (int j1 = 0; j1 <= 3; ++j1) { int k1 = 1 << j1; - if ((l & k1) != 0 && !this.e(world.getTypeId(i + Direction.a[j1], j, k + Direction.b[j1])) && (world.getTypeId(i, j + 1, k) != this.id || (world.getData(i, j + 1, k) & k1) == 0)) { + if ((l & k1) != 0 && !this.d(world.getTypeId(i + Direction.a[j1], j, k + Direction.b[j1])) && (world.getTypeId(i, j + 1, k) != this.id || (world.getData(i, j + 1, k) & k1) == 0)) { i1 &= ~k1; } } } - if (i1 == 0 && !this.e(world.getTypeId(i, j + 1, k))) { + if (i1 == 0 && !this.d(world.getTypeId(i, j + 1, k))) { return false; } else { if (i1 != l) { - world.setData(i, j, k, i1); + world.setData(i, j, k, i1, 2); } return true; @@ -152,13 +152,13 @@ public class BlockVine extends Block { } public void doPhysics(World world, int i, int j, int k, int l) { - if (!world.isStatic && !this.l(world, i, j, k)) { + if (!world.isStatic && !this.k(world, i, j, k)) { this.c(world, i, j, k, world.getData(i, j, k), 0); - world.setTypeId(i, j, k, 0); + world.setAir(i, j, k); } } - public void b(World world, int i, int j, int k, Random random) { + public void a(World world, int i, int j, int k, Random random) { if (!world.isStatic && world.random.nextInt(4) == 0) { byte b0 = 4; int l = 5; @@ -197,7 +197,7 @@ public class BlockVine extends Block { l1 = world.random.nextInt(16) & i1; if (l1 > 0) { for (i2 = 0; i2 <= 3; ++i2) { - if (!this.e(world.getTypeId(i + Direction.a[i2], j + 1, k + Direction.b[i2]))) { + if (!this.d(world.getTypeId(i + Direction.a[i2], j + 1, k + Direction.b[i2]))) { l1 &= ~(1 << i2); } } @@ -206,7 +206,7 @@ public class BlockVine extends Block { // CraftBukkit start - fire BlockSpreadEvent org.bukkit.block.Block source = world.getWorld().getBlockAt(i, j, k); org.bukkit.block.Block block = world.getWorld().getBlockAt(i, j + 1, k); - CraftEventFactory.handleBlockSpreadEvent(block, source, this.id, i2); + CraftEventFactory.handleBlockSpreadEvent(block, source, this.id, l1); // CraftBukkit end } } @@ -221,25 +221,26 @@ public class BlockVine extends Block { l1 = world.getTypeId(i + Direction.a[k1], j, k + Direction.b[k1]); if (l1 != 0 && Block.byId[l1] != null) { if (Block.byId[l1].material.k() && Block.byId[l1].b()) { - world.setData(i, j, k, i1 | 1 << k1); + world.setData(i, j, k, i1 | 1 << k1, 2); } } else { i2 = k1 + 1 & 3; j2 = k1 + 3 & 3; + // CraftBukkit start - fire BlockSpreadEvent org.bukkit.block.Block source = world.getWorld().getBlockAt(i, j, k); org.bukkit.block.Block block = world.getWorld().getBlockAt(i + Direction.a[k1], j, k + Direction.b[k1]); - if ((i1 & 1 << i2) != 0 && this.e(world.getTypeId(i + Direction.a[k1] + Direction.a[i2], j, k + Direction.b[k1] + Direction.b[i2]))) { + if ((i1 & 1 << i2) != 0 && this.d(world.getTypeId(i + Direction.a[k1] + Direction.a[i2], j, k + Direction.b[k1] + Direction.b[i2]))) { CraftEventFactory.handleBlockSpreadEvent(block, source, this.id, 1 << i2); - } else if ((i1 & 1 << j2) != 0 && this.e(world.getTypeId(i + Direction.a[k1] + Direction.a[j2], j, k + Direction.b[k1] + Direction.b[j2]))) { + } else if ((i1 & 1 << j2) != 0 && this.d(world.getTypeId(i + Direction.a[k1] + Direction.a[j2], j, k + Direction.b[k1] + Direction.b[j2]))) { CraftEventFactory.handleBlockSpreadEvent(block, source, this.id, 1 << j2); - } else if ((i1 & 1 << i2) != 0 && world.isEmpty(i + Direction.a[k1] + Direction.a[i2], j, k + Direction.b[k1] + Direction.b[i2]) && this.e(world.getTypeId(i + Direction.a[i2], j, k + Direction.b[i2]))) { + } else if ((i1 & 1 << i2) != 0 && world.isEmpty(i + Direction.a[k1] + Direction.a[i2], j, k + Direction.b[k1] + Direction.b[i2]) && this.d(world.getTypeId(i + Direction.a[i2], j, k + Direction.b[i2]))) { block = world.getWorld().getBlockAt(i + Direction.a[k1] + Direction.a[i2], j, k + Direction.b[k1] + Direction.b[i2]); CraftEventFactory.handleBlockSpreadEvent(block, source, this.id, 1 << (k1 + 2 & 3)); - } else if ((i1 & 1 << j2) != 0 && world.isEmpty(i + Direction.a[k1] + Direction.a[j2], j, k + Direction.b[k1] + Direction.b[j2]) && this.e(world.getTypeId(i + Direction.a[j2], j, k + Direction.b[j2]))) { + } else if ((i1 & 1 << j2) != 0 && world.isEmpty(i + Direction.a[k1] + Direction.a[j2], j, k + Direction.b[k1] + Direction.b[j2]) && this.d(world.getTypeId(i + Direction.a[j2], j, k + Direction.b[j2]))) { block = world.getWorld().getBlockAt(i + Direction.a[k1] + Direction.a[j2], j, k + Direction.b[k1] + Direction.b[j2]); CraftEventFactory.handleBlockSpreadEvent(block, source, this.id, 1 << (k1 + 2 & 3)); - } else if (this.e(world.getTypeId(i + Direction.a[k1], j + 1, k + Direction.b[k1]))) { + } else if (this.d(world.getTypeId(i + Direction.a[k1], j + 1, k + Direction.b[k1]))) { CraftEventFactory.handleBlockSpreadEvent(block, source, this.id, 0); } // CraftBukkit end @@ -259,7 +260,7 @@ public class BlockVine extends Block { i2 = world.random.nextInt(16) & i1; j2 = world.getData(i, j - 1, k); if (j2 != (j2 | i2)) { - world.setData(i, j - 1, k, j2 | i2); + world.setData(i, j - 1, k, j2 | i2, 2); } } } @@ -299,7 +300,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.bS() != null && entityhuman.bS().id == Item.SHEARS.id) { + if (!world.isStatic && entityhuman.cb() != null && entityhuman.cb().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 93c343e115..ce5c73b7ac 100644 --- a/src/main/java/net/minecraft/server/Chunk.java +++ b/src/main/java/net/minecraft/server/Chunk.java @@ -159,7 +159,7 @@ public class Chunk { if (chunksection != null) { chunksection.c(j, i1 & 15, k, l); - this.world.o((this.x << 4) + j, i1, (this.z << 4) + k); + this.world.p((this.x << 4) + j, i1, (this.z << 4) + k); } } @@ -262,7 +262,7 @@ public class Chunk { } if (i1 != l) { - this.world.g(i + this.x * 16, k + this.z * 16, i1, l); + this.world.e(i + this.x * 16, k + this.z * 16, i1, l); this.heightMap[k << 4 | i] = i1; int j1 = this.x * 16 + i; int k1 = this.z * 16 + k; @@ -277,7 +277,7 @@ public class Chunk { chunksection = this.sections[l1 >> 4]; if (chunksection != null) { chunksection.c(i, l1 & 15, k, 15); - this.world.o((this.x << 4) + i, l1, (this.z << 4) + k); + this.world.p((this.x << 4) + i, l1, (this.z << 4) + k); } } } else { @@ -285,7 +285,7 @@ public class Chunk { chunksection = this.sections[l1 >> 4]; if (chunksection != null) { chunksection.c(i, l1 & 15, k, 0); - this.world.o((this.x << 4) + i, l1, (this.z << 4) + k); + this.world.p((this.x << 4) + i, l1, (this.z << 4) + k); } } } @@ -361,10 +361,6 @@ public class Chunk { } } - public boolean a(int i, int j, int k, int l) { - return this.a(i, j, k, l, 0); - } - public boolean a(int i, int j, int k, int l, int i1) { int j1 = k << 4 | i; @@ -387,7 +383,7 @@ public class Chunk { return false; } - chunksection = this.sections[j >> 4] = new ChunkSection(j >> 4 << 4, !world.worldProvider.f); + chunksection = this.sections[j >> 4] = new ChunkSection(j >> 4 << 4, !this.world.worldProvider.f); flag = j >= k1; } @@ -395,15 +391,15 @@ public class Chunk { int k2 = this.z * 16 + k; if (l1 != 0 && !this.world.isStatic) { - Block.byId[l1].h(this.world, j2, j, k2, i2); + Block.byId[l1].l(this.world, j2, j, k2, i2); } chunksection.a(i, j & 15, k, l); if (l1 != 0) { if (!this.world.isStatic) { Block.byId[l1].remove(this.world, j2, j, k2, l1, i2); - } else if (Block.byId[l1] instanceof BlockContainer && l1 != l) { - this.world.r(j2, j, k2); + } else if (Block.byId[l1] instanceof IContainer && l1 != l) { + this.world.s(j2, j, k2); } } @@ -433,7 +429,7 @@ public class Chunk { Block.byId[l].onPlace(this.world, j2, j, k2); } - if (Block.byId[l] instanceof BlockContainer) { + if (Block.byId[l] instanceof IContainer) { // CraftBukkit start - don't create tile entity if placement failed if (this.getTypeId(i, j, k) != l) { return false; @@ -442,18 +438,18 @@ public class Chunk { tileentity = this.e(i, j, k); if (tileentity == null) { - tileentity = ((BlockContainer) Block.byId[l]).a(this.world); + tileentity = ((IContainer) Block.byId[l]).b(this.world); this.world.setTileEntity(j2, j, k2, tileentity); } if (tileentity != null) { - tileentity.h(); + tileentity.i(); } } - } else if (l1 > 0 && Block.byId[l1] instanceof BlockContainer) { + } else if (l1 > 0 && Block.byId[l1] instanceof IContainer) { tileentity = this.e(i, j, k); if (tileentity != null) { - tileentity.h(); + tileentity.i(); } } @@ -478,11 +474,11 @@ public class Chunk { chunksection.b(i, j & 15, k, l); int j1 = chunksection.a(i, j & 15, k); - if (j1 > 0 && Block.byId[j1] instanceof BlockContainer) { + if (j1 > 0 && Block.byId[j1] instanceof IContainer) { TileEntity tileentity = this.e(i, j, k); if (tileentity != null) { - tileentity.h(); + tileentity.i(); tileentity.p = l; } } @@ -502,7 +498,7 @@ public class Chunk { ChunkSection chunksection = this.sections[j >> 4]; if (chunksection == null) { - chunksection = this.sections[j >> 4] = new ChunkSection(j >> 4 << 4, !world.worldProvider.f); + chunksection = this.sections[j >> 4] = new ChunkSection(j >> 4 << 4, !this.world.worldProvider.f); this.initLighting(); } @@ -562,15 +558,15 @@ public class Chunk { k = this.entitySlices.length - 1; } - entity.ah = true; - entity.ai = this.x; - entity.aj = k; - entity.ak = this.z; + entity.ai = true; + entity.aj = this.x; + entity.ak = k; + entity.al = this.z; this.entitySlices[k].add(entity); } public void b(Entity entity) { - this.a(entity, entity.aj); + this.a(entity, entity.ak); } public void a(Entity entity, int i) { @@ -596,12 +592,12 @@ public class Chunk { if (tileentity == null) { int l = this.getTypeId(i, j, k); - if (l <= 0 || !Block.byId[l].u()) { + if (l <= 0 || !Block.byId[l].t()) { return null; } if (tileentity == null) { - tileentity = ((BlockContainer) Block.byId[l]).a(this.world); + tileentity = ((IContainer) Block.byId[l]).b(this.world); this.world.setTileEntity(this.x * 16 + i, j, this.z * 16 + k, tileentity); } @@ -634,7 +630,11 @@ public class Chunk { tileentity.x = this.x * 16 + i; tileentity.y = j; tileentity.z = this.z * 16 + k; - if (this.getTypeId(i, j, k) != 0 && Block.byId[this.getTypeId(i, j, k)] instanceof BlockContainer) { + if (this.getTypeId(i, j, k) != 0 && Block.byId[this.getTypeId(i, j, k)] instanceof IContainer) { + if (this.tileEntities.containsKey(chunkposition)) { + ((TileEntity) this.tileEntities.get(chunkposition)).w_(); + } + tileentity.s(); this.tileEntities.put(chunkposition, tileentity); // CraftBukkit start @@ -700,16 +700,18 @@ public class Chunk { this.l = true; } - public void a(Entity entity, AxisAlignedBB axisalignedbb, List list) { + public void a(Entity entity, AxisAlignedBB axisalignedbb, List list, IEntitySelector ientityselector) { int i = MathHelper.floor((axisalignedbb.b - 2.0D) / 16.0D); int j = MathHelper.floor((axisalignedbb.e + 2.0D) / 16.0D); if (i < 0) { i = 0; + j = Math.max(i, j); } if (j >= this.entitySlices.length) { j = this.entitySlices.length - 1; + i = Math.min(i, j); } for (int k = i; k <= j; ++k) { @@ -718,14 +720,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)) { + if (entity1 != entity && entity1.boundingBox.a(axisalignedbb) && (ientityselector == null || ientityselector.a(entity1))) { list.add(entity1); - Entity[] aentity = entity1.ao(); + Entity[] aentity = entity1.an(); if (aentity != null) { for (int i1 = 0; i1 < aentity.length; ++i1) { entity1 = aentity[i1]; - if (entity1 != entity && entity1.boundingBox.a(axisalignedbb)) { + if (entity1 != entity && entity1.boundingBox.a(axisalignedbb) && (ientityselector == null || ientityselector.a(entity1))) { list.add(entity1); } } @@ -766,7 +768,7 @@ public class Chunk { public boolean a(boolean flag) { if (flag) { - if (this.m && this.world.getTime() != this.n) { + if (this.m && this.world.getTime() != this.n || this.l) { return true; } } else if (this.m && this.world.getTime() >= this.n + 600L) { @@ -906,30 +908,30 @@ public class Chunk { if (this.sections[j] == null && (k1 == 0 || k1 == 15 || k == 0 || k == 15 || l == 0 || l == 15) || this.sections[j] != null && this.sections[j].a(k, k1, l) == 0) { if (Block.lightEmission[this.world.getTypeId(i1, l1 - 1, j1)] > 0) { - this.world.z(i1, l1 - 1, j1); + this.world.A(i1, l1 - 1, j1); } if (Block.lightEmission[this.world.getTypeId(i1, l1 + 1, j1)] > 0) { - this.world.z(i1, l1 + 1, j1); + this.world.A(i1, l1 + 1, j1); } if (Block.lightEmission[this.world.getTypeId(i1 - 1, l1, j1)] > 0) { - this.world.z(i1 - 1, l1, j1); + this.world.A(i1 - 1, l1, j1); } if (Block.lightEmission[this.world.getTypeId(i1 + 1, l1, j1)] > 0) { - this.world.z(i1 + 1, l1, j1); + this.world.A(i1 + 1, l1, j1); } if (Block.lightEmission[this.world.getTypeId(i1, l1, j1 - 1)] > 0) { - this.world.z(i1, l1, j1 - 1); + this.world.A(i1, l1, j1 - 1); } if (Block.lightEmission[this.world.getTypeId(i1, l1, j1 + 1)] > 0) { - this.world.z(i1, l1, j1 + 1); + this.world.A(i1, l1, j1 + 1); } - this.world.z(i1, l1, j1); + this.world.A(i1, l1, j1); } } } diff --git a/src/main/java/net/minecraft/server/ChunkProviderServer.java b/src/main/java/net/minecraft/server/ChunkProviderServer.java index c0bab0fa3f..d5887a987f 100644 --- a/src/main/java/net/minecraft/server/ChunkProviderServer.java +++ b/src/main/java/net/minecraft/server/ChunkProviderServer.java @@ -159,8 +159,8 @@ public class ChunkProviderServer implements IChunkProvider { chunk = chunk == null ? (!this.world.isLoading && !this.forceChunkLoad ? this.emptyChunk : this.getChunkAt(i, j)) : chunk; if (chunk == this.emptyChunk) return chunk; if (i != chunk.x || j != chunk.z) { - MinecraftServer.log.severe("Chunk (" + chunk.x + ", " + chunk.z + ") stored at (" + i + ", " + j + ") in world '" + world.getWorld().getName() + "'"); - MinecraftServer.log.severe(chunk.getClass().getName()); + this.world.getLogger().severe("Chunk (" + chunk.x + ", " + chunk.z + ") stored at (" + i + ", " + j + ") in world '" + world.getWorld().getName() + "'"); + this.world.getLogger().severe(chunk.getClass().getName()); Throwable ex = new Throwable(); ex.fillInStackTrace(); ex.printStackTrace(); diff --git a/src/main/java/net/minecraft/server/ChunkRegionLoader.java b/src/main/java/net/minecraft/server/ChunkRegionLoader.java index 88c33d06e1..8f37333a2b 100644 --- a/src/main/java/net/minecraft/server/ChunkRegionLoader.java +++ b/src/main/java/net/minecraft/server/ChunkRegionLoader.java @@ -85,16 +85,16 @@ public class ChunkRegionLoader implements IAsyncChunkSaver, IChunkLoader { protected Object[] a(World world, int i, int j, NBTTagCompound nbttagcompound) { // CraftBukkit - return Chunk -> Object[] if (!nbttagcompound.hasKey("Level")) { - System.out.println("Chunk file at " + i + "," + j + " is missing level data, skipping"); + world.getLogger().severe("Chunk file at " + i + "," + j + " is missing level data, skipping"); return null; } else if (!nbttagcompound.getCompound("Level").hasKey("Sections")) { - System.out.println("Chunk file at " + i + "," + j + " is missing block data, skipping"); + world.getLogger().severe("Chunk file at " + i + "," + j + " is missing block data, skipping"); return null; } else { Chunk chunk = this.a(world, nbttagcompound.getCompound("Level")); if (!chunk.a(i, j)) { - System.out.println("Chunk file at " + i + "," + j + " is in the wrong location; relocating. (Expected " + i + ", " + j + ", got " + chunk.x + ", " + chunk.z + ")"); + world.getLogger().severe("Chunk file at " + i + "," + j + " is in the wrong location; relocating. (Expected " + i + ", " + j + ", got " + chunk.x + ", " + chunk.z + ")"); nbttagcompound.getCompound("Level").setInt("xPos", i); // CraftBukkit - .getCompound("Level") nbttagcompound.getCompound("Level").setInt("zPos", j); // CraftBukkit - .getCompound("Level") chunk = this.a(world, nbttagcompound.getCompound("Level")); @@ -112,7 +112,7 @@ public class ChunkRegionLoader implements IAsyncChunkSaver, IChunkLoader { public void a(World world, Chunk chunk) { // CraftBukkit start - "handle" exception try { - world.D(); + world.E(); } catch (ExceptionWorldConflict ex) { ex.printStackTrace(); } @@ -236,9 +236,9 @@ public class ChunkRegionLoader implements IAsyncChunkSaver, IChunkLoader { while (iterator.hasNext()) { Entity entity = (Entity) iterator.next(); - chunk.m = true; nbttagcompound1 = new NBTTagCompound(); - if (entity.c(nbttagcompound1)) { + if (entity.d(nbttagcompound1)) { + chunk.m = true; nbttaglist1.add(nbttagcompound1); } } @@ -274,6 +274,7 @@ public class ChunkRegionLoader implements IAsyncChunkSaver, IChunkLoader { nbttagcompound2.setInt("y", nextticklistentry.b); nbttagcompound2.setInt("z", nextticklistentry.c); nbttagcompound2.setInt("t", (int) (nextticklistentry.e - k)); + nbttagcompound2.setInt("p", nextticklistentry.f); nbttaglist3.add(nbttagcompound2); } @@ -335,6 +336,18 @@ public class ChunkRegionLoader implements IAsyncChunkSaver, IChunkLoader { chunk.m = true; if (entity != null) { chunk.a(entity); + Entity entity1 = entity; + + for (NBTTagCompound nbttagcompound3 = nbttagcompound2; nbttagcompound3.hasKey("Riding"); nbttagcompound3 = nbttagcompound3.getCompound("Riding")) { + Entity entity2 = EntityTypes.a(nbttagcompound3.getCompound("Riding"), world); + + if (entity2 != null) { + chunk.a(entity2); + entity1.mount(entity2); + } + + entity1 = entity2; + } } } } @@ -343,8 +356,8 @@ public class ChunkRegionLoader implements IAsyncChunkSaver, IChunkLoader { if (nbttaglist2 != null) { for (int i1 = 0; i1 < nbttaglist2.size(); ++i1) { - NBTTagCompound nbttagcompound3 = (NBTTagCompound) nbttaglist2.get(i1); - TileEntity tileentity = TileEntity.c(nbttagcompound3); + NBTTagCompound nbttagcompound4 = (NBTTagCompound) nbttaglist2.get(i1); + TileEntity tileentity = TileEntity.c(nbttagcompound4); if (tileentity != null) { chunk.a(tileentity); @@ -357,9 +370,9 @@ public class ChunkRegionLoader implements IAsyncChunkSaver, IChunkLoader { if (nbttaglist3 != null) { for (int j1 = 0; j1 < nbttaglist3.size(); ++j1) { - NBTTagCompound nbttagcompound4 = (NBTTagCompound) nbttaglist3.get(j1); + NBTTagCompound nbttagcompound5 = (NBTTagCompound) nbttaglist3.get(j1); - world.b(nbttagcompound4.getInt("x"), nbttagcompound4.getInt("y"), nbttagcompound4.getInt("z"), nbttagcompound4.getInt("i"), nbttagcompound4.getInt("t")); + world.b(nbttagcompound5.getInt("x"), nbttagcompound5.getInt("y"), nbttagcompound5.getInt("z"), nbttagcompound5.getInt("i"), nbttagcompound5.getInt("t"), nbttagcompound5.getInt("p")); } } } diff --git a/src/main/java/net/minecraft/server/ConsoleLogFormatter.java b/src/main/java/net/minecraft/server/ConsoleLogFormatter.java index 6a58493c4e..60d26d589a 100644 --- a/src/main/java/net/minecraft/server/ConsoleLogFormatter.java +++ b/src/main/java/net/minecraft/server/ConsoleLogFormatter.java @@ -9,41 +9,32 @@ import java.util.logging.LogRecord; import java.util.regex.Pattern; // CraftBukkit -final class ConsoleLogFormatter extends Formatter { +class ConsoleLogFormatter extends Formatter { - private SimpleDateFormat a = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); - // CraftBukkit start - add color stripping, change constructor to take it + private SimpleDateFormat b; + + final ConsoleLogManager a; + // CraftBukkit start - add color stripping private Pattern pattern = Pattern.compile("\\x1B\\[([0-9]{1,2}(;[0-9]{1,2})?)?[m|K]"); private boolean strip = false; - - ConsoleLogFormatter(boolean strip) { - this.strip = strip; - } // CraftBukkit end + private ConsoleLogFormatter(ConsoleLogManager consolelogmanager) { + this.a = consolelogmanager; + this.b = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); + this.strip = MinecraftServer.getServer().options.has("log-strip-color"); // CraftBukkit + } + public String format(LogRecord logrecord) { StringBuilder stringbuilder = new StringBuilder(); - stringbuilder.append(this.a.format(Long.valueOf(logrecord.getMillis()))); - Level level = logrecord.getLevel(); - - if (level == Level.FINEST) { - stringbuilder.append(" [FINEST] "); - } else if (level == Level.FINER) { - stringbuilder.append(" [FINER] "); - } else if (level == Level.FINE) { - stringbuilder.append(" [FINE] "); - } else if (level == Level.INFO) { - stringbuilder.append(" [INFO] "); - } else if (level == Level.WARNING) { - stringbuilder.append(" [WARNING] "); - } else if (level == Level.SEVERE) { - stringbuilder.append(" [SEVERE] "); - } else { // CraftBukkit - stringbuilder.append(" [").append(level.getLocalizedName()).append("] "); + stringbuilder.append(this.b.format(Long.valueOf(logrecord.getMillis()))); + if (ConsoleLogManager.a(this.a) != null) { + stringbuilder.append(ConsoleLogManager.a(this.a)); } - stringbuilder.append(formatMessage(logrecord)); // CraftBukkit + stringbuilder.append(" [").append(logrecord.getLevel().getName()).append("] "); + stringbuilder.append(this.formatMessage(logrecord)); stringbuilder.append('\n'); Throwable throwable = logrecord.getThrown(); @@ -62,4 +53,8 @@ final class ConsoleLogFormatter extends Formatter { } // CraftBukkit end } + + ConsoleLogFormatter(ConsoleLogManager consolelogmanager, EmptyClass3 emptyclass3) { + this(consolelogmanager); + } } diff --git a/src/main/java/net/minecraft/server/ConsoleLogManager.java b/src/main/java/net/minecraft/server/ConsoleLogManager.java index 3301ec1f32..98f9a8b102 100644 --- a/src/main/java/net/minecraft/server/ConsoleLogManager.java +++ b/src/main/java/net/minecraft/server/ConsoleLogManager.java @@ -2,24 +2,50 @@ package net.minecraft.server; import java.util.logging.ConsoleHandler; import java.util.logging.FileHandler; +import java.util.logging.Handler; import java.util.logging.Level; import java.util.logging.Logger; import java.io.File; // CraftBukkit -public class ConsoleLogManager { +public class ConsoleLogManager implements IConsoleLogManager { - public static Logger a = Logger.getLogger("Minecraft"); + private final Logger a; + private final String b; + private final String c; + private final String d; public static Logger global = Logger.getLogger(""); // CraftBukkit - // CraftBukkit - change of method signature! - public static void init(MinecraftServer server) { - ConsoleLogFormatter consolelogformatter = new ConsoleLogFormatter(server.options.has("log-strip-color")); // CraftBukkit - pass strip color option + public ConsoleLogManager(String s, String s1, String s2) { + this.a = Logger.getLogger(s); + this.c = s; + this.d = s1; + this.b = s2; + this.b(); + } + + private void b() { + this.a.setUseParentHandlers(false); + Handler[] ahandler = this.a.getHandlers(); + int i = ahandler.length; + + for (int j = 0; j < i; ++j) { + Handler handler = ahandler[j]; + + this.a.removeHandler(handler); + } + + ConsoleLogFormatter consolelogformatter = new ConsoleLogFormatter(this, (EmptyClass3) null); - a.setUseParentHandlers(false); // CraftBukkit start + MinecraftServer server = MinecraftServer.getServer(); ConsoleHandler consolehandler = new org.bukkit.craftbukkit.util.TerminalConsoleHandler(server.reader); + // CraftBukkit end + consolehandler.setFormatter(consolelogformatter); + this.a.addHandler(consolehandler); + + // CraftBukkit start for (java.util.logging.Handler handler : global.getHandlers()) { global.removeHandler(handler); } @@ -28,8 +54,6 @@ public class ConsoleLogManager { global.addHandler(consolehandler); // CraftBukkit end - a.addHandler(consolehandler); - try { // CraftBukkit start String pattern = (String) server.options.valueOf("log-pattern"); @@ -49,26 +73,26 @@ public class ConsoleLogManager { parentPath = parent.getPath(); } - int i = 0; - while (i < parentPath.length()) { - char ch = parentPath.charAt(i); + int j = 0; + while (j < parentPath.length()) { + char ch = parentPath.charAt(j); char ch2 = 0; - if (i + 1 < parentPath.length()) { - ch2 = Character.toLowerCase(pattern.charAt(i + 1)); + if (j + 1 < parentPath.length()) { + ch2 = Character.toLowerCase(pattern.charAt(j + 1)); } if (ch == '%') { if (ch2 == 'h') { - i += 2; + j += 2; fixedPattern.append(homeDir); continue; } else if (ch2 == 't') { - i += 2; + j += 2; fixedPattern.append(tmpDir); continue; } else if (ch2 == '%') { // Even though we don't care about this we have to skip it to avoid matching %%t - i += 2; + j += 2; fixedPattern.append("%%"); continue; } else if (ch2 != 0) { @@ -77,7 +101,7 @@ public class ConsoleLogManager { } fixedPattern.append(ch); - i++; + j++; } // Try to create needed parent directories @@ -93,10 +117,42 @@ public class ConsoleLogManager { // CraftBukkit end filehandler.setFormatter(consolelogformatter); - a.addHandler(filehandler); + this.a.addHandler(filehandler); global.addHandler(filehandler); // CraftBukkit } catch (Exception exception) { - a.log(Level.WARNING, "Failed to log to server.log", exception); + this.a.log(Level.WARNING, "Failed to log " + this.c + " to " + this.b, exception); } } + + public Logger getLogger() { + return this.a; + } + + public void info(String s) { + this.a.log(Level.INFO, s); + } + + public void warning(String s) { + this.a.log(Level.WARNING, s); + } + + public void warning(String s, Object... aobject) { + this.a.log(Level.WARNING, s, aobject); + } + + public void warning(String s, Throwable throwable) { + this.a.log(Level.WARNING, s, throwable); + } + + public void severe(String s) { + this.a.log(Level.SEVERE, s); + } + + public void severe(String s, Throwable throwable) { + this.a.log(Level.SEVERE, s, throwable); + } + + static String a(ConsoleLogManager consolelogmanager) { + return consolelogmanager.d; + } } diff --git a/src/main/java/net/minecraft/server/Container.java b/src/main/java/net/minecraft/server/Container.java index 9ecefea0dc..96f281012d 100644 --- a/src/main/java/net/minecraft/server/Container.java +++ b/src/main/java/net/minecraft/server/Container.java @@ -2,6 +2,7 @@ package net.minecraft.server; import java.util.ArrayList; import java.util.HashSet; +import java.util.Iterator; import java.util.List; import java.util.Set; @@ -16,8 +17,11 @@ public abstract class Container { public List c = new ArrayList(); public int windowId = 0; private short a = 0; + private int f = -1; + private int g = 0; + private final Set h = new HashSet(); protected List listeners = new ArrayList(); - private Set f = new HashSet(); + private Set i = new HashSet(); // CraftBukkit start public boolean checkReachable = true; @@ -105,168 +109,276 @@ public abstract class Container { public ItemStack clickItem(int i, int j, int k, EntityHuman entityhuman) { ItemStack itemstack = null; PlayerInventory playerinventory = entityhuman.inventory; - Slot slot; - ItemStack itemstack1; int l; - ItemStack itemstack2; + ItemStack itemstack1; - if ((k == 0 || k == 1) && (j == 0 || j == 1)) { - if (i == -999) { - if (playerinventory.getCarried() != null && i == -999) { - if (j == 0) { - entityhuman.drop(playerinventory.getCarried()); - playerinventory.setCarried((ItemStack) null); + if (k == 5) { + int i1 = this.g; + + this.g = c(j); + if ((i1 != 1 || this.g != 2) && i1 != this.g) { + this.d(); + } else if (playerinventory.getCarried() == null) { + this.d(); + } else if (this.g == 0) { + this.f = b(j); + if (d(this.f)) { + this.g = 1; + this.h.clear(); + } else { + this.d(); + } + } else if (this.g == 1) { + Slot slot = (Slot) this.c.get(i); + + if (slot != null && a(slot, playerinventory.getCarried(), true) && slot.isAllowed(playerinventory.getCarried()) && playerinventory.getCarried().count > this.h.size() && this.b(slot)) { + this.h.add(slot); + } + } else if (this.g == 2) { + if (!this.h.isEmpty()) { + itemstack1 = playerinventory.getCarried().cloneItemStack(); + l = playerinventory.getCarried().count; + Iterator iterator = this.h.iterator(); + + while (iterator.hasNext()) { + Slot slot1 = (Slot) iterator.next(); + + 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; + + a(this.h, this.f, itemstack2, j1); + if (itemstack2.count > itemstack2.getMaxStackSize()) { + itemstack2.count = itemstack2.getMaxStackSize(); + } + + if (itemstack2.count > slot1.a()) { + itemstack2.count = slot1.a(); + } + + l -= itemstack2.count - j1; + slot1.set(itemstack2); + } } - if (j == 1) { - // CraftBukkit start - store a reference - ItemStack itemstack3 = playerinventory.getCarried(); - if (itemstack3.count > 0) { - entityhuman.drop(itemstack3.a(1)); - } + itemstack1.count = l; + if (itemstack1.count <= 0) { + itemstack1 = null; + } - if (itemstack3.count == 0) { - // CraftBukkit end + playerinventory.setCarried(itemstack1); + } + + this.d(); + } else { + this.d(); + } + } else if (this.g != 0) { + this.d(); + } else { + Slot slot2; + int k1; + ItemStack itemstack3; + + if ((k == 0 || k == 1) && (j == 0 || j == 1)) { + if (i == -999) { + if (playerinventory.getCarried() != null && i == -999) { + if (j == 0) { + entityhuman.drop(playerinventory.getCarried()); playerinventory.setCarried((ItemStack) null); } - } - } - } else if (k == 1) { - slot = (Slot) this.c.get(i); - if (slot != null && slot.a(entityhuman)) { - itemstack1 = this.b(entityhuman, i); - if (itemstack1 != null) { - int i1 = itemstack1.id; - itemstack = itemstack1.cloneItemStack(); - if (slot != null && slot.getItem() != null && slot.getItem().id == i1) { - this.a(i, j, true, entityhuman); - } - } - } - } else { - if (i < 0) { - return null; - } - - slot = (Slot) this.c.get(i); - if (slot != null) { - itemstack1 = slot.getItem(); - ItemStack itemstack3 = playerinventory.getCarried(); - - if (itemstack1 != null) { - itemstack = itemstack1.cloneItemStack(); - } - - if (itemstack1 == null) { - if (itemstack3 != null && slot.isAllowed(itemstack3)) { - l = j == 0 ? itemstack3.count : 1; - if (l > slot.a()) { - l = slot.a(); + if (j == 1) { + // CraftBukkit start - store a reference + ItemStack itemstack4 = playerinventory.getCarried(); + if (itemstack4.count > 0) { + entityhuman.drop(itemstack4.a(1)); } - // CraftBukkit start - if (itemstack3.count >= l) { - slot.set(itemstack3.a(l)); - } - // CraftBukkit end - - if (itemstack3.count == 0) { + if (itemstack4.count == 0) { + // CraftBukkit end playerinventory.setCarried((ItemStack) null); } } - } else if (slot.a(entityhuman)) { - if (itemstack3 == null) { - l = j == 0 ? itemstack1.count : (itemstack1.count + 1) / 2; - itemstack2 = slot.a(l); - playerinventory.setCarried(itemstack2); - if (itemstack1.count == 0) { - slot.set((ItemStack) null); + } + } else if (k == 1) { + if (i < 0) { + return null; + } + + slot2 = (Slot) this.c.get(i); + if (slot2 != null && slot2.a(entityhuman)) { + itemstack1 = this.b(entityhuman, i); + if (itemstack1 != null) { + l = itemstack1.id; + itemstack = itemstack1.cloneItemStack(); + if (slot2 != null && slot2.getItem() != null && slot2.getItem().id == l) { + this.a(i, j, true, entityhuman); } + } + } + } else { + if (i < 0) { + return null; + } - slot.a(entityhuman, playerinventory.getCarried()); - } else if (slot.isAllowed(itemstack3)) { - if (itemstack1.id == itemstack3.id && itemstack1.getData() == itemstack3.getData() && ItemStack.equals(itemstack1, itemstack3)) { - l = j == 0 ? itemstack3.count : 1; - if (l > slot.a() - itemstack1.count) { - l = slot.a() - itemstack1.count; + slot2 = (Slot) this.c.get(i); + if (slot2 != null) { + itemstack1 = slot2.getItem(); + ItemStack itemstack4 = playerinventory.getCarried(); + + if (itemstack1 != null) { + itemstack = itemstack1.cloneItemStack(); + } + + if (itemstack1 == null) { + if (itemstack4 != null && slot2.isAllowed(itemstack4)) { + k1 = j == 0 ? itemstack4.count : 1; + if (k1 > slot2.a()) { + k1 = slot2.a(); } - if (l > itemstack3.getMaxStackSize() - itemstack1.count) { - l = itemstack3.getMaxStackSize() - itemstack1.count; + // CraftBukkit start + if (itemstack4.count >= k1) { + slot2.set(itemstack4.a(k1)); } + // CraftBukkit end - itemstack3.a(l); - if (itemstack3.count == 0) { + if (itemstack4.count == 0) { playerinventory.setCarried((ItemStack) null); } - - itemstack1.count += l; - } else if (itemstack3.count <= slot.a()) { - slot.set(itemstack3); - playerinventory.setCarried(itemstack1); } - } else if (itemstack1.id == itemstack3.id && itemstack3.getMaxStackSize() > 1 && (!itemstack1.usesData() || itemstack1.getData() == itemstack3.getData()) && ItemStack.equals(itemstack1, itemstack3)) { - l = itemstack1.count; - if (l > 0 && l + itemstack3.count <= itemstack3.getMaxStackSize()) { - itemstack3.count += l; - itemstack1 = slot.a(l); + } else if (slot2.a(entityhuman)) { + if (itemstack4 == null) { + k1 = j == 0 ? itemstack1.count : (itemstack1.count + 1) / 2; + itemstack3 = slot2.a(k1); + playerinventory.setCarried(itemstack3); if (itemstack1.count == 0) { - slot.set((ItemStack) null); + slot2.set((ItemStack) null); } - slot.a(entityhuman, playerinventory.getCarried()); + slot2.a(entityhuman, playerinventory.getCarried()); + } else if (slot2.isAllowed(itemstack4)) { + if (itemstack1.id == itemstack4.id && itemstack1.getData() == itemstack4.getData() && ItemStack.equals(itemstack1, itemstack4)) { + k1 = j == 0 ? itemstack4.count : 1; + if (k1 > slot2.a() - itemstack1.count) { + k1 = slot2.a() - itemstack1.count; + } + + if (k1 > itemstack4.getMaxStackSize() - itemstack1.count) { + k1 = itemstack4.getMaxStackSize() - itemstack1.count; + } + + itemstack4.a(k1); + if (itemstack4.count == 0) { + playerinventory.setCarried((ItemStack) null); + } + + itemstack1.count += k1; + } else if (itemstack4.count <= slot2.a()) { + slot2.set(itemstack4); + playerinventory.setCarried(itemstack1); + } + } else if (itemstack1.id == itemstack4.id && itemstack4.getMaxStackSize() > 1 && (!itemstack1.usesData() || itemstack1.getData() == itemstack4.getData()) && ItemStack.equals(itemstack1, itemstack4)) { + k1 = itemstack1.count; + if (k1 > 0 && k1 + itemstack4.count <= itemstack4.getMaxStackSize()) { + itemstack4.count += k1; + itemstack1 = slot2.a(k1); + if (itemstack1.count == 0) { + slot2.set((ItemStack) null); + } + + slot2.a(entityhuman, playerinventory.getCarried()); + } + } + } + + slot2.e(); + } + } + } else if (k == 2 && j >= 0 && j < 9) { + slot2 = (Slot) this.c.get(i); + if (slot2.a(entityhuman)) { + itemstack1 = playerinventory.getItem(j); + boolean flag = itemstack1 == null || slot2.inventory == playerinventory && slot2.isAllowed(itemstack1); + + k1 = -1; + if (!flag) { + k1 = playerinventory.j(); + flag |= k1 > -1; + } + + if (slot2.d() && flag) { + itemstack3 = slot2.getItem(); + playerinventory.setItem(j, itemstack3); + if ((slot2.inventory != playerinventory || !slot2.isAllowed(itemstack1)) && itemstack1 != null) { + if (k1 > -1) { + playerinventory.pickup(itemstack1); + slot2.a(itemstack3.count); + slot2.set((ItemStack) null); + slot2.a(entityhuman, itemstack3); + } + } else { + slot2.a(itemstack3.count); + slot2.set(itemstack1); + slot2.a(entityhuman, itemstack3); + } + } else if (!slot2.d() && 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()) { + 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()) { + itemstack1 = slot2.a(j == 0 ? 1 : slot2.getItem().count); + slot2.a(entityhuman, itemstack1); + entityhuman.drop(itemstack1); + } + } 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))) { + l = j == 0 ? 0 : this.c.size() - 1; + k1 = j == 0 ? 1 : -1; + + for (int l1 = 0; l1 < 2; ++l1) { + 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())) { + int j2 = Math.min(itemstack1.getMaxStackSize() - itemstack1.count, slot3.getItem().count); + ItemStack itemstack5 = slot3.a(j2); + + itemstack1.count += j2; + if (itemstack5.count <= 0) { + slot3.set((ItemStack) null); + } + + slot3.a(entityhuman, itemstack5); } } } - - slot.e(); - } - } - } else if (k == 2 && j >= 0 && j < 9) { - slot = (Slot) this.c.get(i); - if (slot.a(entityhuman)) { - itemstack1 = playerinventory.getItem(j); - boolean flag = itemstack1 == null || slot.inventory == playerinventory && slot.isAllowed(itemstack1); - - l = -1; - if (!flag) { - l = playerinventory.i(); - flag |= l > -1; } - if (slot.d() && flag) { - itemstack2 = slot.getItem(); - playerinventory.setItem(j, itemstack2); - if ((slot.inventory != playerinventory || !slot.isAllowed(itemstack1)) && itemstack1 != null) { - if (l > -1) { - playerinventory.pickup(itemstack1); - slot.a(itemstack2.count); - slot.set((ItemStack) null); - slot.a(entityhuman, itemstack2); - } - } else { - slot.a(itemstack2.count); - slot.set(itemstack1); - slot.a(entityhuman, itemstack2); - } - } else if (!slot.d() && itemstack1 != null && slot.isAllowed(itemstack1)) { - playerinventory.setItem(j, (ItemStack) null); - slot.set(itemstack1); - } - } - } else if (k == 3 && entityhuman.abilities.canInstantlyBuild && playerinventory.getCarried() == null && i >= 0) { - slot = (Slot) this.c.get(i); - if (slot != null && slot.d()) { - itemstack1 = slot.getItem().cloneItemStack(); - itemstack1.count = itemstack1.getMaxStackSize(); - playerinventory.setCarried(itemstack1); + this.b(); } } return itemstack; } + public boolean a(ItemStack itemstack, Slot slot) { + return true; + } + protected void a(int i, int j, boolean flag, EntityHuman entityhuman) { this.clickItem(i, j, 1, entityhuman); } @@ -289,14 +401,14 @@ public abstract class Container { } public boolean c(EntityHuman entityhuman) { - return !this.f.contains(entityhuman); + return !this.i.contains(entityhuman); } public void a(EntityHuman entityhuman, boolean flag) { if (flag) { - this.f.remove(entityhuman); + this.i.remove(entityhuman); } else { - this.f.add(entityhuman); + this.i.add(entityhuman); } } @@ -369,4 +481,71 @@ public abstract class Container { return flag1; } + + public static int b(int i) { + return i >> 2 & 3; + } + + public static int c(int i) { + return i & 3; + } + + public static boolean d(int i) { + return i == 0 || i == 1; + } + + protected void d() { + this.g = 0; + this.h.clear(); + } + + public static boolean a(Slot slot, ItemStack itemstack, boolean flag) { + boolean flag1 = slot == null || !slot.d(); + + if (slot != null && slot.d() && itemstack != null && itemstack.doMaterialsMatch(slot.getItem()) && ItemStack.equals(slot.getItem(), itemstack)) { + int i = flag ? 0 : itemstack.count; + + flag1 |= slot.getItem().count + i <= itemstack.getMaxStackSize(); + } + + return flag1; + } + + public static void a(Set set, int i, ItemStack itemstack, int j) { + switch (i) { + case 0: + itemstack.count = MathHelper.d((float) itemstack.count / (float) set.size()); + break; + + case 1: + itemstack.count = 1; + } + + itemstack.count += j; + } + + public boolean b(Slot slot) { + return true; + } + + public static int b(IInventory iinventory) { + if (iinventory == null) { + return 0; + } else { + int i = 0; + float f = 0.0F; + + for (int j = 0; j < iinventory.getSize(); ++j) { + ItemStack itemstack = iinventory.getItem(j); + + if (itemstack != null) { + f += (float) itemstack.count / (float) Math.min(iinventory.getMaxStackSize(), itemstack.getMaxStackSize()); + ++i; + } + } + + f /= (float) iinventory.getSize(); + return MathHelper.d(f * 14.0F) + (i > 0 ? 1 : 0); + } + } } diff --git a/src/main/java/net/minecraft/server/ContainerAnvil.java b/src/main/java/net/minecraft/server/ContainerAnvil.java index 328db44cd3..fbf76421ad 100644 --- a/src/main/java/net/minecraft/server/ContainerAnvil.java +++ b/src/main/java/net/minecraft/server/ContainerAnvil.java @@ -12,7 +12,7 @@ import org.bukkit.craftbukkit.inventory.CraftInventoryView; public class ContainerAnvil extends Container { private IInventory f = new InventoryCraftResult(); - private IInventory g = new ContainerAnvilInventory(this, "Repair", 2); + private IInventory g = new ContainerAnvilInventory(this, "Repair", true, 2); private World h; private int i; private int j; @@ -53,11 +53,11 @@ public class ContainerAnvil extends Container { public void a(IInventory iinventory) { super.a(iinventory); if (iinventory == this.g) { - this.d(); + this.e(); } } - public void d() { + public void e() { ItemStack itemstack = this.g.getItem(0); this.a = 0; @@ -86,8 +86,8 @@ public class ContainerAnvil extends Container { if (itemstack2 != null) { flag = itemstack2.id == Item.ENCHANTED_BOOK.id && Item.ENCHANTED_BOOK.g(itemstack2).size() > 0; - if (itemstack1.f() && Item.byId[itemstack1.id].a(itemstack, itemstack2)) { - l = Math.min(itemstack1.i(), itemstack1.k() / 4); + if (itemstack1.g() && Item.byId[itemstack1.id].a(itemstack, itemstack2)) { + l = Math.min(itemstack1.j(), itemstack1.l() / 4); if (l <= 0) { this.f.setItem(0, (ItemStack) null); this.a = 0; @@ -95,27 +95,27 @@ public class ContainerAnvil extends Container { } for (i1 = 0; l > 0 && i1 < itemstack2.count; ++i1) { - j1 = itemstack1.i() - l; + j1 = itemstack1.j() - l; itemstack1.setData(j1); i += Math.max(1, l / 100) + map.size(); - l = Math.min(itemstack1.i(), itemstack1.k() / 4); + l = Math.min(itemstack1.j(), itemstack1.l() / 4); } this.l = i1; } else { - if (!flag && (itemstack1.id != itemstack2.id || !itemstack1.f())) { + if (!flag && (itemstack1.id != itemstack2.id || !itemstack1.g())) { this.f.setItem(0, (ItemStack) null); this.a = 0; return; } - if (itemstack1.f() && !flag) { - l = itemstack.k() - itemstack.i(); - i1 = itemstack2.k() - itemstack2.i(); - j1 = i1 + itemstack1.k() * 12 / 100; + if (itemstack1.g() && !flag) { + l = itemstack.l() - itemstack.j(); + i1 = itemstack2.l() - itemstack2.j(); + j1 = i1 + itemstack1.l() * 12 / 100; int i2 = l + j1; - k1 = itemstack1.k() - i2; + k1 = itemstack1.l() - i2; if (k1 < 0) { k1 = 0; } @@ -206,10 +206,10 @@ public class ContainerAnvil extends Container { } } - if (this.m != null && !this.m.equalsIgnoreCase(itemstack.r()) && this.m.length() > 0) { - j = itemstack.f() ? 7 : itemstack.count * 5; + if (this.m != null && !this.m.equalsIgnoreCase(itemstack.getName()) && this.m.length() > 0) { + j = itemstack.g() ? 7 : itemstack.count * 5; i += j; - if (itemstack.s()) { + if (itemstack.hasName()) { k += j / 2; } @@ -264,7 +264,7 @@ public class ContainerAnvil extends Container { } if (j == i && j > 0 && this.a >= 40) { - //System.out.println("Naming an item only, cost too high; giving discount to cap cost to 39 levels"); // CraftBukkit -remove debug + // 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; } @@ -278,7 +278,7 @@ public class ContainerAnvil extends Container { i1 = itemstack2.getRepairCost(); } - if (itemstack1.s()) { + if (itemstack1.hasName()) { i1 -= 9; } @@ -363,7 +363,7 @@ public class ContainerAnvil extends Container { this.getSlot(2).getItem().c(this.m); } - this.d(); + this.e(); } static IInventory a(ContainerAnvil containeranvil) { diff --git a/src/main/java/net/minecraft/server/ContainerAnvilInventory.java b/src/main/java/net/minecraft/server/ContainerAnvilInventory.java index 6a24bca33e..465d6c8c5b 100644 --- a/src/main/java/net/minecraft/server/ContainerAnvilInventory.java +++ b/src/main/java/net/minecraft/server/ContainerAnvilInventory.java @@ -40,8 +40,8 @@ public class ContainerAnvilInventory extends InventorySubcontainer { // CraftBuk } // CraftBukkit end - ContainerAnvilInventory(ContainerAnvil containeranvil, String s, int i) { - super(s, i); + ContainerAnvilInventory(ContainerAnvil containeranvil, String s, boolean flag, int i) { + super(s, flag, i); this.a = containeranvil; this.setMaxStackSize(1); // CraftBukkit } @@ -50,4 +50,8 @@ public class ContainerAnvilInventory extends InventorySubcontainer { // CraftBuk super.update(); this.a.a((IInventory) this); } + + public boolean b(int i, ItemStack itemstack) { + return true; + } } diff --git a/src/main/java/net/minecraft/server/ContainerBeacon.java b/src/main/java/net/minecraft/server/ContainerBeacon.java index e0751630b5..814327cf10 100644 --- a/src/main/java/net/minecraft/server/ContainerBeacon.java +++ b/src/main/java/net/minecraft/server/ContainerBeacon.java @@ -37,9 +37,9 @@ public class ContainerBeacon extends Container { this.a(new Slot(playerinventory, i, b0 + i * 18, 58 + short1)); } - this.g = tileentitybeacon.k(); - this.h = tileentitybeacon.i(); - this.i = tileentitybeacon.j(); + this.g = tileentitybeacon.l(); + this.h = tileentitybeacon.j(); + this.i = tileentitybeacon.k(); } public void addSlotListener(ICrafting icrafting) { @@ -53,13 +53,13 @@ public class ContainerBeacon extends Container { super.b(); } - public TileEntityBeacon d() { + public TileEntityBeacon e() { return this.a; } public boolean a(EntityHuman entityhuman) { if (!this.checkReachable) return true; // CraftBukkit - return this.a.a_(entityhuman); + return this.a.a(entityhuman); } public ItemStack b(EntityHuman entityhuman, int i) { diff --git a/src/main/java/net/minecraft/server/ContainerBrewingStand.java b/src/main/java/net/minecraft/server/ContainerBrewingStand.java index 3411dbbc9e..b796ffdbd5 100644 --- a/src/main/java/net/minecraft/server/ContainerBrewingStand.java +++ b/src/main/java/net/minecraft/server/ContainerBrewingStand.java @@ -57,7 +57,7 @@ public class ContainerBrewingStand extends Container { public boolean a(EntityHuman entityhuman) { if (!this.checkReachable) return true; // CraftBukkit - return this.brewingStand.a_(entityhuman); + return this.brewingStand.a(entityhuman); } public ItemStack b(EntityHuman entityhuman, int i) { diff --git a/src/main/java/net/minecraft/server/ContainerChest.java b/src/main/java/net/minecraft/server/ContainerChest.java index b36d9325af..1ea3d22fb2 100644 --- a/src/main/java/net/minecraft/server/ContainerChest.java +++ b/src/main/java/net/minecraft/server/ContainerChest.java @@ -64,7 +64,7 @@ public class ContainerChest extends Container { public boolean a(EntityHuman entityhuman) { if (!this.checkReachable) return true; // CraftBukkit - return this.container.a_(entityhuman); + return this.container.a(entityhuman); } public ItemStack b(EntityHuman entityhuman, int i) { @@ -95,10 +95,10 @@ public class ContainerChest extends Container { public void b(EntityHuman entityhuman) { super.b(entityhuman); - this.container.f(); + this.container.g(); } - public IInventory d() { + public IInventory e() { return this.container; } } diff --git a/src/main/java/net/minecraft/server/ContainerDispenser.java b/src/main/java/net/minecraft/server/ContainerDispenser.java index f4c093b056..594477c114 100644 --- a/src/main/java/net/minecraft/server/ContainerDispenser.java +++ b/src/main/java/net/minecraft/server/ContainerDispenser.java @@ -42,7 +42,7 @@ public class ContainerDispenser extends Container { public boolean a(EntityHuman entityhuman) { if (!this.checkReachable) return true; // CraftBukkit - return this.items.a_(entityhuman); + return this.items.a(entityhuman); } public ItemStack b(EntityHuman entityhuman, int i) { diff --git a/src/main/java/net/minecraft/server/ContainerEnchantTable.java b/src/main/java/net/minecraft/server/ContainerEnchantTable.java index 6819a60643..02d861e0bb 100644 --- a/src/main/java/net/minecraft/server/ContainerEnchantTable.java +++ b/src/main/java/net/minecraft/server/ContainerEnchantTable.java @@ -17,7 +17,7 @@ import org.bukkit.entity.Player; public class ContainerEnchantTable extends Container { // CraftBukkit - make type specific (changed from IInventory) - public ContainerEnchantTableInventory enchantSlots = new ContainerEnchantTableInventory(this, "Enchant", 1); + public ContainerEnchantTableInventory enchantSlots = new ContainerEnchantTableInventory(this, "Enchant", true, 1); private World world; private int x; private int y; @@ -79,7 +79,7 @@ public class ContainerEnchantTable extends Container { ItemStack itemstack = iinventory.getItem(0); int i; - if (itemstack != null && itemstack.v()) { + if (itemstack != null && itemstack.w()) { this.f = this.l.nextLong(); if (!this.world.isStatic) { i = 0; diff --git a/src/main/java/net/minecraft/server/ContainerEnchantTableInventory.java b/src/main/java/net/minecraft/server/ContainerEnchantTableInventory.java index 0075cb16c9..c279eb3f09 100644 --- a/src/main/java/net/minecraft/server/ContainerEnchantTableInventory.java +++ b/src/main/java/net/minecraft/server/ContainerEnchantTableInventory.java @@ -40,8 +40,8 @@ public class ContainerEnchantTableInventory extends InventorySubcontainer { // C } // CraftBukkit end - ContainerEnchantTableInventory(ContainerEnchantTable containerenchanttable, String s, int i) { - super(s, i); + ContainerEnchantTableInventory(ContainerEnchantTable containerenchanttable, String s, boolean flag, int i) { + super(s, flag, i); this.enchantTable = containerenchanttable; this.setMaxStackSize(1); // CraftBukkit } @@ -54,4 +54,8 @@ public class ContainerEnchantTableInventory extends InventorySubcontainer { // C super.update(); this.enchantTable.a((IInventory) this); } + + public boolean b(int i, ItemStack itemstack) { + return true; + } } diff --git a/src/main/java/net/minecraft/server/ContainerFurnace.java b/src/main/java/net/minecraft/server/ContainerFurnace.java index d8f497b189..5b744d9a74 100644 --- a/src/main/java/net/minecraft/server/ContainerFurnace.java +++ b/src/main/java/net/minecraft/server/ContainerFurnace.java @@ -80,7 +80,7 @@ public class ContainerFurnace extends Container { public boolean a(EntityHuman entityhuman) { if (!this.checkReachable) return true; // CraftBukkit - return this.furnace.a_(entityhuman); + return this.furnace.a(entityhuman); } public ItemStack b(EntityHuman entityhuman, int i) { diff --git a/src/main/java/net/minecraft/server/ContainerHopper.java b/src/main/java/net/minecraft/server/ContainerHopper.java new file mode 100644 index 0000000000..83b95d1387 --- /dev/null +++ b/src/main/java/net/minecraft/server/ContainerHopper.java @@ -0,0 +1,85 @@ +package net.minecraft.server; + +// CraftBukkit start +import org.bukkit.craftbukkit.inventory.CraftInventory; +import org.bukkit.craftbukkit.inventory.CraftInventoryView; +// CraftBukkit end + +public class ContainerHopper extends Container { + + private final IInventory a; + + // CraftBukkit start + private CraftInventoryView bukkitEntity = null; + private PlayerInventory player; + + public CraftInventoryView getBukkitView() { + if (bukkitEntity != null) { + return bukkitEntity; + } + + CraftInventory inventory = new CraftInventory(this.a); // Should be this.hopper + bukkitEntity = new CraftInventoryView(this.player.player.getBukkitEntity(), inventory, this); + return bukkitEntity; + } + // CraftBukkit end + + public ContainerHopper(PlayerInventory playerinventory, IInventory iinventory) { + this.a = iinventory; + this.player = playerinventory; // CraftBukkit - save player + iinventory.startOpen(); + byte b0 = 51; + + int i; + + for (i = 0; i < iinventory.getSize(); ++i) { + this.a(new Slot(iinventory, i, 44 + i * 18, 20)); + } + + for (i = 0; i < 3; ++i) { + for (int j = 0; j < 9; ++j) { + this.a(new Slot(playerinventory, j + i * 9 + 9, 8 + j * 18, i * 18 + b0)); + } + } + + for (i = 0; i < 9; ++i) { + this.a(new Slot(playerinventory, i, 8 + i * 18, 58 + b0)); + } + } + + public boolean a(EntityHuman entityhuman) { + if (!this.checkReachable) return true; // CraftBukkit + return this.a.a(entityhuman); + } + + public ItemStack b(EntityHuman entityhuman, int i) { + ItemStack itemstack = null; + Slot slot = (Slot) this.c.get(i); + + if (slot != null && slot.d()) { + 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.a(itemstack1, 0, this.a.getSize(), false)) { + return null; + } + + if (itemstack1.count == 0) { + slot.set((ItemStack) null); + } else { + slot.e(); + } + } + + 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 0b97cf8be8..2f2567807d 100644 --- a/src/main/java/net/minecraft/server/ContainerMerchant.java +++ b/src/main/java/net/minecraft/server/ContainerMerchant.java @@ -56,11 +56,11 @@ public class ContainerMerchant extends Container { } public void a(IInventory iinventory) { - this.f.g(); + this.f.h(); super.a(iinventory); } - public void b(int i) { + public void e(int i) { this.f.c(i); } @@ -112,7 +112,7 @@ public class ContainerMerchant extends Container { public void b(EntityHuman entityhuman) { super.b(entityhuman); - this.merchant.b_((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 5c850f8b60..d230ce7624 100644 --- a/src/main/java/net/minecraft/server/ContainerPlayer.java +++ b/src/main/java/net/minecraft/server/ContainerPlayer.java @@ -105,8 +105,8 @@ 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()).a)).d()) { - int j = 5 + ((ItemArmor) itemstack.getItem()).a; + } else if (itemstack.getItem() instanceof ItemArmor && !((Slot) this.c.get(5 + ((ItemArmor) itemstack.getItem()).b)).d()) { + int j = 5 + ((ItemArmor) itemstack.getItem()).b; if (!this.a(itemstack1, j, j + 1, false)) { return null; @@ -139,6 +139,10 @@ public class ContainerPlayer extends Container { return itemstack; } + public boolean a(ItemStack itemstack, Slot slot) { + return slot.inventory != this.resultInventory && super.a(itemstack, slot); + } + // CraftBukkit start public CraftInventoryView getBukkitView() { if (bukkitEntity != null) { diff --git a/src/main/java/net/minecraft/server/ContainerWorkbench.java b/src/main/java/net/minecraft/server/ContainerWorkbench.java index eb2fe72a5a..2436d08105 100644 --- a/src/main/java/net/minecraft/server/ContainerWorkbench.java +++ b/src/main/java/net/minecraft/server/ContainerWorkbench.java @@ -127,6 +127,10 @@ public class ContainerWorkbench extends Container { return itemstack; } + public boolean a(ItemStack itemstack, Slot slot) { + return slot.inventory != this.resultInventory && super.a(itemstack, slot); + } + // CraftBukkit start public CraftInventoryView getBukkitView() { if (bukkitEntity != null) { diff --git a/src/main/java/net/minecraft/server/ControllerLook.java b/src/main/java/net/minecraft/server/ControllerLook.java index bed36954a5..bd297b388d 100644 --- a/src/main/java/net/minecraft/server/ControllerLook.java +++ b/src/main/java/net/minecraft/server/ControllerLook.java @@ -53,20 +53,20 @@ public class ControllerLook { // CraftBukkit end this.a.pitch = this.a(this.a.pitch, f1, this.c); - this.a.az = this.a(this.a.az, f, this.b); + this.a.aA = this.a(this.a.aA, f, this.b); } else { - this.a.az = this.a(this.a.az, this.a.ax, 10.0F); + this.a.aA = this.a(this.a.aA, this.a.ax, 10.0F); } - float f2 = MathHelper.g(this.a.az - this.a.ax); + float f2 = MathHelper.g(this.a.aA - this.a.ay); if (!this.a.getNavigation().f()) { if (f2 < -75.0F) { - this.a.az = this.a.ax - 75.0F; + this.a.aA = this.a.ay - 75.0F; } if (f2 > 75.0F) { - this.a.az = this.a.ax + 75.0F; + this.a.aA = this.a.ay + 75.0F; } } } diff --git a/src/main/java/net/minecraft/server/ControllerMove.java b/src/main/java/net/minecraft/server/ControllerMove.java index 4fbaaffb92..1b66c9705d 100644 --- a/src/main/java/net/minecraft/server/ControllerMove.java +++ b/src/main/java/net/minecraft/server/ControllerMove.java @@ -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.bB()); + this.a.e(this.e * this.a.bE()); 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 e33bc55e5c..ff81d366c8 100644 --- a/src/main/java/net/minecraft/server/CraftingManager.java +++ b/src/main/java/net/minecraft/server/CraftingManager.java @@ -45,9 +45,11 @@ public class CraftingManager { 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}); + this.registerShapedRecipe(new ItemStack(Block.SNOW, 6), new Object[] { "###", Character.valueOf('#'), Block.SNOW_BLOCK}); this.registerShapedRecipe(new ItemStack(Block.CLAY, 1), new Object[] { "##", "##", Character.valueOf('#'), Item.CLAY_BALL}); this.registerShapedRecipe(new ItemStack(Block.BRICK, 1), new Object[] { "##", "##", Character.valueOf('#'), Item.CLAY_BRICK}); this.registerShapedRecipe(new ItemStack(Block.GLOWSTONE, 1), new Object[] { "##", "##", Character.valueOf('#'), Item.GLOWSTONE_DUST}); + this.registerShapedRecipe(new ItemStack(Block.QUARTZ_BLOCK, 1), new Object[] { "##", "##", Character.valueOf('#'), Item.QUARTZ}); this.registerShapedRecipe(new ItemStack(Block.WOOL, 1), new Object[] { "##", "##", Character.valueOf('#'), Item.STRING}); this.registerShapedRecipe(new ItemStack(Block.TNT, 1), new Object[] { "X#X", "#X#", "X#X", Character.valueOf('X'), Item.SULPHUR, Character.valueOf('#'), Block.SAND}); this.registerShapedRecipe(new ItemStack(Block.STEP, 6, 3), new Object[] { "###", Character.valueOf('#'), Block.COBBLESTONE}); @@ -56,6 +58,7 @@ public class CraftingManager { this.registerShapedRecipe(new ItemStack(Block.STEP, 6, 4), new Object[] { "###", Character.valueOf('#'), Block.BRICK}); this.registerShapedRecipe(new ItemStack(Block.STEP, 6, 5), new Object[] { "###", Character.valueOf('#'), Block.SMOOTH_BRICK}); this.registerShapedRecipe(new ItemStack(Block.STEP, 6, 6), new Object[] { "###", Character.valueOf('#'), Block.NETHER_BRICK}); + this.registerShapedRecipe(new ItemStack(Block.STEP, 6, 7), new Object[] { "###", Character.valueOf('#'), Block.QUARTZ_BLOCK}); this.registerShapedRecipe(new ItemStack(Block.WOOD_STEP, 6, 0), new Object[] { "###", Character.valueOf('#'), new ItemStack(Block.WOOD, 1, 0)}); this.registerShapedRecipe(new ItemStack(Block.WOOD_STEP, 6, 2), new Object[] { "###", Character.valueOf('#'), new ItemStack(Block.WOOD, 1, 2)}); this.registerShapedRecipe(new ItemStack(Block.WOOD_STEP, 6, 1), new Object[] { "###", Character.valueOf('#'), new ItemStack(Block.WOOD, 1, 1)}); @@ -78,6 +81,7 @@ public class CraftingManager { this.registerShapedRecipe(new ItemStack(Item.GLASS_BOTTLE, 3), new Object[] { "# #", " # ", Character.valueOf('#'), Block.GLASS}); this.registerShapedRecipe(new ItemStack(Block.RAILS, 16), new Object[] { "X X", "X#X", "X X", Character.valueOf('X'), Item.IRON_INGOT, Character.valueOf('#'), Item.STICK}); this.registerShapedRecipe(new ItemStack(Block.GOLDEN_RAIL, 6), new Object[] { "X X", "X#X", "XRX", Character.valueOf('X'), Item.GOLD_INGOT, Character.valueOf('R'), Item.REDSTONE, Character.valueOf('#'), Item.STICK}); + this.registerShapedRecipe(new ItemStack(Block.ACTIVATOR_RAIL, 6), new Object[] { "XSX", "X#X", "XSX", Character.valueOf('X'), Item.IRON_INGOT, Character.valueOf('#'), Block.REDSTONE_TORCH_ON, Character.valueOf('S'), Item.STICK}); this.registerShapedRecipe(new ItemStack(Block.DETECTOR_RAIL, 6), new Object[] { "X X", "X#X", "XRX", Character.valueOf('X'), Item.IRON_INGOT, Character.valueOf('R'), Item.REDSTONE, Character.valueOf('#'), Block.STONE_PLATE}); this.registerShapedRecipe(new ItemStack(Item.MINECART, 1), new Object[] { "# #", "###", Character.valueOf('#'), Item.IRON_INGOT}); this.registerShapedRecipe(new ItemStack(Item.CAULDRON, 1), new Object[] { "# #", "# #", "###", Character.valueOf('#'), Item.IRON_INGOT}); @@ -85,6 +89,8 @@ public class CraftingManager { this.registerShapedRecipe(new ItemStack(Block.JACK_O_LANTERN, 1), new Object[] { "A", "B", Character.valueOf('A'), Block.PUMPKIN, Character.valueOf('B'), Block.TORCH}); this.registerShapedRecipe(new ItemStack(Item.STORAGE_MINECART, 1), new Object[] { "A", "B", Character.valueOf('A'), Block.CHEST, Character.valueOf('B'), Item.MINECART}); this.registerShapedRecipe(new ItemStack(Item.POWERED_MINECART, 1), new Object[] { "A", "B", Character.valueOf('A'), Block.FURNACE, Character.valueOf('B'), Item.MINECART}); + this.registerShapedRecipe(new ItemStack(Item.MINECART_TNT, 1), new Object[] { "A", "B", Character.valueOf('A'), Block.TNT, Character.valueOf('B'), Item.MINECART}); + this.registerShapedRecipe(new ItemStack(Item.MINECART_HOPPER, 1), new Object[] { "A", "B", Character.valueOf('A'), Block.HOPPER, Character.valueOf('B'), Item.MINECART}); this.registerShapedRecipe(new ItemStack(Item.BOAT, 1), new Object[] { "# #", "###", Character.valueOf('#'), Block.WOOD}); this.registerShapedRecipe(new ItemStack(Item.BUCKET, 1), new Object[] { "# #", " # ", Character.valueOf('#'), Item.IRON_INGOT}); this.registerShapedRecipe(new ItemStack(Item.FLOWER_POT, 1), new Object[] { "# #", " # ", Character.valueOf('#'), Item.CLAY_BRICK}); @@ -101,6 +107,7 @@ public class CraftingManager { this.registerShapedRecipe(new ItemStack(Block.STONE_STAIRS, 4), new Object[] { "# ", "## ", "###", Character.valueOf('#'), Block.SMOOTH_BRICK}); this.registerShapedRecipe(new ItemStack(Block.NETHER_BRICK_STAIRS, 4), new Object[] { "# ", "## ", "###", Character.valueOf('#'), Block.NETHER_BRICK}); this.registerShapedRecipe(new ItemStack(Block.SANDSTONE_STAIRS, 4), new Object[] { "# ", "## ", "###", Character.valueOf('#'), Block.SANDSTONE}); + 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}); @@ -110,6 +117,7 @@ public class CraftingManager { 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}); this.registerShapedRecipe(new ItemStack(Item.DIODE, 1), new Object[] { "#X#", "III", Character.valueOf('#'), Block.REDSTONE_TORCH_ON, Character.valueOf('X'), Item.REDSTONE, Character.valueOf('I'), Block.STONE}); + this.registerShapedRecipe(new ItemStack(Item.REDSTONE_COMPARATOR, 1), new Object[] { " # ", "#X#", "III", Character.valueOf('#'), Block.REDSTONE_TORCH_ON, Character.valueOf('X'), Item.QUARTZ, Character.valueOf('I'), Block.STONE}); this.registerShapedRecipe(new ItemStack(Item.WATCH, 1), new Object[] { " # ", "#X#", " # ", Character.valueOf('#'), Item.GOLD_INGOT, Character.valueOf('X'), Item.REDSTONE}); this.registerShapedRecipe(new ItemStack(Item.COMPASS, 1), new Object[] { " # ", "#X#", " # ", Character.valueOf('#'), Item.IRON_INGOT, Character.valueOf('X'), Item.REDSTONE}); this.registerShapedRecipe(new ItemStack(Item.MAP_EMPTY, 1), new Object[] { "###", "#X#", "###", Character.valueOf('#'), Item.PAPER, Character.valueOf('X'), Item.COMPASS}); @@ -117,7 +125,10 @@ public class CraftingManager { this.registerShapedRecipe(new ItemStack(Block.WOOD_BUTTON, 1), new Object[] { "#", Character.valueOf('#'), Block.WOOD}); this.registerShapedRecipe(new ItemStack(Block.STONE_PLATE, 1), new Object[] { "##", Character.valueOf('#'), Block.STONE}); this.registerShapedRecipe(new ItemStack(Block.WOOD_PLATE, 1), new Object[] { "##", Character.valueOf('#'), Block.WOOD}); + this.registerShapedRecipe(new ItemStack(Block.IRON_PLATE, 1), new Object[] { "##", Character.valueOf('#'), Item.IRON_INGOT}); + this.registerShapedRecipe(new ItemStack(Block.GOLD_PLATE, 1), new Object[] { "##", Character.valueOf('#'), Item.GOLD_INGOT}); this.registerShapedRecipe(new ItemStack(Block.DISPENSER, 1), new Object[] { "###", "#X#", "#R#", Character.valueOf('#'), Block.COBBLESTONE, Character.valueOf('X'), Item.BOW, Character.valueOf('R'), Item.REDSTONE}); + this.registerShapedRecipe(new ItemStack(Block.DROPPER, 1), new Object[] { "###", "# #", "#R#", Character.valueOf('#'), Block.COBBLESTONE, Character.valueOf('R'), Item.REDSTONE}); this.registerShapedRecipe(new ItemStack(Block.PISTON, 1), new Object[] { "TTT", "#X#", "#R#", Character.valueOf('#'), Block.COBBLESTONE, Character.valueOf('X'), Item.IRON_INGOT, Character.valueOf('R'), Item.REDSTONE, Character.valueOf('T'), Block.WOOD}); this.registerShapedRecipe(new ItemStack(Block.PISTON_STICKY, 1), new Object[] { "S", "P", Character.valueOf('S'), Item.SLIME_BALL, Character.valueOf('P'), Block.PISTON}); this.registerShapedRecipe(new ItemStack(Item.BED, 1), new Object[] { "###", "XXX", Character.valueOf('#'), Block.WOOL, Character.valueOf('X'), Block.WOOD}); @@ -126,6 +137,8 @@ public class CraftingManager { this.registerShapelessRecipe(new ItemStack(Item.EYE_OF_ENDER, 1), new Object[] { Item.ENDER_PEARL, Item.BLAZE_POWDER}); this.registerShapelessRecipe(new ItemStack(Item.FIREBALL, 3), new Object[] { Item.SULPHUR, Item.BLAZE_POWDER, Item.COAL}); this.registerShapelessRecipe(new ItemStack(Item.FIREBALL, 3), new Object[] { Item.SULPHUR, Item.BLAZE_POWDER, new ItemStack(Item.COAL, 1, 1)}); + this.registerShapedRecipe(new ItemStack(Block.DAYLIGHT_DETECTOR), new Object[] { "GGG", "QQQ", "WWW", Character.valueOf('G'), Block.GLASS, Character.valueOf('Q'), Item.QUARTZ, Character.valueOf('W'), Block.WOOD_STEP}); + 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"); @@ -173,7 +186,7 @@ public class CraftingManager { if (aobject[i + 1] instanceof Item) { itemstack1 = new ItemStack((Item) aobject[i + 1]); } else if (aobject[i + 1] instanceof Block) { - itemstack1 = new ItemStack((Block) aobject[i + 1], 1, -1); + itemstack1 = new ItemStack((Block) aobject[i + 1], 1, 32767); } else if (aobject[i + 1] instanceof ItemStack) { itemstack1 = (ItemStack) aobject[i + 1]; } @@ -247,10 +260,10 @@ public class CraftingManager { } } - if (i == 2 && itemstack.id == itemstack1.id && itemstack.count == 1 && itemstack1.count == 1 && Item.byId[itemstack.id].n()) { + if (i == 2 && itemstack.id == itemstack1.id && itemstack.count == 1 && itemstack1.count == 1 && Item.byId[itemstack.id].o()) { Item item = Item.byId[itemstack.id]; - int k = item.getMaxDurability() - itemstack.i(); - int l = item.getMaxDurability() - itemstack1.i(); + int k = item.getMaxDurability() - itemstack.j(); + int l = item.getMaxDurability() - itemstack1.j(); int i1 = k + l + item.getMaxDurability() * 5 / 100; int j1 = item.getMaxDurability() - i1; diff --git a/src/main/java/net/minecraft/server/CrashReport.java b/src/main/java/net/minecraft/server/CrashReport.java index 9b50bb2f91..211b74205d 100644 --- a/src/main/java/net/minecraft/server/CrashReport.java +++ b/src/main/java/net/minecraft/server/CrashReport.java @@ -11,8 +11,6 @@ import java.util.Date; import java.util.Iterator; import java.util.List; import java.util.concurrent.Callable; -import java.util.logging.Level; -import java.util.logging.Logger; public class CrashReport { @@ -132,7 +130,7 @@ public class CrashReport { return stringbuilder.toString(); } - public boolean a(File file1) { + public boolean a(File file1, IConsoleLogManager iconsolelogmanager) { if (this.e != null) { return false; } else { @@ -148,7 +146,7 @@ public class CrashReport { this.e = file1; return true; } catch (Throwable throwable) { - Logger.getLogger("Minecraft").log(Level.SEVERE, "Could not save crash report to " + file1, throwable); + iconsolelogmanager.severe("Could not save crash report to " + file1, throwable); return false; } } diff --git a/src/main/java/net/minecraft/server/DedicatedServer.java b/src/main/java/net/minecraft/server/DedicatedServer.java index bd0377ae01..f985c05585 100644 --- a/src/main/java/net/minecraft/server/DedicatedServer.java +++ b/src/main/java/net/minecraft/server/DedicatedServer.java @@ -8,10 +8,10 @@ import java.util.Collections; import java.util.List; import java.util.Random; import java.util.concurrent.Callable; -import java.util.logging.Level; // CraftBukkit start import java.io.PrintStream; +import java.util.logging.Level; import org.bukkit.craftbukkit.LoggerOutputStream; import org.bukkit.event.server.ServerCommandEvent; @@ -19,7 +19,8 @@ import org.bukkit.event.server.ServerCommandEvent; public class DedicatedServer extends MinecraftServer implements IMinecraftServer { - private final List l = Collections.synchronizedList(new ArrayList()); + private final List k = Collections.synchronizedList(new ArrayList()); + private final IConsoleLogManager l; private RemoteStatusListener m; private RemoteControlListener n; public PropertyManager propertyManager; // CraftBukkit - private -> public @@ -32,6 +33,7 @@ public class DedicatedServer extends MinecraftServer implements IMinecraftServer public DedicatedServer(joptsimple.OptionSet options) { super(options); // CraftBukkit end + this.l = new ConsoleLogManager("Minecraft-Server", (String) null, (String) null); // CraftBukkit - null last argument new ThreadSleepForever(this); } @@ -40,20 +42,19 @@ public class DedicatedServer extends MinecraftServer implements IMinecraftServer threadcommandreader.setDaemon(true); threadcommandreader.start(); - ConsoleLogManager.init(this); // CraftBukkit // CraftBukkit start - System.setOut(new PrintStream(new LoggerOutputStream(log, Level.INFO), true)); - System.setErr(new PrintStream(new LoggerOutputStream(log, Level.SEVERE), true)); + System.setOut(new PrintStream(new LoggerOutputStream(this.getLogger().getLogger(), Level.INFO), true)); + System.setErr(new PrintStream(new LoggerOutputStream(this.getLogger().getLogger(), Level.SEVERE), true)); // CraftBukkit end - log.info("Starting minecraft server version 1.4.7"); + this.getLogger().info("Starting minecraft server version 1.5"); if (Runtime.getRuntime().maxMemory() / 1024L / 1024L < 512L) { - log.warning("To start the server with more ram, launch it as \"java -Xmx1024M -Xms1024M -jar minecraft_server.jar\""); + this.getLogger().warning("To start the server with more ram, launch it as \"java -Xmx1024M -Xms1024M -jar minecraft_server.jar\""); } - log.info("Loading properties"); - this.propertyManager = new PropertyManager(this.options); // CraftBukkit - CLI argument support + 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"); } else { @@ -77,7 +78,7 @@ public class DedicatedServer extends MinecraftServer implements IMinecraftServer int i = this.propertyManager.getInt("gamemode", EnumGamemode.SURVIVAL.a()); this.q = WorldSettings.a(i); - log.info("Default game type: " + this.q); + this.getLogger().info("Default game type: " + this.q); InetAddress inetaddress = null; if (this.getServerIp().length() > 0) { @@ -88,26 +89,26 @@ public class DedicatedServer extends MinecraftServer implements IMinecraftServer this.setPort(this.propertyManager.getInt("server-port", 25565)); } - log.info("Generating keypair"); + this.getLogger().info("Generating keypair"); this.a(MinecraftEncryption.b()); - log.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.G()); try { this.r = new DedicatedServerConnection(this, inetaddress, this.G()); } catch (Throwable ioexception) { // CraftBukkit - IOException -> Throwable - log.warning("**** FAILED TO BIND TO PORT!"); - log.log(Level.WARNING, "The exception was: " + ioexception.toString()); - log.warning("Perhaps a server is already running on that port?"); + this.getLogger().warning("**** FAILED TO BIND TO PORT!"); + this.getLogger().warning("The exception was: {0}", new Object[] { ioexception.toString()}); + this.getLogger().warning("Perhaps a server is already running on that port?"); return false; } this.a((PlayerList) (new DedicatedPlayerList(this))); // CraftBukkit if (!this.getOnlineMode()) { - log.warning("**** SERVER IS RUNNING IN OFFLINE/INSECURE MODE!"); - log.warning("The server will make no attempt to authenticate usernames. Beware."); - log.warning("While this makes the game possible to play without internet access, it also opens up the ability for hackers to connect with any username they choose."); - log.warning("To change this, set \"online-mode\" to \"true\" in the server.properties file."); + this.getLogger().warning("**** SERVER IS RUNNING IN OFFLINE/INSECURE MODE!"); + this.getLogger().warning("The server will make no attempt to authenticate usernames. Beware."); + this.getLogger().warning("While this makes the game possible to play without internet access, it also opens up the ability for hackers to connect with any username they choose."); + this.getLogger().warning("To change this, set \"online-mode\" to \"true\" in the server.properties file."); } // this.a((PlayerList) (new DedicatedPlayerList(this))); // CraftBukkit - moved up @@ -145,20 +146,20 @@ 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())); - log.info("Preparing level \"" + this.J() + "\""); + this.getLogger().info("Preparing level \"" + this.J() + "\""); this.a(this.J(), this.J(), k, worldtype, s2); long i1 = System.nanoTime() - j; String s3 = String.format("%.3fs", new Object[] { Double.valueOf((double) i1 / 1.0E9D)}); - log.info("Done (" + s3 + ")! For help, type \"help\" or \"?\""); + this.getLogger().info("Done (" + s3 + ")! For help, type \"help\" or \"?\""); if (this.propertyManager.getBoolean("enable-query", false)) { - log.info("Starting GS4 status listener"); + this.getLogger().info("Starting GS4 status listener"); this.m = new RemoteStatusListener(this); this.m.a(); } if (this.propertyManager.getBoolean("enable-rcon", false)) { - log.info("Starting remote control listener"); + this.getLogger().info("Starting remote control listener"); this.n = new RemoteControlListener(this); this.n.a(); this.remoteConsole = new org.bukkit.craftbukkit.command.CraftRemoteConsoleCommandSender(); // CraftBukkit @@ -166,7 +167,7 @@ public class DedicatedServer extends MinecraftServer implements IMinecraftServer // CraftBukkit start if (this.server.getBukkitSpawnRadius() > -1) { - log.info("'settings.spawn-radius' in bukkit.yml has been moved to 'spawn-protection' in server.properties. I will move your config for you."); + this.getLogger().info("'settings.spawn-radius' in bukkit.yml has been moved to 'spawn-protection' in server.properties. I will move your config for you."); this.propertyManager.properties.remove("spawn-protection"); this.propertyManager.getInt("spawn-protection", this.server.getBukkitSpawnRadius()); this.server.removeBukkitSpawnRadius(); @@ -199,7 +200,7 @@ public class DedicatedServer extends MinecraftServer implements IMinecraftServer protected void a(CrashReport crashreport) { while (this.isRunning()) { - this.al(); + this.am(); try { Thread.sleep(10L); @@ -220,9 +221,9 @@ public class DedicatedServer extends MinecraftServer implements IMinecraftServer System.exit(0); } - public void r() { + public void r() { // CraftBukkit - protected -> public super.r(); - this.al(); + this.am(); } public boolean getAllowNether() { @@ -234,8 +235,8 @@ public class DedicatedServer extends MinecraftServer implements IMinecraftServer } public void a(MojangStatisticsGenerator mojangstatisticsgenerator) { - mojangstatisticsgenerator.a("whitelist_enabled", Boolean.valueOf(this.am().getHasWhitelist())); - mojangstatisticsgenerator.a("whitelist_count", Integer.valueOf(this.am().getWhitelisted().size())); + mojangstatisticsgenerator.a("whitelist_enabled", Boolean.valueOf(this.an().getHasWhitelist())); + mojangstatisticsgenerator.a("whitelist_count", Integer.valueOf(this.an().getWhitelisted().size())); super.a(mojangstatisticsgenerator); } @@ -244,12 +245,12 @@ public class DedicatedServer extends MinecraftServer implements IMinecraftServer } public void issueCommand(String s, ICommandListener icommandlistener) { - this.l.add(new ServerCommand(s, icommandlistener)); + this.k.add(new ServerCommand(s, icommandlistener)); } - public void al() { - while (!this.l.isEmpty()) { - ServerCommand servercommand = (ServerCommand) this.l.remove(0); + public void am() { + while (!this.k.isEmpty()) { + ServerCommand servercommand = (ServerCommand) this.k.remove(0); // CraftBukkit start - ServerCommand for preprocessing ServerCommandEvent event = new ServerCommandEvent(this.console, servercommand.command); @@ -266,7 +267,7 @@ public class DedicatedServer extends MinecraftServer implements IMinecraftServer return true; } - public DedicatedPlayerList am() { + public DedicatedPlayerList an() { return (DedicatedPlayerList) super.getPlayerList(); } @@ -300,7 +301,7 @@ public class DedicatedServer extends MinecraftServer implements IMinecraftServer return file1 != null ? file1.getAbsolutePath() : "No settings file"; } - public void an() { + public void ao() { ServerGUI.a(this); this.s = true; } @@ -321,7 +322,30 @@ public class DedicatedServer extends MinecraftServer implements IMinecraftServer return this.propertyManager.getInt("spawn-protection", super.getSpawnProtection()); } + public boolean a(World world, int i, int j, int k, EntityHuman entityhuman) { + if (world.worldProvider.dimension != 0) { + return false; + } else if (this.an().getOPs().isEmpty()) { + return false; + } else if (this.an().isOp(entityhuman.name)) { + return false; + } else if (this.getSpawnProtection() <= 0) { + return false; + } else { + ChunkCoordinates chunkcoordinates = world.getSpawn(); + int l = MathHelper.a(i - chunkcoordinates.x); + int i1 = MathHelper.a(k - chunkcoordinates.z); + int j1 = Math.max(l, i1); + + return j1 <= this.getSpawnProtection(); + } + } + + public IConsoleLogManager getLogger() { + return this.l; + } + public PlayerList getPlayerList() { - return this.am(); + return this.an(); } } diff --git a/src/main/java/net/minecraft/server/DedicatedServerConnectionThread.java b/src/main/java/net/minecraft/server/DedicatedServerConnectionThread.java index 25e2ac1df9..5be8dc2b69 100644 --- a/src/main/java/net/minecraft/server/DedicatedServerConnectionThread.java +++ b/src/main/java/net/minecraft/server/DedicatedServerConnectionThread.java @@ -8,47 +8,44 @@ import java.util.ArrayList; import java.util.Collections; import java.util.HashMap; import java.util.List; -import java.util.logging.Level; -import java.util.logging.Logger; public class DedicatedServerConnectionThread extends Thread { - private static Logger a = Logger.getLogger("Minecraft"); - private final List b = Collections.synchronizedList(new ArrayList()); - private final HashMap c = new HashMap(); - private int d = 0; - private final ServerSocket e; - private ServerConnection f; - private final InetAddress g; - private final int h; + private final List a = Collections.synchronizedList(new ArrayList()); + private final HashMap b = new HashMap(); + private int c = 0; + private final ServerSocket d; + private ServerConnection e; + private final InetAddress f; + private final int g; long connectionThrottle; // CraftBukkit public DedicatedServerConnectionThread(ServerConnection serverconnection, InetAddress inetaddress, int i) throws IOException { // CraftBukkit - added throws super("Listen thread"); - this.f = serverconnection; - this.h = i; - this.e = new ServerSocket(i, 0, inetaddress); - this.g = inetaddress == null ? this.e.getInetAddress() : inetaddress; - this.e.setPerformancePreferences(0, 2, 1); + this.e = serverconnection; + this.g = i; + this.d = new ServerSocket(i, 0, inetaddress); + this.f = inetaddress == null ? this.d.getInetAddress() : inetaddress; + this.d.setPerformancePreferences(0, 2, 1); } public void a() { - List list = this.b; + List list = this.a; - synchronized (this.b) { - for (int i = 0; i < this.b.size(); ++i) { - PendingConnection pendingconnection = (PendingConnection) this.b.get(i); + synchronized (this.a) { + for (int i = 0; i < this.a.size(); ++i) { + PendingConnection pendingconnection = (PendingConnection) this.a.get(i); try { pendingconnection.c(); } catch (Exception exception) { pendingconnection.disconnect("Internal server error"); - a.log(Level.WARNING, "Failed to handle packet for " + pendingconnection.getName() + ": " + exception, exception); + this.e.d().getLogger().warning("Failed to handle packet for " + pendingconnection.getName() + ": " + exception, (Throwable) exception); } - if (pendingconnection.c) { - this.b.remove(i--); + if (pendingconnection.b) { + this.a.remove(i--); } pendingconnection.networkManager.a(); @@ -57,51 +54,51 @@ public class DedicatedServerConnectionThread extends Thread { } public void run() { - while (this.f.b) { + while (this.e.a) { try { - Socket socket = this.e.accept(); + Socket socket = this.d.accept(); InetAddress inetaddress = socket.getInetAddress(); long i = System.currentTimeMillis(); - HashMap hashmap = this.c; + HashMap hashmap = this.b; // CraftBukkit start - if (((MinecraftServer) this.f.d()).server == null) { + if (((MinecraftServer) this.e.d()).server == null) { socket.close(); continue; } - connectionThrottle = ((MinecraftServer) this.f.d()).server.getConnectionThrottle(); + connectionThrottle = ((MinecraftServer) this.e.d()).server.getConnectionThrottle(); // CraftBukkit end - synchronized (this.c) { - if (this.c.containsKey(inetaddress) && !b(inetaddress) && i - ((Long) this.c.get(inetaddress)).longValue() < connectionThrottle) { - this.c.put(inetaddress, Long.valueOf(i)); + synchronized (this.b) { + if (this.b.containsKey(inetaddress) && !b(inetaddress) && i - ((Long) this.b.get(inetaddress)).longValue() < connectionThrottle) { + this.b.put(inetaddress, Long.valueOf(i)); socket.close(); continue; } - this.c.put(inetaddress, Long.valueOf(i)); + this.b.put(inetaddress, Long.valueOf(i)); } - PendingConnection pendingconnection = new PendingConnection(this.f.d(), socket, "Connection #" + this.d++); + PendingConnection pendingconnection = new PendingConnection(this.e.d(), socket, "Connection #" + this.c++); this.a(pendingconnection); } catch (IOException ioexception) { - a.warning("DSCT: " + ioexception.getMessage()); // CraftBukkit + this.e.d().getLogger().warning("DSCT: " + ioexception.getMessage()); // CraftBukkit } } - System.out.println("Closing listening thread"); + this.e.d().getLogger().info("Closing listening thread"); } private void a(PendingConnection pendingconnection) { if (pendingconnection == null) { throw new IllegalArgumentException("Got null pendingconnection!"); } else { - List list = this.b; + List list = this.a; - synchronized (this.b) { - this.b.add(pendingconnection); + synchronized (this.a) { + this.a.add(pendingconnection); } } } @@ -112,17 +109,17 @@ public class DedicatedServerConnectionThread extends Thread { public void a(InetAddress inetaddress) { if (inetaddress != null) { - HashMap hashmap = this.c; + HashMap hashmap = this.b; - synchronized (this.c) { - this.c.remove(inetaddress); + synchronized (this.b) { + this.b.remove(inetaddress); } } } public void b() { try { - this.e.close(); + this.d.close(); } catch (Throwable throwable) { ; } diff --git a/src/main/java/net/minecraft/server/DispenseBehaviorBoat.java b/src/main/java/net/minecraft/server/DispenseBehaviorBoat.java index 2840aa3ed9..8e3a861564 100644 --- a/src/main/java/net/minecraft/server/DispenseBehaviorBoat.java +++ b/src/main/java/net/minecraft/server/DispenseBehaviorBoat.java @@ -5,25 +5,20 @@ import org.bukkit.craftbukkit.inventory.CraftItemStack; import org.bukkit.event.block.BlockDispenseEvent; // CraftBukkit end -public class DispenseBehaviorBoat extends DispenseBehaviorItem { +final class DispenseBehaviorBoat extends DispenseBehaviorItem { - private final DispenseBehaviorItem c; + private final DispenseBehaviorItem b = new DispenseBehaviorItem(); - final MinecraftServer b; - - public DispenseBehaviorBoat(MinecraftServer minecraftserver) { - this.b = minecraftserver; - this.c = new DispenseBehaviorItem(); - } + DispenseBehaviorBoat() {} public ItemStack b(ISourceBlock isourceblock, ItemStack itemstack) { - EnumFacing enumfacing = EnumFacing.a(isourceblock.h()); + EnumFacing enumfacing = BlockDispenser.j_(isourceblock.h()); World world = isourceblock.k(); double d0 = isourceblock.getX() + (double) ((float) enumfacing.c() * 1.125F); - double d1 = isourceblock.getY(); + double d1 = isourceblock.getY() + (double) ((float) enumfacing.d() * 1.125F); double d2 = isourceblock.getZ() + (double) ((float) enumfacing.e() * 1.125F); int i = isourceblock.getBlockX() + enumfacing.c(); - int j = isourceblock.getBlockY(); + int j = isourceblock.getBlockY() + enumfacing.d(); int k = isourceblock.getBlockZ() + enumfacing.e(); Material material = world.getMaterial(i, j, k); double d3; @@ -32,7 +27,7 @@ public class DispenseBehaviorBoat extends DispenseBehaviorItem { d3 = 1.0D; } else { if (!Material.AIR.equals(material) || !Material.WATER.equals(world.getMaterial(i, j - 1, k))) { - return this.c.a(isourceblock, itemstack); + return this.b.a(isourceblock, itemstack); } d3 = 0.0D; diff --git a/src/main/java/net/minecraft/server/DispenseBehaviorEmptyBucket.java b/src/main/java/net/minecraft/server/DispenseBehaviorEmptyBucket.java index b381e2239d..8f7e09b273 100644 --- a/src/main/java/net/minecraft/server/DispenseBehaviorEmptyBucket.java +++ b/src/main/java/net/minecraft/server/DispenseBehaviorEmptyBucket.java @@ -5,22 +5,17 @@ import org.bukkit.craftbukkit.inventory.CraftItemStack; import org.bukkit.event.block.BlockDispenseEvent; // CraftBukkit end -public class DispenseBehaviorEmptyBucket extends DispenseBehaviorItem { +final class DispenseBehaviorEmptyBucket extends DispenseBehaviorItem { - private final DispenseBehaviorItem c; + private final DispenseBehaviorItem b = new DispenseBehaviorItem(); - final MinecraftServer b; - - public DispenseBehaviorEmptyBucket(MinecraftServer minecraftserver) { - this.b = minecraftserver; - this.c = new DispenseBehaviorItem(); - } + DispenseBehaviorEmptyBucket() {} public ItemStack b(ISourceBlock isourceblock, ItemStack itemstack) { - EnumFacing enumfacing = EnumFacing.a(isourceblock.h()); + EnumFacing enumfacing = BlockDispenser.j_(isourceblock.h()); World world = isourceblock.k(); int i = isourceblock.getBlockX() + enumfacing.c(); - int j = isourceblock.getBlockY(); + int j = isourceblock.getBlockY() + enumfacing.d(); int k = isourceblock.getBlockZ() + enumfacing.e(); Material material = world.getMaterial(i, j, k); int l = world.getData(i, j, k); @@ -60,12 +55,12 @@ public class DispenseBehaviorEmptyBucket extends DispenseBehaviorItem { } // CraftBukkit end - world.setTypeId(i, j, k, 0); + world.setAir(i, j, k); if (--itemstack.count == 0) { itemstack.id = item.id; itemstack.count = 1; } else if (((TileEntityDispenser) isourceblock.getTileEntity()).addItem(new ItemStack(item)) < 0) { - this.c.a(isourceblock, new ItemStack(item)); + this.b.a(isourceblock, new ItemStack(item)); } return itemstack; diff --git a/src/main/java/net/minecraft/server/DispenseBehaviorFilledBucket.java b/src/main/java/net/minecraft/server/DispenseBehaviorFilledBucket.java index 309c1e6294..5caf0bde48 100644 --- a/src/main/java/net/minecraft/server/DispenseBehaviorFilledBucket.java +++ b/src/main/java/net/minecraft/server/DispenseBehaviorFilledBucket.java @@ -5,23 +5,18 @@ import org.bukkit.craftbukkit.inventory.CraftItemStack; import org.bukkit.event.block.BlockDispenseEvent; // CraftBukkit end -public class DispenseBehaviorFilledBucket extends DispenseBehaviorItem { +final class DispenseBehaviorFilledBucket extends DispenseBehaviorItem { - private final DispenseBehaviorItem c; + private final DispenseBehaviorItem b = new DispenseBehaviorItem(); - final MinecraftServer b; - - public DispenseBehaviorFilledBucket(MinecraftServer minecraftserver) { - this.b = minecraftserver; - this.c = new DispenseBehaviorItem(); - } + DispenseBehaviorFilledBucket() {} public ItemStack b(ISourceBlock isourceblock, ItemStack itemstack) { ItemBucket itembucket = (ItemBucket) itemstack.getItem(); int i = isourceblock.getBlockX(); int j = isourceblock.getBlockY(); int k = isourceblock.getBlockZ(); - EnumFacing enumfacing = EnumFacing.a(isourceblock.h()); + EnumFacing enumfacing = BlockDispenser.j_(isourceblock.h()); // CraftBukkit start World world = isourceblock.k(); @@ -61,13 +56,13 @@ public class DispenseBehaviorFilledBucket extends DispenseBehaviorItem { itemstack.id = item.id; itemstack.count = 1; } else if (((TileEntityDispenser) isourceblock.getTileEntity()).addItem(new ItemStack(item)) < 0) { - this.c.a(isourceblock, new ItemStack(item)); + this.b.a(isourceblock, new ItemStack(item)); } // CraftBukkit end return itemstack; } else { - return this.c.a(isourceblock, itemstack); + return this.b.a(isourceblock, itemstack); } } } diff --git a/src/main/java/net/minecraft/server/DispenseBehaviorFireball.java b/src/main/java/net/minecraft/server/DispenseBehaviorFireball.java index 9eb4ca2b18..1cb73aaca0 100644 --- a/src/main/java/net/minecraft/server/DispenseBehaviorFireball.java +++ b/src/main/java/net/minecraft/server/DispenseBehaviorFireball.java @@ -7,24 +7,20 @@ import org.bukkit.craftbukkit.inventory.CraftItemStack; import org.bukkit.event.block.BlockDispenseEvent; // CraftBukkit end -public class DispenseBehaviorFireball extends DispenseBehaviorItem { +final class DispenseBehaviorFireball extends DispenseBehaviorItem { - final MinecraftServer b; - - public DispenseBehaviorFireball(MinecraftServer minecraftserver) { - this.b = minecraftserver; - } + DispenseBehaviorFireball() {} public ItemStack b(ISourceBlock isourceblock, ItemStack itemstack) { - EnumFacing enumfacing = EnumFacing.a(isourceblock.h()); + EnumFacing enumfacing = BlockDispenser.j_(isourceblock.h()); IPosition iposition = BlockDispenser.a(isourceblock); double d0 = iposition.getX() + (double) ((float) enumfacing.c() * 0.3F); - double d1 = iposition.getY(); + double d1 = iposition.getY() + (double) ((float) enumfacing.c() * 0.3F); double d2 = iposition.getZ() + (double) ((float) enumfacing.e() * 0.3F); World world = isourceblock.k(); Random random = world.random; double d3 = random.nextGaussian() * 0.05D + (double) enumfacing.c(); - double d4 = random.nextGaussian() * 0.05D; + double d4 = random.nextGaussian() * 0.05D + (double) enumfacing.d(); double d5 = random.nextGaussian() * 0.05D + (double) enumfacing.e(); // CraftBukkit start diff --git a/src/main/java/net/minecraft/server/DispenseBehaviorFireworks.java b/src/main/java/net/minecraft/server/DispenseBehaviorFireworks.java index 039d515222..6141b441d1 100644 --- a/src/main/java/net/minecraft/server/DispenseBehaviorFireworks.java +++ b/src/main/java/net/minecraft/server/DispenseBehaviorFireworks.java @@ -5,16 +5,12 @@ import org.bukkit.craftbukkit.inventory.CraftItemStack; import org.bukkit.event.block.BlockDispenseEvent; // CraftBukkit end -public class DispenseBehaviorFireworks extends DispenseBehaviorItem { +final class DispenseBehaviorFireworks extends DispenseBehaviorItem { - final MinecraftServer b; - - public DispenseBehaviorFireworks(MinecraftServer minecraftserver) { - this.b = minecraftserver; - } + DispenseBehaviorFireworks() {} public ItemStack b(ISourceBlock isourceblock, ItemStack itemstack) { - EnumFacing enumfacing = EnumFacing.a(isourceblock.h()); + EnumFacing enumfacing = BlockDispenser.j_(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/DispenseBehaviorItem.java b/src/main/java/net/minecraft/server/DispenseBehaviorItem.java index 42e08a23f3..c3a9f36d45 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, EnumFacing.a(isourceblock.h())); + this.a(isourceblock, BlockDispenser.j_(isourceblock.h())); return itemstack1; } protected ItemStack b(ISourceBlock isourceblock, ItemStack itemstack) { - EnumFacing enumfacing = EnumFacing.a(isourceblock.h()); + EnumFacing enumfacing = BlockDispenser.j_(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 2da34d377a..2a7b4ad315 100644 --- a/src/main/java/net/minecraft/server/DispenseBehaviorMinecart.java +++ b/src/main/java/net/minecraft/server/DispenseBehaviorMinecart.java @@ -5,34 +5,29 @@ import org.bukkit.craftbukkit.inventory.CraftItemStack; import org.bukkit.event.block.BlockDispenseEvent; // CraftBukkit end -public class DispenseBehaviorMinecart extends DispenseBehaviorItem { +final class DispenseBehaviorMinecart extends DispenseBehaviorItem { - private final DispenseBehaviorItem c; + private final DispenseBehaviorItem b = new DispenseBehaviorItem(); - final MinecraftServer b; - - public DispenseBehaviorMinecart(MinecraftServer minecraftserver) { - this.b = minecraftserver; - this.c = new DispenseBehaviorItem(); - } + DispenseBehaviorMinecart() {} public ItemStack b(ISourceBlock isourceblock, ItemStack itemstack) { - EnumFacing enumfacing = EnumFacing.a(isourceblock.h()); + EnumFacing enumfacing = BlockDispenser.j_(isourceblock.h()); World world = isourceblock.k(); double d0 = isourceblock.getX() + (double) ((float) enumfacing.c() * 1.125F); - double d1 = isourceblock.getY(); + double d1 = isourceblock.getY() + (double) ((float) enumfacing.d() * 1.125F); double d2 = isourceblock.getZ() + (double) ((float) enumfacing.e() * 1.125F); int i = isourceblock.getBlockX() + enumfacing.c(); - int j = isourceblock.getBlockY(); + int j = isourceblock.getBlockY() + enumfacing.d(); int k = isourceblock.getBlockZ() + enumfacing.e(); int l = world.getTypeId(i, j, k); double d3; - if (BlockMinecartTrack.e(l)) { + if (BlockMinecartTrackAbstract.d_(l)) { d3 = 0.0D; } else { - if (l != 0 || !BlockMinecartTrack.e(world.getTypeId(i, j - 1, k))) { - return this.c.a(isourceblock, itemstack); + if (l != 0 || !BlockMinecartTrackAbstract.d_(world.getTypeId(i, j - 1, k))) { + return this.b.a(isourceblock, itemstack); } d3 = -1.0D; @@ -65,10 +60,10 @@ public class DispenseBehaviorMinecart extends DispenseBehaviorItem { } itemstack1 = CraftItemStack.asNMSCopy(event.getItem()); - EntityMinecart entityminecart = new EntityMinecart(world, event.getVelocity().getX(), event.getVelocity().getY(), event.getVelocity().getZ(), ((ItemMinecart) itemstack1.getItem()).a); + EntityMinecartAbstract entityminecartabstract = EntityMinecartAbstract.a(world, event.getVelocity().getX(), event.getVelocity().getY(), event.getVelocity().getZ(), ((ItemMinecart) itemstack1.getItem()).a); // CraftBukkit end - world.addEntity(entityminecart); + 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 e5a011bc56..a29b550ed8 100644 --- a/src/main/java/net/minecraft/server/DispenseBehaviorMonsterEgg.java +++ b/src/main/java/net/minecraft/server/DispenseBehaviorMonsterEgg.java @@ -5,16 +5,12 @@ import org.bukkit.craftbukkit.inventory.CraftItemStack; import org.bukkit.event.block.BlockDispenseEvent; // CraftBukkit end -public class DispenseBehaviorMonsterEgg extends DispenseBehaviorItem { +final class DispenseBehaviorMonsterEgg extends DispenseBehaviorItem { - final MinecraftServer b; - - public DispenseBehaviorMonsterEgg(MinecraftServer minecraftserver) { - this.b = minecraftserver; - } + DispenseBehaviorMonsterEgg() {} public ItemStack b(ISourceBlock isourceblock, ItemStack itemstack) { - EnumFacing enumfacing = EnumFacing.a(isourceblock.h()); + EnumFacing enumfacing = BlockDispenser.j_(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 +43,13 @@ public class DispenseBehaviorMonsterEgg extends DispenseBehaviorItem { } itemstack1 = CraftItemStack.asNMSCopy(event.getItem()); - ItemMonsterEgg.a(isourceblock.k(), itemstack1.getData(), event.getVelocity().getX(), event.getVelocity().getY(), event.getVelocity().getZ()); + + 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()); + } + // itemstack.a(1); // Handled during event processing // CraftBukkit end return itemstack; diff --git a/src/main/java/net/minecraft/server/DispenseBehaviorProjectile.java b/src/main/java/net/minecraft/server/DispenseBehaviorProjectile.java index 984b1fc00d..916ce148c7 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 = EnumFacing.a(isourceblock.h()); + EnumFacing enumfacing = BlockDispenser.j_(isourceblock.h()); IProjectile iprojectile = this.a(world, iposition); // CraftBukkit start @@ -20,7 +20,7 @@ public abstract class DispenseBehaviorProjectile extends DispenseBehaviorItem { org.bukkit.block.Block block = world.getWorld().getBlockAt(isourceblock.getBlockX(), isourceblock.getBlockY(), isourceblock.getBlockZ()); CraftItemStack craftItem = CraftItemStack.asCraftMirror(itemstack1); - BlockDispenseEvent event = new BlockDispenseEvent(block, craftItem.clone(), new org.bukkit.util.Vector((double) enumfacing.c(), 0.10000000149011612D, (double) enumfacing.e())); + BlockDispenseEvent event = new BlockDispenseEvent(block, craftItem.clone(), new org.bukkit.util.Vector((double) enumfacing.c(), (double) ((float) enumfacing.d() + 0.1F), (double) enumfacing.e())); if (!BlockDispenser.eventFired) { world.getServer().getPluginManager().callEvent(event); } diff --git a/src/main/java/net/minecraft/server/Entity.java b/src/main/java/net/minecraft/server/Entity.java index 71707ed197..b9667a0e16 100644 --- a/src/main/java/net/minecraft/server/Entity.java +++ b/src/main/java/net/minecraft/server/Entity.java @@ -2,11 +2,10 @@ package net.minecraft.server; import java.util.List; import java.util.Random; +import java.util.UUID; import java.util.concurrent.Callable; // CraftBukkit start -import java.util.UUID; - import org.bukkit.Bukkit; import org.bukkit.Location; import org.bukkit.Server; @@ -46,6 +45,7 @@ public abstract class Entity { public boolean m; public Entity passenger; public Entity vehicle; + public boolean p; public World world; public double lastX; public double lastY; @@ -63,52 +63,52 @@ public abstract class Entity { public final AxisAlignedBB boundingBox; public boolean onGround; public boolean positionChanged; - public boolean G; public boolean H; + public boolean I; public boolean velocityChanged; - protected boolean J; - public boolean K; + protected boolean K; + public boolean L; public boolean dead; public float height; public float width; public float length; - public float P; public float Q; public float R; + public float S; public float fallDistance; private int c; - public double T; public double U; public double V; - public float W; + public double W; public float X; - public boolean Y; - public float Z; + public float Y; + public boolean Z; + public float aa; protected Random random; public int ticksLived; public int maxFireTicks; public int fireTicks; // CraftBukkit - private -> public - protected boolean ad; + protected boolean ae; public int noDamageTicks; private boolean justCreated; protected boolean fireProof; protected DataWatcher datawatcher; private double f; private double g; - public boolean ah; - public int ai; + public boolean ai; public int aj; public int ak; - public boolean al; + public int al; public boolean am; + public boolean an; public int portalCooldown; - protected boolean ao; - protected int ap; + protected boolean ap; + protected int aq; public int dimension; - protected int ar; + protected int as; private boolean invulnerable; - public EnumEntitySize as; - public UUID uniqueId = UUID.randomUUID(); // CraftBukkit + public UUID uniqueID; // CraftBukkit - private -> public + public EnumEntitySize at; public boolean valid = false; // CraftBukkit public Entity(World world) { @@ -117,35 +117,36 @@ public abstract class Entity { this.m = false; this.boundingBox = AxisAlignedBB.a(0.0D, 0.0D, 0.0D, 0.0D, 0.0D, 0.0D); this.onGround = false; - this.H = false; + this.I = false; this.velocityChanged = false; - this.K = true; + this.L = true; this.dead = false; this.height = 0.0F; this.width = 0.6F; this.length = 1.8F; - this.P = 0.0F; this.Q = 0.0F; this.R = 0.0F; + this.S = 0.0F; this.fallDistance = 0.0F; this.c = 1; - this.W = 0.0F; this.X = 0.0F; - this.Y = false; - this.Z = 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.ad = false; + this.ae = false; this.noDamageTicks = 0; this.justCreated = true; this.fireProof = false; this.datawatcher = new DataWatcher(); - this.ah = false; - this.ar = 0; + this.ai = false; + this.as = 0; this.invulnerable = false; - this.as = EnumEntitySize.SIZE_2; + this.uniqueID = UUID.randomUUID(); + this.at = EnumEntitySize.SIZE_2; this.world = world; this.setPosition(0.0D, 0.0D, 0.0D); if (world != null) { @@ -176,22 +177,28 @@ public abstract class Entity { } protected void a(float f, float f1) { - this.width = f; - this.length = f1; + if (f != this.width || f1 != this.length) { + this.width = f; + this.length = f1; + this.boundingBox.d = this.boundingBox.a + (double) this.width; + this.boundingBox.f = this.boundingBox.c + (double) this.width; + this.boundingBox.e = this.boundingBox.b + (double) this.length; + } + float f2 = f % 2.0F; if ((double) f2 < 0.375D) { - this.as = EnumEntitySize.SIZE_1; + this.at = EnumEntitySize.SIZE_1; } else if ((double) f2 < 0.75D) { - this.as = EnumEntitySize.SIZE_2; + this.at = EnumEntitySize.SIZE_2; } else if ((double) f2 < 1.0D) { - this.as = EnumEntitySize.SIZE_3; + this.at = EnumEntitySize.SIZE_3; } else if ((double) f2 < 1.375D) { - this.as = EnumEntitySize.SIZE_4; + this.at = EnumEntitySize.SIZE_4; } else if ((double) f2 < 1.75D) { - this.as = EnumEntitySize.SIZE_5; + this.at = EnumEntitySize.SIZE_5; } else { - this.as = EnumEntitySize.SIZE_6; + this.at = EnumEntitySize.SIZE_6; } } @@ -203,7 +210,7 @@ public abstract class Entity { if ((f == Float.POSITIVE_INFINITY) || (f == Float.NEGATIVE_INFINITY)) { if (this instanceof EntityPlayer) { - System.err.println(((CraftPlayer) this.getBukkitEntity()).getName() + " was caught trying to crash the server with an invalid yaw"); + this.world.getServer().getLogger().warning(((CraftPlayer) this.getBukkitEntity()).getName() + " was caught trying to crash the server with an invalid yaw"); ((CraftPlayer) this.getBukkitEntity()).kickPlayer("Nope"); } f = 0; @@ -216,7 +223,7 @@ public abstract class Entity { if ((f1 == Float.POSITIVE_INFINITY) || (f1 == Float.NEGATIVE_INFINITY)) { if (this instanceof EntityPlayer) { - System.err.println(((CraftPlayer) this.getBukkitEntity()).getName() + " was caught trying to crash the server with an invalid pitch"); + this.world.getServer().getLogger().warning(((CraftPlayer) this.getBukkitEntity()).getName() + " was caught trying to crash the server with an invalid pitch"); ((CraftPlayer) this.getBukkitEntity()).kickPlayer("Nope"); } f1 = 0; @@ -234,20 +241,20 @@ public abstract class Entity { float f = this.width / 2.0F; float f1 = this.length; - this.boundingBox.b(d0 - (double) f, d1 - (double) this.height + (double) this.W, d2 - (double) f, d0 + (double) f, d1 - (double) this.height + (double) this.W + (double) f1, d2 + (double) f); + this.boundingBox.b(d0 - (double) f, d1 - (double) this.height + (double) this.X, d2 - (double) f, d0 + (double) f, d1 - (double) this.height + (double) this.X + (double) f1, d2 + (double) f); } - public void j_() { - this.y(); + public void l_() { + this.x(); } - public void y() { + public void x() { this.world.methodProfiler.a("entityBaseTick"); if (this.vehicle != null && this.vehicle.dead) { this.vehicle = null; } - this.P = this.Q; + this.Q = this.R; this.lastX = this.locX; this.lastY = this.locY; this.lastZ = this.locZ; @@ -259,12 +266,12 @@ public abstract class Entity { this.world.methodProfiler.a("portal"); MinecraftServer minecraftserver = ((WorldServer) this.world).getMinecraftServer(); - i = this.z(); - if (this.ao) { + i = this.y(); + if (this.ap) { if (true || minecraftserver.getAllowNether()) { // CraftBukkit - if (this.vehicle == null && this.ap++ >= i) { - this.ap = i; - this.portalCooldown = this.ab(); + if (this.vehicle == null && this.aq++ >= i) { + this.aq = i; + this.portalCooldown = this.aa(); byte b0; if (this.world.worldProvider.dimension == -1) { @@ -273,18 +280,18 @@ public abstract class Entity { b0 = -1; } - this.b(b0); + this.c(b0); } - this.ao = false; + this.ap = false; } } else { - if (this.ap > 0) { - this.ap -= 4; + if (this.aq > 0) { + this.aq -= 4; } - if (this.ap < 0) { - this.ap = 0; + if (this.aq < 0) { + this.aq = 0; } } @@ -295,7 +302,7 @@ public abstract class Entity { this.world.methodProfiler.b(); } - if (this.isSprinting() && !this.H()) { + if (this.isSprinting() && !this.G()) { int j = MathHelper.floor(this.locX); i = MathHelper.floor(this.locY - 0.20000000298023224D - (double) this.height); @@ -307,7 +314,7 @@ public abstract class Entity { } } - this.I(); + this.H(); if (this.world.isStatic) { this.fireTicks = 0; } else if (this.fireTicks > 0) { @@ -337,13 +344,13 @@ public abstract class Entity { } } - if (this.J()) { - this.A(); + if (this.I()) { + this.z(); this.fallDistance *= 0.5F; } if (this.locY < -64.0D) { - this.C(); + this.B(); } if (!this.world.isStatic) { @@ -355,11 +362,11 @@ public abstract class Entity { this.world.methodProfiler.b(); } - public int z() { + public int y() { return 0; } - protected void A() { + protected void z() { if (!this.fireProof) { // CraftBukkit start - fallen in lava TODO: this event spams! if (this instanceof EntityLiving) { @@ -411,7 +418,7 @@ public abstract class Entity { this.fireTicks = 0; } - protected void C() { + protected void B() { this.die(); } @@ -423,20 +430,20 @@ public abstract class Entity { } public void move(double d0, double d1, double d2) { - if (this.Y) { + if (this.Z) { this.boundingBox.d(d0, d1, d2); this.locX = (this.boundingBox.a + this.boundingBox.d) / 2.0D; - this.locY = this.boundingBox.b + (double) this.height - (double) this.W; + this.locY = this.boundingBox.b + (double) this.height - (double) this.X; this.locZ = (this.boundingBox.c + this.boundingBox.f) / 2.0D; } else { this.world.methodProfiler.a("move"); - this.W *= 0.4F; + this.X *= 0.4F; double d3 = this.locX; double d4 = this.locY; double d5 = this.locZ; - if (this.J) { - this.J = false; + if (this.K) { + this.K = false; d0 *= 0.25D; d1 *= 0.05000000074505806D; d2 *= 0.25D; @@ -503,7 +510,7 @@ public abstract class Entity { } this.boundingBox.d(0.0D, d1, 0.0D); - if (!this.K && d7 != d1) { + if (!this.L && d7 != d1) { d2 = 0.0D; d1 = 0.0D; d0 = 0.0D; @@ -518,7 +525,7 @@ public abstract class Entity { } this.boundingBox.d(d0, 0.0D, 0.0D); - if (!this.K && d6 != d0) { + if (!this.L && d6 != d0) { d2 = 0.0D; d1 = 0.0D; d0 = 0.0D; @@ -529,7 +536,7 @@ public abstract class Entity { } this.boundingBox.d(0.0D, 0.0D, d2); - if (!this.K && d8 != d2) { + if (!this.L && d8 != d2) { d2 = 0.0D; d1 = 0.0D; d0 = 0.0D; @@ -540,12 +547,12 @@ public abstract class Entity { double d12; int k; - if (this.X > 0.0F && flag1 && (flag || this.W < 0.05F) && (d6 != d0 || d8 != d2)) { + if (this.Y > 0.0F && flag1 && (flag || this.X < 0.05F) && (d6 != d0 || d8 != d2)) { d10 = d0; d11 = d1; d12 = d2; d0 = d6; - d1 = (double) this.X; + d1 = (double) this.Y; d2 = d8; AxisAlignedBB axisalignedbb1 = this.boundingBox.clone(); @@ -557,7 +564,7 @@ public abstract class Entity { } this.boundingBox.d(0.0D, d1, 0.0D); - if (!this.K && d7 != d1) { + if (!this.L && d7 != d1) { d2 = 0.0D; d1 = 0.0D; d0 = 0.0D; @@ -568,7 +575,7 @@ public abstract class Entity { } this.boundingBox.d(d0, 0.0D, 0.0D); - if (!this.K && d6 != d0) { + if (!this.L && d6 != d0) { d2 = 0.0D; d1 = 0.0D; d0 = 0.0D; @@ -579,18 +586,18 @@ public abstract class Entity { } this.boundingBox.d(0.0D, 0.0D, d2); - if (!this.K && d8 != d2) { + if (!this.L && d8 != d2) { d2 = 0.0D; d1 = 0.0D; d0 = 0.0D; } - if (!this.K && d7 != d1) { + if (!this.L && d7 != d1) { d2 = 0.0D; d1 = 0.0D; d0 = 0.0D; } else { - d1 = (double) (-this.X); + d1 = (double) (-this.Y); for (k = 0; k < list.size(); ++k) { d1 = ((AxisAlignedBB) list.get(k)).b(this.boundingBox, d1); @@ -604,24 +611,18 @@ public abstract class Entity { d1 = d11; d2 = d12; this.boundingBox.c(axisalignedbb1); - } else { - double d13 = this.boundingBox.b - (double) ((int) this.boundingBox.b); - - if (d13 > 0.0D) { - this.W = (float) ((double) this.W + d13 + 0.01D); - } } } this.world.methodProfiler.b(); this.world.methodProfiler.a("rest"); this.locX = (this.boundingBox.a + this.boundingBox.d) / 2.0D; - this.locY = this.boundingBox.b + (double) this.height - (double) this.W; + this.locY = this.boundingBox.b + (double) this.height - (double) this.X; this.locZ = (this.boundingBox.c + this.boundingBox.f) / 2.0D; this.positionChanged = d6 != d0 || d8 != d2; - this.G = d7 != d1; + this.H = d7 != d1; this.onGround = d7 != d1 && d7 < 0.0D; - this.H = this.positionChanged || this.G; + this.I = this.positionChanged || this.H; this.a(d1, this.onGround); if (d6 != d0) { this.motX = 0.0D; @@ -678,11 +679,11 @@ public abstract class Entity { d11 = 0.0D; } - this.Q = (float) ((double) this.Q + (double) MathHelper.sqrt(d10 * d10 + d12 * d12) * 0.6D); - this.R = (float) ((double) this.R + (double) MathHelper.sqrt(d10 * d10 + d11 * d11 + d12 * d12) * 0.6D); - if (this.R > (float) this.c && j1 > 0) { - this.c = (int) this.R + 1; - if (this.H()) { + this.R = (float) ((double) this.R + (double) MathHelper.sqrt(d10 * d10 + d12 * d12) * 0.6D); + this.S = (float) ((double) this.S + (double) MathHelper.sqrt(d10 * d10 + d11 * d11 + d12 * d12) * 0.6D); + if (this.S > (float) this.c && j1 > 0) { + this.c = (int) this.S + 1; + if (this.G()) { float f = MathHelper.sqrt(this.motX * this.motX * 0.20000000298023224D + this.motY * this.motY + this.motZ * this.motZ * 0.20000000298023224D) * 0.35F; if (f > 1.0F) { @@ -697,8 +698,8 @@ public abstract class Entity { } } - this.D(); - boolean flag2 = this.G(); + this.C(); + boolean flag2 = this.F(); if (this.world.e(this.boundingBox.shrink(0.001D, 0.001D, 0.001D))) { this.burn(1); @@ -730,7 +731,7 @@ public abstract class Entity { } } - protected void D() { + protected void C() { int i = MathHelper.floor(this.boundingBox.a + 0.001D); int j = MathHelper.floor(this.boundingBox.b + 0.001D); int k = MathHelper.floor(this.boundingBox.c + 0.001D); @@ -738,7 +739,7 @@ public abstract class Entity { int i1 = MathHelper.floor(this.boundingBox.e - 0.001D); int j1 = MathHelper.floor(this.boundingBox.f - 0.001D); - if (this.world.d(i, j, k, l, i1, j1)) { + if (this.world.e(i, j, k, l, i1, j1)) { for (int k1 = i; k1 <= l; ++k1) { for (int l1 = j; l1 <= i1; ++l1) { for (int i2 = k; i2 <= j1; ++i2) { @@ -783,7 +784,7 @@ public abstract class Entity { } } - public AxisAlignedBB E() { + public AxisAlignedBB D() { return null; } @@ -817,17 +818,17 @@ public abstract class Entity { } } + public boolean F() { + return this.ae || this.world.F(MathHelper.floor(this.locX), MathHelper.floor(this.locY), MathHelper.floor(this.locZ)) || this.world.F(MathHelper.floor(this.locX), MathHelper.floor(this.locY + (double) this.length), MathHelper.floor(this.locZ)); + } + public boolean G() { - return this.ad || this.world.D(MathHelper.floor(this.locX), MathHelper.floor(this.locY), MathHelper.floor(this.locZ)) || this.world.D(MathHelper.floor(this.locX), MathHelper.floor(this.locY + (double) this.length), MathHelper.floor(this.locZ)); + return this.ae; } public boolean H() { - return this.ad; - } - - public boolean I() { if (this.world.a(this.boundingBox.grow(0.0D, -0.4000000059604645D, 0.0D).shrink(0.001D, 0.001D, 0.001D), Material.WATER, this)) { - if (!this.ad && !this.justCreated) { + if (!this.ae && !this.justCreated) { float f = MathHelper.sqrt(this.motX * this.motX * 0.20000000298023224D + this.motY * this.motY + this.motZ * this.motZ * 0.20000000298023224D) * 0.2F; if (f > 1.0F) { @@ -855,13 +856,13 @@ public abstract class Entity { } this.fallDistance = 0.0F; - this.ad = true; + this.ae = true; this.fireTicks = 0; } else { - this.ad = false; + this.ae = false; } - return this.ad; + return this.ae; } public boolean a(Material material) { @@ -872,7 +873,7 @@ public abstract class Entity { int l = this.world.getTypeId(i, j, k); if (l != 0 && Block.byId[l].material == material) { - float f = BlockFluids.e(this.world.getData(i, j, k)) - 0.11111111F; + float f = BlockFluids.d(this.world.getData(i, j, k)) - 0.11111111F; float f1 = (float) (j + 1) - f; return d0 < (double) f1; @@ -885,7 +886,7 @@ public abstract class Entity { return 0.0F; } - public boolean J() { + public boolean I() { return this.world.a(this.boundingBox.grow(-0.10000000149011612D, -0.4000000059604645D, -0.10000000149011612D), Material.LAVA); } @@ -917,7 +918,7 @@ public abstract class Entity { double d0 = (this.boundingBox.e - this.boundingBox.b) * 0.66D; int k = MathHelper.floor(this.locY - (double) this.height + d0); - return this.world.p(i, k, j); + return this.world.q(i, k, j); } else { return 0.0F; } @@ -941,7 +942,7 @@ public abstract class Entity { this.lastZ = this.locZ = d2; this.lastYaw = this.yaw = f; this.lastPitch = this.pitch = f1; - this.W = 0.0F; + this.X = 0.0F; double d3 = (double) (this.lastYaw - f); if (d3 < -180.0D) { @@ -957,9 +958,9 @@ public abstract class Entity { } public void setPositionRotation(double d0, double d1, double d2, float f, float f1) { - this.T = this.lastX = this.locX = d0; - this.U = this.lastY = this.locY = d1 + (double) this.height; - this.V = this.lastZ = this.locZ = d2; + this.U = this.lastX = this.locX = d0; + this.V = this.lastY = this.locY = d1 + (double) this.height; + this.W = this.lastZ = this.locZ = d2; this.yaw = f; this.pitch = f1; this.setPosition(this.locX, this.locY, this.locZ); @@ -997,7 +998,7 @@ public abstract class Entity { return d0 * d0 + d1 * d1 + d2 * d2; } - public void c_(EntityHuman entityhuman) {} + public void b_(EntityHuman entityhuman) {} public void collide(Entity entity) { if (entity.passenger != this && entity.vehicle != this) { @@ -1019,8 +1020,8 @@ public abstract class Entity { d1 *= d3; d0 *= 0.05000000074505806D; d1 *= 0.05000000074505806D; - d0 *= (double) (1.0F - this.Z); - d1 *= (double) (1.0F - this.Z); + d0 *= (double) (1.0F - this.aa); + d1 *= (double) (1.0F - this.aa); this.g(-d0, 0.0D, -d1); entity.g(d0, 0.0D, d1); } @@ -1031,10 +1032,10 @@ public abstract class Entity { this.motX += d0; this.motY += d1; this.motZ += d2; - this.am = true; + this.an = true; } - protected void K() { + protected void J() { this.velocityChanged = true; } @@ -1042,36 +1043,48 @@ public abstract class Entity { if (this.isInvulnerable()) { return false; } else { - this.K(); + this.J(); return false; } } + public boolean K() { + return false; + } + public boolean L() { return false; } - public boolean M() { - return false; - } - public void c(Entity entity, int i) {} public boolean c(NBTTagCompound nbttagcompound) { - String s = this.Q(); + String s = this.P(); if (!this.dead && s != null) { nbttagcompound.setString("id", s); - this.d(nbttagcompound); + this.e(nbttagcompound); return true; } else { return false; } } - public void d(NBTTagCompound nbttagcompound) { + public boolean d(NBTTagCompound nbttagcompound) { + String s = this.P(); + + if (!this.dead && s != null && this.passenger == null) { + nbttagcompound.setString("id", s); + this.e(nbttagcompound); + return true; + } else { + return false; + } + } + + public void e(NBTTagCompound nbttagcompound) { try { - nbttagcompound.set("Pos", this.a(new double[] { this.locX, this.locY + (double) this.W, this.locZ})); + nbttagcompound.set("Pos", this.a(new double[] { this.locX, this.locY + (double) this.X, this.locZ})); nbttagcompound.set("Motion", this.a(new double[] { this.motX, this.motY, this.motZ})); // CraftBukkit start - checking for NaN pitch/yaw and resetting to zero @@ -1093,14 +1106,21 @@ public abstract class Entity { nbttagcompound.setInt("Dimension", this.dimension); nbttagcompound.setBoolean("Invulnerable", this.invulnerable); nbttagcompound.setInt("PortalCooldown", this.portalCooldown); + nbttagcompound.setLong("UUIDMost", this.uniqueID.getMostSignificantBits()); + nbttagcompound.setLong("UUIDLeast", this.uniqueID.getLeastSignificantBits()); // CraftBukkit start nbttagcompound.setLong("WorldUUIDLeast", this.world.getDataManager().getUUID().getLeastSignificantBits()); nbttagcompound.setLong("WorldUUIDMost", this.world.getDataManager().getUUID().getMostSignificantBits()); - nbttagcompound.setLong("UUIDLeast", this.uniqueId.getLeastSignificantBits()); - nbttagcompound.setLong("UUIDMost", this.uniqueId.getMostSignificantBits()); nbttagcompound.setInt("Bukkit.updateLevel", CURRENT_LEVEL); // CraftBukkit end this.b(nbttagcompound); + if (this.vehicle != null) { + NBTTagCompound nbttagcompound1 = new NBTTagCompound("Riding"); + + if (this.vehicle.c(nbttagcompound1)) { + nbttagcompound.set("Riding", nbttagcompound1); + } + } } catch (Throwable throwable) { CrashReport crashreport = CrashReport.a(throwable, "Saving entity NBT"); CrashReportSystemDetails crashreportsystemdetails = crashreport.a("Entity being saved"); @@ -1110,7 +1130,7 @@ public abstract class Entity { } } - public void e(NBTTagCompound nbttagcompound) { + public void f(NBTTagCompound nbttagcompound) { try { NBTTagList nbttaglist = nbttagcompound.getList("Pos"); NBTTagList nbttaglist1 = nbttagcompound.getList("Motion"); @@ -1133,9 +1153,9 @@ public abstract class Entity { } // CraftBukkit end */ - this.lastX = this.T = this.locX = ((NBTTagDouble) nbttaglist.get(0)).data; - this.lastY = this.U = this.locY = ((NBTTagDouble) nbttaglist.get(1)).data; - this.lastZ = this.V = this.locZ = ((NBTTagDouble) nbttaglist.get(2)).data; + this.lastX = this.U = this.locX = ((NBTTagDouble) nbttaglist.get(0)).data; + this.lastY = this.V = this.locY = ((NBTTagDouble) nbttaglist.get(1)).data; + this.lastZ = this.W = this.locZ = ((NBTTagDouble) nbttaglist.get(2)).data; this.lastYaw = this.yaw = ((NBTTagFloat) nbttaglist2.get(0)).data; this.lastPitch = this.pitch = ((NBTTagFloat) nbttaglist2.get(1)).data; this.fallDistance = nbttagcompound.getFloat("FallDistance"); @@ -1145,17 +1165,11 @@ public abstract class Entity { this.dimension = nbttagcompound.getInt("Dimension"); this.invulnerable = nbttagcompound.getBoolean("Invulnerable"); this.portalCooldown = nbttagcompound.getInt("PortalCooldown"); - this.setPosition(this.locX, this.locY, this.locZ); - - // CraftBukkit start - long least = nbttagcompound.getLong("UUIDLeast"); - long most = nbttagcompound.getLong("UUIDMost"); - - if (least != 0L && most != 0L) { - this.uniqueId = new UUID(most, least); + if (nbttagcompound.hasKey("UUIDMost") && nbttagcompound.hasKey("UUIDLeast")) { + this.uniqueID = new UUID(nbttagcompound.getLong("UUIDMost"), nbttagcompound.getLong("UUIDLeast")); } - // CraftBukkit end + this.setPosition(this.locX, this.locY, this.locZ); this.b(this.yaw, this.pitch); this.a(nbttagcompound); @@ -1222,7 +1236,7 @@ public abstract class Entity { } } - protected final String Q() { + protected final String P() { return EntityTypes.b(this); } @@ -1287,7 +1301,7 @@ public abstract class Entity { int k = MathHelper.floor(this.locY + (double) this.getHeadHeight() + (double) f1); int l = MathHelper.floor(this.locZ + (double) f2); - if (this.world.t(j, k, l)) { + if (this.world.u(j, k, l)) { return true; } } @@ -1295,7 +1309,7 @@ public abstract class Entity { return false; } - public boolean a(EntityHuman entityhuman) { + public boolean a_(EntityHuman entityhuman) { return false; } @@ -1303,16 +1317,16 @@ public abstract class Entity { return null; } - public void U() { + public void T() { if (this.vehicle.dead) { this.vehicle = null; } else { this.motX = 0.0D; this.motY = 0.0D; this.motZ = 0.0D; - this.j_(); + this.l_(); if (this.vehicle != null) { - this.vehicle.V(); + this.vehicle.U(); this.g += (double) (this.vehicle.yaw - this.vehicle.lastYaw); for (this.f += (double) (this.vehicle.pitch - this.vehicle.lastPitch); this.g >= 180.0D; this.g -= 360.0D) { @@ -1359,21 +1373,23 @@ public abstract class Entity { } } - public void V() { - if (!(this.passenger instanceof EntityHuman) || !((EntityHuman) this.passenger).bV()) { - this.passenger.T = this.T; - this.passenger.U = this.U + this.X() + this.passenger.W(); - this.passenger.V = this.V; - } + public void U() { + if (this.passenger != null) { + if (!(this.passenger instanceof EntityHuman) || !((EntityHuman) this.passenger).ce()) { + 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.X() + this.passenger.W(), this.locZ); + this.passenger.setPosition(this.locX, this.locY + this.W() + this.passenger.V(), this.locZ); + } } - public double W() { + public double V() { return (double) this.height; } - public double X() { + public double W() { return (double) this.length * 0.75D; } @@ -1413,17 +1429,6 @@ public abstract class Entity { this.vehicle.passenger = null; } - this.vehicle = null; - } else if (this.vehicle == entity) { - // CraftBukkit start - if ((this.bukkitEntity instanceof LivingEntity) && (this.vehicle.getBukkitEntity() instanceof Vehicle)) { - VehicleExitEvent event = new VehicleExitEvent((Vehicle) this.vehicle.getBukkitEntity(), (LivingEntity) this.bukkitEntity); - pluginManager.callEvent(event); - } - // CraftBukkit end - - this.h(entity); - this.vehicle.passenger = null; this.vehicle = null; } else { // CraftBukkit start @@ -1441,19 +1446,21 @@ public abstract class Entity { this.vehicle.passenger = null; } - if (entity.passenger != null) { - entity.passenger.vehicle = null; - } - this.vehicle = entity; entity.passenger = this; } } public void h(Entity entity) { - double d0 = entity.locX; - double d1 = entity.boundingBox.b + (double) entity.length; - double d2 = entity.locZ; + 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) { @@ -1463,12 +1470,12 @@ public abstract class Entity { AxisAlignedBB axisalignedbb = this.boundingBox.c(d3, 1.0D, d4); if (this.world.a(axisalignedbb).isEmpty()) { - if (this.world.v(i, (int) this.locY, j)) { + 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.v(i, (int) this.locY - 1, j) || this.world.getMaterial(i, (int) this.locY - 1, j) == Material.WATER) { + 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; @@ -1481,30 +1488,30 @@ public abstract class Entity { this.setPositionRotation(d0, d1, d2, this.yaw, this.pitch); } - public float Y() { + public float X() { return 0.1F; } - public Vec3D Z() { + public Vec3D Y() { return null; } - public void aa() { + public void Z() { if (this.portalCooldown > 0) { - this.portalCooldown = this.ab(); + this.portalCooldown = this.aa(); } else { double d0 = this.lastX - this.locX; double d1 = this.lastZ - this.locZ; - if (!this.world.isStatic && !this.ao) { - this.ar = Direction.a(d0, d1); + if (!this.world.isStatic && !this.ap) { + this.as = Direction.a(d0, d1); } - this.ao = true; + this.ap = true; } } - public int ab() { + public int aa() { return 900; } @@ -1515,15 +1522,15 @@ public abstract class Entity { public void setEquipment(int i, ItemStack itemstack) {} public boolean isBurning() { - return this.fireTicks > 0 || this.e(0); + return this.fireTicks > 0 || this.f(0); } - public boolean ag() { - return this.vehicle != null || this.e(2); + public boolean af() { + return this.vehicle != null || this.f(2); } public boolean isSneaking() { - return this.e(1); + return this.f(1); } public void setSneaking(boolean flag) { @@ -1531,7 +1538,7 @@ public abstract class Entity { } public boolean isSprinting() { - return this.e(3); + return this.f(3); } public void setSprinting(boolean flag) { @@ -1539,18 +1546,18 @@ public abstract class Entity { } public boolean isInvisible() { - return this.e(5); + return this.f(5); } public void setInvisible(boolean flag) { this.a(5, flag); } - public void d(boolean flag) { + public void e(boolean flag) { this.a(4, flag); } - protected boolean e(int i) { + protected boolean f(int i) { return (this.datawatcher.getByte(0) & 1 << i) != 0; } @@ -1621,15 +1628,15 @@ public abstract class Entity { double d5 = d2 - (double) k; List list = this.world.a(this.boundingBox); - if (list.isEmpty() && !this.world.u(i, j, k)) { + if (list.isEmpty() && !this.world.v(i, j, k)) { return false; } else { - boolean flag = !this.world.u(i - 1, j, k); - boolean flag1 = !this.world.u(i + 1, j, k); - boolean flag2 = !this.world.u(i, j - 1, k); - boolean flag3 = !this.world.u(i, j + 1, k); - boolean flag4 = !this.world.u(i, j, k - 1); - boolean flag5 = !this.world.u(i, j, k + 1); + boolean flag = !this.world.v(i - 1, j, k); + boolean flag1 = !this.world.v(i + 1, j, k); + boolean flag2 = !this.world.v(i, j - 1, k); + boolean flag3 = !this.world.v(i, j + 1, k); + boolean flag4 = !this.world.v(i, j, k - 1); + boolean flag5 = !this.world.v(i, j, k + 1); byte b0 = 3; double d6 = 9999.0D; @@ -1688,8 +1695,8 @@ public abstract class Entity { } } - public void am() { - this.J = true; + public void al() { + this.K = true; this.fallDistance = 0.0F; } @@ -1703,7 +1710,7 @@ public abstract class Entity { return LocaleI18n.get("entity." + s + ".name"); } - public Entity[] ao() { + public Entity[] an() { return null; } @@ -1711,11 +1718,11 @@ public abstract class Entity { return this == entity; } - public float ap() { + public float ao() { return 0.0F; } - public boolean aq() { + public boolean ap() { return true; } @@ -1738,13 +1745,13 @@ public abstract class Entity { public void a(Entity entity, boolean flag) { NBTTagCompound nbttagcompound = new NBTTagCompound(); - entity.d(nbttagcompound); - this.e(nbttagcompound); + entity.e(nbttagcompound); + this.f(nbttagcompound); this.portalCooldown = entity.portalCooldown; - this.ar = entity.ar; + this.as = entity.as; } - public void b(int i) { + public void c(int i) { if (!this.world.isStatic && !this.dead) { this.world.methodProfiler.a("changeDimension"); MinecraftServer minecraftserver = MinecraftServer.getServer(); @@ -1814,28 +1821,40 @@ public abstract class Entity { } } - public float a(Explosion explosion, Block block, int i, int j, int k) { + public float a(Explosion explosion, World world, int i, int j, int k, Block block) { return block.a(this); } - public int as() { + public boolean a(Explosion explosion, World world, int i, int j, int k, int l, float f) { + return true; + } + + public int ar() { return 3; } - public int at() { - return this.ar; + public int as() { + return this.as; } - public boolean au() { + public boolean at() { return false; } public void a(CrashReportSystemDetails crashreportsystemdetails) { crashreportsystemdetails.a("Entity Type", (Callable) (new CrashReportEntityType(this))); crashreportsystemdetails.a("Entity ID", Integer.valueOf(this.id)); - crashreportsystemdetails.a("Name", this.getLocalizedName()); - crashreportsystemdetails.a("Exact location", String.format("%.2f, %.2f, %.2f", new Object[] { Double.valueOf(this.locX), Double.valueOf(this.locY), Double.valueOf(this.locZ)})); - crashreportsystemdetails.a("Block location", CrashReportSystemDetails.a(MathHelper.floor(this.locX), MathHelper.floor(this.locY), MathHelper.floor(this.locZ))); - crashreportsystemdetails.a("Momentum", String.format("%.2f, %.2f, %.2f", new Object[] { Double.valueOf(this.motX), Double.valueOf(this.motY), Double.valueOf(this.motZ)})); + crashreportsystemdetails.a("Entity Name", (Callable) (new CrashReportEntityName(this))); + crashreportsystemdetails.a("Entity\'s Exact location", String.format("%.2f, %.2f, %.2f", new Object[] { Double.valueOf(this.locX), Double.valueOf(this.locY), Double.valueOf(this.locZ)})); + crashreportsystemdetails.a("Entity\'s Block location", CrashReportSystemDetails.a(MathHelper.floor(this.locX), MathHelper.floor(this.locY), MathHelper.floor(this.locZ))); + 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() { + return true; + } + + public String getScoreboardDisplayName() { + return this.getLocalizedName(); } } diff --git a/src/main/java/net/minecraft/server/EntityAgeable.java b/src/main/java/net/minecraft/server/EntityAgeable.java index 845a9023e4..fdc9167a9d 100644 --- a/src/main/java/net/minecraft/server/EntityAgeable.java +++ b/src/main/java/net/minecraft/server/EntityAgeable.java @@ -1,6 +1,9 @@ package net.minecraft.server; public abstract class EntityAgeable extends EntityCreature { + + private float d = -1.0F; + private float e; public boolean ageLocked = false; // CraftBukkit public EntityAgeable(World world) { @@ -9,7 +12,7 @@ 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) { @@ -22,9 +25,13 @@ public abstract class EntityAgeable extends EntityCreature { 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 "infinit" + if (itemstack.count == 0) { // CraftBukkit - allow less than 0 stacks as "infinite" entityhuman.inventory.setItem(entityhuman.inventory.itemInHandIndex, (ItemStack) null); } } @@ -32,7 +39,7 @@ public abstract class EntityAgeable extends EntityCreature { } } - return super.a(entityhuman); + return super.a_(entityhuman); } protected void a() { @@ -46,6 +53,7 @@ public abstract class EntityAgeable extends EntityCreature { public void setAge(int i) { this.datawatcher.watch(12, Integer.valueOf(i)); + this.a(this.isBaby()); } public void b(NBTTagCompound nbttagcompound) { @@ -62,19 +70,40 @@ public abstract class EntityAgeable extends EntityCreature { public void c() { super.c(); - int i = this.getAge(); + if (this.world.isStatic || this.ageLocked) { // CraftBukkit + this.a(this.isBaby()); + } else { + int i = this.getAge(); - if (ageLocked) return; // CraftBukkit - if (i < 0) { - ++i; - this.setAge(i); - } else if (i > 0) { - --i; - this.setAge(i); + if (i < 0) { + ++i; + this.setAge(i); + } else if (i > 0) { + --i; + this.setAge(i); + } } } public boolean isBaby() { return this.getAge() < 0; } + + public void a(boolean flag) { + this.j(flag ? 0.5F : 1.0F); + } + + protected final void a(float f, float f1) { + boolean flag = this.d > 0.0F; + + this.d = f; + this.e = f1; + if (!flag) { + this.j(1.0F); + } + } + + private void j(float f) { + super.a(this.d * f, this.e * f); + } } diff --git a/src/main/java/net/minecraft/server/EntityArrow.java b/src/main/java/net/minecraft/server/EntityArrow.java index 916b9dc91f..4b473647c1 100644 --- a/src/main/java/net/minecraft/server/EntityArrow.java +++ b/src/main/java/net/minecraft/server/EntityArrow.java @@ -21,9 +21,9 @@ public class EntityArrow extends Entity implements IProjectile { public int shake = 0; public Entity shooter; private int j; - private int at = 0; + private int au = 0; private double damage = 2.0D; - private int av; + private int aw; public EntityArrow(World world) { super(world); @@ -49,7 +49,7 @@ public class EntityArrow extends Entity implements IProjectile { this.locY = entityliving.locY + (double) entityliving.getHeadHeight() - 0.10000000149011612D; double d0 = entityliving1.locX - entityliving.locX; - double d1 = entityliving1.locY + (double) entityliving1.getHeadHeight() - 0.699999988079071D - this.locY; + double d1 = entityliving1.boundingBox.b + (double) (entityliving1.length / 3.0F) - this.locY; double d2 = entityliving1.locZ - entityliving.locZ; double d3 = (double) MathHelper.sqrt(d0 * d0 + d2 * d2); @@ -98,9 +98,9 @@ public class EntityArrow extends Entity implements IProjectile { d0 /= (double) f2; d1 /= (double) f2; d2 /= (double) f2; - d0 += this.random.nextGaussian() * 0.007499999832361937D * (double) f1; - d1 += this.random.nextGaussian() * 0.007499999832361937D * (double) f1; - d2 += this.random.nextGaussian() * 0.007499999832361937D * (double) f1; + d0 += this.random.nextGaussian() * (double) (this.random.nextBoolean() ? -1 : 1) * 0.007499999832361937D * (double) f1; + d1 += this.random.nextGaussian() * (double) (this.random.nextBoolean() ? -1 : 1) * 0.007499999832361937D * (double) f1; + d2 += this.random.nextGaussian() * (double) (this.random.nextBoolean() ? -1 : 1) * 0.007499999832361937D * (double) f1; d0 *= (double) f; d1 *= (double) f; d2 *= (double) f; @@ -114,8 +114,8 @@ public class EntityArrow extends Entity implements IProjectile { this.j = 0; } - public void j_() { - super.j_(); + public void l_() { + super.l_(); if (this.lastPitch == 0.0F && this.lastYaw == 0.0F) { float f = MathHelper.sqrt(this.motX * this.motX + this.motZ * this.motZ); @@ -127,7 +127,7 @@ public class EntityArrow extends Entity implements IProjectile { if (i > 0) { Block.byId[i].updateShape(this.world, this.d, this.e, this.f); - AxisAlignedBB axisalignedbb = Block.byId[i].e(this.world, this.d, this.e, this.f); + AxisAlignedBB axisalignedbb = Block.byId[i].b(this.world, this.d, this.e, this.f); if (axisalignedbb != null && axisalignedbb.a(this.world.getVec3DPool().create(this.locX, this.locY, this.locZ))) { this.inGround = true; @@ -153,10 +153,10 @@ public class EntityArrow extends Entity implements IProjectile { this.motY *= (double) (this.random.nextFloat() * 0.2F); this.motZ *= (double) (this.random.nextFloat() * 0.2F); this.j = 0; - this.at = 0; + this.au = 0; } } else { - ++this.at; + ++this.au; Vec3D vec3d = this.world.getVec3DPool().create(this.locX, this.locY, this.locZ); Vec3D vec3d1 = this.world.getVec3DPool().create(this.locX + this.motX, this.locY + this.motY, this.locZ + this.motZ); MovingObjectPosition movingobjectposition = this.world.rayTrace(vec3d, vec3d1, false, true); @@ -177,7 +177,7 @@ public class EntityArrow extends Entity implements IProjectile { for (l = 0; l < list.size(); ++l) { Entity entity1 = (Entity) list.get(l); - if (entity1.L() && (entity1 != this.shooter || this.at >= 5)) { + if (entity1.K() && (entity1 != this.shooter || this.au >= 5)) { f1 = 0.3F; AxisAlignedBB axisalignedbb1 = entity1.boundingBox.grow((double) f1, (double) f1, (double) f1); MovingObjectPosition movingobjectposition1 = axisalignedbb1.a(vec3d, vec3d1); @@ -197,6 +197,14 @@ public class EntityArrow extends Entity implements IProjectile { movingobjectposition = new MovingObjectPosition(entity); } + if (movingobjectposition != null && movingobjectposition.entity != null && movingobjectposition.entity instanceof EntityHuman) { + EntityHuman entityhuman = (EntityHuman) movingobjectposition.entity; + + if (entityhuman.abilities.isInvulnerable || this.shooter instanceof EntityHuman && !((EntityHuman) this.shooter).a(entityhuman)) { + movingobjectposition = null; + } + } + float f2; float f3; @@ -206,6 +214,7 @@ public class EntityArrow extends Entity implements IProjectile { ProjectileHitEvent phe = new ProjectileHitEvent(projectile); this.world.getServer().getPluginManager().callEvent(phe); // CraftBukkit end + if (movingobjectposition.entity != null) { f2 = MathHelper.sqrt(this.motX * this.motX + this.motY * this.motY + this.motZ * this.motZ); int i1 = MathHelper.f((double) f2 * this.damage); @@ -224,7 +233,7 @@ public class EntityArrow extends Entity implements IProjectile { // CraftBukkit start - moved damage call if (movingobjectposition.entity.damageEntity(damagesource, i1)) { - if (this.isBurning() && !(movingobjectposition.entity instanceof EntityEnderman) && (!(movingobjectposition.entity instanceof EntityPlayer) || !(this.shooter instanceof EntityPlayer) || this.world.pvpMode)) { // CraftBukkit - abide by pvp setting if destination is a player. + if (this.isBurning() && !(movingobjectposition.entity instanceof EntityEnderman) && (!(movingobjectposition.entity instanceof EntityPlayer) || !(this.shooter instanceof EntityPlayer) || this.world.pvpMode)) { // CraftBukkit - abide by pvp setting if destination is a player EntityCombustByEntityEvent combustEvent = new EntityCombustByEntityEvent(this.getBukkitEntity(), entity.getBukkitEntity(), 5); org.bukkit.Bukkit.getPluginManager().callEvent(combustEvent); @@ -239,14 +248,13 @@ public class EntityArrow extends Entity implements IProjectile { EntityLiving entityliving = (EntityLiving) movingobjectposition.entity; if (!this.world.isStatic) { - entityliving.r(entityliving.bJ() + 1); + entityliving.r(entityliving.bM() + 1); } - if (this.av > 0) { + if (this.aw > 0) { f3 = MathHelper.sqrt(this.motX * this.motX + this.motZ * this.motZ); - if (f3 > 0.0F) { - movingobjectposition.entity.g(this.motX * (double) this.av * 0.6000000238418579D / (double) f3, 0.1D, this.motZ * (double) this.av * 0.6000000238418579D / (double) f3); + movingobjectposition.entity.g(this.motX * (double) this.aw * 0.6000000238418579D / (double) f3, 0.1D, this.motZ * (double) this.aw * 0.6000000238418579D / (double) f3); } } @@ -269,7 +277,7 @@ public class EntityArrow extends Entity implements IProjectile { this.motZ *= -0.10000000149011612D; this.yaw += 180.0F; this.lastYaw += 180.0F; - this.at = 0; + this.au = 0; } } else { this.d = movingobjectposition.b; @@ -287,9 +295,9 @@ public class EntityArrow extends Entity implements IProjectile { this.makeSound("random.bowhit", 1.0F, 1.2F / (this.random.nextFloat() * 0.2F + 0.9F)); this.inGround = true; this.shake = 7; - this.e(false); + this.a(false); if (this.g != 0) { - Block.byId[this.g].a(this.world, this.d, this.e, this.f, this); + Block.byId[this.g].a(this.world, this.d, this.e, this.f, (Entity) this); } } } @@ -327,7 +335,7 @@ public class EntityArrow extends Entity implements IProjectile { float f4 = 0.99F; f1 = 0.05F; - if (this.H()) { + if (this.G()) { for (int j1 = 0; j1 < 4; ++j1) { f3 = 0.25F; this.world.addParticle("bubble", this.locX - this.motX * (double) f3, this.locY - this.motY * (double) f3, this.locZ - this.motZ * (double) f3, this.motX, this.motY, this.motZ); @@ -341,7 +349,7 @@ public class EntityArrow extends Entity implements IProjectile { this.motZ *= (double) f4; this.motY -= (double) f1; this.setPosition(this.locX, this.locY, this.locZ); - this.D(); + this.C(); } } @@ -376,7 +384,7 @@ public class EntityArrow extends Entity implements IProjectile { } } - public void c_(EntityHuman entityhuman) { + public void b_(EntityHuman entityhuman) { if (!this.world.isStatic && this.inGround && this.shake <= 0) { // CraftBukkit start ItemStack itemstack = new ItemStack(Item.ARROW); @@ -420,14 +428,14 @@ public class EntityArrow extends Entity implements IProjectile { } public void a(int i) { - this.av = i; + this.aw = i; } - public boolean aq() { + public boolean ap() { return false; } - public void e(boolean flag) { + public void a(boolean flag) { byte b0 = this.datawatcher.getByte(16); if (flag) { diff --git a/src/main/java/net/minecraft/server/EntityBlaze.java b/src/main/java/net/minecraft/server/EntityBlaze.java index 74739a21a2..8c72066f13 100644 --- a/src/main/java/net/minecraft/server/EntityBlaze.java +++ b/src/main/java/net/minecraft/server/EntityBlaze.java @@ -10,7 +10,7 @@ public class EntityBlaze extends EntityMonster { super(world); this.texture = "/mob/fire.png"; this.fireProof = true; - this.bd = 10; + this.be = 10; } public int getMaxHealth() { @@ -22,15 +22,15 @@ public class EntityBlaze extends EntityMonster { this.datawatcher.a(16, new Byte((byte) 0)); } - protected String aY() { + protected String bb() { return "mob.blaze.breathe"; } - protected String aZ() { + protected String bc() { return "mob.blaze.hit"; } - protected String ba() { + protected String bd() { return "mob.blaze.death"; } @@ -40,7 +40,7 @@ public class EntityBlaze extends EntityMonster { public void c() { if (!this.world.isStatic) { - if (this.G()) { + if (this.F()) { this.damageEntity(DamageSource.DROWN, 1); } @@ -83,13 +83,13 @@ public class EntityBlaze extends EntityMonster { ++this.f; if (this.f == 1) { this.attackTicks = 60; - this.f(true); + this.a(true); } else if (this.f <= 4) { this.attackTicks = 6; } else { this.attackTicks = 100; this.f = 0; - this.f(false); + this.a(false); } if (this.f > 1) { @@ -140,7 +140,7 @@ public class EntityBlaze extends EntityMonster { return (this.datawatcher.getByte(16) & 1) != 0; } - public void f(boolean flag) { + public void a(boolean flag) { byte b0 = this.datawatcher.getByte(16); if (flag) { diff --git a/src/main/java/net/minecraft/server/EntityBoat.java b/src/main/java/net/minecraft/server/EntityBoat.java index 8fce559796..827b3a0f1b 100644 --- a/src/main/java/net/minecraft/server/EntityBoat.java +++ b/src/main/java/net/minecraft/server/EntityBoat.java @@ -66,11 +66,11 @@ public class EntityBoat extends Entity { return entity.boundingBox; } - public AxisAlignedBB E() { + public AxisAlignedBB D() { return this.boundingBox; } - public boolean M() { + public boolean L() { return true; } @@ -87,7 +87,7 @@ public class EntityBoat extends Entity { this.world.getServer().getPluginManager().callEvent(new org.bukkit.event.vehicle.VehicleCreateEvent((Vehicle) this.getBukkitEntity())); // CraftBukkit } - public double X() { + public double W() { return (double) this.length * 0.0D - 0.30000001192092896D; } @@ -109,14 +109,12 @@ public class EntityBoat extends Entity { // CraftBukkit end this.h(-this.h()); - this.g(10); + this.b(10); this.setDamage(this.getDamage() + i * 10); - this.K(); - if (damagesource.getEntity() instanceof EntityHuman && ((EntityHuman) damagesource.getEntity()).abilities.canInstantlyBuild) { - this.setDamage(100); - } + this.J(); + boolean flag = damagesource.getEntity() instanceof EntityHuman && ((EntityHuman) damagesource.getEntity()).abilities.canInstantlyBuild; - if (this.getDamage() > 40) { + if (flag || this.getDamage() > 40) { // CraftBukkit start VehicleDestroyEvent destroyEvent = new VehicleDestroyEvent(vehicle, attacker); this.world.getServer().getPluginManager().callEvent(destroyEvent); @@ -131,7 +129,10 @@ public class EntityBoat extends Entity { this.passenger.mount(this); } - this.a(Item.BOAT.id, 1, 0.0F); + if (!flag) { + this.a(Item.BOAT.id, 1, 0.0F); + } + this.die(); } @@ -141,11 +142,11 @@ public class EntityBoat extends Entity { } } - public boolean L() { + public boolean K() { return !this.dead; } - public void j_() { + public void l_() { // CraftBukkit start double prevX = this.locX; double prevY = this.locY; @@ -154,9 +155,9 @@ public class EntityBoat extends Entity { float prevPitch = this.pitch; // CraftBukkit end - super.j_(); + super.l_(); if (this.g() > 0) { - this.g(this.g() - 1); + this.b(this.g() - 1); } if (this.getDamage() > 0) { @@ -363,7 +364,7 @@ public class EntityBoat extends Entity { for (l = 0; l < list.size(); ++l) { Entity entity = (Entity) list.get(l); - if (entity != this.passenger && entity.M() && entity instanceof EntityBoat) { + if (entity != this.passenger && entity.L() && entity instanceof EntityBoat) { entity.collide(this); } } @@ -376,13 +377,11 @@ public class EntityBoat extends Entity { for (int k1 = 0; k1 < 2; ++k1) { int l1 = MathHelper.floor(this.locY) + k1; int i2 = this.world.getTypeId(i1, l1, j1); - int j2 = this.world.getData(i1, l1, j1); if (i2 == Block.SNOW.id) { - this.world.setTypeId(i1, l1, j1, 0); + this.world.setAir(i1, l1, j1); } else if (i2 == Block.WATER_LILY.id) { - Block.WATER_LILY.dropNaturally(this.world, i1, l1, j1, j2, 0.3F, 0); - this.world.setTypeId(i1, l1, j1, 0); + this.world.setAir(i1, l1, j1, true); } } } @@ -395,12 +394,12 @@ public class EntityBoat extends Entity { } } - public void V() { + public void U() { if (this.passenger != null) { double d0 = Math.cos((double) this.yaw * 3.141592653589793D / 180.0D) * 0.4D; double d1 = Math.sin((double) this.yaw * 3.141592653589793D / 180.0D) * 0.4D; - this.passenger.setPosition(this.locX + d0, this.locY + this.X() + this.passenger.W(), this.locZ + d1); + this.passenger.setPosition(this.locX + d0, this.locY + this.W() + this.passenger.V(), this.locZ + d1); } } @@ -408,7 +407,7 @@ public class EntityBoat extends Entity { protected void a(NBTTagCompound nbttagcompound) {} - public boolean a(EntityHuman entityhuman) { + public boolean a_(EntityHuman entityhuman) { if (this.passenger != null && this.passenger instanceof EntityHuman && this.passenger != entityhuman) { return true; } else { @@ -428,7 +427,7 @@ public class EntityBoat extends Entity { return this.datawatcher.getInt(19); } - public void g(int i) { + public void b(int i) { this.datawatcher.watch(17, Integer.valueOf(i)); } diff --git a/src/main/java/net/minecraft/server/EntityChicken.java b/src/main/java/net/minecraft/server/EntityChicken.java index 2390261b6a..c5cf2d29bb 100644 --- a/src/main/java/net/minecraft/server/EntityChicken.java +++ b/src/main/java/net/minecraft/server/EntityChicken.java @@ -27,7 +27,7 @@ public class EntityChicken extends EntityAnimal { this.goalSelector.a(7, new PathfinderGoalRandomLookaround(this)); } - public boolean be() { + public boolean bh() { return true; } @@ -67,15 +67,15 @@ public class EntityChicken extends EntityAnimal { protected void a(float f) {} - protected String aY() { + protected String bb() { return "mob.chicken.say"; } - protected String aZ() { + protected String bc() { return "mob.chicken.hurt"; } - protected String ba() { + protected String bd() { 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 3bbdb2fa31..961051215f 100644 --- a/src/main/java/net/minecraft/server/EntityCow.java +++ b/src/main/java/net/minecraft/server/EntityCow.java @@ -22,7 +22,7 @@ public class EntityCow extends EntityAnimal { this.goalSelector.a(7, new PathfinderGoalRandomLookaround(this)); } - public boolean be() { + public boolean bh() { return true; } @@ -30,15 +30,15 @@ public class EntityCow extends EntityAnimal { return 10; } - protected String aY() { + protected String bb() { return "mob.cow.say"; } - protected String aZ() { + protected String bc() { return "mob.cow.hurt"; } - protected String ba() { + protected String bd() { return "mob.cow.hurt"; } @@ -46,7 +46,7 @@ public class EntityCow extends EntityAnimal { this.makeSound("mob.cow.step", 0.15F, 1.0F); } - protected float aX() { + protected float ba() { return 0.4F; } @@ -75,7 +75,7 @@ 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) { @@ -96,7 +96,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 45ee98a229..4d91a4618c 100644 --- a/src/main/java/net/minecraft/server/EntityCreature.java +++ b/src/main/java/net/minecraft/server/EntityCreature.java @@ -20,7 +20,7 @@ public abstract class EntityCreature extends EntityLiving { return false; } - protected void bn() { + protected void bq() { this.world.methodProfiler.a("ai"); if (this.c > 0) { --this.c; @@ -73,13 +73,13 @@ 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.bB < 100) { + } 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(); } int i = MathHelper.floor(this.boundingBox.b + 0.5D); - boolean flag = this.H(); - boolean flag1 = this.J(); + boolean flag = this.G(); + boolean flag1 = this.I(); this.pitch = 0.0F; if (this.pathEntity != null && this.random.nextInt(100) != 0) { @@ -97,7 +97,7 @@ public abstract class EntityCreature extends EntityLiving { } } - this.bF = false; + this.bG = false; if (vec3d != null) { double d1 = vec3d.c - this.locX; double d2 = vec3d.e - this.locZ; @@ -106,7 +106,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.bD = this.bH; + this.bE = this.bI; if (f3 > 30.0F) { f3 = 30.0F; } @@ -123,12 +123,12 @@ public abstract class EntityCreature extends EntityLiving { this.yaw = (float) (Math.atan2(d5, d4) * 180.0D / 3.1415927410125732D) - 90.0F; f3 = (f4 - this.yaw + 90.0F) * 3.1415927F / 180.0F; - this.bC = -MathHelper.sin(f3) * this.bD * 1.0F; - this.bD = MathHelper.cos(f3) * this.bD * 1.0F; + this.bD = -MathHelper.sin(f3) * this.bE * 1.0F; + this.bE = MathHelper.cos(f3) * this.bE * 1.0F; } if (d3 > 0.0D) { - this.bF = true; + this.bG = true; } } @@ -137,16 +137,16 @@ public abstract class EntityCreature extends EntityLiving { } if (this.positionChanged && !this.k()) { - this.bF = true; + this.bG = true; } if (this.random.nextFloat() < 0.8F && (flag || flag1)) { - this.bF = true; + this.bG = true; } this.world.methodProfiler.b(); } else { - super.bn(); + super.bq(); this.pathEntity = null; } } @@ -215,10 +215,10 @@ public abstract class EntityCreature extends EntityLiving { this.target = entity; } - public float bB() { - float f = super.bB(); + public float bE() { + float f = super.bE(); - if (this.c > 0 && !this.be()) { + if (this.c > 0 && !this.bh()) { f *= 2.0F; } diff --git a/src/main/java/net/minecraft/server/EntityCreeper.java b/src/main/java/net/minecraft/server/EntityCreeper.java index 1f64c1f656..091b8059a7 100644 --- a/src/main/java/net/minecraft/server/EntityCreeper.java +++ b/src/main/java/net/minecraft/server/EntityCreeper.java @@ -27,11 +27,11 @@ public class EntityCreeper extends EntityMonster { this.targetSelector.a(2, new PathfinderGoalHurtByTarget(this, false)); } - public boolean be() { + public boolean bh() { return true; } - public int as() { + public int ar() { return this.getGoalTarget() == null ? 3 : 3 + (this.health - 1); } @@ -75,7 +75,7 @@ public class EntityCreeper extends EntityMonster { } } - public void j_() { + public void l_() { if (this.isAlive()) { this.d = this.fuseTicks; int i = this.o(); @@ -109,14 +109,14 @@ public class EntityCreeper extends EntityMonster { } } - super.j_(); + super.l_(); } - protected String aZ() { + protected String bc() { return "mob.creeper.say"; } - protected String ba() { + protected String bd() { return "mob.creeper.death"; } diff --git a/src/main/java/net/minecraft/server/EntityDamageSourceIndirect.java b/src/main/java/net/minecraft/server/EntityDamageSourceIndirect.java index 940da7e919..19121530a3 100644 --- a/src/main/java/net/minecraft/server/EntityDamageSourceIndirect.java +++ b/src/main/java/net/minecraft/server/EntityDamageSourceIndirect.java @@ -9,16 +9,21 @@ public class EntityDamageSourceIndirect extends EntityDamageSource { this.owner = entity1; } - public Entity f() { - return this.r; + public Entity h() { + return this.p; } public Entity getEntity() { return this.owner; } - public String getLocalizedDeathMessage(EntityHuman entityhuman) { - return LocaleI18n.get("death." + this.translationIndex, new Object[] { entityhuman.name, this.owner == null ? this.r.getLocalizedName() : this.owner.getLocalizedName()}); + public String 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; + 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}); } // CraftBukkit start diff --git a/src/main/java/net/minecraft/server/EntityEnderCrystal.java b/src/main/java/net/minecraft/server/EntityEnderCrystal.java index f3395b4422..c0155a65c9 100644 --- a/src/main/java/net/minecraft/server/EntityEnderCrystal.java +++ b/src/main/java/net/minecraft/server/EntityEnderCrystal.java @@ -22,7 +22,7 @@ public class EntityEnderCrystal extends Entity { this.datawatcher.a(8, Integer.valueOf(this.b)); } - public void j_() { + public void l_() { this.lastX = this.locX; this.lastY = this.locY; this.lastZ = this.locZ; @@ -33,7 +33,7 @@ public class EntityEnderCrystal extends Entity { int k = MathHelper.floor(this.locZ); if (this.world.getTypeId(i, j, k) != Block.FIRE.id) { - this.world.setTypeId(i, j, k, Block.FIRE.id); + this.world.setTypeIdUpdate(i, j, k, Block.FIRE.id); } } @@ -41,7 +41,7 @@ public class EntityEnderCrystal extends Entity { protected void a(NBTTagCompound nbttagcompound) {} - public boolean L() { + public boolean K() { return true; } diff --git a/src/main/java/net/minecraft/server/EntityEnderDragon.java b/src/main/java/net/minecraft/server/EntityEnderDragon.java index ffbc15a88f..7019a1a23a 100644 --- a/src/main/java/net/minecraft/server/EntityEnderDragon.java +++ b/src/main/java/net/minecraft/server/EntityEnderDragon.java @@ -25,27 +25,27 @@ public class EntityEnderDragon extends EntityLiving implements IComplex { public EntityComplexPart h; public EntityComplexPart i; public EntityComplexPart j; - public EntityComplexPart bJ; public EntityComplexPart bK; public EntityComplexPart bL; - public float bM = 0.0F; + public EntityComplexPart bM; public float bN = 0.0F; - public boolean bO = false; + public float bO = 0.0F; public boolean bP = false; - private Entity bS; - public int bQ = 0; - public EntityEnderCrystal bR = null; + public boolean bQ = false; + private Entity bT; + public int bR = 0; + public EntityEnderCrystal bS = null; 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.bJ = new EntityComplexPart(this, "tail", 4.0F, 4.0F), this.bK = new EntityComplexPart(this, "wing", 4.0F, 4.0F), this.bL = new EntityComplexPart(this, "wing", 4.0F, 4.0F)}; + 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.setHealth(this.getMaxHealth()); this.texture = "/mob/enderdragon/ender.png"; this.a(16.0F, 8.0F); - this.Y = true; + this.Z = true; this.fireProof = true; this.b = 100.0D; - this.al = true; + this.am = true; } public int getMaxHealth() { @@ -57,7 +57,7 @@ public class EntityEnderDragon extends EntityLiving implements IComplex { this.datawatcher.a(16, new Integer(this.getMaxHealth())); } - public double[] a(int i, float f) { + public double[] b(int i, float f) { if (this.health <= 0) { f = 0.0F; } @@ -84,14 +84,14 @@ public class EntityEnderDragon extends EntityLiving implements IComplex { if (!this.world.isStatic) { this.datawatcher.watch(16, Integer.valueOf(this.getScaledHealth())); // CraftBukkit - this.health -> this.getScaledHealth() } else { - f = MathHelper.cos(this.bN * 3.1415927F * 2.0F); - f1 = MathHelper.cos(this.bM * 3.1415927F * 2.0F); + f = MathHelper.cos(this.bO * 3.1415927F * 2.0F); + f1 = MathHelper.cos(this.bN * 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.bM = this.bN; + this.bN = this.bO; float f2; if (this.health <= 0) { @@ -103,10 +103,10 @@ public class EntityEnderDragon extends EntityLiving implements IComplex { this.h(); 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.bP) { - this.bN += f * 0.5F; + if (this.bQ) { + this.bO += f * 0.5F; } else { - this.bN += f; + this.bO += f; } this.yaw = MathHelper.g(this.yaw); @@ -130,14 +130,14 @@ public class EntityEnderDragon extends EntityLiving implements IComplex { float f3; if (this.world.isStatic) { - if (this.bt > 0) { - d0 = this.locX + (this.bt - this.locX) / (double) this.bt; - d1 = this.locY + (this.bu - this.locY) / (double) this.bt; - d2 = this.locZ + (this.bv - this.locZ) / (double) this.bt; - d3 = MathHelper.g(this.bw - (double) this.yaw); - this.yaw = (float) ((double) this.yaw + d3 / (double) this.bt); - this.pitch = (float) ((double) this.pitch + (this.bx - (double) this.pitch) / (double) this.bt); - --this.bt; + 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; this.setPosition(d0, d1, d2); this.b(this.yaw, this.pitch); } @@ -146,9 +146,9 @@ public class EntityEnderDragon extends EntityLiving implements IComplex { d1 = this.b - this.locY; d2 = this.c - this.locZ; d3 = d0 * d0 + d1 * d1 + d2 * d2; - if (this.bS != null) { - this.a = this.bS.locX; - this.c = this.bS.locZ; + 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; double d6 = Math.sqrt(d4 * d4 + d5 * d5); @@ -158,13 +158,13 @@ public class EntityEnderDragon extends EntityLiving implements IComplex { d7 = 10.0D; } - this.b = this.bS.boundingBox.b + d7; + this.b = this.bT.boundingBox.b + d7; } else { this.a += this.random.nextGaussian() * 2.0D; this.c += this.random.nextGaussian() * 2.0D; } - if (this.bO || d3 < 100.0D || d3 > 22500.0D || this.positionChanged || this.G) { + if (this.bP || d3 < 100.0D || d3 > 22500.0D || this.positionChanged || this.H) { this.i(); } @@ -199,7 +199,7 @@ public class EntityEnderDragon extends EntityLiving implements IComplex { f4 = 0.0F; } - this.bE *= 0.8F; + this.bF *= 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 +207,13 @@ public class EntityEnderDragon extends EntityLiving implements IComplex { d10 = 40.0D; } - this.bE = (float) ((double) this.bE + d9 * (0.699999988079071D / d10 / (double) f5)); - this.yaw += this.bE * 0.1F; + this.bF = (float) ((double) this.bF + d9 * (0.699999988079071D / d10 / (double) f5)); + this.yaw += this.bF * 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.bP) { + if (this.bQ) { this.move(this.motX * 0.800000011920929D, this.motY * 0.800000011920929D, this.motZ * 0.800000011920929D); } else { this.move(this.motX, this.motY, this.motZ); @@ -228,43 +228,43 @@ public class EntityEnderDragon extends EntityLiving implements IComplex { this.motY *= 0.9100000262260437D; } - this.ax = this.yaw; + 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.bJ.width = this.bJ.length = 2.0F; + this.bK.width = this.bK.length = 2.0F; this.h.length = 3.0F; this.h.width = 5.0F; - this.bK.length = 2.0F; - this.bK.width = 4.0F; - this.bL.length = 3.0F; + this.bL.length = 2.0F; this.bL.width = 4.0F; - f1 = (float) (this.a(5, 1.0F)[1] - this.a(10, 1.0F)[1]) * 10.0F / 180.0F * 3.1415927F; + this.bM.length = 3.0F; + this.bM.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); float f10 = this.yaw * 3.1415927F / 180.0F; float f11 = MathHelper.sin(f10); float f12 = MathHelper.cos(f10); - this.h.j_(); + 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.bK.j_(); - this.bK.setPositionRotation(this.locX + (double) (f12 * 4.5F), this.locY + 2.0D, this.locZ + (double) (f11 * 4.5F), 0.0F, 0.0F); - this.bL.j_(); - this.bL.setPositionRotation(this.locX - (double) (f12 * 4.5F), this.locY + 2.0D, this.locZ - (double) (f11 * 4.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); if (!this.world.isStatic && this.hurtTicks == 0) { - this.a(this.world.getEntities(this, this.bK.boundingBox.grow(4.0D, 2.0D, 4.0D).d(0.0D, -2.0D, 0.0D))); 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))); } - double[] adouble = this.a(5, 1.0F); - double[] adouble1 = this.a(0, 1.0F); + double[] adouble = this.b(5, 1.0F); + double[] adouble1 = this.b(0, 1.0F); - f3 = MathHelper.sin(this.yaw * 3.1415927F / 180.0F - this.bE * 0.01F); - float f13 = MathHelper.cos(this.yaw * 3.1415927F / 180.0F - this.bE * 0.01F); + 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); - this.g.j_(); + 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); for (int j = 0; j < 3; ++j) { @@ -279,41 +279,41 @@ public class EntityEnderDragon extends EntityLiving implements IComplex { } if (j == 2) { - entitycomplexpart = this.bJ; + entitycomplexpart = this.bK; } - double[] adouble2 = this.a(12 + j * 2, 1.0F); + double[] adouble2 = this.b(12 + j * 2, 1.0F); float f14 = this.yaw * 3.1415927F / 180.0F + this.b(adouble2[0] - adouble[0]) * 3.1415927F / 180.0F * 1.0F; float f15 = MathHelper.sin(f14); float f16 = MathHelper.cos(f14); float f17 = 1.5F; float f18 = (float) (j + 1) * 2.0F; - entitycomplexpart.j_(); + entitycomplexpart.l_(); entitycomplexpart.setPositionRotation(this.locX - (double) ((f11 * f17 + f15 * f18) * f2), this.locY + (adouble2[1] - adouble[1]) * 1.0D - (double) ((f18 + f17) * f9) + 1.5D, this.locZ + (double) ((f12 * f17 + f16 * f18) * f2), 0.0F, 0.0F); } if (!this.world.isStatic) { - this.bO = this.a(this.g.boundingBox) | this.a(this.h.boundingBox); + this.bQ = this.a(this.g.boundingBox) | this.a(this.h.boundingBox); } } } private void h() { - if (this.bR != null) { - if (this.bR.dead) { + if (this.bS != null) { + if (this.bS.dead) { if (!this.world.isStatic) { - this.a(this.g, DamageSource.EXPLOSION, 10); + this.a(this.g, DamageSource.explosion((Explosion) null), 10); } - this.bR = null; + this.bS = null; } else if (this.ticksLived % 10 == 0 && this.health < this.maxHealth) { // CraftBukkit - this.getMaxHealth() -> this.maxHealth // CraftBukkit start EntityRegainHealthEvent event = new EntityRegainHealthEvent(this.getBukkitEntity(), 1, EntityRegainHealthEvent.RegainReason.ENDER_CRYSTAL); this.world.getServer().getPluginManager().callEvent(event); if (!event.isCancelled()) { - this.health += event.getAmount(); + this.setHealth(this.getHealth() + event.getAmount()); } // CraftBukkit end } @@ -336,7 +336,7 @@ public class EntityEnderDragon extends EntityLiving implements IComplex { } } - this.bR = entityendercrystal; + this.bS = entityendercrystal; } } @@ -382,9 +382,9 @@ public class EntityEnderDragon extends EntityLiving implements IComplex { } private void i() { - this.bO = false; + this.bP = false; if (this.random.nextInt(2) == 0 && !this.world.players.isEmpty()) { - this.bS = (Entity) this.world.players.get(this.random.nextInt(this.world.players.size())); + this.bT = (Entity) this.world.players.get(this.random.nextInt(this.world.players.size())); } else { boolean flag = false; @@ -401,7 +401,7 @@ public class EntityEnderDragon extends EntityLiving implements IComplex { flag = d0 * d0 + d1 * d1 + d2 * d2 > 100.0D; } while (!flag); - this.bS = null; + this.bT = null; } } @@ -431,9 +431,9 @@ public class EntityEnderDragon extends EntityLiving implements IComplex { if (j2 != 0) { if (j2 != Block.OBSIDIAN.id && j2 != Block.WHITESTONE.id && j2 != Block.BEDROCK.id) { - flag1 = true; // CraftBukkit start - add blocks to list rather than destroying them - // this.world.setTypeId(k1, l1, i2, 0); + // flag1 = this.world.setAir(k1, l1, i2) || flag1; + flag1 = true; destroyedBlocks.add(craftWorld.getBlockAt(k1, l1, i2)); // CraftBukkit end } else { @@ -482,8 +482,8 @@ public class EntityEnderDragon extends EntityLiving implements IComplex { 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.bS = null; - if (damagesource.getEntity() instanceof EntityHuman || damagesource == DamageSource.EXPLOSION) { + this.bT = null; + if (damagesource.getEntity() instanceof EntityHuman || damagesource.c()) { this.dealDamage(damagesource, i); } @@ -498,9 +498,9 @@ public class EntityEnderDragon extends EntityLiving implements IComplex { return super.damageEntity(damagesource, i); } - protected void aP() { - ++this.bQ; - if (this.bQ >= 180 && this.bQ <= 200) { + protected void aS() { + ++this.bR; + if (this.bR >= 180 && this.bR <= 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; @@ -512,7 +512,7 @@ public class EntityEnderDragon extends EntityLiving implements IComplex { int j; if (!this.world.isStatic) { - if (this.bQ > 150 && this.bQ % 5 == 0) { + if (this.bR > 150 && this.bR % 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) { @@ -522,14 +522,14 @@ public class EntityEnderDragon extends EntityLiving implements IComplex { } } - if (this.bQ == 1) { - this.world.e(1018, (int) this.locX, (int) this.locY, (int) this.locZ, 0); + if (this.bR == 1) { + this.world.d(1018, (int) this.locX, (int) this.locY, (int) this.locZ, 0); } } this.move(0.0D, 0.10000000149011612D, 0.0D); - this.ax = this.yaw += 20.0F; - if (this.bQ == 200 && !this.world.isStatic) { + this.ay = this.yaw += 20.0F; + if (this.bR == 200 && !this.world.isStatic) { i = expToDrop - 10 * (expToDrop / 12); // CraftBukkit - drop the remaining experience while (i > 0) { @@ -609,13 +609,13 @@ public class EntityEnderDragon extends EntityLiving implements IComplex { BlockEnderPortal.a = false; } - protected void bk() {} + protected void bn() {} - public Entity[] ao() { + public Entity[] an() { return this.children; } - public boolean L() { + public boolean K() { return false; } @@ -623,15 +623,15 @@ public class EntityEnderDragon extends EntityLiving implements IComplex { return this.world; } - protected String aY() { + protected String bb() { return "mob.enderdragon.growl"; } - protected String aZ() { + protected String bc() { return "mob.enderdragon.hit"; } - protected float aX() { + protected float ba() { return 5.0F; } diff --git a/src/main/java/net/minecraft/server/EntityEnderman.java b/src/main/java/net/minecraft/server/EntityEnderman.java index 15b5516b26..87d7345502 100644 --- a/src/main/java/net/minecraft/server/EntityEnderman.java +++ b/src/main/java/net/minecraft/server/EntityEnderman.java @@ -15,9 +15,9 @@ public class EntityEnderman extends EntityMonster { public EntityEnderman(World world) { super(world); this.texture = "/mob/enderman.png"; - this.bH = 0.2F; + this.bI = 0.2F; this.a(0.6F, 2.9F); - this.X = 1.0F; + this.Y = 1.0F; } public int getMaxHealth() { @@ -47,14 +47,14 @@ public class EntityEnderman extends EntityMonster { EntityHuman entityhuman = this.world.findNearbyVulnerablePlayer(this, 64.0D); if (entityhuman != null) { - if (this.d(entityhuman)) { + if (this.e(entityhuman)) { if (this.f == 0) { this.world.makeSound(entityhuman, "mob.endermen.stare", 1.0F, 1.0F); } if (this.f++ == 5) { this.f = 0; - this.f(true); + this.a(true); return entityhuman; } } else { @@ -65,7 +65,7 @@ public class EntityEnderman extends EntityMonster { return null; } - private boolean d(EntityHuman entityhuman) { + private boolean e(EntityHuman entityhuman) { ItemStack itemstack = entityhuman.inventory.armor[3]; if (itemstack != null && itemstack.id == Block.PUMPKIN.id) { @@ -83,11 +83,11 @@ public class EntityEnderman extends EntityMonster { } public void c() { - if (this.G()) { + if (this.F()) { this.damageEntity(DamageSource.DROWN, 1); } - this.bH = this.target != null ? 6.5F : 0.3F; + this.bI = this.target != null ? 6.5F : 0.3F; int i; if (!this.world.isStatic && this.world.getGameRules().getBoolean("mobGriefing")) { @@ -106,7 +106,7 @@ public class EntityEnderman extends EntityMonster { if (!CraftEventFactory.callEntityChangeBlockEvent(this, this.world.getWorld().getBlockAt(i, j, k), org.bukkit.Material.AIR).isCancelled()) { this.setCarriedId(this.world.getTypeId(i, j, k)); this.setCarriedData(this.world.getData(i, j, k)); - this.world.setTypeId(i, j, k, 0); + this.world.setTypeIdUpdate(i, j, k, 0); } // CraftBukkit end } @@ -121,7 +121,7 @@ public class EntityEnderman extends EntityMonster { if (l == 0 && i1 > 0 && Block.byId[i1].b()) { // CraftBukkit start - place event if (!CraftEventFactory.callEntityChangeBlockEvent(this, i, j, k, this.getCarriedId(), this.getCarriedData()).isCancelled()) { - this.world.setTypeIdAndData(i, j, k, this.getCarriedId(), this.getCarriedData()); + this.world.setTypeIdAndData(i, j, k, this.getCarriedId(), this.getCarriedData(), 3); this.setCarriedId(0); } // CraftBukkit end @@ -136,29 +136,29 @@ public class EntityEnderman extends EntityMonster { if (this.world.u() && !this.world.isStatic) { float f = this.c(1.0F); - if (f > 0.5F && this.world.k(MathHelper.floor(this.locX), MathHelper.floor(this.locY), MathHelper.floor(this.locZ)) && this.random.nextFloat() * 30.0F < (f - 0.4F) * 2.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.f(false); + this.a(false); this.m(); } } - if (this.G() || this.isBurning()) { + if (this.F() || this.isBurning()) { this.target = null; - this.f(false); + this.a(false); this.m(); } - this.bF = false; + this.bG = 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.d((EntityHuman) this.target)) { - this.bC = this.bD = 0.0F; - this.bH = 0.0F; + if (this.target instanceof EntityHuman && this.e((EntityHuman) this.target)) { + this.bD = this.bE = 0.0F; + this.bI = 0.0F; if (this.target.e((Entity) this) < 16.0D) { this.m(); } @@ -168,7 +168,7 @@ public class EntityEnderman extends EntityMonster { this.e = 0; } } else { - this.f(false); + this.a(false); this.e = 0; } } @@ -265,15 +265,15 @@ public class EntityEnderman extends EntityMonster { } } - protected String aY() { + protected String bb() { return this.q() ? "mob.endermen.scream" : "mob.endermen.idle"; } - protected String aZ() { + protected String bc() { return "mob.endermen.hit"; } - protected String ba() { + protected String bd() { return "mob.endermen.death"; } @@ -318,7 +318,7 @@ public class EntityEnderman extends EntityMonster { if (this.isInvulnerable()) { return false; } else { - this.f(true); + this.a(true); if (damagesource instanceof EntityDamageSourceIndirect) { for (int j = 0; j < 64; ++j) { if (this.m()) { @@ -337,7 +337,7 @@ public class EntityEnderman extends EntityMonster { return this.datawatcher.getByte(18) > 0; } - public void f(boolean flag) { + public void a(boolean flag) { this.datawatcher.watch(18, Byte.valueOf((byte) (flag ? 1 : 0))); } diff --git a/src/main/java/net/minecraft/server/EntityExperienceOrb.java b/src/main/java/net/minecraft/server/EntityExperienceOrb.java index f5fc9cdebe..e76e0f948a 100644 --- a/src/main/java/net/minecraft/server/EntityExperienceOrb.java +++ b/src/main/java/net/minecraft/server/EntityExperienceOrb.java @@ -39,8 +39,8 @@ public class EntityExperienceOrb extends Entity { protected void a() {} - public void j_() { - super.j_(); + public void l_() { + super.l_(); if (this.c > 0) { --this.c; } @@ -114,7 +114,7 @@ public class EntityExperienceOrb extends Entity { } } - public boolean I() { + public boolean H() { return this.world.a(this.boundingBox, Material.WATER, (Entity) this); } @@ -126,7 +126,7 @@ public class EntityExperienceOrb extends Entity { if (this.isInvulnerable()) { return false; } else { - this.K(); + this.J(); this.d -= i; if (this.d <= 0) { this.die(); @@ -148,10 +148,10 @@ public class EntityExperienceOrb extends Entity { this.value = nbttagcompound.getShort("Value"); } - public void c_(EntityHuman entityhuman) { + public void b_(EntityHuman entityhuman) { if (!this.world.isStatic) { - if (this.c == 0 && entityhuman.bS == 0) { - entityhuman.bS = 2; + if (this.c == 0 && entityhuman.bT == 0) { + entityhuman.bT = 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 aq() { + public boolean ap() { return false; } } diff --git a/src/main/java/net/minecraft/server/EntityFallingBlock.java b/src/main/java/net/minecraft/server/EntityFallingBlock.java index ea440dcbed..96120d872d 100644 --- a/src/main/java/net/minecraft/server/EntityFallingBlock.java +++ b/src/main/java/net/minecraft/server/EntityFallingBlock.java @@ -14,20 +14,21 @@ public class EntityFallingBlock extends Entity { public int data; public int c; public boolean dropItem; - private boolean e; + private boolean f; private boolean hurtEntities; private int fallHurtMax; private float fallHurtAmount; - private NBTTagCompound tileEntityData; // CraftBukkit + public NBTTagCompound tileEntityData; public EntityFallingBlock(World world) { super(world); this.c = 0; this.dropItem = true; - this.e = false; + 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) { @@ -38,10 +39,11 @@ public class EntityFallingBlock extends Entity { super(world); this.c = 0; this.dropItem = true; - this.e = false; + 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; @@ -62,11 +64,11 @@ public class EntityFallingBlock extends Entity { protected void a() {} - public boolean L() { + public boolean K() { return !this.dead; } - public void j_() { + public void l_() { if (this.id == 0) { this.die(); } else { @@ -91,18 +93,7 @@ public class EntityFallingBlock extends Entity { return; } - // CraftBukkit start - Store the block tile entity with this entity - TileEntity tile = this.world.getTileEntity(i, j, k); - if (tile != null) { - tileEntityData = new NBTTagCompound(); - // Save the data - tile.b(tileEntityData); - // Remove the existing tile entity - this.world.r(i, j, k); - } - // CraftBukkit end - - this.world.setTypeId(i, j, k, 0); + this.world.setAir(i, j, k); } if (this.onGround) { @@ -112,20 +103,39 @@ public class EntityFallingBlock extends Entity { if (this.world.getTypeId(i, j, k) != Block.PISTON_MOVING.id) { this.die(); // CraftBukkit start - if (!this.e && this.world.mayPlace(this.id, i, j, k, true, 1, (Entity) null) && !BlockSand.canFall(this.world, i, j - 1, k) /* mimic the false conditions of setTypeIdAndData */ && i >= -30000000 && k >= -30000000 && i < 30000000 && k < 30000000 && j > 0 && j < 256 && !(this.world.getTypeId(i, j, k) == this.id && this.world.getData(i, j, k) == this.data)) { + if (!this.f && this.world.mayPlace(this.id, i, j, k, true, 1, (Entity) null, (ItemStack) null) && !BlockSand.canFall(this.world, i, j - 1, k) /* mimic the false conditions of setTypeIdAndData */ && i >= -30000000 && k >= -30000000 && i < 30000000 && k < 30000000 && j > 0 && j < 256 && !(this.world.getTypeId(i, j, k) == this.id && this.world.getData(i, j, k) == this.data)) { if (CraftEventFactory.callEntityChangeBlockEvent(this, i, j, k, this.id, this.data).isCancelled()) { return; } - this.world.setTypeIdAndData(i, j, k, this.id, this.data); - - if (this.tileEntityData != null) { - this.world.setTileEntity(i, j, k, TileEntity.c(this.tileEntityData)); - } + this.world.setTypeIdAndData(i, j, k, this.id, this.data, 3); // CraftBukkit end + if (Block.byId[this.id] instanceof BlockSand) { ((BlockSand) Block.byId[this.id]).a_(this.world, i, j, k, this.data); } - } else if (this.dropItem && !this.e) { + + if (this.tileEntityData != null && Block.byId[this.id] instanceof IContainer) { + TileEntity tileentity = this.world.getTileEntity(i, j, k); + + if (tileentity != null) { + NBTTagCompound nbttagcompound = new NBTTagCompound(); + + tileentity.b(nbttagcompound); + Iterator iterator = this.tileEntityData.c().iterator(); + + while (iterator.hasNext()) { + NBTBase nbtbase = (NBTBase) iterator.next(); + + if (!nbtbase.getName().equals("x") && !nbtbase.getName().equals("y") && !nbtbase.getName().equals("z")) { + nbttagcompound.set(nbtbase.getName(), nbtbase.clone()); + } + } + + tileentity.a(nbttagcompound); + tileentity.update(); + } + } + } else if (this.dropItem && !this.f) { this.a(new ItemStack(this.id, 1, Block.byId[this.id].getDropData(this.data)), 0.0F); } } @@ -170,7 +180,7 @@ public class EntityFallingBlock extends Entity { ++j; if (j > 2) { - this.e = true; + this.f = true; } else { this.data = k | j << 2; } @@ -181,21 +191,25 @@ public class EntityFallingBlock extends Entity { protected void b(NBTTagCompound nbttagcompound) { nbttagcompound.setByte("Tile", (byte) this.id); + nbttagcompound.setInt("TileID", this.id); nbttagcompound.setByte("Data", (byte) this.data); nbttagcompound.setByte("Time", (byte) this.c); nbttagcompound.setBoolean("DropItem", this.dropItem); nbttagcompound.setBoolean("HurtEntities", this.hurtEntities); nbttagcompound.setFloat("FallHurtAmount", this.fallHurtAmount); nbttagcompound.setInt("FallHurtMax", this.fallHurtMax); - // CraftBukkit start - store the tile data if (this.tileEntityData != null) { - nbttagcompound.set("Bukkit.tileData", this.tileEntityData.clone()); + nbttagcompound.setCompound("TileEntityData", this.tileEntityData); } - // CraftBukkit end } protected void a(NBTTagCompound nbttagcompound) { - this.id = nbttagcompound.getByte("Tile") & 255; + if (nbttagcompound.hasKey("TileID")) { + this.id = nbttagcompound.getInt("TileID"); + } else { + this.id = nbttagcompound.getByte("Tile") & 255; + } + this.data = nbttagcompound.getByte("Data") & 255; this.c = nbttagcompound.getByte("Time") & 255; if (nbttagcompound.hasKey("HurtEntities")) { @@ -206,22 +220,26 @@ public class EntityFallingBlock extends Entity { this.hurtEntities = true; } - // CraftBukkit start - load tileData + if (nbttagcompound.hasKey("DropItem")) { + this.dropItem = nbttagcompound.getBoolean("DropItem"); + } + + if (nbttagcompound.hasKey("TileEntityData")) { + this.tileEntityData = nbttagcompound.getCompound("TileEntityData"); + } + + // CraftBukkit start - backward compatibility, remove in 1.6 if (nbttagcompound.hasKey("Bukkit.tileData")) { this.tileEntityData = (NBTTagCompound) nbttagcompound.getCompound("Bukkit.tileData").clone(); } // CraftBukkit end - if (nbttagcompound.hasKey("DropItem")) { - this.dropItem = nbttagcompound.getBoolean("DropItem"); - } - if (this.id == 0) { this.id = Block.SAND.id; } } - public void e(boolean flag) { + public void a(boolean flag) { this.hurtEntities = flag; } diff --git a/src/main/java/net/minecraft/server/EntityFireball.java b/src/main/java/net/minecraft/server/EntityFireball.java index 107abcad3c..4a19b1d673 100644 --- a/src/main/java/net/minecraft/server/EntityFireball.java +++ b/src/main/java/net/minecraft/server/EntityFireball.java @@ -13,7 +13,7 @@ public abstract class EntityFireball extends Entity { private boolean i = false; public EntityLiving shooter; private int j; - private int at = 0; + private int au = 0; public double dirX; public double dirY; public double dirZ; @@ -63,11 +63,11 @@ public abstract class EntityFireball extends Entity { this.dirZ = d2 / d3 * 0.1D; } - public void j_() { + public void l_() { if (!this.world.isStatic && (this.shooter != null && this.shooter.dead || !this.world.isLoaded((int) this.locX, (int) this.locY, (int) this.locZ))) { this.die(); } else { - super.j_(); + super.l_(); this.setOnFire(1); if (this.i) { int i = this.world.getTypeId(this.e, this.f, this.g); @@ -86,9 +86,9 @@ public abstract class EntityFireball extends Entity { this.motY *= (double) (this.random.nextFloat() * 0.2F); this.motZ *= (double) (this.random.nextFloat() * 0.2F); this.j = 0; - this.at = 0; + this.au = 0; } else { - ++this.at; + ++this.au; } Vec3D vec3d = this.world.getVec3DPool().create(this.locX, this.locY, this.locZ); @@ -108,7 +108,7 @@ public abstract class EntityFireball extends Entity { for (int j = 0; j < list.size(); ++j) { Entity entity1 = (Entity) list.get(j); - if (entity1.L() && (!entity1.i(this.shooter) || this.at >= 25)) { + if (entity1.K() && (!entity1.i(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); @@ -166,7 +166,7 @@ public abstract class EntityFireball extends Entity { this.yaw = this.lastYaw + (this.yaw - this.lastYaw) * 0.2F; float f2 = this.c(); - if (this.H()) { + if (this.G()) { for (int k = 0; k < 4; ++k) { float f3 = 0.25F; @@ -222,11 +222,11 @@ public abstract class EntityFireball extends Entity { } } - public boolean L() { + public boolean K() { return true; } - public float Y() { + public float X() { return 1.0F; } @@ -234,9 +234,9 @@ public abstract class EntityFireball extends Entity { if (this.isInvulnerable()) { return false; } else { - this.K(); + this.J(); if (damagesource.getEntity() != null) { - Vec3D vec3d = damagesource.getEntity().Z(); + Vec3D vec3d = damagesource.getEntity().Y(); if (vec3d != null) { this.motX = vec3d.c; diff --git a/src/main/java/net/minecraft/server/EntityFireworks.java b/src/main/java/net/minecraft/server/EntityFireworks.java index 64454f5bee..6856e5b557 100644 --- a/src/main/java/net/minecraft/server/EntityFireworks.java +++ b/src/main/java/net/minecraft/server/EntityFireworks.java @@ -38,11 +38,11 @@ public class EntityFireworks extends Entity { this.expectedLifespan = 10 * i + this.random.nextInt(6) + this.random.nextInt(7); } - public void j_() { - this.T = this.locX; - this.U = this.locY; - this.V = this.locZ; - super.j_(); + public void l_() { + this.U = this.locX; + this.V = this.locY; + this.W = this.locZ; + super.l_(); this.motX *= 1.15D; this.motZ *= 1.15D; this.motY += 0.04D; @@ -115,7 +115,7 @@ public class EntityFireworks extends Entity { return super.c(f); } - public boolean aq() { + public boolean ap() { return false; } } diff --git a/src/main/java/net/minecraft/server/EntityFishingHook.java b/src/main/java/net/minecraft/server/EntityFishingHook.java index 4e722876df..a37ac26d6a 100644 --- a/src/main/java/net/minecraft/server/EntityFishingHook.java +++ b/src/main/java/net/minecraft/server/EntityFishingHook.java @@ -18,24 +18,24 @@ public class EntityFishingHook extends Entity { public EntityHuman owner; private int i; private int j = 0; - private int at = 0; + private int au = 0; public Entity hooked = null; - private int au; - private double av; + private int av; private double aw; private double ax; private double ay; private double az; + private double aA; public EntityFishingHook(World world) { super(world); this.a(0.25F, 0.25F); - this.al = true; + this.am = true; } public EntityFishingHook(World world, EntityHuman entityhuman) { super(world); - this.al = true; + this.am = true; this.owner = entityhuman; this.owner.hookedFish = this; this.a(0.25F, 0.25F); @@ -77,22 +77,22 @@ public class EntityFishingHook extends Entity { this.i = 0; } - public void j_() { - super.j_(); - if (this.au > 0) { - double d0 = this.locX + (this.av - this.locX) / (double) this.au; - double d1 = this.locY + (this.aw - this.locY) / (double) this.au; - double d2 = this.locZ + (this.ax - this.locZ) / (double) this.au; - double d3 = MathHelper.g(this.ay - (double) this.yaw); + public void l_() { + super.l_(); + if (this.av > 0) { + double d0 = this.locX + (this.aw - this.locX) / (double) this.av; + double d1 = this.locY + (this.ax - this.locY) / (double) this.av; + double d2 = this.locZ + (this.ay - this.locZ) / (double) this.av; + double d3 = MathHelper.g(this.az - (double) this.yaw); - this.yaw = (float) ((double) this.yaw + d3 / (double) this.au); - this.pitch = (float) ((double) this.pitch + (this.az - (double) this.pitch) / (double) this.au); - --this.au; + this.yaw = (float) ((double) this.yaw + d3 / (double) this.av); + this.pitch = (float) ((double) this.pitch + (this.aA - (double) this.pitch) / (double) this.av); + --this.av; this.setPosition(d0, d1, d2); this.b(this.yaw, this.pitch); } else { if (!this.world.isStatic) { - ItemStack itemstack = this.owner.bS(); + ItemStack itemstack = this.owner.cb(); if (this.owner.dead || !this.owner.isAlive() || itemstack == null || itemstack.getItem() != Item.FISHING_ROD || this.e(this.owner) > 1024.0D) { this.die(); @@ -157,7 +157,7 @@ public class EntityFishingHook extends Entity { for (int j = 0; j < list.size(); ++j) { Entity entity1 = (Entity) list.get(j); - if (entity1.L() && (entity1 != this.owner || this.j >= 5)) { + if (entity1.K() && (entity1 != this.owner || this.j >= 5)) { float f = 0.3F; AxisAlignedBB axisalignedbb = entity1.boundingBox.grow((double) f, (double) f, (double) f); MovingObjectPosition movingobjectposition1 = axisalignedbb.a(vec3d, vec3d1); @@ -230,17 +230,17 @@ public class EntityFishingHook extends Entity { } if (d6 > 0.0D) { - if (this.at > 0) { - --this.at; + if (this.au > 0) { + --this.au; } else { short short1 = 500; - if (this.world.D(MathHelper.floor(this.locX), MathHelper.floor(this.locY) + 1, MathHelper.floor(this.locZ))) { + if (this.world.F(MathHelper.floor(this.locX), MathHelper.floor(this.locY) + 1, MathHelper.floor(this.locZ))) { short1 = 300; } if (this.random.nextInt(short1) == 0) { - this.at = this.random.nextInt(30) + 10; + this.au = this.random.nextInt(30) + 10; this.motY -= 0.20000000298023224D; this.makeSound("random.splash", 0.25F, 1.0F + (this.random.nextFloat() - this.random.nextFloat()) * 0.4F); float f3 = (float) MathHelper.floor(this.boundingBox.b); @@ -264,7 +264,7 @@ public class EntityFishingHook extends Entity { } } - if (this.at > 0) { + if (this.au > 0) { this.motY -= (double) (this.random.nextFloat() * this.random.nextFloat() * this.random.nextFloat()) * 0.2D; } @@ -329,7 +329,7 @@ public class EntityFishingHook extends Entity { this.hooked.motY += d1 * d4 + (double) MathHelper.sqrt(d3) * 0.08D; this.hooked.motZ += d2 * d4; b0 = 3; - } else if (this.at > 0) { + } else if (this.au > 0) { EntityItem entityitem = new EntityItem(this.world, this.locX, this.locY, this.locZ, new ItemStack(Item.RAW_FISH)); // CraftBukkit start PlayerFishEvent playerFishEvent = new PlayerFishEvent((Player) this.owner.getBukkitEntity(), entityitem.getBukkitEntity(), PlayerFishEvent.State.CAUGHT_FISH); diff --git a/src/main/java/net/minecraft/server/EntityGhast.java b/src/main/java/net/minecraft/server/EntityGhast.java index beed78625a..f18a9246f7 100644 --- a/src/main/java/net/minecraft/server/EntityGhast.java +++ b/src/main/java/net/minecraft/server/EntityGhast.java @@ -23,13 +23,13 @@ public class EntityGhast extends EntityFlying implements IMonster { this.texture = "/mob/ghast.png"; this.a(4.0F, 4.0F); this.fireProof = true; - this.bd = 5; + this.be = 5; } public boolean damageEntity(DamageSource damagesource, int i) { if (this.isInvulnerable()) { return false; - } else if ("fireball".equals(damagesource.l()) && damagesource.getEntity() instanceof EntityHuman) { + } else if ("fireball".equals(damagesource.n()) && damagesource.getEntity() instanceof EntityHuman) { super.damageEntity(damagesource, 1000); ((EntityHuman) damagesource.getEntity()).a((Statistic) AchievementList.y); return true; @@ -47,19 +47,19 @@ public class EntityGhast extends EntityFlying implements IMonster { return 10; } - public void j_() { - super.j_(); + public void l_() { + super.l_(); byte b0 = this.datawatcher.getByte(16); this.texture = b0 == 1 ? "/mob/ghast_fire.png" : "/mob/ghast.png"; } - protected void bn() { + protected void bq() { if (!this.world.isStatic && this.world.difficulty == 0) { this.die(); } - this.bk(); + this.bn(); this.f = this.g; double d0 = this.c - this.locX; double d1 = this.d - this.locY; @@ -130,7 +130,7 @@ 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.ax = this.yaw = -((float) Math.atan2(d5, d7)) * 180.0F / 3.1415927F; + this.ay = this.yaw = -((float) Math.atan2(d5, d7)) * 180.0F / 3.1415927F; if (this.n(this.target)) { if (this.g == 10) { this.world.a((EntityHuman) null, 1007, (int) this.locX, (int) this.locY, (int) this.locZ, 0); @@ -156,7 +156,7 @@ public class EntityGhast extends EntityFlying implements IMonster { --this.g; } } else { - this.ax = this.yaw = -((float) Math.atan2(this.motX, this.motZ)) * 180.0F / 3.1415927F; + this.ay = this.yaw = -((float) Math.atan2(this.motX, this.motZ)) * 180.0F / 3.1415927F; if (this.g > 0) { --this.g; } @@ -188,15 +188,15 @@ public class EntityGhast extends EntityFlying implements IMonster { return true; } - protected String aY() { + protected String bb() { return "mob.ghast.moan"; } - protected String aZ() { + protected String bc() { return "mob.ghast.scream"; } - protected String ba() { + protected String bd() { return "mob.ghast.death"; } @@ -225,7 +225,7 @@ public class EntityGhast extends EntityFlying implements IMonster { // CraftBukkit end } - protected float aX() { + protected float ba() { return 10.0F; } @@ -233,7 +233,7 @@ public class EntityGhast extends EntityFlying implements IMonster { return this.random.nextInt(20) == 0 && super.canSpawn() && this.world.difficulty > 0; } - public int bv() { + public int by() { return 1; } diff --git a/src/main/java/net/minecraft/server/EntityHanging.java b/src/main/java/net/minecraft/server/EntityHanging.java index 8cc80b9710..c35a88a6f0 100644 --- a/src/main/java/net/minecraft/server/EntityHanging.java +++ b/src/main/java/net/minecraft/server/EntityHanging.java @@ -75,33 +75,33 @@ public abstract class EntityHanging extends Entity { } if (i == 2) { - f3 -= this.g(this.d()); + f3 -= this.b(this.d()); } if (i == 1) { - f5 += this.g(this.d()); + f5 += this.b(this.d()); } if (i == 0) { - f3 += this.g(this.d()); + f3 += this.b(this.d()); } if (i == 3) { - f5 -= this.g(this.d()); + f5 -= this.b(this.d()); } - f4 += this.g(this.g()); + f4 += this.b(this.g()); 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 g(int i) { + private float b(int i) { return i == 32 ? 0.5F : (i == 64 ? 0.5F : 0.0F); } - public void j_() { + public void l_() { if (this.e++ == 100 && !this.world.isStatic) { this.e = 0; if (!this.dead && !this.survives()) { @@ -199,7 +199,7 @@ public abstract class EntityHanging extends Entity { } } - public boolean L() { + public boolean K() { return true; } @@ -222,7 +222,7 @@ public abstract class EntityHanging extends Entity { // Fire old painting event until it can be removed paintingEvent = new org.bukkit.event.painting.PaintingBreakByEntityEvent((Painting) this.getBukkitEntity(), damagesource.getEntity() == null ? null : damagesource.getEntity().getBukkitEntity()); } - } else if (damagesource == DamageSource.EXPLOSION || damagesource == DamageSource.EXPLOSION2) { + } else if (damagesource.c()) { event = new HangingBreakEvent((Hanging) this.getBukkitEntity(), HangingBreakEvent.RemoveCause.EXPLOSION); } @@ -239,7 +239,7 @@ public abstract class EntityHanging extends Entity { // CraftBukkit end this.die(); - this.K(); + this.J(); EntityHuman entityhuman = null; if (damagesource.getEntity() instanceof EntityHuman) { diff --git a/src/main/java/net/minecraft/server/EntityHuman.java b/src/main/java/net/minecraft/server/EntityHuman.java index ce0715b5f8..bfcb6ce7cc 100644 --- a/src/main/java/net/minecraft/server/EntityHuman.java +++ b/src/main/java/net/minecraft/server/EntityHuman.java @@ -1,5 +1,6 @@ package net.minecraft.server; +import java.util.Collection; import java.util.Iterator; import java.util.List; @@ -22,18 +23,18 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen public Container defaultContainer; public Container activeContainer; protected FoodMetaData foodData = new FoodMetaData(); - protected int bN = 0; - public byte bO = 0; - public float bP; + protected int bO = 0; + public byte bP = 0; public float bQ; + public float bR; public String name; - public int bS = 0; - public double bT; + public int bT = 0; public double bU; public double bV; public double bW; public double bX; public double bY; + public double bZ; // CraftBukkit start public boolean sleeping; // protected -> public public boolean fauxSleeping; @@ -45,10 +46,10 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen } // CraftBukkit end - public ChunkCoordinates ca; + public ChunkCoordinates cb; public int sleepTicks; // CraftBukkit - private -> public - public float cb; public float cc; + public float cd; private ChunkCoordinates c; private boolean d; private ChunkCoordinates e; @@ -59,8 +60,8 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen public float exp; private ItemStack f; private int g; - protected float ch = 0.1F; - protected float ci = 0.02F; + protected float ci = 0.1F; + protected float cj = 0.02F; private int h = 0; public EntityFishingHook hookedFish = null; @@ -72,8 +73,8 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen 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.aJ = "humanoid"; - this.aI = 180.0F; + this.aK = "humanoid"; + this.aJ = 180.0F; this.maxFireTicks = 20; this.texture = "/mob/char.png"; } @@ -89,31 +90,31 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen this.datawatcher.a(18, Integer.valueOf(0)); } - public boolean bM() { + public boolean bV() { return this.f != null; } - public void bO() { + public void bX() { if (this.f != null) { this.f.b(this.world, this, this.g); } - this.bP(); + this.bY(); } - public void bP() { + public void bY() { this.f = null; this.g = 0; if (!this.world.isStatic) { - this.d(false); + this.e(false); } } - public boolean bh() { - return this.bM() && Item.byId[this.f.id].b_(this.f) == EnumAnimation.d; + public boolean bk() { + return this.bV() && Item.byId[this.f.id].b_(this.f) == EnumAnimation.BLOCK; } - public void j_() { + public void l_() { if (this.f != null) { ItemStack itemstack = this.inventory.getItemInHand(); @@ -123,15 +124,15 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen } if (--this.g == 0 && !this.world.isStatic) { - this.n(); + this.m(); } } else { - this.bP(); + this.bY(); } } - if (this.bS > 0) { - --this.bS; + if (this.bT > 0) { + --this.bT; } if (this.isSleeping()) { @@ -141,7 +142,7 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen } if (!this.world.isStatic) { - if (!this.j()) { + if (!this.i()) { this.a(true, true, false); } else if (this.world.u()) { this.a(false, true, true); @@ -154,7 +155,7 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen } } - super.j_(); + super.l_(); if (!this.world.isStatic && this.activeContainer != null && !this.activeContainer.a(this)) { this.closeInventory(); this.activeContainer = this.defaultContainer; @@ -164,41 +165,41 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen this.extinguish(); } - this.bT = this.bW; this.bU = this.bX; this.bV = this.bY; - double d0 = this.locX - this.bW; - double d1 = this.locY - this.bX; - double d2 = this.locZ - this.bY; + this.bW = this.bZ; + double d0 = this.locX - this.bX; + double d1 = this.locY - this.bY; + double d2 = this.locZ - this.bZ; double d3 = 10.0D; if (d0 > d3) { - this.bT = this.bW = this.locX; + this.bU = this.bX = this.locX; } if (d2 > d3) { - this.bV = this.bY = this.locZ; + this.bW = this.bZ = this.locZ; } if (d1 > d3) { - this.bU = this.bX = this.locY; + this.bV = this.bY = this.locY; } if (d0 < -d3) { - this.bT = this.bW = this.locX; + this.bU = this.bX = this.locX; } if (d2 < -d3) { - this.bV = this.bY = this.locZ; + this.bW = this.bZ = this.locZ; } if (d1 < -d3) { - this.bU = this.bX = this.locY; + this.bV = this.bY = this.locY; } - this.bW += d0 * 0.25D; - this.bY += d2 * 0.25D; - this.bX += d1 * 0.25D; + this.bX += d0 * 0.25D; + this.bZ += d2 * 0.25D; + this.bY += d1 * 0.25D; this.a(StatisticList.k, 1); if (this.vehicle == null) { this.e = null; @@ -209,11 +210,11 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen } } - public int z() { + public int y() { return this.abilities.isInvulnerable ? 0 : 80; } - public int ab() { + public int aa() { return 10; } @@ -222,11 +223,11 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen } protected void c(ItemStack itemstack, int i) { - if (itemstack.n() == EnumAnimation.c) { + if (itemstack.o() == EnumAnimation.DRINK) { this.makeSound("random.drink", 0.5F, this.world.random.nextFloat() * 0.1F + 0.9F); } - if (itemstack.n() == EnumAnimation.b) { + if (itemstack.o() == EnumAnimation.EAT) { for (int j = 0; j < i; ++j) { Vec3D vec3d = this.world.getVec3DPool().create(((double) this.random.nextFloat() - 0.5D) * 0.1D, Math.random() * 0.1D + 0.1D, 0.0D); @@ -244,7 +245,7 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen } } - protected void n() { + protected void m() { if (this.f != null) { this.c(this.f, 16); int i = this.f.count; @@ -283,11 +284,11 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen } } - this.bP(); + this.bY(); } } - protected boolean bg() { + protected boolean bj() { return this.getHealth() <= 0 || this.isSleeping(); } @@ -296,31 +297,50 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen this.activeContainer = this.defaultContainer; } - public void U() { + public void mount(Entity entity) { + // CraftBukkit start - mirror Entity mount changes + this.setPassengerOf(entity); + } + + public void setPassengerOf(Entity entity) { + // CraftBukkit end + if (this.vehicle == entity) { + this.h(entity); + if (this.vehicle != null) { + this.vehicle.passenger = null; + } + + this.vehicle = null; + } else { + super.setPassengerOf(entity); // CraftBukkit - call new parent + } + } + + public void T() { double d0 = this.locX; double d1 = this.locY; double d2 = this.locZ; float f = this.yaw; float f1 = this.pitch; - super.U(); - this.bP = this.bQ; - this.bQ = 0.0F; + 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.ax = ((EntityPig) this.vehicle).ax; + this.ay = ((EntityPig) this.vehicle).ay; } } - protected void bn() { - this.bo(); + protected void bq() { + this.br(); } public void c() { - if (this.bN > 0) { - --this.bN; + if (this.bO > 0) { + --this.bO; } // CraftBukkit - this.getMaxHealth() -> this.maxHealth @@ -329,14 +349,14 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen this.heal(1, org.bukkit.event.entity.EntityRegainHealthEvent.RegainReason.REGEN); } - this.inventory.j(); - this.bP = this.bQ; + this.inventory.k(); + this.bQ = this.bR; super.c(); - this.aN = this.abilities.b(); - this.aO = this.ci; + this.aO = this.abilities.b(); + this.aP = this.cj; if (this.isSprinting()) { - this.aN = (float) ((double) this.aN + (double) this.abilities.b() * 0.3D); - this.aO = (float) ((double) this.aO + (double) this.ci * 0.3D); + this.aO = (float) ((double) this.aO + (double) this.abilities.b() * 0.3D); + this.aP = (float) ((double) this.aP + (double) this.cj * 0.3D); } float f = MathHelper.sqrt(this.motX * this.motX + this.motZ * this.motZ); @@ -355,8 +375,8 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen f1 = 0.0F; } - this.bQ += (f - this.bQ) * 0.4F; - this.bb += (f1 - this.bb) * 0.8F; + 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)); @@ -373,7 +393,7 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen } private void r(Entity entity) { - entity.c_(this); + entity.b_(this); } public int getScore() { @@ -400,12 +420,12 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen } if (!this.world.getGameRules().getBoolean("keepInventory")) { - this.inventory.l(); + this.inventory.m(); } if (damagesource != null) { - this.motX = (double) (-MathHelper.cos((this.aX + this.yaw) * 3.1415927F / 180.0F) * 0.1F); - this.motZ = (double) (-MathHelper.sin((this.aX + this.yaw) * 3.1415927F / 180.0F) * 0.1F); + 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); } else { this.motX = this.motZ = 0.0D; } @@ -416,14 +436,26 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen public void c(Entity entity, int i) { this.addScore(i); + Collection collection = this.getScoreboard().a(IObjective.e); + if (entity instanceof EntityHuman) { this.a(StatisticList.A, 1); + collection.addAll(this.getScoreboard().a(IObjective.d)); } else { this.a(StatisticList.z, 1); } + + Iterator iterator = collection.iterator(); + + while (iterator.hasNext()) { + ScoreboardObjective scoreboardobjective = (ScoreboardObjective) iterator.next(); + ScoreboardScore scoreboardscore = this.getScoreboard().a(this.getLocalizedName(), scoreboardobjective); + + scoreboardscore.a(); + } } - public EntityItem f(boolean flag) { + public EntityItem a(boolean flag) { return this.a(this.inventory.splitStack(this.inventory.itemInHandIndex, flag && this.inventory.getItemInHand() != null ? this.inventory.getItemInHand().count : 1), false); } @@ -484,18 +516,21 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen this.world.addEntity(entityitem); } - public float a(Block block) { + public float a(Block block, boolean flag) { float f = this.inventory.a(block); - int i = EnchantmentManager.getDigSpeedEnchantmentLevel(this); - ItemStack itemstack = this.inventory.getItemInHand(); - if (i > 0 && itemstack != null) { - float f1 = (float) (i * i + 1); + if (f > 1.0F) { + int i = EnchantmentManager.getDigSpeedEnchantmentLevel(this); + ItemStack itemstack = this.inventory.getItemInHand(); - if (!itemstack.b(block) && f <= 1.0F) { - f += f1 * 0.08F; - } else { - f += f1; + if (i > 0 && itemstack != null) { + float f1 = (float) (i * i + 1); + + if (!itemstack.b(block) && f <= 1.0F) { + f += f1 * 0.08F; + } else { + f += f1; + } } } @@ -518,7 +553,7 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen return f; } - public boolean b(Block block) { + public boolean a(Block block) { return this.inventory.b(block); } @@ -535,7 +570,7 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen this.expTotal = nbttagcompound.getInt("XpTotal"); this.setScore(nbttagcompound.getInt("Score")); if (this.sleeping) { - this.ca = new ChunkCoordinates(MathHelper.floor(this.locX), MathHelper.floor(this.locY), MathHelper.floor(this.locZ)); + this.cb = new ChunkCoordinates(MathHelper.floor(this.locX), MathHelper.floor(this.locY), MathHelper.floor(this.locZ)); this.a(true, true, false); } @@ -580,12 +615,16 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen this.foodData.b(nbttagcompound); this.abilities.a(nbttagcompound); - nbttagcompound.set("EnderItems", this.enderChest.g()); + nbttagcompound.set("EnderItems", this.enderChest.h()); } public void openContainer(IInventory iinventory) {} - public void startEnchanting(int i, int j, int k) {} + public void openHopper(TileEntityHopper tileentityhopper) {} + + public void openMinecartHopper(EntityMinecartHopper entityminecarthopper) {} + + public void startEnchanting(int i, int j, int k, String s) {} public void openAnvil(int i, int j, int k) {} @@ -605,7 +644,7 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen } else if (this.abilities.isInvulnerable && !damagesource.ignoresInvulnerability()) { return false; } else { - this.bB = 0; + this.bC = 0; if (this.getHealth() <= 0) { return false; } else { @@ -613,7 +652,7 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen this.a(true, true, false); } - if (damagesource.n()) { + if (damagesource.p()) { if (this.world.difficulty == 0) { return false; // CraftBukkit - i = 0 -> return false } @@ -647,32 +686,11 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen } } - protected int c(DamageSource damagesource, int i) { - int j = super.c(damagesource, i); + public boolean a(EntityHuman entityhuman) { + ScoreboardTeam scoreboardteam = this.getScoreboardTeam(); + ScoreboardTeam scoreboardteam1 = entityhuman.getScoreboardTeam(); - if (j <= 0) { - return 0; - } else { - int k = EnchantmentManager.a(this.inventory.armor, damagesource); - - if (k > 20) { - k = 20; - } - - if (k > 0 && k <= 20) { - int l = 25 - k; - int i1 = j * l + this.aT; - - j = i1 / 25; - this.aT = i1 % 25; - } - - return j; - } - } - - protected boolean h() { - return false; + return scoreboardteam != scoreboardteam1 ? true : (scoreboardteam != null ? scoreboardteam.g() : true); } protected void a(EntityLiving entityliving, boolean flag) { @@ -685,7 +703,7 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen } } - if (!(entityliving instanceof EntityHuman) || this.h()) { + 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(); @@ -705,11 +723,11 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen this.inventory.g(i); } - public int aW() { - return this.inventory.k(); + public int aZ() { + return this.inventory.l(); } - public float bR() { + public float ca() { int i = 0; ItemStack[] aitemstack = this.inventory.armor; int j = aitemstack.length; @@ -727,14 +745,17 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen protected void d(DamageSource damagesource, int i) { if (!this.isInvulnerable()) { - if (!damagesource.ignoresArmor() && this.bh()) { + if (!damagesource.ignoresArmor() && this.bk()) { i = 1 + i >> 1; } i = this.b(damagesource, i); i = this.c(damagesource, i); - this.j(damagesource.d()); - this.health -= i; + this.j(damagesource.f()); + int j = this.getHealth(); + + this.setHealth(this.getHealth() - i); + this.bt.a(damagesource, j, i); } } @@ -748,15 +769,15 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen public void openBeacon(TileEntityBeacon tileentitybeacon) {} - public void openTrade(IMerchant imerchant) {} + public void openTrade(IMerchant imerchant, String s) {} public void d(ItemStack itemstack) {} public boolean p(Entity entity) { - if (entity.a(this)) { + if (entity.a_(this)) { return true; } else { - ItemStack itemstack = this.bS(); + ItemStack itemstack = this.cb(); if (itemstack != null && entity instanceof EntityLiving) { if (this.abilities.canInstantlyBuild) { @@ -766,7 +787,7 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen if (itemstack.a((EntityLiving) entity)) { // CraftBukkit - bypass infinite items; <= 0 -> == 0 if (itemstack.count == 0 && !this.abilities.canInstantlyBuild) { - this.bT(); + this.cc(); } return true; @@ -777,20 +798,20 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen } } - public ItemStack bS() { + public ItemStack cb() { return this.inventory.getItemInHand(); } - public void bT() { + public void cc() { this.inventory.setItem(this.inventory.itemInHandIndex, (ItemStack) null); } - public double W() { + public double V() { return (double) (this.height - 0.5F); } public void attack(Entity entity) { - if (entity.aq()) { + if (entity.ap()) { if (!entity.j(this)) { int i = this.inventory.a(entity); @@ -815,9 +836,9 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen } if (i > 0 || k > 0) { - boolean flag = this.fallDistance > 0.0F && !this.onGround && !this.g_() && !this.H() && !this.hasEffect(MobEffectList.BLINDNESS) && this.vehicle == null && entity instanceof EntityLiving; + boolean flag = this.fallDistance > 0.0F && !this.onGround && !this.g_() && !this.G() && !this.hasEffect(MobEffectList.BLINDNESS) && this.vehicle == null && entity instanceof EntityLiving; - if (flag) { + if (flag && i > 0) { i += this.random.nextInt(i / 2 + 2); } @@ -867,13 +888,22 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen } } - ItemStack itemstack = this.bS(); + ItemStack itemstack = this.cb(); + Object object = entity; - if (itemstack != null && entity instanceof EntityLiving) { - itemstack.a((EntityLiving) entity, this); + if (entity instanceof EntityComplexPart) { + IComplex icomplex = ((EntityComplexPart) entity).owner; + + if (icomplex != null && icomplex instanceof EntityLiving) { + object = (EntityLiving) icomplex; + } + } + + if (itemstack != null && object instanceof EntityLiving) { + itemstack.a((EntityLiving) object, this); // CraftBukkit - bypass infinite items; <= 0 -> == 0 if (itemstack.count == 0) { - this.bT(); + this.cc(); } } @@ -919,7 +949,7 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen return !this.sleeping && super.inBlock(); } - public boolean bV() { + public boolean ce() { return false; } @@ -968,7 +998,7 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen this.height = 0.2F; if (this.world.isLoaded(i, j, k)) { int l = this.world.getData(i, j, k); - int i1 = BlockBed.e(l); + int i1 = BlockBed.j(l); float f = 0.5F; float f1 = 0.5F; @@ -997,7 +1027,7 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen this.sleeping = true; this.sleepTicks = 0; - this.ca = new ChunkCoordinates(i, j, k); + this.cb = new ChunkCoordinates(i, j, k); this.motX = this.motZ = this.motY = 0.0D; if (!this.world.isStatic) { this.world.everyoneSleeping(); @@ -1007,31 +1037,31 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen } private void x(int i) { - this.cb = 0.0F; this.cc = 0.0F; + this.cd = 0.0F; switch (i) { case 0: - this.cc = -1.8F; + this.cd = -1.8F; break; case 1: - this.cb = 1.8F; - break; - - case 2: this.cc = 1.8F; break; + case 2: + this.cd = 1.8F; + break; + case 3: - this.cb = -1.8F; + this.cc = -1.8F; } } public void a(boolean flag, boolean flag1, boolean flag2) { this.a(0.6F, 1.8F); this.e_(); - ChunkCoordinates chunkcoordinates = this.ca; - ChunkCoordinates chunkcoordinates1 = this.ca; + ChunkCoordinates chunkcoordinates = this.cb; + ChunkCoordinates chunkcoordinates1 = this.cb; 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); @@ -1071,16 +1101,16 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen } if (flag2) { - this.setRespawnPosition(this.ca, false); + this.setRespawnPosition(this.cb, false); } } - private boolean j() { - return this.world.getTypeId(this.ca.x, this.ca.y, this.ca.z) == Block.BED.id; + private boolean i() { + return this.world.getTypeId(this.cb.x, this.cb.y, this.cb.z) == Block.BED.id; } public static ChunkCoordinates getBed(World world, ChunkCoordinates chunkcoordinates, boolean flag) { - IChunkProvider ichunkprovider = world.I(); + IChunkProvider ichunkprovider = world.J(); ichunkprovider.getChunkAt(chunkcoordinates.x - 3 >> 4, chunkcoordinates.z - 3 >> 4); ichunkprovider.getChunkAt(chunkcoordinates.x + 3 >> 4, chunkcoordinates.z - 3 >> 4); @@ -1146,8 +1176,8 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen public void a(Statistic statistic, int i) {} - protected void bi() { - super.bi(); + protected void bl() { + super.bl(); this.a(StatisticList.u, 1); if (this.isSprinting()) { this.j(0.8F); @@ -1163,12 +1193,12 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen if (this.abilities.isFlying && this.vehicle == null) { double d3 = this.motY; - float f2 = this.aO; + float f2 = this.aP; - this.aO = this.abilities.a(); + this.aP = this.abilities.a(); super.e(f, f1); this.motY = d3 * 0.6D; - this.aO = f2; + this.aP = f2; } else { super.e(f, f1); } @@ -1186,7 +1216,7 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen this.a(StatisticList.q, i); this.j(0.015F * (float) i * 0.01F); } - } else if (this.H()) { + } else if (this.G()) { i = Math.round(MathHelper.sqrt(d0 * d0 + d2 * d2) * 100.0F); if (i > 0) { this.a(StatisticList.m, i); @@ -1220,7 +1250,7 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen int i = Math.round(MathHelper.sqrt(d0 * d0 + d1 * d1 + d2 * d2) * 100.0F); if (i > 0) { - if (this.vehicle instanceof EntityMinecart) { + if (this.vehicle instanceof EntityMinecartAbstract) { this.a(StatisticList.r, i); if (this.e == null) { this.e = new ChunkCoordinates(MathHelper.floor(this.locX), MathHelper.floor(this.locY), MathHelper.floor(this.locZ)); @@ -1252,9 +1282,9 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen } } - public void am() { + public void al() { if (!this.abilities.isFlying) { - super.am(); + super.al(); } } @@ -1262,9 +1292,9 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen return this.inventory.f(i); } - protected void bE() {} + protected void bH() {} - protected void bF() {} + protected void bI() {} public void giveExp(int i) { this.addScore(i); @@ -1314,11 +1344,11 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen return this.foodData; } - public boolean g(boolean flag) { + public boolean i(boolean flag) { return (flag || this.foodData.c()) && !this.abilities.isInvulnerable; } - public boolean cd() { + public boolean cm() { return this.getHealth() > 0 && this.getHealth() < this.maxHealth; // CraftBukkit - this.getMaxHealth() -> this.maxHealth } @@ -1327,12 +1357,12 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen this.f = itemstack; this.g = i; if (!this.world.isStatic) { - this.d(true); + this.e(true); } } } - public boolean f(int i, int j, int k) { + public boolean e(int i, int j, int k) { if (this.abilities.mayBuild) { return true; } else { @@ -1345,8 +1375,8 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen return true; } - if (this.bS() != null) { - ItemStack itemstack = this.bS(); + if (this.cb() != null) { + ItemStack itemstack = this.cb(); if (itemstack.b(block) || itemstack.a(block) > 1.0F) { return true; @@ -1359,7 +1389,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.x() : false); + return this.abilities.mayBuild ? true : (itemstack != null ? itemstack.y() : false); } protected int getExpValue(EntityHuman entityhuman) { @@ -1380,6 +1410,16 @@ 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 bS() { + return false; + } + // CraftBukkit end */ + public void copyTo(EntityHuman entityhuman, boolean flag) { if (flag) { this.inventory.b(entityhuman.inventory); @@ -1389,7 +1429,7 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen this.expTotal = entityhuman.expTotal; this.exp = entityhuman.exp; this.setScore(entityhuman.getScore()); - this.ar = entityhuman.ar; + this.as = entityhuman.as; } else if (this.world.getGameRules().getBoolean("keepInventory")) { this.inventory.b(entityhuman.inventory); this.expLevel = entityhuman.expLevel; @@ -1429,7 +1469,7 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen return i == 0 ? this.inventory.getItemInHand() : this.inventory.armor[i - 1]; } - public ItemStack bD() { + public ItemStack bG() { return this.inventory.getItemInHand(); } @@ -1440,4 +1480,20 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen public ItemStack[] getEquipment() { return this.inventory.armor; } + + public boolean aw() { + return !this.abilities.isFlying; + } + + public Scoreboard getScoreboard() { + return this.world.getScoreboard(); + } + + public ScoreboardTeam getScoreboardTeam() { + return this.getScoreboard().i(this.name); + } + + public String getScoreboardDisplayName() { + return ScoreboardTeam.a(this.getScoreboardTeam(), this.name); + } } diff --git a/src/main/java/net/minecraft/server/EntityIronGolem.java b/src/main/java/net/minecraft/server/EntityIronGolem.java index c0655dfbfc..d2c5857ee5 100644 --- a/src/main/java/net/minecraft/server/EntityIronGolem.java +++ b/src/main/java/net/minecraft/server/EntityIronGolem.java @@ -32,16 +32,16 @@ public class EntityIronGolem extends EntityGolem { this.datawatcher.a(16, Byte.valueOf((byte) 0)); } - public boolean be() { + public boolean bh() { return true; } - protected void bm() { + 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.aL(); + this.aO(); } else { ChunkCoordinates chunkcoordinates = this.d.getCenter(); @@ -49,19 +49,19 @@ public class EntityIronGolem extends EntityGolem { } } - super.bm(); + super.bp(); } public int getMaxHealth() { return 100; } - protected int g(int i) { + protected int h(int i) { return i; } protected void o(Entity entity) { - if (entity instanceof IMonster && this.aB().nextInt(20) == 0) { + if (entity instanceof IMonster && this.aE().nextInt(20) == 0) { this.setGoalTarget((EntityLiving) entity); } @@ -121,20 +121,20 @@ public class EntityIronGolem extends EntityGolem { return this.d; } - public void f(boolean flag) { + public void a(boolean flag) { this.g = flag ? 400 : 0; this.world.broadcastEntityEffect(this, (byte) 11); } - protected String aY() { + protected String bb() { return "none"; } - protected String aZ() { + protected String bc() { return "mob.irongolem.hit"; } - protected String ba() { + protected String bd() { return "mob.irongolem.death"; } diff --git a/src/main/java/net/minecraft/server/EntityItem.java b/src/main/java/net/minecraft/server/EntityItem.java index b8b6d52efb..ee775bf740 100644 --- a/src/main/java/net/minecraft/server/EntityItem.java +++ b/src/main/java/net/minecraft/server/EntityItem.java @@ -53,8 +53,8 @@ public class EntityItem extends Entity { this.getDataWatcher().a(10, 5); } - public void j_() { - super.j_(); + public void l_() { + super.l_(); // CraftBukkit start int currentTick = (int) (System.currentTimeMillis() / 50); this.pickupDelay -= (currentTick - this.lastTick); @@ -65,7 +65,7 @@ public class EntityItem extends Entity { this.lastY = this.locY; this.lastZ = this.locZ; this.motY -= 0.03999999910593033D; - this.Y = this.i(this.locX, (this.boundingBox.b + this.boundingBox.e) / 2.0D, this.locZ); + this.Z = this.i(this.locX, (this.boundingBox.b + this.boundingBox.e) / 2.0D, this.locZ); this.move(this.motX, this.motY, this.motZ); boolean flag = (int) this.lastX != (int) this.locX || (int) this.lastY != (int) this.locY || (int) this.lastZ != (int) this.locZ; @@ -135,7 +135,7 @@ public class EntityItem extends Entity { return false; } else if (itemstack1.hasTag() && !itemstack1.getTag().equals(itemstack.getTag())) { return false; - } else if (itemstack1.getItem().l() && itemstack1.getData() != itemstack.getData()) { + } else if (itemstack1.getItem().m() && itemstack1.getData() != itemstack.getData()) { return false; } else if (itemstack1.count < itemstack.count) { return entityitem.a(this); @@ -158,7 +158,7 @@ public class EntityItem extends Entity { this.age = 4800; } - public boolean I() { + public boolean H() { return this.world.a(this.boundingBox, Material.WATER, (Entity) this); } @@ -169,10 +169,10 @@ public class EntityItem extends Entity { public boolean damageEntity(DamageSource damagesource, int i) { if (this.isInvulnerable()) { return false; - } else if (this.getItemStack() != null && this.getItemStack().id == Item.NETHER_STAR.id && damagesource == DamageSource.EXPLOSION) { + } else if (this.getItemStack() != null && this.getItemStack().id == Item.NETHER_STAR.id && damagesource.c()) { return false; } else { - this.K(); + this.J(); this.d -= i; if (this.d <= 0) { this.die(); @@ -212,7 +212,7 @@ public class EntityItem extends Entity { } } - public void c_(EntityHuman entityhuman) { + public void b_(EntityHuman entityhuman) { if (!this.world.isStatic) { ItemStack itemstack = this.getItemStack(); int i = itemstack.count; @@ -267,12 +267,12 @@ public class EntityItem extends Entity { return LocaleI18n.get("item." + this.getItemStack().a()); } - public boolean aq() { + public boolean ap() { return false; } - public void b(int i) { - super.b(i); + public void c(int i) { + super.c(i); if (!this.world.isStatic) { this.g(); } @@ -282,7 +282,10 @@ public class EntityItem extends Entity { ItemStack itemstack = this.getDataWatcher().getItemStack(10); if (itemstack == null) { - System.out.println("Item entity " + this.id + " has no item?!"); + if (this.world != null) { + this.world.getLogger().severe("Item entity " + this.id + " has no item?!"); + } + return new ItemStack(Block.STONE); } else { return itemstack; diff --git a/src/main/java/net/minecraft/server/EntityLightning.java b/src/main/java/net/minecraft/server/EntityLightning.java index 606ae347db..638615d4f3 100644 --- a/src/main/java/net/minecraft/server/EntityLightning.java +++ b/src/main/java/net/minecraft/server/EntityLightning.java @@ -45,7 +45,7 @@ public class EntityLightning extends EntityWeather { world.getServer().getPluginManager().callEvent(event); if (!event.isCancelled()) { - world.setTypeId(i, j, k, Block.FIRE.id); + world.setTypeIdUpdate(i, j, k, Block.FIRE.id); } // CraftBukkit end } @@ -61,7 +61,7 @@ public class EntityLightning extends EntityWeather { world.getServer().getPluginManager().callEvent(event); if (!event.isCancelled()) { - world.setTypeId(j, k, l, Block.FIRE.id); + world.setTypeIdUpdate(j, k, l, Block.FIRE.id); } // CraftBukkit end } @@ -69,8 +69,8 @@ public class EntityLightning extends EntityWeather { } } - public void j_() { - super.j_(); + public void l_() { + super.l_(); if (this.lifeTicks == 2) { this.world.makeSound(this.locX, this.locY, this.locZ, "ambient.weather.thunder", 10000.0F, 0.8F + this.random.nextFloat() * 0.2F); this.world.makeSound(this.locX, this.locY, this.locZ, "random.explode", 2.0F, 0.5F + this.random.nextFloat() * 0.2F); @@ -96,7 +96,7 @@ public class EntityLightning extends EntityWeather { this.world.getServer().getPluginManager().callEvent(event); if (!event.isCancelled()) { - this.world.setTypeId(i, j, k, Block.FIRE.id); + this.world.setTypeIdUpdate(i, j, k, Block.FIRE.id); } // CraftBukkit end } diff --git a/src/main/java/net/minecraft/server/EntityLiving.java b/src/main/java/net/minecraft/server/EntityLiving.java index 7d2e633bf9..ae180c2453 100644 --- a/src/main/java/net/minecraft/server/EntityLiving.java +++ b/src/main/java/net/minecraft/server/EntityLiving.java @@ -15,57 +15,57 @@ import org.bukkit.event.entity.EntityRegainHealthEvent; public abstract class EntityLiving extends Entity { - private static final float[] b = new float[] { 0.0F, 0.0F, 0.05F, 0.1F}; - private static final float[] c = new float[] { 0.0F, 0.0F, 0.05F, 0.2F}; + 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.02F}; - public static final float[] at = new float[] { 0.0F, 0.1F, 0.15F, 0.45F}; + public static final float[] au = new float[] { 0.0F, 0.1F, 0.15F, 0.45F}; public int maxNoDamageTicks = 20; - public float av; public float aw; - public float ax = 0.0F; + public float ax; public float ay = 0.0F; public float az = 0.0F; public float aA = 0.0F; - protected float aB; + public float aB = 0.0F; protected float aC; protected float aD; protected float aE; - protected boolean aF = true; + protected float aF; + protected boolean aG = true; protected String texture = "/mob/char.png"; - protected boolean aH = true; - protected float aI = 0.0F; - protected String aJ = null; - protected float aK = 1.0F; - protected int aL = 0; - protected float aM = 0.0F; - public float aN = 0.1F; - public float aO = 0.02F; - public float aP; + 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 aS; - protected int aT; - public int aU; + public int aT; + protected int aU; + public int aV; public int hurtTicks; - public int aW; - public float aX = 0.0F; + public int aX; + public float aY = 0.0F; public int deathTicks = 0; public int attackTicks = 0; - public float ba; public float bb; - protected boolean bc = false; - protected int bd; - public int be = -1; - public float bf = (float) (Math.random() * 0.8999999761581421D + 0.10000000149011612D); - public float bg; + 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 bl = 0; + public int bm = 0; public HashMap effects = new HashMap(); // CraftBukkit - protected -> public public boolean updateEffects = true; // CraftBukkit - private -> public private int i; @@ -77,35 +77,36 @@ public abstract class EntityLiving extends Entity { protected final PathfinderGoalSelector goalSelector; protected final PathfinderGoalSelector targetSelector; private EntityLiving goalTarget; - private EntitySenses bO; - private float bP; - private ChunkCoordinates bQ = new ChunkCoordinates(0, 0, 0); - private float bR = -1.0F; + 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[] bT = new ItemStack[5]; - public boolean bq = false; - public int br = 0; + 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 int bt; - protected double bu; + protected final CombatTracker bt = new CombatTracker(this); + protected int bu; protected double bv; protected double bw; protected double bx; protected double by; - float bz = 0.0F; + protected double bz; + float bA = 0.0F; public int lastDamage = 0; // CraftBukkit - protected -> public - protected int bB = 0; - protected float bC; + protected int bC = 0; protected float bD; protected float bE; - protected boolean bF = false; - protected float bG = 0.0F; - protected float bH = 0.7F; - private int bV = 0; - private Entity bW; - protected int bI = 0; + 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; // CraftBukkit start public int expToDrop = 0; public int maxAirTicks = 300; @@ -121,19 +122,23 @@ public abstract class EntityLiving extends Entity { this.moveController = new ControllerMove(this); this.jumpController = new ControllerJump(this); this.senses = new EntityAIBodyControl(this); - this.navigation = new Navigation(this, world, 16.0F); - this.bO = new EntitySenses(this); - this.aw = (float) (Math.random() + 1.0D) * 0.01F; + this.navigation = new Navigation(this, world, (float) this.ay()); + this.bP = new EntitySenses(this); + this.ax = (float) (Math.random() + 1.0D) * 0.01F; this.setPosition(this.locX, this.locY, this.locZ); - this.av = (float) Math.random() * 12398.0F; + this.aw = (float) Math.random() * 12398.0F; this.yaw = (float) (Math.random() * 3.1415927410125732D * 2.0D); - this.az = this.yaw; + this.aA = this.yaw; for (int i = 0; i < this.dropChances.length; ++i) { - this.dropChances[i] = 0.05F; + this.dropChances[i] = 0.085F; } - this.X = 0.5F; + this.Y = 0.5F; + } + + protected int ay() { + return 16; } public ControllerLook getControllerLook() { @@ -152,19 +157,19 @@ public abstract class EntityLiving extends Entity { return this.navigation; } - public EntitySenses aA() { - return this.bO; + public EntitySenses aD() { + return this.bP; } - public Random aB() { + public Random aE() { return this.random; } - public EntityLiving aC() { + public EntityLiving aF() { return this.lastDamager; } - public EntityLiving aD() { + public EntityLiving aG() { return this.g; } @@ -174,20 +179,20 @@ public abstract class EntityLiving extends Entity { } } - public int aE() { - return this.bB; + public int aH() { + return this.bC; } - public float ap() { - return this.az; + public float ao() { + return this.aA; } - public float aF() { - return this.bP; + public float aI() { + return this.bQ; } public void e(float f) { - this.bP = f; + this.bQ = f; this.f(f); } @@ -208,11 +213,11 @@ public abstract class EntityLiving extends Entity { return EntityCreeper.class != oclass && EntityGhast.class != oclass; } - public void aH() {} + public void aK() {} protected void a(double d0, boolean flag) { - if (!this.H()) { - this.I(); + if (!this.G()) { + this.H(); } if (flag && this.fallDistance > 0.0F) { @@ -237,55 +242,57 @@ public abstract class EntityLiving extends Entity { super.a(d0, flag); } - public boolean aI() { - return this.e(MathHelper.floor(this.locX), MathHelper.floor(this.locY), MathHelper.floor(this.locZ)); + public boolean aL() { + return this.d(MathHelper.floor(this.locX), MathHelper.floor(this.locY), MathHelper.floor(this.locZ)); } - public boolean e(int i, int j, int k) { - return this.bR == -1.0F ? true : this.bQ.e(i, j, k) < this.bR * this.bR; + 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.bQ.b(i, j, k); - this.bR = (float) l; + this.bR.b(i, j, k); + this.bS = (float) l; } - public ChunkCoordinates aJ() { - return this.bQ; - } - - public float aK() { + public ChunkCoordinates aM() { return this.bR; } - public void aL() { - this.bR = -1.0F; + public float aN() { + return this.bS; } - public boolean aM() { - return this.bR != -1.0F; + 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 ? 60 : 0; + 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 L() { + public boolean K() { return !this.dead; } - public boolean M() { + public boolean L() { return !this.dead; } @@ -293,25 +300,25 @@ public abstract class EntityLiving extends Entity { return this.length * 0.85F; } - public int aN() { + public int aQ() { return 80; } - public void aO() { - String s = this.aY(); + public void aR() { + String s = this.bb(); if (s != null) { - this.makeSound(s, this.aX(), this.aV()); + this.makeSound(s, this.ba(), this.aY()); } } - public void y() { - this.aP = this.aQ; - super.y(); + public void x() { + this.aQ = this.aR; + super.x(); this.world.methodProfiler.a("mobBaseTick"); - if (this.isAlive() && this.random.nextInt(1000) < this.aU++) { - this.aU = -this.aN(); - this.aO(); + if (this.isAlive() && this.random.nextInt(1000) < this.aV++) { + this.aV = -this.aQ(); + this.aR(); } // CraftBukkit start @@ -323,8 +330,8 @@ public abstract class EntityLiving extends Entity { event.getEntity().setLastDamageCause(event); this.damageEntity(DamageSource.STUCK, event.getDamage()); } - // CraftBukkit end } + // CraftBukkit end if (this.isFireproof() || this.world.isStatic) { this.extinguish(); @@ -332,8 +339,8 @@ public abstract class EntityLiving extends Entity { boolean flag = this instanceof EntityHuman && ((EntityHuman) this).abilities.isInvulnerable; - if (this.isAlive() && this.a(Material.WATER) && !this.bc() && !this.effects.containsKey(Integer.valueOf(MobEffectList.WATER_BREATHING.id)) && !flag) { - this.setAirTicks(this.g(this.getAirTicks())); + 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); @@ -365,7 +372,7 @@ public abstract class EntityLiving extends Entity { // CraftBukkit end } - this.ba = this.bb; + this.bb = this.bc; if (this.attackTicks > 0) { --this.attackTicks; } @@ -379,7 +386,7 @@ public abstract class EntityLiving extends Entity { } if (this.health <= 0) { - this.aP(); + this.aS(); } if (this.lastDamageByPlayerTime > 0) { @@ -402,10 +409,10 @@ public abstract class EntityLiving extends Entity { } } - this.bx(); - this.aE = this.aD; - this.ay = this.ax; - this.aA = this.az; + this.bA(); + this.aF = this.aE; + this.az = this.ay; + this.aB = this.aA; this.lastYaw = this.yaw; this.lastPitch = this.pitch; this.world.methodProfiler.b(); @@ -414,7 +421,7 @@ public abstract class EntityLiving extends Entity { // CraftBukkit start public int getExpReward() { int exp = this.getExpValue(this.killer); - + if (!this.world.isStatic && (this.lastDamageByPlayerTime > 0 || this.alwaysGivesExp()) && !this.isBaby()) { return exp; } else { @@ -431,7 +438,7 @@ public abstract class EntityLiving extends Entity { } // CraftBukkit end - protected void aP() { + protected void aS() { ++this.deathTicks; if (this.deathTicks >= 20 && !this.dead) { // CraftBukkit - (this.deathTicks == 20) -> (this.deathTicks >= 20 && !this.dead) int i; @@ -459,15 +466,15 @@ public abstract class EntityLiving extends Entity { } } - protected int g(int i) { + protected int h(int i) { int j = EnchantmentManager.getOxygenEnchantmentLevel(this); return j > 0 && this.random.nextInt(j + 1) > 0 ? i : i - 1; } protected int getExpValue(EntityHuman entityhuman) { - if (this.bd > 0) { - int i = this.bd; + if (this.be > 0) { + int i = this.be; ItemStack[] aitemstack = this.getEquipment(); for (int j = 0; j < aitemstack.length; ++j) { @@ -478,7 +485,7 @@ public abstract class EntityLiving extends Entity { return i; } else { - return this.bd; + return this.be; } } @@ -486,7 +493,7 @@ public abstract class EntityLiving extends Entity { return false; } - public void aR() { + public void aU() { for (int i = 0; i < 20; ++i) { double d0 = this.random.nextGaussian() * 0.02D; double d1 = this.random.nextGaussian() * 0.02D; @@ -497,35 +504,35 @@ public abstract class EntityLiving extends Entity { } } - public void U() { - super.U(); - this.aB = this.aC; - this.aC = 0.0F; + public void T() { + super.T(); + this.aC = this.aD; + this.aD = 0.0F; this.fallDistance = 0.0F; } - public void j_() { - super.j_(); + public void l_() { + super.l_(); if (!this.world.isStatic) { int i; for (i = 0; i < 5; ++i) { ItemStack itemstack = this.getEquipment(i); - if (!ItemStack.matches(itemstack, this.bT[i])) { + if (!ItemStack.matches(itemstack, this.bU[i])) { ((WorldServer) this.world).getTracker().a((Entity) this, (Packet) (new Packet5EntityEquipment(this.id, i, itemstack))); - this.bT[i] = itemstack == null ? null : itemstack.cloneItemStack(); + this.bU[i] = itemstack == null ? null : itemstack.cloneItemStack(); } } - i = this.bJ(); + i = this.bM(); if (i > 0) { - if (this.bl <= 0) { - this.bl = 20 * (30 - i); + if (this.bm <= 0) { + this.bm = 20 * (30 - i); } - --this.bl; - if (this.bl <= 0) { + --this.bm; + if (this.bm <= 0) { this.r(i - 1); } } @@ -535,10 +542,10 @@ public abstract class EntityLiving extends Entity { double d0 = this.locX - this.lastX; double d1 = this.locZ - this.lastZ; float f = (float) (d0 * d0 + d1 * d1); - float f1 = this.ax; + float f1 = this.ay; float f2 = 0.0F; - this.aB = this.aC; + this.aC = this.aD; float f3 = 0.0F; if (f > 0.0025000002F) { @@ -548,7 +555,7 @@ public abstract class EntityLiving extends Entity { f1 = (float) org.bukkit.craftbukkit.TrigMath.atan2(d1, d0) * 180.0F / 3.1415927F - 90.0F; } - if (this.aQ > 0.0F) { + if (this.aR > 0.0F) { f1 = this.yaw; } @@ -556,15 +563,15 @@ public abstract class EntityLiving extends Entity { f3 = 0.0F; } - this.aC += (f3 - this.aC) * 0.3F; + this.aD += (f3 - this.aD) * 0.3F; this.world.methodProfiler.a("headTurn"); - if (this.be()) { + if (this.bh()) { this.senses.a(); } else { - float f4 = MathHelper.g(f1 - this.ax); + float f4 = MathHelper.g(f1 - this.ay); - this.ax += f4 * 0.3F; - float f5 = MathHelper.g(this.yaw - this.ax); + this.ay += f4 * 0.3F; + float f5 = MathHelper.g(this.yaw - this.ay); boolean flag = f5 < -90.0F || f5 >= 90.0F; if (f5 < -75.0F) { @@ -575,9 +582,9 @@ public abstract class EntityLiving extends Entity { f5 = 75.0F; } - this.ax = this.yaw - f5; + this.ay = this.yaw - f5; if (f5 * f5 > 2500.0F) { - this.ax += f5 * 0.2F; + this.ay += f5 * 0.2F; } if (flag) { @@ -596,12 +603,12 @@ public abstract class EntityLiving extends Entity { this.lastYaw += 360.0F; } - while (this.ax - this.ay < -180.0F) { - this.ay -= 360.0F; + while (this.ay - this.az < -180.0F) { + this.az -= 360.0F; } - while (this.ax - this.ay >= 180.0F) { - this.ay += 360.0F; + while (this.ay - this.az >= 180.0F) { + this.az += 360.0F; } while (this.pitch - this.lastPitch < -180.0F) { @@ -612,16 +619,16 @@ public abstract class EntityLiving extends Entity { this.lastPitch += 360.0F; } - while (this.az - this.aA < -180.0F) { - this.aA -= 360.0F; + while (this.aA - this.aB < -180.0F) { + this.aB -= 360.0F; } - while (this.az - this.aA >= 180.0F) { - this.aA += 360.0F; + while (this.aA - this.aB >= 180.0F) { + this.aB += 360.0F; } this.world.methodProfiler.b(); - this.aD += f2; + this.aE += f2; } // CraftBukkit start - delegate so we can handle providing a reason for health being regained @@ -667,10 +674,10 @@ public abstract class EntityLiving extends Entity { } else if (this.world.isStatic) { return false; } else { - this.bB = 0; + this.bC = 0; if (this.health <= 0) { return false; - } else if (damagesource.k() && this.hasEffect(MobEffectList.FIRE_RESISTANCE)) { + } else if (damagesource.m() && this.hasEffect(MobEffectList.FIRE_RESISTANCE)) { return false; } else { if ((damagesource == DamageSource.ANVIL || damagesource == DamageSource.FALLING_BLOCK) && this.getEquipment(4) != null) { @@ -678,7 +685,7 @@ public abstract class EntityLiving extends Entity { i = (int) ((float) i * 0.75F); } - this.bh = 1.5F; + this.bi = 1.5F; boolean flag = true; // CraftBukkit start @@ -701,13 +708,13 @@ public abstract class EntityLiving extends Entity { flag = false; } else { this.lastDamage = i; - this.aS = this.health; + this.aT = this.health; this.noDamageTicks = this.maxNoDamageTicks; this.d(damagesource, i); - this.hurtTicks = this.aW = 10; + this.hurtTicks = this.aX = 10; } - this.aX = 0.0F; + this.aY = 0.0F; Entity entity = damagesource.getEntity(); if (entity != null) { @@ -716,13 +723,13 @@ public abstract class EntityLiving extends Entity { } if (entity instanceof EntityHuman) { - this.lastDamageByPlayerTime = 60; + this.lastDamageByPlayerTime = 100; this.killer = (EntityHuman) entity; } else if (entity instanceof EntityWolf) { EntityWolf entitywolf = (EntityWolf) entity; if (entitywolf.isTamed()) { - this.lastDamageByPlayerTime = 60; + this.lastDamageByPlayerTime = 100; this.killer = null; } } @@ -730,8 +737,8 @@ public abstract class EntityLiving extends Entity { if (flag) { this.world.broadcastEntityEffect(this, (byte) 2); - if (damagesource != DamageSource.DROWN && damagesource != DamageSource.EXPLOSION2) { - this.K(); + if (damagesource != DamageSource.DROWN) { + this.J(); } if (entity != null) { @@ -743,21 +750,21 @@ public abstract class EntityLiving extends Entity { d0 = (Math.random() - Math.random()) * 0.01D; } - this.aX = (float) (Math.atan2(d1, d0) * 180.0D / 3.1415927410125732D) - this.yaw; + this.aY = (float) (Math.atan2(d1, d0) * 180.0D / 3.1415927410125732D) - this.yaw; this.a(entity, i, d0, d1); } else { - this.aX = (float) ((int) (Math.random() * 2.0D) * 180); + this.aY = (float) ((int) (Math.random() * 2.0D) * 180); } } if (this.health <= 0) { if (flag) { - this.makeSound(this.ba(), this.aX(), this.aV()); + this.makeSound(this.bd(), this.ba(), this.aY()); } this.die(damagesource); } else if (flag) { - this.makeSound(this.aZ(), this.aX(), this.aV()); + this.makeSound(this.bc(), this.ba(), this.aY()); } return true; @@ -765,11 +772,11 @@ public abstract class EntityLiving extends Entity { } } - protected float aV() { + 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 int aW() { + public int aZ() { int i = 0; ItemStack[] aitemstack = this.getEquipment(); int j = aitemstack.length; @@ -778,7 +785,7 @@ public abstract class EntityLiving extends Entity { ItemStack itemstack = aitemstack[k]; if (itemstack != null && itemstack.getItem() instanceof ItemArmor) { - int l = ((ItemArmor) itemstack.getItem()).b; + int l = ((ItemArmor) itemstack.getItem()).c; i += l; } @@ -791,56 +798,78 @@ public abstract class EntityLiving extends Entity { protected int b(DamageSource damagesource, int i) { if (!damagesource.ignoresArmor()) { - int j = 25 - this.aW(); - int k = i * j + this.aT; + int j = 25 - this.aZ(); + int k = i * j + this.aU; this.k(i); i = k / 25; - this.aT = k % 25; + this.aU = k % 25; } return i; } protected int c(DamageSource damagesource, int i) { - if (this.hasEffect(MobEffectList.RESISTANCE)) { - int j = (this.getEffect(MobEffectList.RESISTANCE).getAmplifier() + 1) * 5; - int k = 25 - j; - int l = i * k + this.aT; + int j; + int k; + int l; + 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.aT = l % 25; + this.aU = l % 25; } - return i; + if (i <= 0) { + return 0; + } else { + j = EnchantmentManager.a(this.getEquipment(), damagesource); + if (j > 20) { + j = 20; + } + + if (j > 0 && j <= 20) { + k = 25 - j; + l = i * k + this.aU; + i = l / 25; + this.aU = l % 25; + } + + return i; + } } protected void d(DamageSource damagesource, int i) { if (!this.isInvulnerable()) { i = this.b(damagesource, i); i = this.c(damagesource, i); + int j = this.getHealth(); + this.health -= i; + this.bt.a(damagesource, j, i); } } - protected float aX() { + protected float ba() { return 1.0F; } - protected String aY() { + protected String bb() { return null; } - protected String aZ() { + protected String bc() { return "damage.hit"; } - protected String ba() { + protected String bd() { return "damage.hit"; } public void a(Entity entity, int i, double d0, double d1) { - this.am = true; + this.an = true; float f = MathHelper.sqrt(d0 * d0 + d1 * d1); float f1 = 0.4F; @@ -857,16 +886,17 @@ public abstract class EntityLiving extends Entity { public void die(DamageSource damagesource) { Entity entity = damagesource.getEntity(); + EntityLiving entityliving = this.bN(); - if (this.aL >= 0 && entity != null) { - entity.c(this, this.aL); + if (this.aM >= 0 && entityliving != null) { + entityliving.c(this, this.aM); } if (entity != null) { entity.a(this); } - this.bc = true; + this.bd = true; if (!this.world.isStatic) { int i = 0; @@ -971,9 +1001,9 @@ public abstract class EntityLiving extends Entity { public void e(float f, float f1) { double d0; - if (this.H() && (!(this instanceof EntityHuman) || !((EntityHuman) this).abilities.isFlying)) { + if (this.G() && (!(this instanceof EntityHuman) || !((EntityHuman) this).abilities.isFlying)) { d0 = this.locY; - this.a(f, f1, this.be() ? 0.04F : 0.02F); + this.a(f, f1, this.bh() ? 0.04F : 0.02F); this.move(this.motX, this.motY, this.motZ); this.motX *= 0.800000011920929D; this.motY *= 0.800000011920929D; @@ -982,7 +1012,7 @@ public abstract class EntityLiving extends Entity { if (this.positionChanged && this.c(this.motX, this.motY + 0.6000000238418579D - this.locY + d0, this.motZ)) { this.motY = 0.30000001192092896D; } - } else if (this.J() && (!(this instanceof EntityHuman) || !((EntityHuman) this).abilities.isFlying)) { + } else if (this.I() && (!(this instanceof EntityHuman) || !((EntityHuman) this).abilities.isFlying)) { d0 = this.locY; this.a(f, f1, 0.02F); this.move(this.motX, this.motY, this.motZ); @@ -1009,15 +1039,15 @@ public abstract class EntityLiving extends Entity { float f4; if (this.onGround) { - if (this.be()) { - f4 = this.aF(); + if (this.bh()) { + f4 = this.aI(); } else { - f4 = this.aN; + f4 = this.aO; } f4 *= f3; } else { - f4 = this.aO; + f4 = this.aP; } this.a(f, f1, f4); @@ -1082,7 +1112,7 @@ public abstract class EntityLiving extends Entity { this.motZ *= (double) f2; } - this.bg = this.bh; + this.bh = this.bi; d0 = this.locX - this.lastX; double d1 = this.locZ - this.lastZ; float f6 = MathHelper.sqrt(d0 * d0 + d1 * d1) * 4.0F; @@ -1091,8 +1121,8 @@ public abstract class EntityLiving extends Entity { f6 = 1.0F; } - this.bh += (f6 - this.bh) * 0.4F; - this.bi += this.bh; + this.bi += (f6 - this.bi) * 0.4F; + this.bj += this.bi; } public boolean g_() { @@ -1113,7 +1143,7 @@ public abstract class EntityLiving extends Entity { nbttagcompound.setShort("HurtTime", (short) this.hurtTicks); nbttagcompound.setShort("DeathTime", (short) this.deathTicks); nbttagcompound.setShort("AttackTime", (short) this.attackTicks); - nbttagcompound.setBoolean("CanPickUpLoot", this.canPickUpLoot); + nbttagcompound.setBoolean("CanPickUpLoot", this.bS()); nbttagcompound.setBoolean("PersistenceRequired", this.persistent); NBTTagList nbttaglist = new NBTTagList(); @@ -1150,6 +1180,8 @@ public abstract class EntityLiving extends Entity { } nbttagcompound.set("DropChances", nbttaglist1); + nbttagcompound.setString("CustomName", this.getCustomName()); + nbttagcompound.setBoolean("CustomNameVisible", this.getCustomNameVisible()); nbttagcompound.setInt("Bukkit.MaxHealth", this.maxHealth); // CraftBukkit } @@ -1161,8 +1193,7 @@ public abstract class EntityLiving extends Entity { } if (!nbttagcompound.hasKey("Health")) { - this.health = this.maxHealth; // this.getMaxHealth() -> this.maxHealth - // CraftBukkit + this.health = this.maxHealth; // CraftBukkit - this.getMaxHealth() -> this.maxHealth } this.hurtTicks = nbttagcompound.getShort("HurtTime"); @@ -1180,6 +1211,11 @@ public abstract class EntityLiving extends Entity { } // 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; @@ -1215,35 +1251,35 @@ public abstract class EntityLiving extends Entity { return !this.dead && this.health > 0; } - public boolean bc() { + public boolean bf() { return false; } public void f(float f) { - this.bD = f; + this.bE = f; } - public void e(boolean flag) { - this.bF = flag; + public void f(boolean flag) { + this.bG = flag; } public void c() { - if (this.bV > 0) { - --this.bV; + if (this.bX > 0) { + --this.bX; } - if (this.bt > 0) { - double d0 = this.locX + (this.bu - this.locX) / (double) this.bt; - double d1 = this.locY + (this.bv - this.locY) / (double) this.bt; - double d2 = this.locZ + (this.bw - this.locZ) / (double) this.bt; - double d3 = MathHelper.g(this.bx - (double) this.yaw); + 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); - this.yaw = (float) ((double) this.yaw + d3 / (double) this.bt); - this.pitch = (float) ((double) this.pitch + (this.by - (double) this.pitch) / (double) this.bt); - --this.bt; + 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.setPosition(d0, d1, d2); this.b(this.yaw, this.pitch); - } else if (!this.bf()) { + } else if (!this.bi()) { this.motX *= 0.98D; this.motY *= 0.98D; this.motZ *= 0.98D; @@ -1262,59 +1298,59 @@ public abstract class EntityLiving extends Entity { } this.world.methodProfiler.a("ai"); - if (this.bg()) { - this.bF = false; - this.bC = 0.0F; + if (this.bj()) { + this.bG = false; this.bD = 0.0F; this.bE = 0.0F; - } else if (this.bf()) { - if (this.be()) { + this.bF = 0.0F; + } else if (this.bi()) { + if (this.bh()) { this.world.methodProfiler.a("newAi"); - this.bl(); + this.bo(); this.world.methodProfiler.b(); } else { this.world.methodProfiler.a("oldAi"); - this.bn(); + this.bq(); this.world.methodProfiler.b(); - this.az = this.yaw; + this.aA = this.yaw; } } this.world.methodProfiler.b(); this.world.methodProfiler.a("jump"); - if (this.bF) { - if (!this.H() && !this.J()) { - if (this.onGround && this.bV == 0) { - this.bi(); - this.bV = 10; + if (this.bG) { + if (!this.G() && !this.I()) { + if (this.onGround && this.bX == 0) { + this.bl(); + this.bX = 10; } } else { this.motY += 0.03999999910593033D; } } else { - this.bV = 0; + this.bX = 0; } this.world.methodProfiler.b(); this.world.methodProfiler.a("travel"); - this.bC *= 0.98F; this.bD *= 0.98F; - this.bE *= 0.9F; - float f = this.aN; + this.bE *= 0.98F; + this.bF *= 0.9F; + float f = this.aO; - this.aN *= this.bB(); - this.e(this.bC, this.bD); - this.aN = f; + this.aO *= this.bE(); + this.e(this.bD, this.bE); + this.aO = f; this.world.methodProfiler.b(); this.world.methodProfiler.a("push"); if (!this.world.isStatic) { - this.bd(); + 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.canPickUpLoot && !this.bc && this.world.getGameRules().getBoolean("mobGriefing")) { + if (!this.world.isStatic && !(this instanceof EntityPlayer) && this.bS() && !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(); @@ -1351,10 +1387,10 @@ public abstract class EntityLiving extends Entity { ItemArmor itemarmor = (ItemArmor) itemstack.getItem(); ItemArmor itemarmor1 = (ItemArmor) itemstack1.getItem(); - if (itemarmor.b == itemarmor1.b) { + if (itemarmor.c == itemarmor1.c) { flag = itemstack.getData() > itemstack1.getData() || itemstack.hasTag() && !itemstack1.hasTag(); } else { - flag = itemarmor.b > itemarmor1.b; + flag = itemarmor.c > itemarmor1.c; } } else { flag = false; @@ -1380,14 +1416,14 @@ public abstract class EntityLiving extends Entity { this.world.methodProfiler.b(); } - protected void bd() { + protected void bg() { 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); - if (entity.M()) { + if (entity.L()) { this.o(entity); } } @@ -1398,23 +1434,23 @@ public abstract class EntityLiving extends Entity { entity.collide(this); } - protected boolean be() { + protected boolean bh() { return false; } - protected boolean bf() { + protected boolean bi() { return !this.world.isStatic; } - protected boolean bg() { + protected boolean bj() { return this.health <= 0; } - public boolean bh() { + public boolean bk() { return false; } - protected void bi() { + protected void bl() { this.motY = 0.41999998688697815D; if (this.hasEffect(MobEffectList.JUMP)) { this.motY += (double) ((float) (this.getEffect(MobEffectList.JUMP).getAmplifier() + 1) * 0.1F); @@ -1427,14 +1463,14 @@ public abstract class EntityLiving extends Entity { this.motZ += (double) (MathHelper.cos(f) * 0.2F); } - this.am = true; + this.an = true; } protected boolean isTypeNotPersistent() { return true; } - protected void bk() { + protected void bn() { if (!this.persistent) { EntityHuman entityhuman = this.world.findNearbyPlayer(this, -1.0D); @@ -1444,30 +1480,30 @@ public abstract class EntityLiving extends Entity { double d2 = entityhuman.locZ - this.locZ; double d3 = d0 * d0 + d1 * d1 + d2 * d2; - if (d3 > 16384.0D) { // CraftBukkit - remove this.bj() check + if (d3 > 16384.0D) { // CraftBukkit - remove isTypeNotPersistent() check this.die(); } - if (this.bB > 600 && this.random.nextInt(800) == 0 && d3 > 1024.0D) { // CraftBukkit - remove this.bj() check + if (this.bC > 600 && this.random.nextInt(800) == 0 && d3 > 1024.0D) { // CraftBukkit - remove isTypeNotPersistent() check this.die(); } else if (d3 < 1024.0D) { - this.bB = 0; + this.bC = 0; } } // CraftBukkit start } else { - this.bB = 0; + this.bC = 0; } // CraftBukkit end } - protected void bl() { - ++this.bB; + protected void bo() { + ++this.bC; this.world.methodProfiler.a("checkDespawn"); - this.bk(); + this.bn(); this.world.methodProfiler.b(); this.world.methodProfiler.a("sensing"); - this.bO.a(); + this.bP.a(); this.world.methodProfiler.b(); this.world.methodProfiler.a("targetSelector"); this.targetSelector.a(); @@ -1479,7 +1515,7 @@ public abstract class EntityLiving extends Entity { this.navigation.e(); this.world.methodProfiler.b(); this.world.methodProfiler.a("mob tick"); - this.bm(); + this.bp(); this.world.methodProfiler.b(); this.world.methodProfiler.a("controls"); this.world.methodProfiler.a("move"); @@ -1492,65 +1528,65 @@ public abstract class EntityLiving extends Entity { this.world.methodProfiler.b(); } - protected void bm() {} + protected void bp() {} - protected void bn() { - ++this.bB; - this.bk(); - this.bC = 0.0F; + 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); if (entityhuman != null) { - this.bW = entityhuman; - this.bI = 10 + this.random.nextInt(20); + this.bY = entityhuman; + this.bJ = 10 + this.random.nextInt(20); } else { - this.bE = (this.random.nextFloat() - 0.5F) * 20.0F; + this.bF = (this.random.nextFloat() - 0.5F) * 20.0F; } } - if (this.bW != null) { - this.a(this.bW, 10.0F, (float) this.bp()); - if (this.bI-- <= 0 || this.bW.dead || this.bW.e((Entity) this) > (double) (f * f)) { - this.bW = null; + 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.bE = (this.random.nextFloat() - 0.5F) * 20.0F; + this.bF = (this.random.nextFloat() - 0.5F) * 20.0F; } - this.yaw += this.bE; - this.pitch = this.bG; + this.yaw += this.bF; + this.pitch = this.bH; } - boolean flag = this.H(); - boolean flag1 = this.J(); + boolean flag = this.G(); + boolean flag1 = this.I(); if (flag || flag1) { - this.bF = this.random.nextFloat() < 0.8F; + this.bG = this.random.nextFloat() < 0.8F; } } - protected void bo() { + protected void br() { int i = this.h(); - if (this.bq) { - ++this.br; - if (this.br >= i) { - this.br = 0; - this.bq = false; + if (this.br) { + ++this.bs; + if (this.bs >= i) { + this.bs = 0; + this.br = false; } } else { - this.br = 0; + this.bs = 0; } - this.aQ = (float) this.br / (float) i; + this.aR = (float) this.bs / (float) i; } - public int bp() { + public int bs() { return 40; } @@ -1562,7 +1598,7 @@ public abstract class EntityLiving extends Entity { if (entity instanceof EntityLiving) { EntityLiving entityliving = (EntityLiving) entity; - d2 = this.locY + (double) this.getHeadHeight() - (entityliving.locY + (double) entityliving.getHeadHeight()); + 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()); } @@ -1571,7 +1607,7 @@ public abstract class EntityLiving extends Entity { 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.pitch = this.b(this.pitch, f3, f1); this.yaw = this.b(this.yaw, f2, f); } @@ -1593,7 +1629,7 @@ public abstract class EntityLiving extends Entity { return this.world.b(this.boundingBox) && this.world.getCubes(this, this.boundingBox).isEmpty() && !this.world.containsLiquid(this.boundingBox); } - protected void C() { + protected void B() { // CraftBukkit start EntityDamageByBlockEvent event = new EntityDamageByBlockEvent(null, this.getBukkitEntity(), EntityDamageEvent.DamageCause.VOID, 4); this.world.getServer().getPluginManager().callEvent(event); @@ -1607,7 +1643,7 @@ public abstract class EntityLiving extends Entity { // CraftBukkit end } - public Vec3D Z() { + public Vec3D Y() { return this.i(1.0F); } @@ -1635,7 +1671,7 @@ public abstract class EntityLiving extends Entity { } } - public int bv() { + public int by() { return 4; } @@ -1643,7 +1679,7 @@ public abstract class EntityLiving extends Entity { return false; } - protected void bx() { + protected void bA() { Iterator iterator = this.effects.keySet().iterator(); while (iterator.hasNext()) { @@ -1705,7 +1741,7 @@ public abstract class EntityLiving extends Entity { } } - public void by() { + public void bB() { Iterator iterator = this.effects.keySet().iterator(); while (iterator.hasNext()) { @@ -1759,7 +1795,7 @@ public abstract class EntityLiving extends Entity { return true; } - public boolean bA() { + public boolean bD() { return this.getMonsterType() == EnumMonsterType.UNDEAD; } @@ -1783,7 +1819,7 @@ public abstract class EntityLiving extends Entity { this.updateEffects = true; } - public float bB() { + public float bE() { float f = 1.0F; if (this.hasEffect(MobEffectList.FASTER_MOVEMENT)) { @@ -1794,6 +1830,10 @@ public abstract class EntityLiving extends Entity { f *= 1.0F - 0.15F * (float) (this.getEffect(MobEffectList.SLOWER_MOVEMENT).getAmplifier() + 1); } + if (f < 0.0F) { + f = 0.0F; + } + return f; } @@ -1826,7 +1866,7 @@ public abstract class EntityLiving extends Entity { } } - public int as() { + public int ar() { if (this.getGoalTarget() == null) { return 3; } else { @@ -1841,7 +1881,7 @@ public abstract class EntityLiving extends Entity { } } - public ItemStack bD() { + public ItemStack bG() { return this.equipment[0]; } @@ -1867,9 +1907,9 @@ public abstract class EntityLiving extends Entity { 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.f()) { - int k = Math.max(itemstack.k() - 25, 1); - int l = itemstack.k() - this.random.nextInt(this.random.nextInt(k) + 1); + 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; @@ -1887,20 +1927,20 @@ public abstract class EntityLiving extends Entity { } } - protected void bE() { + 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.1F) { + if (this.random.nextFloat() < 0.095F) { ++i; } - if (this.random.nextFloat() < 0.1F) { + if (this.random.nextFloat() < 0.095F) { ++i; } - if (this.random.nextFloat() < 0.1F) { + if (this.random.nextFloat() < 0.095F) { ++i; } @@ -1943,7 +1983,7 @@ public abstract class EntityLiving extends Entity { 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()).a) { + switch (((ItemArmor) itemstack.getItem()).b) { case 0: return 4; @@ -2023,9 +2063,9 @@ public abstract class EntityLiving extends Entity { } } - protected void bF() { - if (this.bD() != null && this.random.nextFloat() < b[this.world.difficulty]) { - EnchantmentManager.a(this.random, this.bD(), 5 + this.world.difficulty * this.random.nextInt(6)); + 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) { @@ -2037,31 +2077,71 @@ public abstract class EntityLiving extends Entity { } } - public void bG() {} + 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 bH() { - if (!this.bq || this.br >= this.h() / 2 || this.br < 0) { - this.br = -1; - this.bq = true; + 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 bI() { + public boolean bL() { return false; } - public final int bJ() { + 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 bS() { + return this.canPickUpLoot; + } + + public void h(boolean flag) { + this.canPickUpLoot = flag; + } } diff --git a/src/main/java/net/minecraft/server/EntityMagmaCube.java b/src/main/java/net/minecraft/server/EntityMagmaCube.java index a60539262c..b63d42e0f6 100644 --- a/src/main/java/net/minecraft/server/EntityMagmaCube.java +++ b/src/main/java/net/minecraft/server/EntityMagmaCube.java @@ -6,14 +6,14 @@ public class EntityMagmaCube extends EntitySlime { super(world); this.texture = "/mob/lava.png"; this.fireProof = true; - this.aN = 0.2F; + this.aO = 0.2F; } 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 aW() { + public int aZ() { return this.getSize() * 3; } @@ -66,9 +66,9 @@ public class EntityMagmaCube extends EntitySlime { this.b *= 0.9F; } - protected void bi() { + protected void bl() { this.motY = (double) (0.42F + (float) this.getSize() * 0.1F); - this.am = true; + this.an = true; } protected void a(float f) {} @@ -81,11 +81,11 @@ public class EntityMagmaCube extends EntitySlime { return super.m() + 2; } - protected String aZ() { + protected String bc() { return "mob.slime." + (this.getSize() > 1 ? "big" : "small"); } - protected String ba() { + protected String bd() { return "mob.slime." + (this.getSize() > 1 ? "big" : "small"); } @@ -93,7 +93,7 @@ public class EntityMagmaCube extends EntitySlime { return this.getSize() > 1 ? "mob.magmacube.big" : "mob.magmacube.small"; } - public boolean J() { + public boolean I() { return false; } diff --git a/src/main/java/net/minecraft/server/EntityMinecart.java b/src/main/java/net/minecraft/server/EntityMinecart.java deleted file mode 100644 index cabc3ce686..0000000000 --- a/src/main/java/net/minecraft/server/EntityMinecart.java +++ /dev/null @@ -1,1050 +0,0 @@ -package net.minecraft.server; - -import java.util.List; - -// CraftBukkit start -import org.bukkit.Location; -import org.bukkit.entity.HumanEntity; -import org.bukkit.entity.Vehicle; -import org.bukkit.event.vehicle.VehicleDamageEvent; -import org.bukkit.event.vehicle.VehicleDestroyEvent; -import org.bukkit.event.vehicle.VehicleEntityCollisionEvent; -import org.bukkit.util.Vector; -import org.bukkit.inventory.InventoryHolder; -import org.bukkit.craftbukkit.entity.CraftHumanEntity; -// CraftBukkit end - -public class EntityMinecart extends Entity implements IInventory { - - private ItemStack[] items; - private int e; - private boolean f; - public int type; - public double b; - public double c; - private final IUpdatePlayerListBox g; - private boolean h; - private static final int[][][] matrix = new int[][][] { { { 0, 0, -1}, { 0, 0, 1}}, { { -1, 0, 0}, { 1, 0, 0}}, { { -1, -1, 0}, { 1, 0, 0}}, { { -1, 0, 0}, { 1, -1, 0}}, { { 0, 0, -1}, { 0, -1, 1}}, { { 0, -1, -1}, { 0, 0, 1}}, { { 0, 0, 1}, { 1, 0, 0}}, { { 0, 0, 1}, { -1, 0, 0}}, { { 0, 0, -1}, { -1, 0, 0}}, { { 0, 0, -1}, { 1, 0, 0}}}; - private int j; - private double at; - private double au; - private double av; - private double aw; - private double ax; - - // CraftBukkit start - public boolean slowWhenEmpty = true; - private double derailedX = 0.5; - private double derailedY = 0.5; - private double derailedZ = 0.5; - private double flyingX = 0.95; - private double flyingY = 0.95; - private double flyingZ = 0.95; - public double maxSpeed = 0.4D; - public List transaction = new java.util.ArrayList(); - private int maxStack = MAX_STACK; - - public ItemStack[] getContents() { - return this.items; - } - - public void onOpen(CraftHumanEntity who) { - transaction.add(who); - } - - public void onClose(CraftHumanEntity who) { - transaction.remove(who); - } - - public List getViewers() { - return transaction; - } - - public InventoryHolder getOwner() { - org.bukkit.entity.Entity cart = getBukkitEntity(); - if(cart instanceof InventoryHolder) return (InventoryHolder) cart; - return null; - } - - public void setMaxStackSize(int size) { - maxStack = size; - } - // CraftBukkit end - - public EntityMinecart(World world) { - super(world); - this.items = new ItemStack[27]; // CraftBukkit - this.e = 0; - this.f = false; - this.h = true; - this.m = true; - this.a(0.98F, 0.7F); - this.height = this.length / 2.0F; - this.g = world != null ? world.a(this) : null; - } - - protected boolean f_() { - return false; - } - - protected void a() { - this.datawatcher.a(16, new Byte((byte) 0)); - this.datawatcher.a(17, new Integer(0)); - this.datawatcher.a(18, new Integer(1)); - this.datawatcher.a(19, new Integer(0)); - } - - public AxisAlignedBB g(Entity entity) { - return entity.M() ? entity.boundingBox : null; - } - - public AxisAlignedBB E() { - return null; - } - - public boolean M() { - return true; - } - - public EntityMinecart(World world, double d0, double d1, double d2, int i) { - this(world); - this.setPosition(d0, d1 + (double) this.height, d2); - this.motX = 0.0D; - this.motY = 0.0D; - this.motZ = 0.0D; - this.lastX = d0; - this.lastY = d1; - this.lastZ = d2; - this.type = i; - - this.world.getServer().getPluginManager().callEvent(new org.bukkit.event.vehicle.VehicleCreateEvent((Vehicle) this.getBukkitEntity())); // CraftBukkit - } - - public double X() { - return (double) this.length * 0.0D - 0.30000001192092896D; - } - - public boolean damageEntity(DamageSource damagesource, int i) { - if (this.isInvulnerable()) { - return false; - } else { - if (!this.world.isStatic && !this.dead) { - // CraftBukkit start - Vehicle vehicle = (Vehicle) this.getBukkitEntity(); - org.bukkit.entity.Entity passenger = (damagesource.getEntity() == null) ? null : damagesource.getEntity().getBukkitEntity(); - - VehicleDamageEvent event = new VehicleDamageEvent(vehicle, passenger, i); - this.world.getServer().getPluginManager().callEvent(event); - - if (event.isCancelled()) { - return true; - } - - i = event.getDamage(); - // CraftBukkit end - - this.i(-this.k()); - this.h(10); - this.K(); - this.setDamage(this.getDamage() + i * 10); - if (damagesource.getEntity() instanceof EntityHuman && ((EntityHuman) damagesource.getEntity()).abilities.canInstantlyBuild) { - this.setDamage(100); - } - - if (this.getDamage() > 40) { - if (this.passenger != null) { - this.passenger.mount(this); - } - - // CraftBukkit start - VehicleDestroyEvent destroyEvent = new VehicleDestroyEvent(vehicle, passenger); - this.world.getServer().getPluginManager().callEvent(destroyEvent); - - if (destroyEvent.isCancelled()) { - this.setDamage(40); // Maximize damage so this doesn't get triggered again right away - return true; - } - // CraftBukkit end - - this.die(); - this.a(Item.MINECART.id, 1, 0.0F); - if (this.type == 1) { - EntityMinecart entityminecart = this; - - for (int j = 0; j < entityminecart.getSize(); ++j) { - ItemStack itemstack = entityminecart.getItem(j); - - if (itemstack != null) { - float f = this.random.nextFloat() * 0.8F + 0.1F; - float f1 = this.random.nextFloat() * 0.8F + 0.1F; - float f2 = this.random.nextFloat() * 0.8F + 0.1F; - - while (itemstack.count > 0) { - int k = this.random.nextInt(21) + 10; - - if (k > itemstack.count) { - k = itemstack.count; - } - - itemstack.count -= k; - // CraftBukkit - include enchantments in the new itemstack - EntityItem entityitem = new EntityItem(this.world, this.locX + (double) f, this.locY + (double) f1, this.locZ + (double) f2, org.bukkit.craftbukkit.inventory.CraftItemStack.copyNMSStack(itemstack, k)); - float f3 = 0.05F; - - entityitem.motX = (double) ((float) this.random.nextGaussian() * f3); - entityitem.motY = (double) ((float) this.random.nextGaussian() * f3 + 0.2F); - entityitem.motZ = (double) ((float) this.random.nextGaussian() * f3); - this.world.addEntity(entityitem); - } - } - } - - this.a(Block.CHEST.id, 1, 0.0F); - } else if (this.type == 2) { - this.a(Block.FURNACE.id, 1, 0.0F); - } - } - - return true; - } else { - return true; - } - } - } - - public boolean L() { - return !this.dead; - } - - public void die() { - if (this.h) { - for (int i = 0; i < this.getSize(); ++i) { - ItemStack itemstack = this.getItem(i); - - if (itemstack != null) { - float f = this.random.nextFloat() * 0.8F + 0.1F; - float f1 = this.random.nextFloat() * 0.8F + 0.1F; - float f2 = this.random.nextFloat() * 0.8F + 0.1F; - - while (itemstack.count > 0) { - int j = this.random.nextInt(21) + 10; - - if (j > itemstack.count) { - j = itemstack.count; - } - - itemstack.count -= j; - EntityItem entityitem = new EntityItem(this.world, this.locX + (double) f, this.locY + (double) f1, this.locZ + (double) f2, new ItemStack(itemstack.id, j, itemstack.getData())); - - if (itemstack.hasTag()) { - entityitem.getItemStack().setTag((NBTTagCompound) itemstack.getTag().clone()); - } - - float f3 = 0.05F; - - entityitem.motX = (double) ((float) this.random.nextGaussian() * f3); - entityitem.motY = (double) ((float) this.random.nextGaussian() * f3 + 0.2F); - entityitem.motZ = (double) ((float) this.random.nextGaussian() * f3); - this.world.addEntity(entityitem); - } - } - } - } - - super.die(); - if (this.g != null) { - this.g.a(); - } - } - - public void b(int i) { - this.h = false; - super.b(i); - } - - public void j_() { - // CraftBukkit start - double prevX = this.locX; - double prevY = this.locY; - double prevZ = this.locZ; - float prevYaw = this.yaw; - float prevPitch = this.pitch; - // CraftBukkit end - - if (this.g != null) { - this.g.a(); - } - - if (this.j() > 0) { - this.h(this.j() - 1); - } - - if (this.getDamage() > 0) { - this.setDamage(this.getDamage() - 1); - } - - if (this.locY < -64.0D) { - this.C(); - } - - if (this.h() && this.random.nextInt(4) == 0) { - this.world.addParticle("largesmoke", this.locX, this.locY + 0.8D, this.locZ, 0.0D, 0.0D, 0.0D); - } - - int i; - - if (!this.world.isStatic && this.world instanceof WorldServer) { - this.world.methodProfiler.a("portal"); - MinecraftServer minecraftserver = ((WorldServer) this.world).getMinecraftServer(); - - i = this.z(); - if (this.ao) { - if (true || minecraftserver.getAllowNether()) { // CraftBukkit - multi-world should still allow teleport even if default vanilla nether disabled - if (this.vehicle == null && this.ap++ >= i) { - this.ap = i; - this.portalCooldown = this.ab(); - byte b0; - - if (this.world.worldProvider.dimension == -1) { - b0 = 0; - } else { - b0 = -1; - } - - this.b(b0); - } - - this.ao = false; - } - } else { - if (this.ap > 0) { - this.ap -= 4; - } - - if (this.ap < 0) { - this.ap = 0; - } - } - - if (this.portalCooldown > 0) { - --this.portalCooldown; - } - - this.world.methodProfiler.b(); - } - - if (this.world.isStatic) { - if (this.j > 0) { - double d0 = this.locX + (this.at - this.locX) / (double) this.j; - double d1 = this.locY + (this.au - this.locY) / (double) this.j; - double d2 = this.locZ + (this.av - this.locZ) / (double) this.j; - double d3 = MathHelper.g(this.aw - (double) this.yaw); - - this.yaw = (float) ((double) this.yaw + d3 / (double) this.j); - this.pitch = (float) ((double) this.pitch + (this.ax - (double) this.pitch) / (double) this.j); - --this.j; - this.setPosition(d0, d1, d2); - this.b(this.yaw, this.pitch); - } else { - this.setPosition(this.locX, this.locY, this.locZ); - this.b(this.yaw, this.pitch); - } - } else { - this.lastX = this.locX; - this.lastY = this.locY; - this.lastZ = this.locZ; - this.motY -= 0.03999999910593033D; - int j = MathHelper.floor(this.locX); - i = MathHelper.floor(this.locY); - int k = MathHelper.floor(this.locZ); - - if (BlockMinecartTrack.e_(this.world, j, i - 1, k)) { - --i; - } - - // CraftBukkit - double d4 = this.maxSpeed; - double d5 = 0.0078125D; - int l = this.world.getTypeId(j, i, k); - - if (BlockMinecartTrack.e(l)) { - this.fallDistance = 0.0F; - Vec3D vec3d = this.a(this.locX, this.locY, this.locZ); - int i1 = this.world.getData(j, i, k); - - this.locY = (double) i; - boolean flag = false; - boolean flag1 = false; - - if (l == Block.GOLDEN_RAIL.id) { - flag = (i1 & 8) != 0; - flag1 = !flag; - } - - if (((BlockMinecartTrack) Block.byId[l]).p()) { - i1 &= 7; - } - - if (i1 >= 2 && i1 <= 5) { - this.locY = (double) (i + 1); - } - - if (i1 == 2) { - this.motX -= d5; - } - - if (i1 == 3) { - this.motX += d5; - } - - if (i1 == 4) { - this.motZ += d5; - } - - if (i1 == 5) { - this.motZ -= d5; - } - - int[][] aint = matrix[i1]; - double d6 = (double) (aint[1][0] - aint[0][0]); - double d7 = (double) (aint[1][2] - aint[0][2]); - double d8 = Math.sqrt(d6 * d6 + d7 * d7); - double d9 = this.motX * d6 + this.motZ * d7; - - if (d9 < 0.0D) { - d6 = -d6; - d7 = -d7; - } - - double d10 = Math.sqrt(this.motX * this.motX + this.motZ * this.motZ); - - this.motX = d10 * d6 / d8; - this.motZ = d10 * d7 / d8; - double d11; - double d12; - - if (this.passenger != null) { - d12 = this.passenger.motX * this.passenger.motX + this.passenger.motZ * this.passenger.motZ; - d11 = this.motX * this.motX + this.motZ * this.motZ; - if (d12 > 1.0E-4D && d11 < 0.01D) { - this.motX += this.passenger.motX * 0.1D; - this.motZ += this.passenger.motZ * 0.1D; - flag1 = false; - } - } - - if (flag1) { - d12 = Math.sqrt(this.motX * this.motX + this.motZ * this.motZ); - if (d12 < 0.03D) { - this.motX *= 0.0D; - this.motY *= 0.0D; - this.motZ *= 0.0D; - } else { - this.motX *= 0.5D; - this.motY *= 0.0D; - this.motZ *= 0.5D; - } - } - - d12 = 0.0D; - d11 = (double) j + 0.5D + (double) aint[0][0] * 0.5D; - double d13 = (double) k + 0.5D + (double) aint[0][2] * 0.5D; - double d14 = (double) j + 0.5D + (double) aint[1][0] * 0.5D; - double d15 = (double) k + 0.5D + (double) aint[1][2] * 0.5D; - - d6 = d14 - d11; - d7 = d15 - d13; - double d16; - double d17; - - if (d6 == 0.0D) { - this.locX = (double) j + 0.5D; - d12 = this.locZ - (double) k; - } else if (d7 == 0.0D) { - this.locZ = (double) k + 0.5D; - d12 = this.locX - (double) j; - } else { - d16 = this.locX - d11; - d17 = this.locZ - d13; - d12 = (d16 * d6 + d17 * d7) * 2.0D; - } - - this.locX = d11 + d6 * d12; - this.locZ = d13 + d7 * d12; - this.setPosition(this.locX, this.locY + (double) this.height, this.locZ); - d16 = this.motX; - d17 = this.motZ; - if (this.passenger != null) { - d16 *= 0.75D; - d17 *= 0.75D; - } - - if (d16 < -d4) { - d16 = -d4; - } - - if (d16 > d4) { - d16 = d4; - } - - if (d17 < -d4) { - d17 = -d4; - } - - if (d17 > d4) { - d17 = d4; - } - - this.move(d16, 0.0D, d17); - if (aint[0][1] != 0 && MathHelper.floor(this.locX) - j == aint[0][0] && MathHelper.floor(this.locZ) - k == aint[0][2]) { - this.setPosition(this.locX, this.locY + (double) aint[0][1], this.locZ); - } else if (aint[1][1] != 0 && MathHelper.floor(this.locX) - j == aint[1][0] && MathHelper.floor(this.locZ) - k == aint[1][2]) { - this.setPosition(this.locX, this.locY + (double) aint[1][1], this.locZ); - } - - // CraftBukkit - if (this.passenger != null || !this.slowWhenEmpty) { - this.motX *= 0.996999979019165D; - this.motY *= 0.0D; - this.motZ *= 0.996999979019165D; - } else { - if (this.type == 2) { - double d18 = this.b * this.b + this.c * this.c; - - if (d18 > 1.0E-4D) { - d18 = (double) MathHelper.sqrt(d18); - this.b /= d18; - this.c /= d18; - double d19 = 0.04D; - - this.motX *= 0.800000011920929D; - this.motY *= 0.0D; - this.motZ *= 0.800000011920929D; - this.motX += this.b * d19; - this.motZ += this.c * d19; - } else { - this.motX *= 0.8999999761581421D; - this.motY *= 0.0D; - this.motZ *= 0.8999999761581421D; - } - } - - this.motX *= 0.9599999785423279D; - this.motY *= 0.0D; - this.motZ *= 0.9599999785423279D; - } - - Vec3D vec3d1 = this.a(this.locX, this.locY, this.locZ); - - if (vec3d1 != null && vec3d != null) { - double d20 = (vec3d.d - vec3d1.d) * 0.05D; - - d10 = Math.sqrt(this.motX * this.motX + this.motZ * this.motZ); - if (d10 > 0.0D) { - this.motX = this.motX / d10 * (d10 + d20); - this.motZ = this.motZ / d10 * (d10 + d20); - } - - this.setPosition(this.locX, vec3d1.d, this.locZ); - } - - int j1 = MathHelper.floor(this.locX); - int k1 = MathHelper.floor(this.locZ); - - if (j1 != j || k1 != k) { - d10 = Math.sqrt(this.motX * this.motX + this.motZ * this.motZ); - this.motX = d10 * (double) (j1 - j); - this.motZ = d10 * (double) (k1 - k); - } - - double d21; - - if (this.type == 2) { - d21 = this.b * this.b + this.c * this.c; - if (d21 > 1.0E-4D && this.motX * this.motX + this.motZ * this.motZ > 0.001D) { - d21 = (double) MathHelper.sqrt(d21); - this.b /= d21; - this.c /= d21; - if (this.b * this.motX + this.c * this.motZ < 0.0D) { - this.b = 0.0D; - this.c = 0.0D; - } else { - this.b = this.motX; - this.c = this.motZ; - } - } - } - - if (flag) { - d21 = Math.sqrt(this.motX * this.motX + this.motZ * this.motZ); - if (d21 > 0.01D) { - double d22 = 0.06D; - - this.motX += this.motX / d21 * d22; - this.motZ += this.motZ / d21 * d22; - } else if (i1 == 1) { - if (this.world.t(j - 1, i, k)) { - this.motX = 0.02D; - } else if (this.world.t(j + 1, i, k)) { - this.motX = -0.02D; - } - } else if (i1 == 0) { - if (this.world.t(j, i, k - 1)) { - this.motZ = 0.02D; - } else if (this.world.t(j, i, k + 1)) { - this.motZ = -0.02D; - } - } - } - } else { - if (this.motX < -d4) { - this.motX = -d4; - } - - if (this.motX > d4) { - this.motX = d4; - } - - if (this.motZ < -d4) { - this.motZ = -d4; - } - - if (this.motZ > d4) { - this.motZ = d4; - } - - if (this.onGround) { - // CraftBukkit start - this.motX *= this.derailedX; - this.motY *= this.derailedY; - this.motZ *= this.derailedZ; - // CraftBukkit end - } - - this.move(this.motX, this.motY, this.motZ); - if (!this.onGround) { - // CraftBukkit start - this.motX *= this.flyingX; - this.motY *= this.flyingY; - this.motZ *= this.flyingZ; - // CraftBukkit end - } - } - - this.D(); - this.pitch = 0.0F; - double d23 = this.lastX - this.locX; - double d24 = this.lastZ - this.locZ; - - if (d23 * d23 + d24 * d24 > 0.001D) { - this.yaw = (float) (Math.atan2(d24, d23) * 180.0D / 3.141592653589793D); - if (this.f) { - this.yaw += 180.0F; - } - } - - double d25 = (double) MathHelper.g(this.yaw - this.lastYaw); - - if (d25 < -170.0D || d25 >= 170.0D) { - this.yaw += 180.0F; - this.f = !this.f; - } - - this.b(this.yaw, this.pitch); - - // CraftBukkit start - org.bukkit.World bworld = this.world.getWorld(); - Location from = new Location(bworld, prevX, prevY, prevZ, prevYaw, prevPitch); - Location to = new Location(bworld, this.locX, this.locY, this.locZ, this.yaw, this.pitch); - Vehicle vehicle = (Vehicle) this.getBukkitEntity(); - - this.world.getServer().getPluginManager().callEvent(new org.bukkit.event.vehicle.VehicleUpdateEvent(vehicle)); - - if (!from.equals(to)) { - this.world.getServer().getPluginManager().callEvent(new org.bukkit.event.vehicle.VehicleMoveEvent(vehicle, from, to)); - } - // CraftBukkit end - - List list = this.world.getEntities(this, this.boundingBox.grow(0.20000000298023224D, 0.0D, 0.20000000298023224D)); - - if (list != null && !list.isEmpty()) { - for (int l1 = 0; l1 < list.size(); ++l1) { - Entity entity = (Entity) list.get(l1); - - if (entity != this.passenger && entity.M() && entity instanceof EntityMinecart) { - entity.collide(this); - } - } - } - - if (this.passenger != null && this.passenger.dead) { - if (this.passenger.vehicle == this) { - this.passenger.vehicle = null; - } - - this.passenger = null; - } - - if (this.e > 0) { - --this.e; - } - - if (this.e <= 0) { - this.b = this.c = 0.0D; - } - - this.e(this.e > 0); - } - } - - public Vec3D a(double d0, double d1, double d2) { - int i = MathHelper.floor(d0); - int j = MathHelper.floor(d1); - int k = MathHelper.floor(d2); - - if (BlockMinecartTrack.e_(this.world, i, j - 1, k)) { - --j; - } - - int l = this.world.getTypeId(i, j, k); - - if (BlockMinecartTrack.e(l)) { - int i1 = this.world.getData(i, j, k); - - d1 = (double) j; - if (((BlockMinecartTrack) Block.byId[l]).p()) { - i1 &= 7; - } - - if (i1 >= 2 && i1 <= 5) { - d1 = (double) (j + 1); - } - - int[][] aint = matrix[i1]; - double d3 = 0.0D; - double d4 = (double) i + 0.5D + (double) aint[0][0] * 0.5D; - double d5 = (double) j + 0.5D + (double) aint[0][1] * 0.5D; - double d6 = (double) k + 0.5D + (double) aint[0][2] * 0.5D; - double d7 = (double) i + 0.5D + (double) aint[1][0] * 0.5D; - double d8 = (double) j + 0.5D + (double) aint[1][1] * 0.5D; - double d9 = (double) k + 0.5D + (double) aint[1][2] * 0.5D; - double d10 = d7 - d4; - double d11 = (d8 - d5) * 2.0D; - double d12 = d9 - d6; - - if (d10 == 0.0D) { - d0 = (double) i + 0.5D; - d3 = d2 - (double) k; - } else if (d12 == 0.0D) { - d2 = (double) k + 0.5D; - d3 = d0 - (double) i; - } else { - double d13 = d0 - d4; - double d14 = d2 - d6; - - d3 = (d13 * d10 + d14 * d12) * 2.0D; - } - - d0 = d4 + d10 * d3; - d1 = d5 + d11 * d3; - d2 = d6 + d12 * d3; - if (d11 < 0.0D) { - ++d1; - } - - if (d11 > 0.0D) { - d1 += 0.5D; - } - - return this.world.getVec3DPool().create(d0, d1, d2); - } else { - return null; - } - } - - protected void b(NBTTagCompound nbttagcompound) { - nbttagcompound.setInt("Type", this.type); - if (this.type == 2) { - nbttagcompound.setDouble("PushX", this.b); - nbttagcompound.setDouble("PushZ", this.c); - nbttagcompound.setShort("Fuel", (short) this.e); - } else if (this.type == 1) { - NBTTagList nbttaglist = new NBTTagList(); - - for (int i = 0; i < this.items.length; ++i) { - if (this.items[i] != null) { - NBTTagCompound nbttagcompound1 = new NBTTagCompound(); - - nbttagcompound1.setByte("Slot", (byte) i); - this.items[i].save(nbttagcompound1); - nbttaglist.add(nbttagcompound1); - } - } - - nbttagcompound.set("Items", nbttaglist); - } - } - - protected void a(NBTTagCompound nbttagcompound) { - this.type = nbttagcompound.getInt("Type"); - if (this.type == 2) { - this.b = nbttagcompound.getDouble("PushX"); - this.c = nbttagcompound.getDouble("PushZ"); - this.e = nbttagcompound.getShort("Fuel"); - } else if (this.type == 1) { - NBTTagList nbttaglist = nbttagcompound.getList("Items"); - - this.items = new ItemStack[this.getSize()]; - - for (int i = 0; i < nbttaglist.size(); ++i) { - NBTTagCompound nbttagcompound1 = (NBTTagCompound) nbttaglist.get(i); - int j = nbttagcompound1.getByte("Slot") & 255; - - if (j >= 0 && j < this.items.length) { - this.items[j] = ItemStack.createStack(nbttagcompound1); - } - } - } - } - - public void collide(Entity entity) { - if (!this.world.isStatic) { - if (entity != this.passenger) { - // CraftBukkit start - Vehicle vehicle = (Vehicle) this.getBukkitEntity(); - org.bukkit.entity.Entity hitEntity = (entity == null) ? null : entity.getBukkitEntity(); - - VehicleEntityCollisionEvent collisionEvent = new VehicleEntityCollisionEvent(vehicle, hitEntity); - this.world.getServer().getPluginManager().callEvent(collisionEvent); - - if (collisionEvent.isCancelled()) { - return; - } - // CraftBukkit end - - if (entity instanceof EntityLiving && !(entity instanceof EntityHuman) && !(entity instanceof EntityIronGolem) && this.type == 0 && this.motX * this.motX + this.motZ * this.motZ > 0.01D && this.passenger == null && entity.vehicle == null) { - entity.mount(this); - } - - double d0 = entity.locX - this.locX; - double d1 = entity.locZ - this.locZ; - double d2 = d0 * d0 + d1 * d1; - - // CraftBukkit - collision - if (d2 >= 9.999999747378752E-5D && !collisionEvent.isCollisionCancelled()) { - d2 = (double) MathHelper.sqrt(d2); - d0 /= d2; - d1 /= d2; - double d3 = 1.0D / d2; - - if (d3 > 1.0D) { - d3 = 1.0D; - } - - d0 *= d3; - d1 *= d3; - d0 *= 0.10000000149011612D; - d1 *= 0.10000000149011612D; - d0 *= (double) (1.0F - this.Z); - d1 *= (double) (1.0F - this.Z); - d0 *= 0.5D; - d1 *= 0.5D; - if (entity instanceof EntityMinecart) { - double d4 = entity.locX - this.locX; - double d5 = entity.locZ - this.locZ; - Vec3D vec3d = this.world.getVec3DPool().create(d4, 0.0D, d5).a(); - Vec3D vec3d1 = this.world.getVec3DPool().create((double) MathHelper.cos(this.yaw * 3.1415927F / 180.0F), 0.0D, (double) MathHelper.sin(this.yaw * 3.1415927F / 180.0F)).a(); - double d6 = Math.abs(vec3d.b(vec3d1)); - - if (d6 < 0.800000011920929D) { - return; - } - - double d7 = entity.motX + this.motX; - double d8 = entity.motZ + this.motZ; - - if (((EntityMinecart) entity).type == 2 && this.type != 2) { - this.motX *= 0.20000000298023224D; - this.motZ *= 0.20000000298023224D; - this.g(entity.motX - d0, 0.0D, entity.motZ - d1); - entity.motX *= 0.949999988079071D; - entity.motZ *= 0.949999988079071D; - } else if (((EntityMinecart) entity).type != 2 && this.type == 2) { - entity.motX *= 0.20000000298023224D; - entity.motZ *= 0.20000000298023224D; - entity.g(this.motX + d0, 0.0D, this.motZ + d1); - this.motX *= 0.949999988079071D; - this.motZ *= 0.949999988079071D; - } else { - d7 /= 2.0D; - d8 /= 2.0D; - this.motX *= 0.20000000298023224D; - this.motZ *= 0.20000000298023224D; - this.g(d7 - d0, 0.0D, d8 - d1); - entity.motX *= 0.20000000298023224D; - entity.motZ *= 0.20000000298023224D; - entity.g(d7 + d0, 0.0D, d8 + d1); - } - } else { - this.g(-d0, 0.0D, -d1); - entity.g(d0 / 4.0D, 0.0D, d1 / 4.0D); - } - } - } - } - } - - public int getSize() { - return 27; - } - - public ItemStack getItem(int i) { - return this.items[i]; - } - - public ItemStack splitStack(int i, int j) { - if (this.items[i] != null) { - ItemStack itemstack; - - if (this.items[i].count <= j) { - itemstack = this.items[i]; - this.items[i] = null; - return itemstack; - } else { - itemstack = this.items[i].a(j); - if (this.items[i].count == 0) { - this.items[i] = null; - } - - return itemstack; - } - } else { - return null; - } - } - - public ItemStack splitWithoutUpdate(int i) { - if (this.items[i] != null) { - ItemStack itemstack = this.items[i]; - - this.items[i] = null; - return itemstack; - } else { - return null; - } - } - - public void setItem(int i, ItemStack itemstack) { - this.items[i] = itemstack; - if (itemstack != null && itemstack.count > this.getMaxStackSize()) { - itemstack.count = this.getMaxStackSize(); - } - } - - public String getName() { - return "container.minecart"; - } - - public int getMaxStackSize() { - return maxStack; // CraftBukkit - } - - public void update() {} - - public boolean a(EntityHuman entityhuman) { - if (this.type == 0) { - if (this.passenger != null && this.passenger instanceof EntityHuman && this.passenger != entityhuman) { - return true; - } - - if (!this.world.isStatic) { - entityhuman.mount(this); - } - } else if (this.type == 1) { - if (!this.world.isStatic) { - entityhuman.openContainer(this); - } - } else if (this.type == 2) { - ItemStack itemstack = entityhuman.inventory.getItemInHand(); - - if (itemstack != null && itemstack.id == Item.COAL.id) { - if (--itemstack.count == 0) { - entityhuman.inventory.setItem(entityhuman.inventory.itemInHandIndex, (ItemStack) null); - } - - this.e += 3600; - } - - this.b = this.locX - entityhuman.locX; - this.c = this.locZ - entityhuman.locZ; - } - - return true; - } - - public boolean a_(EntityHuman entityhuman) { - return this.dead ? false : entityhuman.e(this) <= 64.0D; - } - - protected boolean h() { - return (this.datawatcher.getByte(16) & 1) != 0; - } - - protected void e(boolean flag) { - if (flag) { - this.datawatcher.watch(16, Byte.valueOf((byte) (this.datawatcher.getByte(16) | 1))); - } else { - this.datawatcher.watch(16, Byte.valueOf((byte) (this.datawatcher.getByte(16) & -2))); - } - } - - public void startOpen() {} - - public void f() {} - - public void setDamage(int i) { - this.datawatcher.watch(19, Integer.valueOf(i)); - } - - public int getDamage() { - return this.datawatcher.getInt(19); - } - - public void h(int i) { - this.datawatcher.watch(17, Integer.valueOf(i)); - } - - public int j() { - return this.datawatcher.getInt(17); - } - - public void i(int i) { - this.datawatcher.watch(18, Integer.valueOf(i)); - } - - public int k() { - return this.datawatcher.getInt(18); - } - - // CraftBukkit start - methods for getting and setting flying and derailed velocity modifiers - public Vector getFlyingVelocityMod() { - return new Vector(flyingX, flyingY, flyingZ); - } - - public void setFlyingVelocityMod(Vector flying) { - flyingX = flying.getX(); - flyingY = flying.getY(); - flyingZ = flying.getZ(); - } - - public Vector getDerailedVelocityMod() { - return new Vector(derailedX, derailedY, derailedZ); - } - - public void setDerailedVelocityMod(Vector derailed) { - derailedX = derailed.getX(); - derailedY = derailed.getY(); - derailedZ = derailed.getZ(); - } - // CraftBukkit end -} diff --git a/src/main/java/net/minecraft/server/EntityMinecartAbstract.java b/src/main/java/net/minecraft/server/EntityMinecartAbstract.java new file mode 100644 index 0000000000..ad54c7ac0d --- /dev/null +++ b/src/main/java/net/minecraft/server/EntityMinecartAbstract.java @@ -0,0 +1,888 @@ +package net.minecraft.server; + +import java.util.List; + +// CraftBukkit start +import org.bukkit.Location; +import org.bukkit.entity.HumanEntity; +import org.bukkit.entity.Vehicle; +import org.bukkit.event.vehicle.VehicleDamageEvent; +import org.bukkit.event.vehicle.VehicleDestroyEvent; +import org.bukkit.event.vehicle.VehicleEntityCollisionEvent; +import org.bukkit.util.Vector; +import org.bukkit.craftbukkit.entity.CraftHumanEntity; +// CraftBukkit end + +public abstract class EntityMinecartAbstract extends Entity { + + private boolean a; + private final IUpdatePlayerListBox b; + private String c; + private static final int[][][] matrix = new int[][][] { { { 0, 0, -1}, { 0, 0, 1}}, { { -1, 0, 0}, { 1, 0, 0}}, { { -1, -1, 0}, { 1, 0, 0}}, { { -1, 0, 0}, { 1, -1, 0}}, { { 0, 0, -1}, { 0, -1, 1}}, { { 0, -1, -1}, { 0, 0, 1}}, { { 0, 0, 1}, { 1, 0, 0}}, { { 0, 0, 1}, { -1, 0, 0}}, { { 0, 0, -1}, { -1, 0, 0}}, { { 0, 0, -1}, { 1, 0, 0}}}; + private int e; + private double f; + private double g; + private double h; + private double i; + private double j; + + // CraftBukkit start + public boolean slowWhenEmpty = true; + private double derailedX = 0.5; + private double derailedY = 0.5; + private double derailedZ = 0.5; + private double flyingX = 0.95; + private double flyingY = 0.95; + private double flyingZ = 0.95; + public double maxSpeed = 0.4D; + // CraftBukkit end + + public EntityMinecartAbstract(World world) { + super(world); + this.a = false; + this.m = true; + this.a(0.98F, 0.7F); + this.height = this.length / 2.0F; + this.b = world != null ? world.a(this) : null; + } + + public static EntityMinecartAbstract a(World world, double d0, double d1, double d2, int i) { + switch (i) { + case 1: + return new EntityMinecartChest(world, d0, d1, d2); + + case 2: + return new EntityMinecartFurnace(world, d0, d1, d2); + + case 3: + return new EntityMinecartTNT(world, d0, d1, d2); + + case 4: + return new EntityMinecartMobSpawner(world, d0, d1, d2); + + case 5: + return new EntityMinecartHopper(world, d0, d1, d2); + + default: + return new EntityMinecartRideable(world, d0, d1, d2); + } + } + + protected boolean f_() { + 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(20, new Integer(0)); + this.datawatcher.a(21, new Integer(6)); + this.datawatcher.a(22, Byte.valueOf((byte) 0)); + } + + public AxisAlignedBB g(Entity entity) { + return entity.L() ? entity.boundingBox : null; + } + + public AxisAlignedBB D() { + return null; + } + + public boolean L() { + return true; + } + + public EntityMinecartAbstract(World world, double d0, double d1, double d2) { + this(world); + this.setPosition(d0, d1 + (double) this.height, d2); + this.motX = 0.0D; + this.motY = 0.0D; + this.motZ = 0.0D; + this.lastX = d0; + this.lastY = d1; + this.lastZ = d2; + + this.world.getServer().getPluginManager().callEvent(new org.bukkit.event.vehicle.VehicleCreateEvent((Vehicle) this.getBukkitEntity())); // CraftBukkit + } + + public double W() { + return (double) this.length * 0.0D - 0.30000001192092896D; + } + + public boolean damageEntity(DamageSource damagesource, int i) { + if (!this.world.isStatic && !this.dead) { + if (this.isInvulnerable()) { + return false; + } else { + // CraftBukkit start + Vehicle vehicle = (Vehicle) this.getBukkitEntity(); + org.bukkit.entity.Entity passenger = (damagesource.getEntity() == null) ? null : damagesource.getEntity().getBukkitEntity(); + + VehicleDamageEvent event = new VehicleDamageEvent(vehicle, passenger, i); + this.world.getServer().getPluginManager().callEvent(event); + + if (event.isCancelled()) { + return true; + } + + i = event.getDamage(); + // CraftBukkit end + + this.j(-this.k()); + this.i(10); + this.J(); + this.setDamage(this.getDamage() + i * 10); + boolean flag = damagesource.getEntity() instanceof EntityHuman && ((EntityHuman) damagesource.getEntity()).abilities.canInstantlyBuild; + + if (flag || this.getDamage() > 40) { + if (this.passenger != null) { + this.passenger.mount(this); + } + + // CraftBukkit start + VehicleDestroyEvent destroyEvent = new VehicleDestroyEvent(vehicle, passenger); + this.world.getServer().getPluginManager().callEvent(destroyEvent); + + if (destroyEvent.isCancelled()) { + this.setDamage(40); // Maximize damage so this doesn't get triggered again right away + return true; + } + // CraftBukkit end + + if (flag && !this.c()) { + this.die(); + } else { + this.a(damagesource); + } + } + + return true; + } + } else { + return true; + } + } + + public void a(DamageSource damagesource) { + this.die(); + ItemStack itemstack = new ItemStack(Item.MINECART, 1); + + if (this.c != null) { + itemstack.c(this.c); + } + + this.a(itemstack, 0.0F); + } + + public boolean K() { + return !this.dead; + } + + public void die() { + super.die(); + if (this.b != null) { + this.b.a(); + } + } + + public void l_() { + // CraftBukkit start + double prevX = this.locX; + double prevY = this.locY; + double prevZ = this.locZ; + float prevYaw = this.yaw; + float prevPitch = this.pitch; + // CraftBukkit end + + if (this.b != null) { + this.b.a(); + } + + if (this.j() > 0) { + this.i(this.j() - 1); + } + + if (this.getDamage() > 0) { + this.setDamage(this.getDamage() - 1); + } + + if (this.locY < -64.0D) { + this.B(); + } + + int i; + + if (!this.world.isStatic && this.world instanceof WorldServer) { + this.world.methodProfiler.a("portal"); + MinecraftServer minecraftserver = ((WorldServer) this.world).getMinecraftServer(); + + i = this.y(); + if (this.ap) { + if (true || minecraftserver.getAllowNether()) { // CraftBukkit - multi-world should still allow teleport even if default vanilla nether disabled + if (this.vehicle == null && this.aq++ >= i) { + this.aq = i; + this.portalCooldown = this.aa(); + byte b0; + + if (this.world.worldProvider.dimension == -1) { + b0 = 0; + } else { + b0 = -1; + } + + this.c(b0); + } + + this.ap = false; + } + } else { + if (this.aq > 0) { + this.aq -= 4; + } + + if (this.aq < 0) { + this.aq = 0; + } + } + + if (this.portalCooldown > 0) { + --this.portalCooldown; + } + + this.world.methodProfiler.b(); + } + + if (this.world.isStatic) { + if (this.e > 0) { + double d0 = this.locX + (this.f - this.locX) / (double) this.e; + double d1 = this.locY + (this.g - this.locY) / (double) this.e; + double d2 = this.locZ + (this.h - this.locZ) / (double) this.e; + double d3 = MathHelper.g(this.i - (double) this.yaw); + + this.yaw = (float) ((double) this.yaw + d3 / (double) this.e); + this.pitch = (float) ((double) this.pitch + (this.j - (double) this.pitch) / (double) this.e); + --this.e; + this.setPosition(d0, d1, d2); + this.b(this.yaw, this.pitch); + } else { + this.setPosition(this.locX, this.locY, this.locZ); + this.b(this.yaw, this.pitch); + } + } else { + this.lastX = this.locX; + this.lastY = this.locY; + this.lastZ = this.locZ; + this.motY -= 0.03999999910593033D; + int j = MathHelper.floor(this.locX); + + i = MathHelper.floor(this.locY); + int k = MathHelper.floor(this.locZ); + + if (BlockMinecartTrackAbstract.d_(this.world, j, i - 1, k)) { + --i; + } + + double d4 = this.maxSpeed; // CraftBukkit + double d5 = 0.0078125D; + int l = this.world.getTypeId(j, i, k); + + if (BlockMinecartTrackAbstract.d_(l)) { + int i1 = this.world.getData(j, i, k); + + this.a(j, i, k, d4, d5, l, i1); + if (l == Block.ACTIVATOR_RAIL.id) { + this.a(j, i, k, (i1 & 8) != 0); + } + } else { + this.b(d4); + } + + this.C(); + this.pitch = 0.0F; + double d6 = this.lastX - this.locX; + double d7 = this.lastZ - this.locZ; + + if (d6 * d6 + d7 * d7 > 0.001D) { + this.yaw = (float) (Math.atan2(d7, d6) * 180.0D / 3.141592653589793D); + if (this.a) { + this.yaw += 180.0F; + } + } + + double d8 = (double) MathHelper.g(this.yaw - this.lastYaw); + + if (d8 < -170.0D || d8 >= 170.0D) { + this.yaw += 180.0F; + this.a = !this.a; + } + + this.b(this.yaw, this.pitch); + + // CraftBukkit start + org.bukkit.World bworld = this.world.getWorld(); + Location from = new Location(bworld, prevX, prevY, prevZ, prevYaw, prevPitch); + Location to = new Location(bworld, this.locX, this.locY, this.locZ, this.yaw, this.pitch); + Vehicle vehicle = (Vehicle) this.getBukkitEntity(); + + this.world.getServer().getPluginManager().callEvent(new org.bukkit.event.vehicle.VehicleUpdateEvent(vehicle)); + + if (!from.equals(to)) { + this.world.getServer().getPluginManager().callEvent(new org.bukkit.event.vehicle.VehicleMoveEvent(vehicle, from, to)); + } + // CraftBukkit end + + List list = this.world.getEntities(this, this.boundingBox.grow(0.20000000298023224D, 0.0D, 0.20000000298023224D)); + + if (list != null && !list.isEmpty()) { + for (int j1 = 0; j1 < list.size(); ++j1) { + Entity entity = (Entity) list.get(j1); + + if (entity != this.passenger && entity.L() && entity instanceof EntityMinecartAbstract) { + entity.collide(this); + } + } + } + + if (this.passenger != null && this.passenger.dead) { + if (this.passenger.vehicle == this) { + this.passenger.vehicle = null; + } + + this.passenger = null; + } + } + } + + public void a(int i, int j, int k, boolean flag) {} + + protected void b(double d0) { + if (this.motX < -d0) { + this.motX = -d0; + } + + if (this.motX > d0) { + this.motX = d0; + } + + if (this.motZ < -d0) { + this.motZ = -d0; + } + + if (this.motZ > d0) { + this.motZ = d0; + } + + if (this.onGround) { + // CraftBukkit start + this.motX *= this.derailedX; + this.motY *= this.derailedY; + this.motZ *= this.derailedZ; + // CraftBukkit end + } + + this.move(this.motX, this.motY, this.motZ); + if (!this.onGround) { + // CraftBukkit start + this.motX *= this.flyingX; + this.motY *= this.flyingY; + this.motZ *= this.flyingZ; + // CraftBukkit end + } + } + + protected void a(int i, int j, int k, double d0, double d1, int l, int i1) { + this.fallDistance = 0.0F; + Vec3D vec3d = this.a(this.locX, this.locY, this.locZ); + + this.locY = (double) j; + boolean flag = false; + boolean flag1 = false; + + if (l == Block.GOLDEN_RAIL.id) { + flag = (i1 & 8) != 0; + flag1 = !flag; + } + + if (((BlockMinecartTrackAbstract) Block.byId[l]).e()) { + i1 &= 7; + } + + if (i1 >= 2 && i1 <= 5) { + this.locY = (double) (j + 1); + } + + if (i1 == 2) { + this.motX -= d1; + } + + if (i1 == 3) { + this.motX += d1; + } + + if (i1 == 4) { + this.motZ += d1; + } + + if (i1 == 5) { + this.motZ -= d1; + } + + int[][] aint = matrix[i1]; + double d2 = (double) (aint[1][0] - aint[0][0]); + double d3 = (double) (aint[1][2] - aint[0][2]); + double d4 = Math.sqrt(d2 * d2 + d3 * d3); + double d5 = this.motX * d2 + this.motZ * d3; + + if (d5 < 0.0D) { + d2 = -d2; + d3 = -d3; + } + + double d6 = Math.sqrt(this.motX * this.motX + this.motZ * this.motZ); + + if (d6 > 2.0D) { + d6 = 2.0D; + } + + this.motX = d6 * d2 / d4; + 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; + } + } + + if (flag1) { + d7 = Math.sqrt(this.motX * this.motX + this.motZ * this.motZ); + if (d7 < 0.03D) { + this.motX *= 0.0D; + this.motY *= 0.0D; + this.motZ *= 0.0D; + } else { + this.motX *= 0.5D; + this.motY *= 0.0D; + this.motZ *= 0.5D; + } + } + + 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; + double d11 = (double) k + 0.5D + (double) aint[1][2] * 0.5D; + + d2 = d10 - d8; + d3 = d11 - d9; + double d12; + double d13; + + if (d2 == 0.0D) { + this.locX = (double) i + 0.5D; + d7 = this.locZ - (double) k; + } else if (d3 == 0.0D) { + this.locZ = (double) k + 0.5D; + d7 = this.locX - (double) i; + } else { + d12 = this.locX - d8; + d13 = this.locZ - d9; + d7 = (d12 * d2 + d13 * d3) * 2.0D; + } + + this.locX = d8 + d2 * d7; + this.locZ = d9 + d3 * d7; + this.setPosition(this.locX, this.locY + (double) this.height, this.locZ); + d12 = this.motX; + d13 = this.motZ; + if (this.passenger != null) { + d12 *= 0.75D; + d13 *= 0.75D; + } + + if (d12 < -d0) { + d12 = -d0; + } + + if (d12 > d0) { + d12 = d0; + } + + if (d13 < -d0) { + d13 = -d0; + } + + if (d13 > d0) { + d13 = d0; + } + + this.move(d12, 0.0D, d13); + if (aint[0][1] != 0 && MathHelper.floor(this.locX) - i == aint[0][0] && MathHelper.floor(this.locZ) - k == aint[0][2]) { + this.setPosition(this.locX, this.locY + (double) aint[0][1], this.locZ); + } else if (aint[1][1] != 0 && MathHelper.floor(this.locX) - i == aint[1][0] && MathHelper.floor(this.locZ) - k == aint[1][2]) { + this.setPosition(this.locX, this.locY + (double) aint[1][1], this.locZ); + } + + this.h(); + Vec3D vec3d1 = this.a(this.locX, this.locY, this.locZ); + + if (vec3d1 != null && vec3d != null) { + double d14 = (vec3d.d - vec3d1.d) * 0.05D; + + d6 = Math.sqrt(this.motX * this.motX + this.motZ * this.motZ); + if (d6 > 0.0D) { + this.motX = this.motX / d6 * (d6 + d14); + this.motZ = this.motZ / d6 * (d6 + d14); + } + + this.setPosition(this.locX, vec3d1.d, this.locZ); + } + + int j1 = MathHelper.floor(this.locX); + int k1 = MathHelper.floor(this.locZ); + + if (j1 != i || k1 != k) { + d6 = Math.sqrt(this.motX * this.motX + this.motZ * this.motZ); + this.motX = d6 * (double) (j1 - i); + this.motZ = d6 * (double) (k1 - k); + } + + if (flag) { + double d15 = Math.sqrt(this.motX * this.motX + this.motZ * this.motZ); + + if (d15 > 0.01D) { + double d16 = 0.06D; + + this.motX += this.motX / d15 * d16; + this.motZ += this.motZ / d15 * d16; + } else if (i1 == 1) { + if (this.world.u(i - 1, j, k)) { + this.motX = 0.02D; + } else if (this.world.u(i + 1, j, k)) { + this.motX = -0.02D; + } + } else if (i1 == 0) { + if (this.world.u(i, j, k - 1)) { + this.motZ = 0.02D; + } else if (this.world.u(i, j, k + 1)) { + this.motZ = -0.02D; + } + } + } + } + + protected void h() { + if (this.passenger != null || !this.slowWhenEmpty) { // CraftBukkit + this.motX *= 0.996999979019165D; + this.motY *= 0.0D; + this.motZ *= 0.996999979019165D; + } else { + this.motX *= 0.9599999785423279D; + this.motY *= 0.0D; + this.motZ *= 0.9599999785423279D; + } + } + + public Vec3D a(double d0, double d1, double d2) { + int i = MathHelper.floor(d0); + int j = MathHelper.floor(d1); + int k = MathHelper.floor(d2); + + if (BlockMinecartTrackAbstract.d_(this.world, i, j - 1, k)) { + --j; + } + + int l = this.world.getTypeId(i, j, k); + + if (BlockMinecartTrackAbstract.d_(l)) { + int i1 = this.world.getData(i, j, k); + + d1 = (double) j; + if (((BlockMinecartTrackAbstract) Block.byId[l]).e()) { + i1 &= 7; + } + + if (i1 >= 2 && i1 <= 5) { + d1 = (double) (j + 1); + } + + int[][] aint = matrix[i1]; + double d3 = 0.0D; + double d4 = (double) i + 0.5D + (double) aint[0][0] * 0.5D; + double d5 = (double) j + 0.5D + (double) aint[0][1] * 0.5D; + double d6 = (double) k + 0.5D + (double) aint[0][2] * 0.5D; + double d7 = (double) i + 0.5D + (double) aint[1][0] * 0.5D; + double d8 = (double) j + 0.5D + (double) aint[1][1] * 0.5D; + double d9 = (double) k + 0.5D + (double) aint[1][2] * 0.5D; + double d10 = d7 - d4; + double d11 = (d8 - d5) * 2.0D; + double d12 = d9 - d6; + + if (d10 == 0.0D) { + d0 = (double) i + 0.5D; + d3 = d2 - (double) k; + } else if (d12 == 0.0D) { + d2 = (double) k + 0.5D; + d3 = d0 - (double) i; + } else { + double d13 = d0 - d4; + double d14 = d2 - d6; + + d3 = (d13 * d10 + d14 * d12) * 2.0D; + } + + d0 = d4 + d10 * d3; + d1 = d5 + d11 * d3; + d2 = d6 + d12 * d3; + if (d11 < 0.0D) { + ++d1; + } + + if (d11 > 0.0D) { + d1 += 0.5D; + } + + return this.world.getVec3DPool().create(d0, d1, d2); + } else { + return null; + } + } + + protected void a(NBTTagCompound nbttagcompound) { + if (nbttagcompound.getBoolean("CustomDisplayTile")) { + this.k(nbttagcompound.getInt("DisplayTile")); + this.l(nbttagcompound.getInt("DisplayData")); + this.m(nbttagcompound.getInt("DisplayOffset")); + } + + if (nbttagcompound.hasKey("CustomName") && nbttagcompound.getString("CustomName").length() > 0) { + this.c = nbttagcompound.getString("CustomName"); + } + } + + protected void b(NBTTagCompound nbttagcompound) { + if (this.s()) { + nbttagcompound.setBoolean("CustomDisplayTile", true); + nbttagcompound.setInt("DisplayTile", this.m() == null ? 0 : this.m().id); + nbttagcompound.setInt("DisplayData", this.o()); + nbttagcompound.setInt("DisplayOffset", this.q()); + } + + if (this.c != null && this.c.length() > 0) { + nbttagcompound.setString("CustomName", this.c); + } + } + + public void collide(Entity entity) { + if (!this.world.isStatic) { + if (entity != this.passenger) { + // CraftBukkit start + Vehicle vehicle = (Vehicle) this.getBukkitEntity(); + org.bukkit.entity.Entity hitEntity = (entity == null) ? null : entity.getBukkitEntity(); + + VehicleEntityCollisionEvent collisionEvent = new VehicleEntityCollisionEvent(vehicle, hitEntity); + this.world.getServer().getPluginManager().callEvent(collisionEvent); + + if (collisionEvent.isCancelled()) { + return; + } + // CraftBukkit end + + if (entity instanceof EntityLiving && !(entity instanceof EntityHuman) && !(entity instanceof EntityIronGolem) && this.getType() == 0 && this.motX * this.motX + this.motZ * this.motZ > 0.01D && this.passenger == null && entity.vehicle == null) { + entity.mount(this); + } + + double d0 = entity.locX - this.locX; + double d1 = entity.locZ - this.locZ; + double d2 = d0 * d0 + d1 * d1; + + // CraftBukkit - collision + if (d2 >= 9.999999747378752E-5D && !collisionEvent.isCollisionCancelled()) { + d2 = (double) MathHelper.sqrt(d2); + d0 /= d2; + d1 /= d2; + double d3 = 1.0D / d2; + + if (d3 > 1.0D) { + d3 = 1.0D; + } + + d0 *= d3; + d1 *= d3; + d0 *= 0.10000000149011612D; + d1 *= 0.10000000149011612D; + d0 *= (double) (1.0F - this.aa); + d1 *= (double) (1.0F - this.aa); + d0 *= 0.5D; + d1 *= 0.5D; + if (entity instanceof EntityMinecartAbstract) { + double d4 = entity.locX - this.locX; + double d5 = entity.locZ - this.locZ; + Vec3D vec3d = this.world.getVec3DPool().create(d4, 0.0D, d5).a(); + Vec3D vec3d1 = this.world.getVec3DPool().create((double) MathHelper.cos(this.yaw * 3.1415927F / 180.0F), 0.0D, (double) MathHelper.sin(this.yaw * 3.1415927F / 180.0F)).a(); + double d6 = Math.abs(vec3d.b(vec3d1)); + + if (d6 < 0.800000011920929D) { + return; + } + + double d7 = entity.motX + this.motX; + double d8 = entity.motZ + this.motZ; + + if (((EntityMinecartAbstract) entity).getType() == 2 && this.getType() != 2) { + this.motX *= 0.20000000298023224D; + this.motZ *= 0.20000000298023224D; + this.g(entity.motX - d0, 0.0D, entity.motZ - d1); + entity.motX *= 0.949999988079071D; + entity.motZ *= 0.949999988079071D; + } else if (((EntityMinecartAbstract) entity).getType() != 2 && this.getType() == 2) { + entity.motX *= 0.20000000298023224D; + entity.motZ *= 0.20000000298023224D; + entity.g(this.motX + d0, 0.0D, this.motZ + d1); + this.motX *= 0.949999988079071D; + this.motZ *= 0.949999988079071D; + } else { + d7 /= 2.0D; + d8 /= 2.0D; + this.motX *= 0.20000000298023224D; + this.motZ *= 0.20000000298023224D; + this.g(d7 - d0, 0.0D, d8 - d1); + entity.motX *= 0.20000000298023224D; + entity.motZ *= 0.20000000298023224D; + entity.g(d7 + d0, 0.0D, d8 + d1); + } + } else { + this.g(-d0, 0.0D, -d1); + entity.g(d0 / 4.0D, 0.0D, d1 / 4.0D); + } + } + } + } + } + + public void setDamage(int i) { + this.datawatcher.watch(19, Integer.valueOf(i)); + } + + public int getDamage() { + return this.datawatcher.getInt(19); + } + + public void i(int i) { + this.datawatcher.watch(17, Integer.valueOf(i)); + } + + public int j() { + return this.datawatcher.getInt(17); + } + + public void j(int i) { + this.datawatcher.watch(18, Integer.valueOf(i)); + } + + public int k() { + return this.datawatcher.getInt(18); + } + + public abstract int getType(); + + public Block m() { + if (!this.s()) { + return this.n(); + } else { + int i = this.getDataWatcher().getInt(20) & '\uffff'; + + return i > 0 && i < Block.byId.length ? Block.byId[i] : null; + } + } + + public Block n() { + return null; + } + + public int o() { + return !this.s() ? this.p() : this.getDataWatcher().getInt(20) >> 16; + } + + public int p() { + return 0; + } + + public int q() { + return !this.s() ? this.r() : this.getDataWatcher().getInt(21); + } + + public int r() { + return 6; + } + + public void k(int i) { + this.getDataWatcher().watch(20, Integer.valueOf(i & '\uffff' | this.o() << 16)); + this.a(true); + } + + public void l(int i) { + Block block = this.m(); + int j = block == null ? 0 : block.id; + + this.getDataWatcher().watch(20, Integer.valueOf(j & '\uffff' | i << 16)); + this.a(true); + } + + public void m(int i) { + this.getDataWatcher().watch(21, Integer.valueOf(i)); + this.a(true); + } + + public boolean s() { + return this.getDataWatcher().getByte(22) == 1; + } + + public void a(boolean flag) { + this.getDataWatcher().watch(22, Byte.valueOf((byte) (flag ? 1 : 0))); + } + + public void a(String s) { + this.c = s; + } + + public String getLocalizedName() { + return this.c != null ? this.c : super.getLocalizedName(); + } + + public boolean c() { + return this.c != null; + } + + public String t() { + return this.c; + } + + // CraftBukkit start - methods for getting and setting flying and derailed velocity modifiers + public Vector getFlyingVelocityMod() { + return new Vector(flyingX, flyingY, flyingZ); + } + + public void setFlyingVelocityMod(Vector flying) { + flyingX = flying.getX(); + flyingY = flying.getY(); + flyingZ = flying.getZ(); + } + + public Vector getDerailedVelocityMod() { + return new Vector(derailedX, derailedY, derailedZ); + } + + public void setDerailedVelocityMod(Vector derailed) { + derailedX = derailed.getX(); + derailedY = derailed.getY(); + derailedZ = derailed.getZ(); + } + // CraftBukkit end +} diff --git a/src/main/java/net/minecraft/server/EntityMinecartContainer.java b/src/main/java/net/minecraft/server/EntityMinecartContainer.java new file mode 100644 index 0000000000..e7398f8d3e --- /dev/null +++ b/src/main/java/net/minecraft/server/EntityMinecartContainer.java @@ -0,0 +1,236 @@ +package net.minecraft.server; + +// CraftBukkit start +import java.util.List; + +import org.bukkit.craftbukkit.entity.CraftHumanEntity; +import org.bukkit.entity.HumanEntity; +// CraftBukkit end + +public abstract class EntityMinecartContainer extends EntityMinecartAbstract implements IInventory { + + private ItemStack[] items = new ItemStack[36]; + private boolean b = true; + + // CraftBukkit start + public List transaction = new java.util.ArrayList(); + private int maxStack = MAX_STACK; + + public ItemStack[] getContents() { + return this.items; + } + + public void onOpen(CraftHumanEntity who) { + transaction.add(who); + } + + public void onClose(CraftHumanEntity who) { + transaction.remove(who); + } + + public List getViewers() { + return transaction; + } + + public void setMaxStackSize(int size) { + maxStack = size; + } + // CraftBukkit end + + public EntityMinecartContainer(World world) { + super(world); + } + + public EntityMinecartContainer(World world, double d0, double d1, double d2) { + super(world, d0, d1, d2); + } + + public void a(DamageSource damagesource) { + super.a(damagesource); + + for (int i = 0; i < this.getSize(); ++i) { + ItemStack itemstack = this.getItem(i); + + if (itemstack != null) { + float f = this.random.nextFloat() * 0.8F + 0.1F; + float f1 = this.random.nextFloat() * 0.8F + 0.1F; + float f2 = this.random.nextFloat() * 0.8F + 0.1F; + + while (itemstack.count > 0) { + int j = this.random.nextInt(21) + 10; + + if (j > itemstack.count) { + j = itemstack.count; + } + + itemstack.count -= j; + EntityItem entityitem = new EntityItem(this.world, this.locX + (double) f, this.locY + (double) f1, this.locZ + (double) f2, new ItemStack(itemstack.id, j, itemstack.getData())); + float f3 = 0.05F; + + entityitem.motX = (double) ((float) this.random.nextGaussian() * f3); + entityitem.motY = (double) ((float) this.random.nextGaussian() * f3 + 0.2F); + entityitem.motZ = (double) ((float) this.random.nextGaussian() * f3); + this.world.addEntity(entityitem); + } + } + } + } + + public ItemStack getItem(int i) { + return this.items[i]; + } + + public ItemStack splitStack(int i, int j) { + if (this.items[i] != null) { + ItemStack itemstack; + + if (this.items[i].count <= j) { + itemstack = this.items[i]; + this.items[i] = null; + return itemstack; + } else { + itemstack = this.items[i].a(j); + if (this.items[i].count == 0) { + this.items[i] = null; + } + + return itemstack; + } + } else { + return null; + } + } + + public ItemStack splitWithoutUpdate(int i) { + if (this.items[i] != null) { + ItemStack itemstack = this.items[i]; + + this.items[i] = null; + return itemstack; + } else { + return null; + } + } + + public void setItem(int i, ItemStack itemstack) { + this.items[i] = itemstack; + if (itemstack != null && itemstack.count > this.getMaxStackSize()) { + itemstack.count = this.getMaxStackSize(); + } + } + + public void update() {} + + public boolean a(EntityHuman entityhuman) { + return this.dead ? false : entityhuman.e(this) <= 64.0D; + } + + public void startOpen() {} + + public void g() {} + + public boolean b(int i, ItemStack itemstack) { + return true; + } + + public String getName() { + return this.c() ? this.t() : "container.minecart"; + } + + public int getMaxStackSize() { + return 64; + } + + public void c(int i) { + this.b = false; + super.c(i); + } + + public void die() { + if (this.b) { + for (int i = 0; i < this.getSize(); ++i) { + ItemStack itemstack = this.getItem(i); + + if (itemstack != null) { + float f = this.random.nextFloat() * 0.8F + 0.1F; + float f1 = this.random.nextFloat() * 0.8F + 0.1F; + float f2 = this.random.nextFloat() * 0.8F + 0.1F; + + while (itemstack.count > 0) { + int j = this.random.nextInt(21) + 10; + + if (j > itemstack.count) { + j = itemstack.count; + } + + itemstack.count -= j; + EntityItem entityitem = new EntityItem(this.world, this.locX + (double) f, this.locY + (double) f1, this.locZ + (double) f2, new ItemStack(itemstack.id, j, itemstack.getData())); + + if (itemstack.hasTag()) { + entityitem.getItemStack().setTag((NBTTagCompound) itemstack.getTag().clone()); + } + + float f3 = 0.05F; + + entityitem.motX = (double) ((float) this.random.nextGaussian() * f3); + entityitem.motY = (double) ((float) this.random.nextGaussian() * f3 + 0.2F); + entityitem.motZ = (double) ((float) this.random.nextGaussian() * f3); + this.world.addEntity(entityitem); + } + } + } + } + + super.die(); + } + + protected void b(NBTTagCompound nbttagcompound) { + super.b(nbttagcompound); + NBTTagList nbttaglist = new NBTTagList(); + + for (int i = 0; i < this.items.length; ++i) { + if (this.items[i] != null) { + NBTTagCompound nbttagcompound1 = new NBTTagCompound(); + + nbttagcompound1.setByte("Slot", (byte) i); + this.items[i].save(nbttagcompound1); + nbttaglist.add(nbttagcompound1); + } + } + + nbttagcompound.set("Items", nbttaglist); + } + + protected void a(NBTTagCompound nbttagcompound) { + super.a(nbttagcompound); + NBTTagList nbttaglist = nbttagcompound.getList("Items"); + + this.items = new ItemStack[this.getSize()]; + + for (int i = 0; i < nbttaglist.size(); ++i) { + NBTTagCompound nbttagcompound1 = (NBTTagCompound) nbttaglist.get(i); + int j = nbttagcompound1.getByte("Slot") & 255; + + if (j >= 0 && j < this.items.length) { + this.items[j] = ItemStack.createStack(nbttagcompound1); + } + } + } + + public boolean a_(EntityHuman entityhuman) { + if (!this.world.isStatic) { + entityhuman.openContainer(this); + } + + return true; + } + + protected void h() { + int i = 15 - Container.b((IInventory) this); + float f = 0.98F + (float) i * 0.001F; + + this.motX *= (double) f; + this.motY *= 0.0D; + this.motZ *= (double) f; + } +} diff --git a/src/main/java/net/minecraft/server/EntityMonster.java b/src/main/java/net/minecraft/server/EntityMonster.java index 2b39bbf63c..ecace08298 100644 --- a/src/main/java/net/minecraft/server/EntityMonster.java +++ b/src/main/java/net/minecraft/server/EntityMonster.java @@ -6,22 +6,22 @@ public abstract class EntityMonster extends EntityCreature implements IMonster { public EntityMonster(World world) { super(world); - this.bd = 5; + this.be = 5; } public void c() { - this.bo(); + this.br(); float f = this.c(1.0F); if (f > 0.5F) { - this.bB += 2; + this.bC += 2; } super.c(); } - public void j_() { - super.j_(); + public void l_() { + super.l_(); if (!this.world.isStatic && this.world.difficulty == 0) { this.die(); } @@ -116,7 +116,7 @@ public abstract class EntityMonster extends EntityCreature implements IMonster { } public float a(int i, int j, int k) { - return 0.5F - this.world.p(i, j, k); + return 0.5F - this.world.q(i, j, k); } protected boolean i_() { @@ -129,7 +129,7 @@ public abstract class EntityMonster extends EntityCreature implements IMonster { } else { int l = this.world.getLightLevel(i, j, k); - if (this.world.M()) { + if (this.world.N()) { int i1 = this.world.j; this.world.j = 10; diff --git a/src/main/java/net/minecraft/server/EntityMushroomCow.java b/src/main/java/net/minecraft/server/EntityMushroomCow.java index 29fdc83403..3f22c9fc14 100644 --- a/src/main/java/net/minecraft/server/EntityMushroomCow.java +++ b/src/main/java/net/minecraft/server/EntityMushroomCow.java @@ -10,7 +10,7 @@ public class EntityMushroomCow extends EntityCow { 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 +42,7 @@ public class EntityMushroomCow extends EntityCow { entitycow.setPositionRotation(this.locX, this.locY, this.locZ, this.yaw, this.pitch); entitycow.setHealth(this.getHealth()); - entitycow.ax = this.ax; + entitycow.ay = this.ay; this.world.addEntity(entitycow); for (int i = 0; i < 5; ++i) { @@ -52,7 +52,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 68b08ae764..48d311f10d 100644 --- a/src/main/java/net/minecraft/server/EntityOcelot.java +++ b/src/main/java/net/minecraft/server/EntityOcelot.java @@ -28,7 +28,7 @@ public class EntityOcelot extends EntityTameableAnimal { this.datawatcher.a(18, Byte.valueOf((byte) 0)); } - public void bm() { + public void bp() { if (this.getControllerMove().a()) { float f = this.getControllerMove().b(); @@ -52,7 +52,7 @@ public class EntityOcelot extends EntityTameableAnimal { return !this.isTamed(); } - public boolean be() { + public boolean bh() { return true; } @@ -72,19 +72,19 @@ public class EntityOcelot extends EntityTameableAnimal { this.setCatType(nbttagcompound.getInt("CatType")); } - protected String aY() { + protected String bb() { return this.isTamed() ? (this.r() ? "mob.cat.purr" : (this.random.nextInt(4) == 0 ? "mob.cat.purreow" : "mob.cat.meow")) : ""; } - protected String aZ() { + protected String bc() { return "mob.cat.hitt"; } - protected String ba() { + protected String bd() { return "mob.cat.hitt"; } - protected float aX() { + protected float ba() { return 0.4F; } @@ -109,7 +109,7 @@ 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()) { @@ -131,11 +131,11 @@ public class EntityOcelot extends EntityTameableAnimal { this.setTamed(true); this.setCatType(1 + this.world.random.nextInt(3)); this.setOwnerName(entityhuman.name); - this.f(true); + this.i(true); this.d.setSitting(true); this.world.broadcastEntityEffect(this, (byte) 7); } else { - this.f(false); + this.i(false); this.world.broadcastEntityEffect(this, (byte) 6); } } @@ -143,7 +143,7 @@ public class EntityOcelot extends EntityTameableAnimal { return true; } - return super.a(entityhuman); + return super.a_(entityhuman); } public EntityOcelot b(EntityAgeable entityageable) { @@ -209,10 +209,10 @@ public class EntityOcelot extends EntityTameableAnimal { } public String getLocalizedName() { - return this.isTamed() ? "entity.Cat.name" : super.getLocalizedName(); + return this.hasCustomName() ? this.getCustomName() : (this.isTamed() ? "entity.Cat.name" : super.getLocalizedName()); } - public void bG() { + public void bJ() { if (this.world.random.nextInt(7) == 0) { for (int i = 0; i < 2; ++i) { EntityOcelot entityocelot = new EntityOcelot(this.world); diff --git a/src/main/java/net/minecraft/server/EntityPig.java b/src/main/java/net/minecraft/server/EntityPig.java index c1ee363827..e9fe7cfffa 100644 --- a/src/main/java/net/minecraft/server/EntityPig.java +++ b/src/main/java/net/minecraft/server/EntityPig.java @@ -25,7 +25,7 @@ public class EntityPig extends EntityAnimal { this.goalSelector.a(8, new PathfinderGoalRandomLookaround(this)); } - public boolean be() { + public boolean bh() { return true; } @@ -33,12 +33,12 @@ public class EntityPig extends EntityAnimal { return 10; } - protected void bl() { - super.bl(); + protected void bo() { + super.bo(); } - public boolean bI() { - ItemStack itemstack = ((EntityHuman) this.passenger).bD(); + public boolean bL() { + ItemStack itemstack = ((EntityHuman) this.passenger).bG(); return itemstack != null && itemstack.id == Item.CARROT_STICK.id; } @@ -58,15 +58,15 @@ public class EntityPig extends EntityAnimal { this.setSaddle(nbttagcompound.getBoolean("Saddle")); } - protected String aY() { + protected String bb() { return "mob.pig.say"; } - protected String aZ() { + protected String bc() { return "mob.pig.say"; } - protected String ba() { + protected String bd() { return "mob.pig.death"; } @@ -74,8 +74,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); diff --git a/src/main/java/net/minecraft/server/EntityPigZombie.java b/src/main/java/net/minecraft/server/EntityPigZombie.java index 3a07b6226b..b626215897 100644 --- a/src/main/java/net/minecraft/server/EntityPigZombie.java +++ b/src/main/java/net/minecraft/server/EntityPigZombie.java @@ -15,21 +15,21 @@ public class EntityPigZombie extends EntityZombie { public EntityPigZombie(World world) { super(world); this.texture = "/mob/pigzombie.png"; - this.bH = 0.5F; + this.bI = 0.5F; this.fireProof = true; } - protected boolean be() { + protected boolean bh() { return false; } - public void j_() { - this.bH = this.target != null ? 0.95F : 0.5F; + public void l_() { + this.bI = this.target != null ? 0.95F : 0.5F; if (this.soundDelay > 0 && --this.soundDelay == 0) { - this.makeSound("mob.zombiepig.zpigangry", this.aX() * 2.0F, ((this.random.nextFloat() - this.random.nextFloat()) * 0.2F + 1.0F) * 1.8F); + this.makeSound("mob.zombiepig.zpigangry", this.ba() * 2.0F, ((this.random.nextFloat() - this.random.nextFloat()) * 0.2F + 1.0F) * 1.8F); } - super.j_(); + super.l_(); } public boolean canSpawn() { @@ -99,15 +99,15 @@ public class EntityPigZombie extends EntityZombie { this.soundDelay = this.random.nextInt(40); } - protected String aY() { + protected String bb() { return "mob.zombiepig.zpig"; } - protected String aZ() { + protected String bc() { return "mob.zombiepig.zpighurt"; } - protected String ba() { + protected String bd() { return "mob.zombiepig.zpigdeath"; } @@ -142,7 +142,7 @@ public class EntityPigZombie extends EntityZombie { // CraftBukkit end } - public boolean a(EntityHuman entityhuman) { + public boolean a_(EntityHuman entityhuman) { return false; } @@ -155,17 +155,17 @@ public class EntityPigZombie extends EntityZombie { return Item.ROTTEN_FLESH.id; } - protected void bE() { + protected void bH() { this.setEquipment(0, new ItemStack(Item.GOLD_SWORD)); } - public void bG() { - super.bG(); + public void bJ() { + super.bJ(); this.setVillager(false); } public int c(Entity entity) { - ItemStack itemstack = this.bD(); + ItemStack itemstack = this.bG(); int i = 5; if (itemstack != null) { diff --git a/src/main/java/net/minecraft/server/EntityPlayer.java b/src/main/java/net/minecraft/server/EntityPlayer.java index 8d61ca63f8..52fd5612c5 100644 --- a/src/main/java/net/minecraft/server/EntityPlayer.java +++ b/src/main/java/net/minecraft/server/EntityPlayer.java @@ -4,6 +4,8 @@ import java.io.ByteArrayOutputStream; import java.io.DataOutputStream; import java.io.IOException; import java.util.ArrayList; +import java.util.Arrays; +import java.util.Collection; import java.util.Iterator; import java.util.LinkedList; import java.util.List; @@ -28,14 +30,14 @@ public class EntityPlayer extends EntityHuman implements ICrafting { public double e; public final List chunkCoordIntPairQueue = new LinkedList(); public final List removeQueue = new LinkedList(); - private int cl = -99999999; private int cm = -99999999; - private boolean cn = true; + private int cn = -99999999; + private boolean co = true; public int lastSentExp = -99999999; // CraftBukkit - private -> public public int invulnerableTicks = 60; // CraftBukkit - private -> public - private int cq = 0; private int cr = 0; - private boolean cs = true; + private int cs = 0; + private boolean ct = true; private int containerCounter = 0; public boolean h; public int ping; @@ -54,7 +56,7 @@ public class EntityPlayer extends EntityHuman implements ICrafting { super(world); playerinteractmanager.player = this; this.playerInteractManager = playerinteractmanager; - this.cq = minecraftserver.getPlayerList().o(); + this.cr = minecraftserver.getPlayerList().o(); ChunkCoordinates chunkcoordinates = world.getSpawn(); int i = chunkcoordinates.x; int j = chunkcoordinates.z; @@ -68,14 +70,21 @@ public class EntityPlayer extends EntityHuman implements ICrafting { k = world.i(i, j); } - this.setPositionRotation((double) i + 0.5D, (double) k, (double) j + 0.5D, 0.0F, 0.0F); this.server = minecraftserver; - this.X = 0.0F; + this.Y = 0.0F; this.name = s; this.height = 0.0F; - this.displayName = this.name; // CraftBukkit - this.listName = this.name; // CraftBukkit - this.canPickUpLoot = true; // CraftBukkit + this.setPositionRotation((double) i + 0.5D, (double) k, (double) j + 0.5D, 0.0F, 0.0F); + + while (!world.getCubes(this, this.boundingBox).isEmpty()) { + this.setPosition(this.locX, this.locY + 1.0D, this.locZ); + } + + // CraftBukkit start + this.displayName = this.name; + this.listName = this.name; + this.canPickUpLoot = true; + // CraftBukkit end } public void a(NBTTagCompound nbttagcompound) { @@ -134,7 +143,7 @@ public class EntityPlayer extends EntityHuman implements ICrafting { return 1.62F; } - public void j_() { + public void l_() { this.playerInteractManager.a(); --this.invulnerableTicks; this.activeContainer.b(); @@ -170,7 +179,6 @@ public class EntityPlayer extends EntityHuman implements ICrafting { if (!arraylist.isEmpty()) { this.playerConnection.sendPacket(new Packet56MapChunkBulk(arraylist)); - Iterator iterator2 = arraylist1.iterator(); while (iterator2.hasNext()) { @@ -184,50 +192,70 @@ public class EntityPlayer extends EntityHuman implements ICrafting { while (iterator2.hasNext()) { Chunk chunk = (Chunk) iterator2.next(); - this.p().getTracker().a(this, chunk); + this.o().getTracker().a(this, chunk); } } } } + public void setHealth(int i) { + super.setHealth(i); + Collection collection = this.getScoreboard().a(IObjective.f); + Iterator iterator = collection.iterator(); + + while (iterator.hasNext()) { + ScoreboardObjective scoreboardobjective = (ScoreboardObjective) iterator.next(); + + this.getScoreboard().a(this.getLocalizedName(), scoreboardobjective).a(Arrays.asList(new EntityHuman[] { this})); + } + } + public void g() { - super.j_(); + try { + super.l_(); - for (int i = 0; i < this.inventory.getSize(); ++i) { - ItemStack itemstack = this.inventory.getItem(i); + for (int i = 0; i < this.inventory.getSize(); ++i) { + ItemStack itemstack = this.inventory.getItem(i); - if (itemstack != null && Item.byId[itemstack.id].f() && this.playerConnection.lowPriorityCount() <= 5) { - Packet packet = ((ItemWorldMapBase) Item.byId[itemstack.id]).c(itemstack, this.world, this); + if (itemstack != null && Item.byId[itemstack.id].f() && this.playerConnection.lowPriorityCount() <= 5) { + Packet packet = ((ItemWorldMapBase) Item.byId[itemstack.id]).c(itemstack, this.world, this); - if (packet != null) { - this.playerConnection.sendPacket(packet); + if (packet != null) { + this.playerConnection.sendPacket(packet); + } } } - } - if (this.getHealth() != this.cl || this.cm != this.foodData.a() || this.foodData.e() == 0.0F != this.cn) { - // CraftBukkit - this.getHealth() -> this.getScaledHealth() - this.playerConnection.sendPacket(new Packet8UpdateHealth(this.getScaledHealth(), this.foodData.a(), this.foodData.e())); - this.cl = this.getHealth(); - this.cm = this.foodData.a(); - this.cn = this.foodData.e() == 0.0F; - } + if (this.getHealth() != this.cm || this.cn != this.foodData.a() || this.foodData.e() == 0.0F != this.co) { + // 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; + } - if (this.expTotal != this.lastSentExp) { - this.lastSentExp = this.expTotal; - this.playerConnection.sendPacket(new Packet43SetExperience(this.exp, this.expTotal, this.expLevel)); - } + if (this.expTotal != this.lastSentExp) { + this.lastSentExp = this.expTotal; + this.playerConnection.sendPacket(new Packet43SetExperience(this.exp, this.expTotal, this.expLevel)); + } - // CraftBukkit start - if (this.oldLevel == -1) { - this.oldLevel = this.expLevel; - } + // CraftBukkit start + if (this.oldLevel == -1) { + this.oldLevel = this.expLevel; + } - if (this.oldLevel != this.expLevel) { - CraftEventFactory.callPlayerLevelChangeEvent(this.world.getServer().getPlayer((EntityPlayer) this), this.oldLevel, this.expLevel); - this.oldLevel = this.expLevel; + if (this.oldLevel != this.expLevel) { + CraftEventFactory.callPlayerLevelChangeEvent(this.world.getServer().getPlayer((EntityPlayer) this), this.oldLevel, this.expLevel); + this.oldLevel = this.expLevel; + } + // CraftBukkit end + } catch (Throwable throwable) { + CrashReport crashreport = CrashReport.a(throwable, "Ticking player"); + CrashReportSystemDetails crashreportsystemdetails = crashreport.a("Player being ticked"); + + this.a(crashreportsystemdetails); + throw new ReportedException(crashreport); } - // CraftBukkit end } public void die(DamageSource damagesource) { @@ -253,7 +281,7 @@ public class EntityPlayer extends EntityHuman implements ICrafting { } } - org.bukkit.event.entity.PlayerDeathEvent event = CraftEventFactory.callPlayerDeathEvent(this, loot, damagesource.getLocalizedDeathMessage(this)); + org.bukkit.event.entity.PlayerDeathEvent event = CraftEventFactory.callPlayerDeathEvent(this, loot, this.bt.b()); String deathMessage = event.getDeathMessage(); @@ -273,10 +301,23 @@ public class EntityPlayer extends EntityHuman implements ICrafting { } this.closeInventory(); - - // Update effects on player death - this.updateEffects = true; // CraftBukkit end + + Collection collection = this.world.getScoreboard().a(IObjective.c); + Iterator iterator = collection.iterator(); + + while (iterator.hasNext()) { + ScoreboardObjective scoreboardobjective = (ScoreboardObjective) iterator.next(); + ScoreboardScore scoreboardscore = this.getScoreboard().a(this.getLocalizedName(), scoreboardobjective); + + scoreboardscore.a(); + } + + EntityLiving entityliving = this.bN(); + + if (entityliving != null) { + entityliving.c(this, this.aM); + } } public boolean damageEntity(DamageSource damagesource, int i) { @@ -289,18 +330,17 @@ public class EntityPlayer extends EntityHuman implements ICrafting { if (!flag && this.invulnerableTicks > 0 && damagesource != DamageSource.OUT_OF_WORLD) { return false; } else { - // CraftBukkit - this.server.getPvP() -> this.world.pvpMode - if (!this.world.pvpMode && damagesource instanceof EntityDamageSource) { + if (damagesource instanceof EntityDamageSource) { Entity entity = damagesource.getEntity(); - if (entity instanceof EntityHuman) { + if (entity instanceof EntityHuman && !this.a((EntityHuman) entity)) { return false; } if (entity instanceof EntityArrow) { EntityArrow entityarrow = (EntityArrow) entity; - if (entityarrow.shooter instanceof EntityHuman) { + if (entityarrow.shooter instanceof EntityHuman && !this.a((EntityHuman) entityarrow.shooter)) { return false; } } @@ -311,11 +351,12 @@ public class EntityPlayer extends EntityHuman implements ICrafting { } } - protected boolean h() { - return this.server.getPvP(); + public boolean a(EntityHuman entityhuman) { + // CraftBukkit - this.server.getPvP() -> this.world.pvpMode + return !this.world.pvpMode ? false : super.a(entityhuman); } - public void b(int i) { + public void c(int i) { if (this.dimension == 1 && i == 1) { this.a((Statistic) AchievementList.C); this.world.kill(this); @@ -329,7 +370,7 @@ public class EntityPlayer extends EntityHuman implements ICrafting { ChunkCoordinates chunkcoordinates = this.server.getWorldServer(i).getDimensionSpawn(); if (chunkcoordinates != null) { - this.netServerHandler.a((double) chunkcoordinates.x, (double) chunkcoordinates.y, (double) chunkcoordinates.z, 0.0F, 0.0F); + this.playerConnection.a((double) chunkcoordinates.x, (double) chunkcoordinates.y, (double) chunkcoordinates.z, 0.0F, 0.0F); } i = 1; @@ -344,8 +385,8 @@ public class EntityPlayer extends EntityHuman implements ICrafting { this.server.getPlayerList().changeDimension(this, i, cause); // CraftBukkit end this.lastSentExp = -1; - this.cl = -1; this.cm = -1; + this.cn = -1; } } @@ -370,7 +411,7 @@ public class EntityPlayer extends EntityHuman implements ICrafting { if (enumbedresult == EnumBedResult.OK) { Packet17EntityLocationAction packet17entitylocationaction = new Packet17EntityLocationAction(this, 0, i, j, k); - this.p().getTracker().a((Entity) this, (Packet) packet17entitylocationaction); + this.o().getTracker().a((Entity) this, (Packet) packet17entitylocationaction); this.playerConnection.a(this.locX, this.locY, this.locZ, this.yaw, this.pitch); this.playerConnection.sendPacket(packet17entitylocationaction); } @@ -382,7 +423,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.p().getTracker().sendPacketToEntity(this, new Packet18ArmAnimation(this, 3)); + this.o().getTracker().sendPacketToEntity(this, new Packet18ArmAnimation(this, 3)); } super.a(flag, flag1, flag2); @@ -425,20 +466,20 @@ public class EntityPlayer extends EntityHuman implements ICrafting { // CraftBukkit end this.nextContainerCounter(); - this.playerConnection.sendPacket(new Packet100OpenWindow(this.containerCounter, 1, "Crafting", 9)); + this.playerConnection.sendPacket(new Packet100OpenWindow(this.containerCounter, 1, "Crafting", 9, true)); this.activeContainer = container; // CraftBukkit - Use container we passed to event this.activeContainer.windowId = this.containerCounter; this.activeContainer.addSlotListener(this); } - public void startEnchanting(int i, int j, int k) { + public void startEnchanting(int i, int j, int k, String s) { // CraftBukkit start - inventory open hook Container container = CraftEventFactory.callInventoryOpenEvent(this, new ContainerEnchantTable(this.inventory, this.world, i, j, k)); if(container == null) return; // CraftBukkit end this.nextContainerCounter(); - this.playerConnection.sendPacket(new Packet100OpenWindow(this.containerCounter, 4, "Enchanting", 9)); + this.playerConnection.sendPacket(new Packet100OpenWindow(this.containerCounter, 4, s == null ? "" : s, 9, s != null)); this.activeContainer = container; // CraftBukkit - Use container we passed to event this.activeContainer.windowId = this.containerCounter; this.activeContainer.addSlotListener(this); @@ -451,8 +492,8 @@ public class EntityPlayer extends EntityHuman implements ICrafting { // CraftBukkit end this.nextContainerCounter(); - this.playerConnection.sendPacket(new Packet100OpenWindow(this.containerCounter, 8, "Repairing", 9)); - this.activeContainer = container; // CraftBukkit - use container we passed to event + this.playerConnection.sendPacket(new Packet100OpenWindow(this.containerCounter, 8, "Repairing", 9, true)); + this.activeContainer = container; // CraftBukkit - Use container we passed to event this.activeContainer.windowId = this.containerCounter; this.activeContainer.addSlotListener(this); } @@ -468,8 +509,34 @@ public class EntityPlayer extends EntityHuman implements ICrafting { // CraftBukkit end this.nextContainerCounter(); - this.playerConnection.sendPacket(new Packet100OpenWindow(this.containerCounter, 0, iinventory.getName(), iinventory.getSize())); - this.activeContainer = container; // CraftBukkit - Use container passed to event + this.playerConnection.sendPacket(new Packet100OpenWindow(this.containerCounter, 0, iinventory.getName(), iinventory.getSize(), iinventory.c())); + this.activeContainer = container; // CraftBukkit - Use container we passed to event + this.activeContainer.windowId = this.containerCounter; + this.activeContainer.addSlotListener(this); + } + + public void openHopper(TileEntityHopper tileentityhopper) { + // CraftBukkit start - inventory open hook + Container container = CraftEventFactory.callInventoryOpenEvent(this, new ContainerHopper(this.inventory, tileentityhopper)); + if(container == null) return; + // CraftBukkit end + + this.nextContainerCounter(); + this.playerConnection.sendPacket(new Packet100OpenWindow(this.containerCounter, 9, tileentityhopper.getName(), tileentityhopper.getSize(), tileentityhopper.c())); + this.activeContainer = container; // CraftBukkit - Use container we passed to event + this.activeContainer.windowId = this.containerCounter; + this.activeContainer.addSlotListener(this); + } + + public void openMinecartHopper(EntityMinecartHopper entityminecarthopper) { + // CraftBukkit start - inventory open hook + Container container = CraftEventFactory.callInventoryOpenEvent(this, new ContainerHopper(this.inventory, entityminecarthopper)); + if(container == null) return; + // CraftBukkit end + + this.nextContainerCounter(); + this.playerConnection.sendPacket(new Packet100OpenWindow(this.containerCounter, 9, entityminecarthopper.getName(), entityminecarthopper.getSize(), entityminecarthopper.c())); + this.activeContainer = container; // CraftBukkit - Use container we passed to event this.activeContainer.windowId = this.containerCounter; this.activeContainer.addSlotListener(this); } @@ -481,8 +548,8 @@ public class EntityPlayer extends EntityHuman implements ICrafting { // CraftBukkit end this.nextContainerCounter(); - this.playerConnection.sendPacket(new Packet100OpenWindow(this.containerCounter, 2, tileentityfurnace.getName(), tileentityfurnace.getSize())); - this.activeContainer = container; // CraftBukkit - Use container passed to event + this.playerConnection.sendPacket(new Packet100OpenWindow(this.containerCounter, 2, tileentityfurnace.getName(), tileentityfurnace.getSize(), tileentityfurnace.c())); + this.activeContainer = container; // CraftBukkit - Use container we passed to event this.activeContainer.windowId = this.containerCounter; this.activeContainer.addSlotListener(this); } @@ -494,8 +561,8 @@ public class EntityPlayer extends EntityHuman implements ICrafting { // CraftBukkit end this.nextContainerCounter(); - this.playerConnection.sendPacket(new Packet100OpenWindow(this.containerCounter, 3, tileentitydispenser.getName(), tileentitydispenser.getSize())); - this.activeContainer = container; // CraftBukkit - Use container passed to event + this.playerConnection.sendPacket(new Packet100OpenWindow(this.containerCounter, tileentitydispenser instanceof TileEntityDropper ? 10 : 3, tileentitydispenser.getName(), tileentitydispenser.getSize(), tileentitydispenser.c())); + this.activeContainer = container; // CraftBukkit - Use container we passed to event this.activeContainer.windowId = this.containerCounter; this.activeContainer.addSlotListener(this); } @@ -507,8 +574,8 @@ public class EntityPlayer extends EntityHuman implements ICrafting { // CraftBukkit end this.nextContainerCounter(); - this.playerConnection.sendPacket(new Packet100OpenWindow(this.containerCounter, 5, tileentitybrewingstand.getName(), tileentitybrewingstand.getSize())); - this.activeContainer = container; // CraftBukkit - Use container passed to event + this.playerConnection.sendPacket(new Packet100OpenWindow(this.containerCounter, 5, tileentitybrewingstand.getName(), tileentitybrewingstand.getSize(), tileentitybrewingstand.c())); + this.activeContainer = container; // CraftBukkit - Use container we passed to event this.activeContainer.windowId = this.containerCounter; this.activeContainer.addSlotListener(this); } @@ -520,25 +587,25 @@ public class EntityPlayer extends EntityHuman implements ICrafting { // CraftBukkit end this.nextContainerCounter(); - this.playerConnection.sendPacket(new Packet100OpenWindow(this.containerCounter, 7, tileentitybeacon.getName(), tileentitybeacon.getSize())); - this.activeContainer = container; // CraftBukkit - Use container passed to event + this.playerConnection.sendPacket(new Packet100OpenWindow(this.containerCounter, 7, tileentitybeacon.getName(), tileentitybeacon.getSize(), tileentitybeacon.c())); + this.activeContainer = container; // CraftBukkit - Use container we passed to event this.activeContainer.windowId = this.containerCounter; this.activeContainer.addSlotListener(this); } - public void openTrade(IMerchant imerchant) { + public void openTrade(IMerchant imerchant, String s) { // CraftBukkit start - inventory open hook Container container = CraftEventFactory.callInventoryOpenEvent(this, new ContainerMerchant(this.inventory, imerchant, this.world)); if(container == null) return; // CraftBukkit end this.nextContainerCounter(); - this.activeContainer = container; // CraftBukkit - Use container passed to event + this.activeContainer = container; // CraftBukkit - Use container we passed to event this.activeContainer.windowId = this.containerCounter; this.activeContainer.addSlotListener(this); InventoryMerchant inventorymerchant = ((ContainerMerchant) this.activeContainer).getMerchantInventory(); - this.playerConnection.sendPacket(new Packet100OpenWindow(this.containerCounter, 6, inventorymerchant.getName(), inventorymerchant.getSize())); + this.playerConnection.sendPacket(new Packet100OpenWindow(this.containerCounter, 6, s == null ? "" : s, inventorymerchant.getSize(), s != null)); MerchantRecipeList merchantrecipelist = imerchant.getOffers(this); if (merchantrecipelist != null) { @@ -583,7 +650,7 @@ public class EntityPlayer extends EntityHuman implements ICrafting { public void closeInventory() { this.playerConnection.sendPacket(new Packet101CloseWindow(this.activeContainer.windowId)); - this.k(); + this.j(); } public void broadcastCarriedItem() { @@ -592,8 +659,8 @@ public class EntityPlayer extends EntityHuman implements ICrafting { } } - public void k() { - this.activeContainer.b(this); + public void j() { + this.activeContainer.b((EntityHuman) this); this.activeContainer = this.defaultContainer; } @@ -610,11 +677,7 @@ public class EntityPlayer extends EntityHuman implements ICrafting { } } - public void l() { - if (this.vehicle != null) { - this.mount(this.vehicle); - } - + public void k() { if (this.passenger != null) { this.passenger.mount(this); } @@ -625,34 +688,34 @@ public class EntityPlayer extends EntityHuman implements ICrafting { } public void triggerHealthUpdate() { - this.cl = -99999999; + this.cm = -99999999; this.lastSentExp = -1; // CraftBukkit - Added to reset } public void b(String s) { LocaleLanguage localelanguage = LocaleLanguage.a(); - String s1 = localelanguage.b(s); + String s1 = localelanguage.a(s); this.playerConnection.sendPacket(new Packet3Chat(s1)); } - protected void n() { + protected void m() { this.playerConnection.sendPacket(new Packet38EntityStatus(this.id, (byte) 9)); - super.n(); + super.m(); } public void a(ItemStack itemstack, int i) { super.a(itemstack, i); - if (itemstack != null && itemstack.getItem() != null && itemstack.getItem().b_(itemstack) == EnumAnimation.b) { - this.p().getTracker().sendPacketToEntity(this, new Packet18ArmAnimation(this, 5)); + if (itemstack != null && itemstack.getItem() != null && itemstack.getItem().b_(itemstack) == EnumAnimation.EAT) { + this.o().getTracker().sendPacketToEntity(this, new Packet18ArmAnimation(this, 5)); } } public void copyTo(EntityHuman entityhuman, boolean flag) { super.copyTo(entityhuman, flag); this.lastSentExp = -1; - this.cl = -1; this.cm = -1; + this.cn = -1; this.removeQueue.addAll(((EntityPlayer) entityhuman).removeQueue); } @@ -676,11 +739,11 @@ public class EntityPlayer extends EntityHuman implements ICrafting { } public void b(Entity entity) { - this.p().getTracker().sendPacketToEntity(this, new Packet18ArmAnimation(entity, 6)); + this.o().getTracker().sendPacketToEntity(this, new Packet18ArmAnimation(entity, 6)); } public void c(Entity entity) { - this.p().getTracker().sendPacketToEntity(this, new Packet18ArmAnimation(entity, 7)); + this.o().getTracker().sendPacketToEntity(this, new Packet18ArmAnimation(entity, 7)); } public void updateAbilities() { @@ -689,7 +752,7 @@ public class EntityPlayer extends EntityHuman implements ICrafting { } } - public WorldServer p() { + public WorldServer o() { return (WorldServer) this.world; } @@ -706,7 +769,7 @@ public class EntityPlayer extends EntityHuman implements ICrafting { return "seed".equals(s) && !this.server.T() ? true : (!"tell".equals(s) && !"help".equals(s) && !"me".equals(s) ? this.server.getPlayerList().isOp(this.name) : true); } - public String q() { + public String p() { String s = this.playerConnection.networkManager.getSocketAddress().toString(); s = s.substring(s.indexOf("/") + 1); @@ -716,17 +779,17 @@ public class EntityPlayer extends EntityHuman implements ICrafting { public void a(Packet204LocaleAndViewDistance packet204localeandviewdistance) { if (this.locale.b().containsKey(packet204localeandviewdistance.d())) { - this.locale.a(packet204localeandviewdistance.d()); + this.locale.a(packet204localeandviewdistance.d(), false); } int i = 256 >> packet204localeandviewdistance.f(); if (i > 3 && i < 15) { - this.cq = i; + this.cr = i; } - this.cr = packet204localeandviewdistance.g(); - this.cs = packet204localeandviewdistance.h(); + this.cs = packet204localeandviewdistance.g(); + this.ct = packet204localeandviewdistance.h(); if (this.server.I() && this.server.H().equals(this.name)) { this.server.c(packet204localeandviewdistance.i()); } @@ -739,7 +802,7 @@ public class EntityPlayer extends EntityHuman implements ICrafting { } public int getChatFlags() { - return this.cr; + return this.cs; } public void a(String s, int i) { diff --git a/src/main/java/net/minecraft/server/EntityProjectile.java b/src/main/java/net/minecraft/server/EntityProjectile.java index 7e8122dd6a..85ca93d3f3 100644 --- a/src/main/java/net/minecraft/server/EntityProjectile.java +++ b/src/main/java/net/minecraft/server/EntityProjectile.java @@ -80,11 +80,11 @@ public abstract class EntityProjectile extends Entity implements IProjectile { this.i = 0; } - public void j_() { - this.T = this.locX; - this.U = this.locY; - this.V = this.locZ; - super.j_(); + public void l_() { + this.U = this.locX; + this.V = this.locY; + this.W = this.locZ; + super.l_(); if (this.shake > 0) { --this.shake; } @@ -130,7 +130,7 @@ public abstract class EntityProjectile extends Entity implements IProjectile { for (int j = 0; j < list.size(); ++j) { Entity entity1 = (Entity) list.get(j); - if (entity1.L() && (entity1 != entityliving || this.j >= 5)) { + if (entity1.K() && (entity1 != entityliving || this.j >= 5)) { float f = 0.3F; AxisAlignedBB axisalignedbb = entity1.boundingBox.grow((double) f, (double) f, (double) f); MovingObjectPosition movingobjectposition1 = axisalignedbb.a(vec3d, vec3d1); @@ -153,7 +153,7 @@ public abstract class EntityProjectile extends Entity implements IProjectile { if (movingobjectposition != null) { if (movingobjectposition.type == EnumMovingObjectType.TILE && this.world.getTypeId(movingobjectposition.b, movingobjectposition.c, movingobjectposition.d) == Block.PORTAL.id) { - this.aa(); + this.Z(); } else { this.a(movingobjectposition); // CraftBukkit start @@ -193,7 +193,7 @@ public abstract class EntityProjectile extends Entity implements IProjectile { float f2 = 0.99F; float f3 = this.g(); - if (this.H()) { + if (this.G()) { for (int k = 0; k < 4; ++k) { float f4 = 0.25F; diff --git a/src/main/java/net/minecraft/server/EntitySheep.java b/src/main/java/net/minecraft/server/EntitySheep.java index 5ad86c0db1..77f6907527 100644 --- a/src/main/java/net/minecraft/server/EntitySheep.java +++ b/src/main/java/net/minecraft/server/EntitySheep.java @@ -35,13 +35,13 @@ public class EntitySheep extends EntityAnimal { this.e.resultInventory = new InventoryCraftResult(); // CraftBukkit - add result slot for event } - protected boolean be() { + protected boolean bh() { return true; } - protected void bl() { + protected void bo() { this.f = this.g.f(); - super.bl(); + super.bo(); } public void c() { @@ -77,7 +77,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 +107,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 +122,15 @@ public class EntitySheep extends EntityAnimal { this.setColor(nbttagcompound.getByte("Color")); } - protected String aY() { + protected String bb() { return "mob.sheep.say"; } - protected String aZ() { + protected String bc() { return "mob.sheep.say"; } - protected String ba() { + protected String bd() { return "mob.sheep.say"; } @@ -177,7 +177,7 @@ public class EntitySheep extends EntityAnimal { return entitysheep1; } - public void aH() { + public void aK() { // CraftBukkit start SheepRegrowWoolEvent event = new SheepRegrowWoolEvent((org.bukkit.entity.Sheep) this.getBukkitEntity()); this.world.getServer().getPluginManager().callEvent(event); @@ -198,7 +198,7 @@ public class EntitySheep extends EntityAnimal { } } - public void bG() { + public void bJ() { this.setColor(a(this.world.random)); } diff --git a/src/main/java/net/minecraft/server/EntitySilverfish.java b/src/main/java/net/minecraft/server/EntitySilverfish.java index 7b524cdaca..4ea06d0a6a 100644 --- a/src/main/java/net/minecraft/server/EntitySilverfish.java +++ b/src/main/java/net/minecraft/server/EntitySilverfish.java @@ -10,7 +10,7 @@ public class EntitySilverfish extends EntityMonster { super(world); this.texture = "/mob/silverfish.png"; this.a(0.3F, 0.7F); - this.bH = 0.6F; + this.bI = 0.6F; } public int getMaxHealth() { @@ -27,15 +27,15 @@ public class EntitySilverfish extends EntityMonster { return this.world.findNearbyVulnerablePlayer(this, d0); } - protected String aY() { + protected String bb() { return "mob.silverfish.say"; } - protected String aZ() { + protected String bc() { return "mob.silverfish.hit"; } - protected String ba() { + protected String bd() { return "mob.silverfish.kill"; } @@ -66,13 +66,13 @@ public class EntitySilverfish extends EntityMonster { return 0; } - public void j_() { - this.ax = this.yaw; - super.j_(); + public void l_() { + this.ay = this.yaw; + super.l_(); } - protected void bn() { - super.bn(); + protected void bq() { + super.bq(); if (!this.world.isStatic) { int i; int j; @@ -99,8 +99,7 @@ public class EntitySilverfish extends EntityMonster { } // CraftBukkit end - this.world.triggerEffect(2001, i + i1, j + l, k + j1, Block.MONSTER_EGGS.id + (this.world.getData(i + i1, j + l, k + j1) << 12)); - this.world.setTypeId(i + i1, j + l, k + j1, 0); + 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; @@ -120,15 +119,15 @@ public class EntitySilverfish extends EntityMonster { int l1 = this.random.nextInt(6); l = this.world.getTypeId(i + Facing.b[l1], j + Facing.c[l1], k + Facing.d[l1]); - if (BlockMonsterEggs.e(l)) { + 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.f(l)).isCancelled()) { + if (CraftEventFactory.callEntityChangeBlockEvent(this, i + Facing.b[l1], j + Facing.c[l1], k + Facing.d[l1], 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.f(l)); - this.aR(); + 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.die(); } else { this.i(); diff --git a/src/main/java/net/minecraft/server/EntitySkeleton.java b/src/main/java/net/minecraft/server/EntitySkeleton.java index 4ea580bed0..a69323bf70 100644 --- a/src/main/java/net/minecraft/server/EntitySkeleton.java +++ b/src/main/java/net/minecraft/server/EntitySkeleton.java @@ -12,11 +12,11 @@ public class EntitySkeleton extends EntityMonster implements IRangedEntity { public EntitySkeleton(World world) { super(world); this.texture = "/mob/skeleton.png"; - this.bH = 0.25F; + 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.bH)); - this.goalSelector.a(5, new PathfinderGoalRandomStroll(this, this.bH)); + this.goalSelector.a(3, new PathfinderGoalFleeSun(this, this.bI)); + this.goalSelector.a(5, new PathfinderGoalRandomStroll(this, this.bI)); 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)); @@ -31,7 +31,7 @@ public class EntitySkeleton extends EntityMonster implements IRangedEntity { this.datawatcher.a(13, new Byte((byte) 0)); } - public boolean be() { + public boolean bh() { return true; } @@ -39,15 +39,15 @@ public class EntitySkeleton extends EntityMonster implements IRangedEntity { return 20; } - protected String aY() { + protected String bb() { return "mob.skeleton.say"; } - protected String aZ() { + protected String bc() { return "mob.skeleton.hurt"; } - protected String ba() { + protected String bd() { return "mob.skeleton.death"; } @@ -69,7 +69,7 @@ public class EntitySkeleton extends EntityMonster implements IRangedEntity { public int c(Entity entity) { if (this.getSkeletonType() == 1) { - ItemStack itemstack = this.bD(); + ItemStack itemstack = this.bG(); int i = 4; if (itemstack != null) { @@ -90,14 +90,14 @@ public class EntitySkeleton extends EntityMonster implements IRangedEntity { if (this.world.u() && !this.world.isStatic) { float f = this.c(1.0F); - if (f > 0.5F && this.random.nextFloat() * 30.0F < (f - 0.4F) * 2.0F && this.world.k(MathHelper.floor(this.locX), MathHelper.floor(this.locY), MathHelper.floor(this.locZ))) { + 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; ItemStack itemstack = this.getEquipment(4); if (itemstack != null) { - if (itemstack.f()) { - itemstack.setData(itemstack.i() + this.random.nextInt(2)); - if (itemstack.i() >= itemstack.k()) { + if (itemstack.g()) { + itemstack.setData(itemstack.j() + this.random.nextInt(2)); + if (itemstack.j() >= itemstack.l()) { this.a(itemstack); this.setEquipment(4, (ItemStack) null); } @@ -119,12 +119,16 @@ public class EntitySkeleton extends EntityMonster implements IRangedEntity { } } + if (this.world.isStatic && this.getSkeletonType() == 1) { + this.a(0.72F, 2.34F); + } + super.c(); } public void die(DamageSource damagesource) { super.die(damagesource); - if (damagesource.f() instanceof EntityArrow && damagesource.getEntity() instanceof EntityHuman) { + if (damagesource.h() instanceof EntityArrow && damagesource.getEntity() instanceof EntityHuman) { EntityHuman entityhuman = (EntityHuman) damagesource.getEntity(); double d0 = entityhuman.locX - this.locX; double d1 = entityhuman.locZ - this.locZ; @@ -185,25 +189,25 @@ public class EntitySkeleton extends EntityMonster implements IRangedEntity { return null; } - protected void bE() { - super.bD(); + protected void bH() { + super.bH(); this.setEquipment(0, new ItemStack(Item.BOW)); } - public void bG() { - if (this.world.worldProvider instanceof WorldProviderHell && this.aB().nextInt(5) > 0) { + public void bJ() { + if (this.world.worldProvider instanceof WorldProviderHell && this.aE().nextInt(5) > 0) { this.goalSelector.a(4, this.e); this.setSkeletonType(1); this.setEquipment(0, new ItemStack(Item.STONE_SWORD)); } else { this.goalSelector.a(4, this.d); - this.bE(); - this.bF(); + this.bH(); + this.bI(); } - this.canPickUpLoot = this.random.nextFloat() < at[this.world.difficulty]; + this.h(this.random.nextFloat() < au[this.world.difficulty]); if (this.getEquipment(4) == null) { - Calendar calendar = this.world.T(); + Calendar calendar = this.world.U(); 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)); @@ -215,7 +219,7 @@ public class EntitySkeleton extends EntityMonster implements IRangedEntity { public void m() { this.goalSelector.a((PathfinderGoal) this.e); this.goalSelector.a((PathfinderGoal) this.d); - ItemStack itemstack = this.bD(); + ItemStack itemstack = this.bG(); if (itemstack != null && itemstack.id == Item.BOW.id) { this.goalSelector.a(4, this.d); @@ -224,11 +228,12 @@ public class EntitySkeleton extends EntityMonster implements IRangedEntity { } } - public void d(EntityLiving entityliving) { - EntityArrow entityarrow = new EntityArrow(this.world, this, entityliving, 1.6F, 12.0F); - int i = EnchantmentManager.getEnchantmentLevel(Enchantment.ARROW_DAMAGE.id, this.bD()); - int j = EnchantmentManager.getEnchantmentLevel(Enchantment.ARROW_KNOCKBACK.id, this.bD()); + 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()); + entityarrow.b((double) (f * 2.0F) + this.random.nextGaussian() * 0.25D + (double) ((float) this.world.difficulty * 0.11F)); if (i > 0) { entityarrow.b(entityarrow.c() + (double) i * 0.5D + 0.5D); } @@ -237,11 +242,11 @@ public class EntitySkeleton extends EntityMonster implements IRangedEntity { entityarrow.a(j); } - if (EnchantmentManager.getEnchantmentLevel(Enchantment.ARROW_FIRE.id, this.bD()) > 0 || this.getSkeletonType() == 1) { + if (EnchantmentManager.getEnchantmentLevel(Enchantment.ARROW_FIRE.id, this.bG()) > 0 || this.getSkeletonType() == 1) { entityarrow.setOnFire(100); } - this.makeSound("random.bow", 1.0F, 1.0F / (this.aB().nextFloat() * 0.4F + 0.8F)); + this.makeSound("random.bow", 1.0F, 1.0F / (this.aE().nextFloat() * 0.4F + 0.8F)); this.world.addEntity(entityarrow); } @@ -253,7 +258,7 @@ public class EntitySkeleton extends EntityMonster implements IRangedEntity { this.datawatcher.watch(13, Byte.valueOf((byte) i)); this.fireProof = i == 1; if (i == 1) { - this.a(0.72F, 2.16F); + this.a(0.72F, 2.34F); } else { this.a(0.6F, 1.8F); } diff --git a/src/main/java/net/minecraft/server/EntitySlime.java b/src/main/java/net/minecraft/server/EntitySlime.java index 8be7249847..011c5ee8b2 100644 --- a/src/main/java/net/minecraft/server/EntitySlime.java +++ b/src/main/java/net/minecraft/server/EntitySlime.java @@ -4,6 +4,7 @@ import org.bukkit.event.entity.SlimeSplitEvent; // CraftBukkit public class EntitySlime extends EntityLiving 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; @@ -36,7 +37,7 @@ public class EntitySlime extends EntityLiving implements IMonster { } this.setHealth(this.maxHealth); // CraftBukkit end - this.bd = i; + this.be = i; } public int getMaxHealth() { @@ -67,7 +68,7 @@ public class EntitySlime extends EntityLiving implements IMonster { return "mob.slime." + (this.getSize() > 1 ? "big" : "small"); } - public void j_() { + public void l_() { if (!this.world.isStatic && this.world.difficulty == 0 && this.getSize() > 0) { this.dead = true; } @@ -76,7 +77,7 @@ public class EntitySlime extends EntityLiving implements IMonster { this.d = this.c; boolean flag = this.onGround; - super.j_(); + super.l_(); int i; if (this.onGround && !flag) { @@ -92,7 +93,7 @@ public class EntitySlime extends EntityLiving implements IMonster { } if (this.o()) { - this.makeSound(this.n(), this.aX(), ((this.random.nextFloat() - this.random.nextFloat()) * 0.2F + 1.0F) / 0.8F); + this.makeSound(this.n(), this.ba(), ((this.random.nextFloat() - this.random.nextFloat()) * 0.2F + 1.0F) / 0.8F); } this.b = -0.5F; @@ -107,8 +108,8 @@ public class EntitySlime extends EntityLiving implements IMonster { } } - protected void bn() { - this.bk(); + protected void bq() { + this.bn(); EntityHuman entityhuman = this.world.findNearbyVulnerablePlayer(this, 16.0D); // CraftBukkit TODO: EntityTargetEvent if (entityhuman != null) { @@ -121,17 +122,17 @@ public class EntitySlime extends EntityLiving implements IMonster { this.jumpDelay /= 3; } - this.bF = true; + this.bG = true; if (this.q()) { - this.makeSound(this.n(), this.aX(), ((this.random.nextFloat() - this.random.nextFloat()) * 0.2F + 1.0F) * 0.8F); + this.makeSound(this.n(), this.ba(), ((this.random.nextFloat() - this.random.nextFloat()) * 0.2F + 1.0F) * 0.8F); } - this.bC = 1.0F - this.random.nextFloat() * 2.0F; - this.bD = (float) (1 * this.getSize()); + this.bD = 1.0F - this.random.nextFloat() * 2.0F; + this.bE = (float) (1 * this.getSize()); } else { - this.bF = false; + this.bG = false; if (this.onGround) { - this.bC = this.bD = 0.0F; + this.bD = this.bE = 0.0F; } } } @@ -180,7 +181,7 @@ public class EntitySlime extends EntityLiving implements IMonster { super.die(); } - public void c_(EntityHuman entityhuman) { + public void b_(EntityHuman entityhuman) { if (this.l()) { int i = this.getSize(); @@ -198,11 +199,11 @@ public class EntitySlime extends EntityLiving implements IMonster { return this.getSize(); } - protected String aZ() { + protected String bc() { return "mob.slime." + (this.getSize() > 1 ? "big" : "small"); } - protected String ba() { + protected String bd() { return "mob.slime." + (this.getSize() > 1 ? "big" : "small"); } @@ -217,7 +218,9 @@ public class EntitySlime extends EntityLiving implements IMonster { return false; } else { if (this.getSize() == 1 || this.world.difficulty > 0) { - if (this.world.getBiome(MathHelper.floor(this.locX), MathHelper.floor(this.locZ)) == BiomeBase.SWAMPLAND && this.locY > 50.0D && this.locY < 70.0D && this.world.getLightLevel(MathHelper.floor(this.locX), MathHelper.floor(this.locY), MathHelper.floor(this.locZ)) <= this.random.nextInt(8)) { + 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.v()] && this.world.getLightLevel(MathHelper.floor(this.locX), MathHelper.floor(this.locY), MathHelper.floor(this.locZ)) <= this.random.nextInt(8)) { return super.canSpawn(); } @@ -230,11 +233,11 @@ public class EntitySlime extends EntityLiving implements IMonster { } } - protected float aX() { + protected float ba() { return 0.4F * (float) this.getSize(); } - public int bp() { + public int bs() { return 0; } diff --git a/src/main/java/net/minecraft/server/EntitySmallFireball.java b/src/main/java/net/minecraft/server/EntitySmallFireball.java index a1265bfcb6..a7e7915b91 100644 --- a/src/main/java/net/minecraft/server/EntitySmallFireball.java +++ b/src/main/java/net/minecraft/server/EntitySmallFireball.java @@ -72,7 +72,7 @@ public class EntitySmallFireball extends EntityFireball { world.getServer().getPluginManager().callEvent(event); if (!event.isCancelled()) { - this.world.setTypeId(i, j, k, Block.FIRE.id); + this.world.setTypeIdUpdate(i, j, k, Block.FIRE.id); } // CraftBukkit end } @@ -82,7 +82,7 @@ public class EntitySmallFireball extends EntityFireball { } } - public boolean L() { + public boolean K() { return false; } diff --git a/src/main/java/net/minecraft/server/EntitySnowman.java b/src/main/java/net/minecraft/server/EntitySnowman.java index 5da1e6c6dc..fd88beabb9 100644 --- a/src/main/java/net/minecraft/server/EntitySnowman.java +++ b/src/main/java/net/minecraft/server/EntitySnowman.java @@ -19,7 +19,7 @@ public class EntitySnowman extends EntityGolem implements IRangedEntity { this.targetSelector.a(1, new PathfinderGoalNearestAttackableTarget(this, EntityLiving.class, 16.0F, 0, true, false, IMonster.a)); } - public boolean be() { + public boolean bh() { return true; } @@ -29,7 +29,7 @@ public class EntitySnowman extends EntityGolem implements IRangedEntity { public void c() { super.c(); - if (this.G()) { + if (this.F()) { // CraftBukkit start EntityDamageEvent event = new EntityDamageEvent(this.getBukkitEntity(), EntityDamageEvent.DamageCause.DROWNING, 1); this.world.getServer().getPluginManager().callEvent(event); @@ -94,15 +94,15 @@ public class EntitySnowman extends EntityGolem implements IRangedEntity { // CraftBukkit end } - public void d(EntityLiving entityliving) { + public void a(EntityLiving entityliving, float f) { EntitySnowball entitysnowball = new EntitySnowball(this.world, this); double d0 = entityliving.locX - this.locX; double d1 = entityliving.locY + (double) entityliving.getHeadHeight() - 1.100000023841858D - entitysnowball.locY; double d2 = entityliving.locZ - this.locZ; - float f = MathHelper.sqrt(d0 * d0 + d2 * d2) * 0.2F; + float f1 = MathHelper.sqrt(d0 * d0 + d2 * d2) * 0.2F; - entitysnowball.shoot(d0, d1 + (double) f, d2, 1.6F, 12.0F); - this.makeSound("random.bow", 1.0F, 1.0F / (this.aB().nextFloat() * 0.4F + 0.8F)); + 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.world.addEntity(entitysnowball); } } diff --git a/src/main/java/net/minecraft/server/EntitySpider.java b/src/main/java/net/minecraft/server/EntitySpider.java index 9b466d497f..7761d7178f 100644 --- a/src/main/java/net/minecraft/server/EntitySpider.java +++ b/src/main/java/net/minecraft/server/EntitySpider.java @@ -8,7 +8,7 @@ public class EntitySpider extends EntityMonster { super(world); this.texture = "/mob/spider.png"; this.a(1.4F, 0.9F); - this.bH = 0.8F; + this.bI = 0.8F; } protected void a() { @@ -16,10 +16,10 @@ public class EntitySpider extends EntityMonster { this.datawatcher.a(16, new Byte((byte) 0)); } - public void j_() { - super.j_(); + public void l_() { + super.l_(); if (!this.world.isStatic) { - this.f(this.positionChanged); + this.a(this.positionChanged); } } @@ -27,7 +27,7 @@ public class EntitySpider extends EntityMonster { return 16; } - public double X() { + public double W() { return (double) this.length * 0.75D - 0.5D; } @@ -43,15 +43,15 @@ public class EntitySpider extends EntityMonster { } } - protected String aY() { + protected String bb() { return "mob.spider.say"; } - protected String aZ() { + protected String bc() { return "mob.spider.say"; } - protected String ba() { + protected String bd() { return "mob.spider.death"; } @@ -123,7 +123,7 @@ public class EntitySpider extends EntityMonster { return this.o(); } - public void am() {} + public void al() {} public EnumMonsterType getMonsterType() { return EnumMonsterType.ARTHROPOD; @@ -137,7 +137,7 @@ public class EntitySpider extends EntityMonster { return (this.datawatcher.getByte(16) & 1) != 0; } - public void f(boolean flag) { + public void a(boolean flag) { byte b0 = this.datawatcher.getByte(16); if (flag) { @@ -149,12 +149,12 @@ public class EntitySpider extends EntityMonster { this.datawatcher.watch(16, Byte.valueOf(b0)); } - public void bG() { + public void bJ() { 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.bG(); + entityskeleton.bJ(); this.world.addEntity(entityskeleton); entityskeleton.mount(this); } diff --git a/src/main/java/net/minecraft/server/EntitySquid.java b/src/main/java/net/minecraft/server/EntitySquid.java index 961d83a4bd..30259de3b6 100644 --- a/src/main/java/net/minecraft/server/EntitySquid.java +++ b/src/main/java/net/minecraft/server/EntitySquid.java @@ -11,38 +11,38 @@ public class EntitySquid extends EntityWaterAnimal { public float h = 0.0F; public float i = 0.0F; public float j = 0.0F; - public float bJ = 0.0F; - private float bK = 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 EntitySquid(World world) { super(world); this.texture = "/mob/squid.png"; this.a(0.95F, 0.95F); - this.bL = 1.0F / (this.random.nextFloat() + 1.0F) * 0.2F; + this.bM = 1.0F / (this.random.nextFloat() + 1.0F) * 0.2F; } public int getMaxHealth() { return 10; } - protected String aY() { + protected String bb() { return null; } - protected String aZ() { + protected String bc() { return null; } - protected String ba() { + protected String bd() { return null; } - protected float aX() { + protected float ba() { return 0.4F; } @@ -63,7 +63,7 @@ public class EntitySquid extends EntityWaterAnimal { // CraftBukkit end } - public boolean H() { + public boolean G() { return this.world.a(this.boundingBox.grow(0.0D, -0.6000000238418579D, 0.0D), Material.WATER, (Entity) this); } @@ -72,44 +72,44 @@ public class EntitySquid extends EntityWaterAnimal { this.e = this.d; this.g = this.f; this.i = this.h; - this.bJ = this.j; - this.h += this.bL; + this.bK = this.j; + this.h += this.bM; if (this.h > 6.2831855F) { this.h -= 6.2831855F; if (this.random.nextInt(10) == 0) { - this.bL = 1.0F / (this.random.nextFloat() + 1.0F) * 0.2F; + this.bM = 1.0F / (this.random.nextFloat() + 1.0F) * 0.2F; } } - if (this.H()) { + 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 ((double) f > 0.75D) { - this.bK = 1.0F; - this.bM = 1.0F; + this.bL = 1.0F; + this.bN = 1.0F; } else { - this.bM *= 0.8F; + this.bN *= 0.8F; } } else { this.j = 0.0F; - this.bK *= 0.9F; - this.bM *= 0.99F; + this.bL *= 0.9F; + this.bN *= 0.99F; } if (!this.world.isStatic) { - this.motX = (double) (this.bN * this.bK); - this.motY = (double) (this.bO * this.bK); - this.motZ = (double) (this.bP * this.bK); + this.motX = (double) (this.bO * this.bL); + this.motY = (double) (this.bP * this.bL); + this.motZ = (double) (this.bQ * this.bL); } f = MathHelper.sqrt(this.motX * this.motX + this.motZ * this.motZ); // CraftBukkit - Math -> TrigMath - this.ax += (-((float) TrigMath.atan2(this.motX, this.motZ)) * 180.0F / 3.1415927F - this.ax) * 0.1F; - this.yaw = this.ax; - this.f += 3.1415927F * this.bM * 1.5F; + 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; // CraftBukkit - Math -> TrigMath this.d += (-((float) TrigMath.atan2((double) f, this.motY)) * 180.0F / 3.1415927F - this.d) * 0.1F; } else { @@ -129,19 +129,19 @@ public class EntitySquid extends EntityWaterAnimal { this.move(this.motX, this.motY, this.motZ); } - protected void bn() { - ++this.bB; - if (this.bB > 100) { - this.bN = this.bO = this.bP = 0.0F; - } else if (this.random.nextInt(50) == 0 || !this.ad || this.bN == 0.0F && this.bO == 0.0F && this.bP == 0.0F) { + 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.ae || this.bO == 0.0F && this.bP == 0.0F && this.bQ == 0.0F) { float f = this.random.nextFloat() * 3.1415927F * 2.0F; - this.bN = MathHelper.cos(f) * 0.2F; - this.bO = -0.1F + this.random.nextFloat() * 0.2F; - this.bP = MathHelper.sin(f) * 0.2F; + this.bO = MathHelper.cos(f) * 0.2F; + this.bP = -0.1F + this.random.nextFloat() * 0.2F; + this.bQ = MathHelper.sin(f) * 0.2F; } - this.bk(); + this.bn(); } public boolean canSpawn() { diff --git a/src/main/java/net/minecraft/server/EntityTNTPrimed.java b/src/main/java/net/minecraft/server/EntityTNTPrimed.java index 8db94ffe47..41139997ad 100644 --- a/src/main/java/net/minecraft/server/EntityTNTPrimed.java +++ b/src/main/java/net/minecraft/server/EntityTNTPrimed.java @@ -5,6 +5,7 @@ import org.bukkit.event.entity.ExplosionPrimeEvent; // CraftBukkit public class EntityTNTPrimed extends Entity { public int fuseTicks; + private EntityLiving source; public float yield = 4; // CraftBukkit public boolean isIncendiary = false; // CraftBukkit @@ -16,7 +17,7 @@ public class EntityTNTPrimed extends Entity { this.height = this.length / 2.0F; } - public EntityTNTPrimed(World world, double d0, double d1, double d2) { + public EntityTNTPrimed(World world, double d0, double d1, double d2, EntityLiving entityliving) { this(world); this.setPosition(d0, d1, d2); float f = (float) (Math.random() * 3.1415927410125732D * 2.0D); @@ -28,6 +29,7 @@ public class EntityTNTPrimed extends Entity { this.lastX = d0; this.lastY = d1; this.lastZ = d2; + this.source = entityliving; } protected void a() {} @@ -36,11 +38,11 @@ public class EntityTNTPrimed extends Entity { return false; } - public boolean L() { + public boolean K() { return !this.dead; } - public void j_() { + public void l_() { this.lastX = this.locX; this.lastY = this.locY; this.lastZ = this.locZ; @@ -90,4 +92,8 @@ public class EntityTNTPrimed extends Entity { protected void a(NBTTagCompound nbttagcompound) { this.fuseTicks = nbttagcompound.getByte("Fuse"); } + + public EntityLiving getSource() { + return this.source; + } } diff --git a/src/main/java/net/minecraft/server/EntityTracker.java b/src/main/java/net/minecraft/server/EntityTracker.java index d2d6ff0d73..cfcd647a84 100644 --- a/src/main/java/net/minecraft/server/EntityTracker.java +++ b/src/main/java/net/minecraft/server/EntityTracker.java @@ -4,6 +4,7 @@ import java.util.ArrayList; import java.util.HashSet; import java.util.Iterator; import java.util.Set; +import java.util.concurrent.Callable; public class EntityTracker { @@ -55,7 +56,7 @@ public class EntityTracker { this.addEntity(entity, 64, 10, true); } else if (entity instanceof EntityItem) { this.addEntity(entity, 64, 20, true); - } else if (entity instanceof EntityMinecart) { + } else if (entity instanceof EntityMinecartAbstract) { this.addEntity(entity, 80, 3, true); } else if (entity instanceof EntityBoat) { this.addEntity(entity, 80, 3, true); @@ -94,15 +95,24 @@ public class EntityTracker { i = this.d; } - if (this.trackedEntities.b(entity.id)) { - // CraftBukkit - removed exception throw as tracking an already tracked entity theoretically shouldn't cause any issues. - // throw new IllegalStateException("Entity is already tracked!"); - } else { - EntityTrackerEntry entitytrackerentry = new EntityTrackerEntry(entity, i, j, flag); + try { + if (this.trackedEntities.b(entity.id)) { + throw new IllegalStateException("Entity is already tracked!"); + } else { + EntityTrackerEntry entitytrackerentry = new EntityTrackerEntry(entity, i, j, flag); - this.b.add(entitytrackerentry); - this.trackedEntities.a(entity.id, entitytrackerentry); - entitytrackerentry.scanPlayers(this.world.players); + this.b.add(entitytrackerentry); + this.trackedEntities.a(entity.id, entitytrackerentry); + entitytrackerentry.scanPlayers(this.world.players); + } + } catch (Throwable throwable) { + CrashReport crashreport = CrashReport.a(throwable, "Adding entity to track"); + CrashReportSystemDetails crashreportsystemdetails = crashreport.a("Entity To Track"); + + crashreportsystemdetails.a("Tracking range", (i + " blocks")); + crashreportsystemdetails.a("Update interval", (Callable) (new CrashReportEntityTrackerUpdateInterval(this, j))); + entity.a(crashreportsystemdetails); + throw new ReportedException(crashreport); } } @@ -190,7 +200,7 @@ public class EntityTracker { while (iterator.hasNext()) { EntityTrackerEntry entitytrackerentry = (EntityTrackerEntry) iterator.next(); - if (entitytrackerentry.tracker != entityplayer && entitytrackerentry.tracker.ai == chunk.x && entitytrackerentry.tracker.ak == chunk.z) { + if (entitytrackerentry.tracker != entityplayer && entitytrackerentry.tracker.aj == chunk.x && entitytrackerentry.tracker.al == chunk.z) { entitytrackerentry.updatePlayer(entityplayer); } } diff --git a/src/main/java/net/minecraft/server/EntityTrackerEntry.java b/src/main/java/net/minecraft/server/EntityTrackerEntry.java index a026c4ce60..4948f23d3c 100644 --- a/src/main/java/net/minecraft/server/EntityTrackerEntry.java +++ b/src/main/java/net/minecraft/server/EntityTrackerEntry.java @@ -46,7 +46,7 @@ public class EntityTrackerEntry { this.zLoc = MathHelper.floor(entity.locZ * 32.0D); this.yRot = MathHelper.d(entity.yaw * 256.0F / 360.0F); this.xRot = MathHelper.d(entity.pitch * 256.0F / 360.0F); - this.i = MathHelper.d(entity.ap() * 256.0F / 360.0F); + this.i = MathHelper.d(entity.ao() * 256.0F / 360.0F); } public boolean equals(Object object) { @@ -68,7 +68,7 @@ public class EntityTrackerEntry { this.scanPlayers(list); } - if (this.v != this.tracker.vehicle) { + if (this.v != this.tracker.vehicle || this.tracker.vehicle != null && this.m % 60 == 0) { this.v = this.tracker.vehicle; this.broadcast(new Packet39AttachEntity(this.tracker, this.tracker.vehicle)); } @@ -101,15 +101,15 @@ public class EntityTrackerEntry { if (i9.a()) { this.broadcastIncludingSelf(new Packet40EntityMetadata(this.tracker.id, i9, false)); } - } else if (this.m++ % this.c == 0 || this.tracker.am) { + } else if (this.m % this.c == 0 || this.tracker.an || this.tracker.getDataWatcher().a()) { int i; int j; if (this.tracker.vehicle == null) { ++this.u; - i = this.tracker.as.a(this.tracker.locX); + i = this.tracker.at.a(this.tracker.locX); j = MathHelper.floor(this.tracker.locY * 32.0D); - int k = this.tracker.as.a(this.tracker.locZ); + int k = this.tracker.at.a(this.tracker.locZ); int l = MathHelper.d(this.tracker.yaw * 256.0F / 360.0F); int i1 = MathHelper.d(this.tracker.pitch * 256.0F / 360.0F); int j1 = i - this.xLoc; @@ -200,9 +200,9 @@ public class EntityTrackerEntry { this.xRot = j; } - this.xLoc = this.tracker.as.a(this.tracker.locX); + this.xLoc = this.tracker.at.a(this.tracker.locX); this.yLoc = MathHelper.floor(this.tracker.locY * 32.0D); - this.zLoc = this.tracker.as.a(this.tracker.locZ); + this.zLoc = this.tracker.at.a(this.tracker.locZ); DataWatcher datawatcher2 = this.tracker.getDataWatcher(); if (datawatcher2.a()) { @@ -212,15 +212,16 @@ public class EntityTrackerEntry { this.w = true; } - i = MathHelper.d(this.tracker.ap() * 256.0F / 360.0F); + i = MathHelper.d(this.tracker.ao() * 256.0F / 360.0F); if (Math.abs(i - this.i) >= 4) { this.broadcast(new Packet35EntityHeadRotation(this.tracker.id, (byte) i)); this.i = i; } - this.tracker.am = false; + this.tracker.an = false; } + ++this.m; if (this.tracker.velocityChanged) { // CraftBukkit start - create PlayerVelocity event boolean cancelled = false; @@ -288,7 +289,7 @@ public class EntityTrackerEntry { double d1 = entityplayer.locZ - (double) (this.zLoc / 32); if (d0 >= (double) (-this.b) && d0 <= (double) this.b && d1 >= (double) (-this.b) && d1 <= (double) this.b) { - if (!this.trackedPlayers.contains(entityplayer) && this.d(entityplayer)) { + if (!this.trackedPlayers.contains(entityplayer) && (this.d(entityplayer) || this.tracker.p)) { // CraftBukkit start if (this.tracker instanceof EntityPlayer) { Player player = ((EntityPlayer) this.tracker).getBukkitEntity(); @@ -338,7 +339,7 @@ public class EntityTrackerEntry { } // CraftBukkit start - Fix for nonsensical head yaw - this.i = MathHelper.d(this.tracker.ap() * 256.0F / 360.0F); // tracker.am() should be getHeadRotation + this.i = MathHelper.d(this.tracker.ao() * 256.0F / 360.0F); // tracker.ao() should be getHeadRotation this.broadcast(new Packet35EntityHeadRotation(this.tracker.id, (byte) i)); // CraftBukkit end @@ -361,7 +362,7 @@ public class EntityTrackerEntry { } private boolean d(EntityPlayer entityplayer) { - return entityplayer.p().getPlayerChunkMap().a(entityplayer, this.tracker.ai, this.tracker.ak); + return entityplayer.o().getPlayerChunkMap().a(entityplayer, this.tracker.aj, this.tracker.al); } public void scanPlayers(List list) { @@ -373,7 +374,7 @@ public class EntityTrackerEntry { private Packet b() { if (this.tracker.dead) { // CraftBukkit start - remove useless error spam, just return - // System.out.println("Fetching addPacket for removed entity"); + // this.tracker.world.getLogger().warning("Fetching addPacket for removed entity"); return null; // CraftBukkit end } @@ -382,101 +383,87 @@ public class EntityTrackerEntry { return new Packet23VehicleSpawn(this.tracker, 2, 1); } else if (this.tracker instanceof EntityPlayer) { return new Packet20NamedEntitySpawn((EntityHuman) this.tracker); - } else { - if (this.tracker instanceof EntityMinecart) { - EntityMinecart entityminecart = (EntityMinecart) this.tracker; + } else if (this.tracker instanceof EntityMinecartAbstract) { + EntityMinecartAbstract entityminecartabstract = (EntityMinecartAbstract) this.tracker; - if (entityminecart.type == 0) { - return new Packet23VehicleSpawn(this.tracker, 10); - } + return new Packet23VehicleSpawn(this.tracker, 10, entityminecartabstract.getType()); + } else if (this.tracker instanceof EntityBoat) { + return new Packet23VehicleSpawn(this.tracker, 1); + } else if (!(this.tracker instanceof IAnimal) && !(this.tracker instanceof EntityEnderDragon)) { + if (this.tracker instanceof EntityFishingHook) { + EntityHuman entityhuman = ((EntityFishingHook) this.tracker).owner; - if (entityminecart.type == 1) { - return new Packet23VehicleSpawn(this.tracker, 11); - } + return new Packet23VehicleSpawn(this.tracker, 90, entityhuman != null ? entityhuman.id : this.tracker.id); + } else if (this.tracker instanceof EntityArrow) { + Entity entity = ((EntityArrow) this.tracker).shooter; - if (entityminecart.type == 2) { - return new Packet23VehicleSpawn(this.tracker, 12); - } - } - - if (this.tracker instanceof EntityBoat) { - return new Packet23VehicleSpawn(this.tracker, 1); - } else if (!(this.tracker instanceof IAnimal) && !(this.tracker instanceof EntityEnderDragon)) { - if (this.tracker instanceof EntityFishingHook) { - EntityHuman entityhuman = ((EntityFishingHook) this.tracker).owner; - - return new Packet23VehicleSpawn(this.tracker, 90, entityhuman != null ? entityhuman.id : this.tracker.id); - } else if (this.tracker instanceof EntityArrow) { - Entity entity = ((EntityArrow) this.tracker).shooter; - - return new Packet23VehicleSpawn(this.tracker, 60, entity != null ? entity.id : this.tracker.id); - } else if (this.tracker instanceof EntitySnowball) { - return new Packet23VehicleSpawn(this.tracker, 61); - } else if (this.tracker instanceof EntityPotion) { - return new Packet23VehicleSpawn(this.tracker, 73, ((EntityPotion) this.tracker).getPotionValue()); - } else if (this.tracker instanceof EntityThrownExpBottle) { - return new Packet23VehicleSpawn(this.tracker, 75); - } else if (this.tracker instanceof EntityEnderPearl) { - return new Packet23VehicleSpawn(this.tracker, 65); - } else if (this.tracker instanceof EntityEnderSignal) { - return new Packet23VehicleSpawn(this.tracker, 72); - } else if (this.tracker instanceof EntityFireworks) { - return new Packet23VehicleSpawn(this.tracker, 76); - } else { - Packet23VehicleSpawn packet23vehiclespawn; - - if (this.tracker instanceof EntityFireball) { - EntityFireball entityfireball = (EntityFireball) this.tracker; - - packet23vehiclespawn = null; - byte b0 = 63; - - if (this.tracker instanceof EntitySmallFireball) { - b0 = 64; - } else if (this.tracker instanceof EntityWitherSkull) { - b0 = 66; - } - - if (entityfireball.shooter != null) { - packet23vehiclespawn = new Packet23VehicleSpawn(this.tracker, b0, ((EntityFireball) this.tracker).shooter.id); - } else { - packet23vehiclespawn = new Packet23VehicleSpawn(this.tracker, b0, 0); - } - - packet23vehiclespawn.e = (int) (entityfireball.dirX * 8000.0D); - packet23vehiclespawn.f = (int) (entityfireball.dirY * 8000.0D); - packet23vehiclespawn.g = (int) (entityfireball.dirZ * 8000.0D); - return packet23vehiclespawn; - } else if (this.tracker instanceof EntityEgg) { - return new Packet23VehicleSpawn(this.tracker, 62); - } else if (this.tracker instanceof EntityTNTPrimed) { - return new Packet23VehicleSpawn(this.tracker, 50); - } else if (this.tracker instanceof EntityEnderCrystal) { - return new Packet23VehicleSpawn(this.tracker, 51); - } else if (this.tracker instanceof EntityFallingBlock) { - EntityFallingBlock entityfallingblock = (EntityFallingBlock) this.tracker; - - return new Packet23VehicleSpawn(this.tracker, 70, entityfallingblock.id | entityfallingblock.data << 16); - } else if (this.tracker instanceof EntityPainting) { - return new Packet25EntityPainting((EntityPainting) this.tracker); - } else if (this.tracker instanceof EntityItemFrame) { - EntityItemFrame entityitemframe = (EntityItemFrame) this.tracker; - - packet23vehiclespawn = new Packet23VehicleSpawn(this.tracker, 71, entityitemframe.direction); - packet23vehiclespawn.b = MathHelper.d((float) (entityitemframe.x * 32)); - packet23vehiclespawn.c = MathHelper.d((float) (entityitemframe.y * 32)); - packet23vehiclespawn.d = MathHelper.d((float) (entityitemframe.z * 32)); - return packet23vehiclespawn; - } else if (this.tracker instanceof EntityExperienceOrb) { - return new Packet26AddExpOrb((EntityExperienceOrb) this.tracker); - } else { - throw new IllegalArgumentException("Don\'t know how to add " + this.tracker.getClass() + "!"); - } - } + return new Packet23VehicleSpawn(this.tracker, 60, entity != null ? entity.id : this.tracker.id); + } else if (this.tracker instanceof EntitySnowball) { + return new Packet23VehicleSpawn(this.tracker, 61); + } else if (this.tracker instanceof EntityPotion) { + return new Packet23VehicleSpawn(this.tracker, 73, ((EntityPotion) this.tracker).getPotionValue()); + } else if (this.tracker instanceof EntityThrownExpBottle) { + return new Packet23VehicleSpawn(this.tracker, 75); + } else if (this.tracker instanceof EntityEnderPearl) { + return new Packet23VehicleSpawn(this.tracker, 65); + } else if (this.tracker instanceof EntityEnderSignal) { + return new Packet23VehicleSpawn(this.tracker, 72); + } else if (this.tracker instanceof EntityFireworks) { + return new Packet23VehicleSpawn(this.tracker, 76); } else { - this.i = MathHelper.d(this.tracker.ap() * 256.0F / 360.0F); - return new Packet24MobSpawn((EntityLiving) this.tracker); + Packet23VehicleSpawn packet23vehiclespawn; + + if (this.tracker instanceof EntityFireball) { + EntityFireball entityfireball = (EntityFireball) this.tracker; + + packet23vehiclespawn = null; + byte b0 = 63; + + if (this.tracker instanceof EntitySmallFireball) { + b0 = 64; + } else if (this.tracker instanceof EntityWitherSkull) { + b0 = 66; + } + + if (entityfireball.shooter != null) { + packet23vehiclespawn = new Packet23VehicleSpawn(this.tracker, b0, ((EntityFireball) this.tracker).shooter.id); + } else { + packet23vehiclespawn = new Packet23VehicleSpawn(this.tracker, b0, 0); + } + + packet23vehiclespawn.e = (int) (entityfireball.dirX * 8000.0D); + packet23vehiclespawn.f = (int) (entityfireball.dirY * 8000.0D); + packet23vehiclespawn.g = (int) (entityfireball.dirZ * 8000.0D); + return packet23vehiclespawn; + } else if (this.tracker instanceof EntityEgg) { + return new Packet23VehicleSpawn(this.tracker, 62); + } else if (this.tracker instanceof EntityTNTPrimed) { + return new Packet23VehicleSpawn(this.tracker, 50); + } else if (this.tracker instanceof EntityEnderCrystal) { + return new Packet23VehicleSpawn(this.tracker, 51); + } else if (this.tracker instanceof EntityFallingBlock) { + EntityFallingBlock entityfallingblock = (EntityFallingBlock) this.tracker; + + return new Packet23VehicleSpawn(this.tracker, 70, entityfallingblock.id | entityfallingblock.data << 16); + } else if (this.tracker instanceof EntityPainting) { + return new Packet25EntityPainting((EntityPainting) this.tracker); + } else if (this.tracker instanceof EntityItemFrame) { + EntityItemFrame entityitemframe = (EntityItemFrame) this.tracker; + + packet23vehiclespawn = new Packet23VehicleSpawn(this.tracker, 71, entityitemframe.direction); + packet23vehiclespawn.b = MathHelper.d((float) (entityitemframe.x * 32)); + packet23vehiclespawn.c = MathHelper.d((float) (entityitemframe.y * 32)); + packet23vehiclespawn.d = MathHelper.d((float) (entityitemframe.z * 32)); + return packet23vehiclespawn; + } else if (this.tracker instanceof EntityExperienceOrb) { + return new Packet26AddExpOrb((EntityExperienceOrb) this.tracker); + } else { + throw new IllegalArgumentException("Don\'t know how to add " + this.tracker.getClass() + "!"); + } } + } else { + this.i = MathHelper.d(this.tracker.ao() * 256.0F / 360.0F); + return new Packet24MobSpawn((EntityLiving) this.tracker); } } diff --git a/src/main/java/net/minecraft/server/EntityWitch.java b/src/main/java/net/minecraft/server/EntityWitch.java index daa9845e59..e44d7bee8a 100644 --- a/src/main/java/net/minecraft/server/EntityWitch.java +++ b/src/main/java/net/minecraft/server/EntityWitch.java @@ -11,10 +11,10 @@ public class EntityWitch extends EntityMonster implements IRangedEntity { public EntityWitch(World world) { super(world); this.texture = "/mob/villager/witch.png"; - this.bH = 0.25F; + this.bI = 0.25F; this.goalSelector.a(1, new PathfinderGoalFloat(this)); - this.goalSelector.a(2, new PathfinderGoalArrowAttack(this, this.bH, 60, 10.0F)); - this.goalSelector.a(2, new PathfinderGoalRandomStroll(this, this.bH)); + this.goalSelector.a(2, new PathfinderGoalArrowAttack(this, this.bI, 60, 10.0F)); + this.goalSelector.a(2, new PathfinderGoalRandomStroll(this, this.bI)); 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)); @@ -26,19 +26,19 @@ public class EntityWitch extends EntityMonster implements IRangedEntity { this.getDataWatcher().a(21, Byte.valueOf((byte) 0)); } - protected String aY() { + protected String bb() { return "mob.witch.idle"; } - protected String aZ() { + protected String bc() { return "mob.witch.hurt"; } - protected String ba() { + protected String bd() { return "mob.witch.death"; } - public void f(boolean flag) { + public void a(boolean flag) { this.getDataWatcher().watch(21, Byte.valueOf((byte) (flag ? 1 : 0))); } @@ -50,7 +50,7 @@ public class EntityWitch extends EntityMonster implements IRangedEntity { return 26; } - public boolean be() { + public boolean bh() { return true; } @@ -58,8 +58,8 @@ public class EntityWitch extends EntityMonster implements IRangedEntity { if (!this.world.isStatic) { if (this.m()) { if (this.e-- <= 0) { - this.f(false); - ItemStack itemstack = this.bD(); + this.a(false); + ItemStack itemstack = this.bG(); this.setEquipment(0, (ItemStack) null); if (itemstack != null && itemstack.id == Item.POTION.id) { @@ -91,8 +91,8 @@ public class EntityWitch extends EntityMonster implements IRangedEntity { if (short1 > -1) { this.setEquipment(0, new ItemStack(Item.POTION, 1, short1)); - this.e = this.bD().m(); - this.f(true); + this.e = this.bG().n(); + this.a(true); } } @@ -110,15 +110,15 @@ public class EntityWitch extends EntityMonster implements IRangedEntity { i = 0; } - if (damagesource.o()) { + if (damagesource.q()) { i = (int) ((double) i * 0.15D); } return i; } - public float bB() { - float f = super.bB(); + public float bE() { + float f = super.bE(); if (this.m()) { f *= 0.75F; @@ -148,7 +148,7 @@ public class EntityWitch extends EntityMonster implements IRangedEntity { // CraftBukkit end } - public void d(EntityLiving entityliving) { + public void a(EntityLiving entityliving, float f) { if (!this.m()) { EntityPotion entitypotion = new EntityPotion(this.world, this, 32732); @@ -156,17 +156,17 @@ public class EntityWitch extends EntityMonster implements IRangedEntity { double d0 = entityliving.locX + entityliving.motX - this.locX; double d1 = entityliving.locY + (double) entityliving.getHeadHeight() - 1.100000023841858D - this.locY; double d2 = entityliving.locZ + entityliving.motZ - this.locZ; - float f = MathHelper.sqrt(d0 * d0 + d2 * d2); + float f1 = MathHelper.sqrt(d0 * d0 + d2 * d2); - if (f >= 8.0F && !entityliving.hasEffect(MobEffectList.SLOWER_MOVEMENT)) { + if (f1 >= 8.0F && !entityliving.hasEffect(MobEffectList.SLOWER_MOVEMENT)) { entitypotion.setPotionValue(32698); } else if (entityliving.getHealth() >= 8 && !entityliving.hasEffect(MobEffectList.POISON)) { entitypotion.setPotionValue(32660); - } else if (f <= 3.0F && !entityliving.hasEffect(MobEffectList.WEAKNESS) && this.random.nextFloat() < 0.25F) { + } else if (f1 <= 3.0F && !entityliving.hasEffect(MobEffectList.WEAKNESS) && this.random.nextFloat() < 0.25F) { entitypotion.setPotionValue(32696); } - entitypotion.shoot(d0, d1 + (double) (f * 0.2F), d2, 0.75F, 8.0F); + entitypotion.shoot(d0, d1 + (double) (f1 * 0.2F), d2, 0.75F, 8.0F); this.world.addEntity(entitypotion); } } diff --git a/src/main/java/net/minecraft/server/EntityWither.java b/src/main/java/net/minecraft/server/EntityWither.java index 2dc6e98f72..1790a44d96 100644 --- a/src/main/java/net/minecraft/server/EntityWither.java +++ b/src/main/java/net/minecraft/server/EntityWither.java @@ -16,7 +16,7 @@ public class EntityWither extends EntityMonster implements IRangedEntity { private int[] h = new int[2]; private int[] i = new int[2]; private int j; - private static final IEntitySelector bJ = new EntitySelectorNotUndead(); + private static final IEntitySelector bK = new EntitySelectorNotUndead(); public EntityWither(World world) { super(world); @@ -24,16 +24,16 @@ public class EntityWither extends EntityMonster implements IRangedEntity { this.texture = "/mob/wither.png"; this.a(0.9F, 4.0F); this.fireProof = true; - this.bH = 0.6F; + this.bI = 0.6F; this.getNavigation().e(true); this.goalSelector.a(0, new PathfinderGoalFloat(this)); - this.goalSelector.a(2, new PathfinderGoalArrowAttack(this, this.bH, 40, 20.0F)); - this.goalSelector.a(5, new PathfinderGoalRandomStroll(this, this.bH)); + this.goalSelector.a(2, new PathfinderGoalArrowAttack(this, this.bI, 40, 20.0F)); + this.goalSelector.a(5, new PathfinderGoalRandomStroll(this, this.bI)); 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, bJ)); - this.bd = 50; + this.targetSelector.a(2, new PathfinderGoalNearestAttackableTarget(this, EntityLiving.class, 30.0F, 0, false, false, bK)); + this.be = 50; } protected void a() { @@ -56,15 +56,15 @@ public class EntityWither extends EntityMonster implements IRangedEntity { this.datawatcher.watch(16, Integer.valueOf(this.health)); } - protected String aY() { + protected String bb() { return "mob.wither.idle"; } - protected String aZ() { + protected String bc() { return "mob.wither.hurt"; } - protected String ba() { + protected String bd() { return "mob.wither.death"; } @@ -139,7 +139,7 @@ public class EntityWither extends EntityMonster implements IRangedEntity { this.d[i] = this.b(this.d[i], f1, 40.0F); this.e[i] = this.b(this.e[i], f, 10.0F); } else { - this.e[i] = this.b(this.e[i], this.ax, 10.0F); + this.e[i] = this.b(this.e[i], this.ay, 10.0F); } } @@ -163,7 +163,7 @@ public class EntityWither extends EntityMonster implements IRangedEntity { } } - protected void bl() { + protected void bo() { int i; if (this.n() > 0) { @@ -178,7 +178,7 @@ public class EntityWither extends EntityMonster implements IRangedEntity { } // CraftBukkit end - this.world.e(1013, (int) this.locX, (int) this.locY, (int) this.locZ, 0); + this.world.d(1013, (int) this.locX, (int) this.locY, (int) this.locZ, 0); } this.t(i); @@ -186,7 +186,7 @@ public class EntityWither extends EntityMonster implements IRangedEntity { this.heal(10, EntityRegainHealthEvent.RegainReason.WITHER_SPAWN); // CraftBukkit } } else { - super.bl(); + super.bo(); int j; @@ -222,7 +222,7 @@ public class EntityWither extends EntityMonster implements IRangedEntity { this.c(i, 0); } } else { - List list = this.world.a(EntityLiving.class, this.boundingBox.grow(20.0D, 8.0D, 20.0D), bJ); + List list = this.world.a(EntityLiving.class, this.boundingBox.grow(20.0D, 8.0D, 20.0D), bK); for (int i1 = 0; i1 < 10 && !list.isEmpty(); ++i1) { EntityLiving entityliving = (EntityLiving) list.get(this.random.nextInt(list.size())); @@ -267,18 +267,13 @@ public class EntityWither extends EntityMonster implements IRangedEntity { int i3 = this.world.getTypeId(j2, k2, l2); if (i3 > 0 && i3 != Block.BEDROCK.id && i3 != Block.ENDER_PORTAL.id && i3 != Block.ENDER_PORTAL_FRAME.id) { - int j3 = this.world.getData(j2, k2, l2); - // CraftBukkit start if (org.bukkit.craftbukkit.event.CraftEventFactory.callEntityChangeBlockEvent(this, j2, k2, l2, 0, 0).isCancelled()) { continue; } // CraftBukkit end - this.world.triggerEffect(2001, j2, k2, l2, i3 + (j3 << 12)); - Block.byId[i3].c(this.world, j2, k2, l2, j3, 0); - this.world.setTypeId(j2, k2, l2, 0); - flag = true; + flag = this.world.setAir(j2, k2, l2, true) || flag; } } } @@ -301,9 +296,9 @@ public class EntityWither extends EntityMonster implements IRangedEntity { this.setHealth(this.getMaxHealth() / 3); } - public void am() {} + public void al() {} - public int aW() { + public int aZ() { return 4; } @@ -311,7 +306,7 @@ public class EntityWither extends EntityMonster implements IRangedEntity { if (i <= 0) { return this.locX; } else { - float f = (this.ax + (float) (180 * (i - 1))) / 180.0F * 3.1415927F; + float f = (this.ay + (float) (180 * (i - 1))) / 180.0F * 3.1415927F; float f1 = MathHelper.cos(f); return this.locX + (double) f1 * 1.3D; @@ -326,7 +321,7 @@ public class EntityWither extends EntityMonster implements IRangedEntity { if (i <= 0) { return this.locZ; } else { - float f = (this.ax + (float) (180 * (i - 1))) / 180.0F * 3.1415927F; + float f = (this.ay + (float) (180 * (i - 1))) / 180.0F * 3.1415927F; float f1 = MathHelper.sin(f); return this.locZ + (double) f1 * 1.3D; @@ -362,7 +357,7 @@ public class EntityWither extends EntityMonster implements IRangedEntity { EntityWitherSkull entitywitherskull = new EntityWitherSkull(this.world, this, d6, d7, d8); if (flag) { - entitywitherskull.e(true); + entitywitherskull.a(true); } entitywitherskull.locY = d4; @@ -371,7 +366,7 @@ public class EntityWither extends EntityMonster implements IRangedEntity { this.world.addEntity(entitywitherskull); } - public void d(EntityLiving entityliving) { + public void a(EntityLiving entityliving, float f) { this.a(0, entityliving); } @@ -386,7 +381,7 @@ public class EntityWither extends EntityMonster implements IRangedEntity { Entity entity; if (this.o()) { - entity = damagesource.f(); + entity = damagesource.h(); if (entity instanceof EntityArrow) { return false; } @@ -417,11 +412,11 @@ public class EntityWither extends EntityMonster implements IRangedEntity { // CraftBukkit end } - protected void bk() { - this.bB = 0; + protected void bn() { + this.bC = 0; } - public boolean L() { + public boolean K() { return !this.dead; } @@ -433,7 +428,7 @@ public class EntityWither extends EntityMonster implements IRangedEntity { public void addEffect(MobEffect mobeffect) {} - protected boolean be() { + protected boolean bh() { return true; } @@ -464,4 +459,8 @@ public class EntityWither extends EntityMonster implements IRangedEntity { public EnumMonsterType getMonsterType() { return EnumMonsterType.UNDEAD; } + + public void mount(Entity entity) { + this.vehicle = null; + } } diff --git a/src/main/java/net/minecraft/server/EntityWitherSkull.java b/src/main/java/net/minecraft/server/EntityWitherSkull.java index a1fcdb1d32..2afb9761c7 100644 --- a/src/main/java/net/minecraft/server/EntityWitherSkull.java +++ b/src/main/java/net/minecraft/server/EntityWitherSkull.java @@ -25,8 +25,8 @@ public class EntityWitherSkull extends EntityFireball { return false; } - public float a(Explosion explosion, Block block, int i, int j, int k) { - float f = super.a(explosion, block, i, j, k); + public float a(Explosion explosion, World world, int i, int j, int k, Block block) { + float f = super.a(explosion, world, i, j, k, block); if (this.d() && block != Block.BEDROCK && block != Block.ENDER_PORTAL && block != Block.ENDER_PORTAL_FRAME) { f = Math.min(0.8F, f); @@ -76,7 +76,7 @@ public class EntityWitherSkull extends EntityFireball { } } - public boolean L() { + public boolean K() { return false; } @@ -92,7 +92,7 @@ public class EntityWitherSkull extends EntityFireball { return this.datawatcher.getByte(10) == 1; } - public void e(boolean flag) { + public void a(boolean flag) { this.datawatcher.watch(10, Byte.valueOf((byte) (flag ? 1 : 0))); } } diff --git a/src/main/java/net/minecraft/server/EntityWolf.java b/src/main/java/net/minecraft/server/EntityWolf.java index d413d8e888..158084420b 100644 --- a/src/main/java/net/minecraft/server/EntityWolf.java +++ b/src/main/java/net/minecraft/server/EntityWolf.java @@ -13,15 +13,15 @@ public class EntityWolf extends EntityTameableAnimal { super(world); this.texture = "/mob/wolf.png"; this.a(0.6F, 0.8F); - this.bH = 0.3F; + this.bI = 0.3F; this.getNavigation().a(true); this.goalSelector.a(1, new PathfinderGoalFloat(this)); this.goalSelector.a(2, this.d); this.goalSelector.a(3, new PathfinderGoalLeapAtTarget(this, 0.4F)); - this.goalSelector.a(4, new PathfinderGoalMeleeAttack(this, this.bH, true)); - this.goalSelector.a(5, new PathfinderGoalFollowOwner(this, this.bH, 10.0F, 2.0F)); - this.goalSelector.a(6, new PathfinderGoalBreed(this, this.bH)); - this.goalSelector.a(7, new PathfinderGoalRandomStroll(this, this.bH)); + 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(8, new PathfinderGoalBeg(this, 8.0F)); this.goalSelector.a(9, new PathfinderGoalLookAtPlayer(this, EntityHuman.class, 8.0F)); this.goalSelector.a(9, new PathfinderGoalRandomLookaround(this)); @@ -31,7 +31,7 @@ public class EntityWolf extends EntityTameableAnimal { this.targetSelector.a(4, new PathfinderGoalRandomTargetNonTamed(this, EntitySheep.class, 16.0F, 200, false)); } - public boolean be() { + public boolean bh() { return true; } @@ -42,7 +42,7 @@ public class EntityWolf extends EntityTameableAnimal { } } - protected void bm() { + protected void bp() { this.datawatcher.watch(18, Integer.valueOf(this.getScaledHealth())); // CraftBukkit - this.getHealth() -> this.getScaledHealth() } @@ -54,7 +54,7 @@ public class EntityWolf extends EntityTameableAnimal { super.a(); this.datawatcher.a(18, new Integer(this.getHealth())); this.datawatcher.a(19, new Byte((byte) 0)); - this.datawatcher.a(20, new Byte((byte) BlockCloth.e_(1))); + this.datawatcher.a(20, new Byte((byte) BlockCloth.g_(1))); } protected void a(int i, int j, int k, int l) { @@ -80,20 +80,20 @@ public class EntityWolf extends EntityTameableAnimal { return this.isAngry() && !this.isTamed(); } - protected String aY() { + protected String bb() { // 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"); } - protected String aZ() { + protected String bc() { return "mob.wolf.hurt"; } - protected String ba() { + protected String bd() { return "mob.wolf.death"; } - protected float aX() { + protected float ba() { return 0.4F; } @@ -111,27 +111,27 @@ public class EntityWolf extends EntityTameableAnimal { } } - public void j_() { - super.j_(); + public void l_() { + super.l_(); this.f = this.e; - if (this.bM()) { + if (this.bW()) { this.e += (1.0F - this.e) * 0.4F; } else { this.e += (0.0F - this.e) * 0.4F; } - if (this.bM()) { - this.bI = 10; + if (this.bW()) { + this.bJ = 10; } - if (this.G()) { + 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.aX(), (this.random.nextFloat() - this.random.nextFloat()) * 0.2F + 1.0F); + this.makeSound("mob.wolf.shake", this.ba(), (this.random.nextFloat() - this.random.nextFloat()) * 0.2F + 1.0F); } this.j = this.i; @@ -161,8 +161,8 @@ public class EntityWolf extends EntityTameableAnimal { return this.length * 0.8F; } - public int bp() { - return this.isSitting() ? 20 : super.bp(); + public int bs() { + return this.isSitting() ? 20 : super.bs(); } public boolean damageEntity(DamageSource damagesource, int i) { @@ -186,7 +186,7 @@ public class EntityWolf extends EntityTameableAnimal { return entity.damageEntity(DamageSource.mobAttack(this), i); } - public boolean a(EntityHuman entityhuman) { + public boolean a_(EntityHuman entityhuman) { ItemStack itemstack = entityhuman.inventory.getItemInHand(); if (this.isTamed()) { @@ -207,7 +207,7 @@ public class EntityWolf extends EntityTameableAnimal { return true; } } else if (itemstack.id == Item.INK_SACK.id) { - int i = BlockCloth.e_(itemstack.getData()); + int i = BlockCloth.g_(itemstack.getData()); if (i != this.getCollarColor()) { this.setCollarColor(i); @@ -222,7 +222,7 @@ public class EntityWolf extends EntityTameableAnimal { if (entityhuman.name.equalsIgnoreCase(this.getOwnerName()) && !this.world.isStatic && !this.c(itemstack)) { this.d.setSitting(!this.isSitting()); - this.bF = false; + this.bG = false; this.setPathEntity((PathEntity) null); } } else if (itemstack != null && itemstack.id == Item.BONE.id && !this.isAngry()) { @@ -249,10 +249,10 @@ public class EntityWolf extends EntityTameableAnimal { this.setHealth(this.maxHealth); // CraftBukkit end this.setOwnerName(entityhuman.name); - this.f(true); + this.i(true); this.world.broadcastEntityEffect(this, (byte) 7); } else { - this.f(false); + this.i(false); this.world.broadcastEntityEffect(this, (byte) 6); } } @@ -260,14 +260,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()); } - public int bv() { + public int by() { return 8; } @@ -305,7 +305,7 @@ public class EntityWolf extends EntityTameableAnimal { return entitywolf; } - public void j(boolean flag) { + public void m(boolean flag) { byte b0 = this.datawatcher.getByte(19); if (flag) { @@ -329,7 +329,7 @@ public class EntityWolf extends EntityTameableAnimal { } } - public boolean bM() { + public boolean bW() { return this.datawatcher.getByte(19) == 1; } diff --git a/src/main/java/net/minecraft/server/EntityZombie.java b/src/main/java/net/minecraft/server/EntityZombie.java index 87a63e1331..da478d746c 100644 --- a/src/main/java/net/minecraft/server/EntityZombie.java +++ b/src/main/java/net/minecraft/server/EntityZombie.java @@ -11,24 +11,28 @@ public class EntityZombie extends EntityMonster { public EntityZombie(World world) { super(world); this.texture = "/mob/zombie.png"; - this.bH = 0.23F; + 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.bH, false)); - this.goalSelector.a(3, new PathfinderGoalMeleeAttack(this, EntityVillager.class, this.bH, true)); - this.goalSelector.a(4, new PathfinderGoalMoveTowardsRestriction(this, this.bH)); - this.goalSelector.a(5, new PathfinderGoalMoveThroughVillage(this, this.bH, false)); - this.goalSelector.a(6, new PathfinderGoalRandomStroll(this, this.bH)); + 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(7, 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(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)); } - public float bB() { - return super.bB() * (this.isBaby() ? 1.5F : 1.0F); + protected int ay() { + return 40; + } + + public float bE() { + return super.bE() * (this.isBaby() ? 1.5F : 1.0F); } protected void a() { @@ -42,8 +46,8 @@ public class EntityZombie extends EntityMonster { return 20; } - public int aW() { - int i = super.aW() + 2; + public int aZ() { + int i = super.aZ() + 2; if (i > 20) { i = 20; @@ -52,7 +56,7 @@ public class EntityZombie extends EntityMonster { return i; } - protected boolean be() { + protected boolean bh() { return true; } @@ -76,14 +80,14 @@ public class EntityZombie extends EntityMonster { if (this.world.u() && !this.world.isStatic && !this.isBaby()) { float f = this.c(1.0F); - if (f > 0.5F && this.random.nextFloat() * 30.0F < (f - 0.4F) * 2.0F && this.world.k(MathHelper.floor(this.locX), MathHelper.floor(this.locY), MathHelper.floor(this.locZ))) { + 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; ItemStack itemstack = this.getEquipment(4); if (itemstack != null) { - if (itemstack.f()) { - itemstack.setData(itemstack.i() + this.random.nextInt(2)); - if (itemstack.i() >= itemstack.k()) { + if (itemstack.g()) { + itemstack.setData(itemstack.j() + this.random.nextInt(2)); + if (itemstack.j() >= itemstack.l()) { this.a(itemstack); this.setEquipment(4, (ItemStack) null); } @@ -108,7 +112,7 @@ public class EntityZombie extends EntityMonster { super.c(); } - public void j_() { + public void l_() { if (!this.world.isStatic && this.o()) { int i = this.q(); @@ -118,12 +122,23 @@ public class EntityZombie extends EntityMonster { } } - super.j_(); + super.l_(); + } + + 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) { + entity.setOnFire(2 * this.world.difficulty); + } + + return flag; } public int c(Entity entity) { - ItemStack itemstack = this.bD(); - int i = 4; + ItemStack itemstack = this.bG(); + float f = (float) (this.getMaxHealth() - this.getHealth()) / (float) this.getMaxHealth(); + int i = 3 + MathHelper.d(f * 4.0F); if (itemstack != null) { i += itemstack.a((Entity) this); @@ -132,15 +147,15 @@ public class EntityZombie extends EntityMonster { return i; } - protected String aY() { + protected String bb() { return "mob.zombie.say"; } - protected String aZ() { + protected String bc() { return "mob.zombie.hurt"; } - protected String ba() { + protected String bd() { return "mob.zombie.death"; } @@ -171,8 +186,8 @@ public class EntityZombie extends EntityMonster { } // CraftBukkit end - protected void bE() { - super.bE(); + protected void bH() { + super.bH(); if (this.random.nextFloat() < (this.world.difficulty == 3 ? 0.05F : 0.01F)) { int i = this.random.nextInt(3); @@ -223,7 +238,7 @@ public class EntityZombie extends EntityMonster { entityzombie.k(entityliving); this.world.kill(entityliving); - entityzombie.bG(); + entityzombie.bJ(); entityzombie.setVillager(true); if (entityliving.isBaby()) { entityzombie.setBaby(true); @@ -234,16 +249,16 @@ public class EntityZombie extends EntityMonster { } } - public void bG() { - this.canPickUpLoot = this.random.nextFloat() < at[this.world.difficulty]; + public void bJ() { + this.h(this.random.nextFloat() < au[this.world.difficulty]); if (this.world.random.nextFloat() < 0.05F) { this.setVillager(true); } - this.bE(); - this.bF(); + this.bH(); + this.bI(); if (this.getEquipment(4) == null) { - Calendar calendar = this.world.T(); + Calendar calendar = this.world.U(); 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)); @@ -252,8 +267,8 @@ public class EntityZombie extends EntityMonster { } } - public boolean a(EntityHuman entityhuman) { - ItemStack itemstack = entityhuman.bS(); + public boolean a_(EntityHuman entityhuman) { + ItemStack itemstack = entityhuman.cb(); if (itemstack != null && itemstack.getItem() == Item.GOLDEN_APPLE && itemstack.getData() == 0 && this.isVillager() && this.hasEffect(MobEffectList.WEAKNESS)) { if (!entityhuman.abilities.canInstantlyBuild) { @@ -290,7 +305,7 @@ public class EntityZombie extends EntityMonster { EntityVillager entityvillager = new EntityVillager(this.world); entityvillager.k(this); - entityvillager.bG(); + entityvillager.bJ(); entityvillager.q(); if (this.isBaby()) { entityvillager.setAge(-24000); diff --git a/src/main/java/net/minecraft/server/Explosion.java b/src/main/java/net/minecraft/server/Explosion.java index ba2f88f0af..aa3ae585bd 100644 --- a/src/main/java/net/minecraft/server/Explosion.java +++ b/src/main/java/net/minecraft/server/Explosion.java @@ -85,12 +85,12 @@ public class Explosion { if (k1 > 0) { Block block = Block.byId[k1]; - float f3 = this.source != null ? this.source.a(this, block, l, i1, j1) : block.a(this.source); + float f3 = this.source != null ? this.source.a(this, this.world, l, i1, j1, block) : block.a(this.source); f1 -= (f3 + 0.3F) * f2; } - if (f1 > 0.0F && i1 < 256 && i1 >= 0) { // CraftBukkit - don't wrap explosions + if (f1 > 0.0F && (this.source == null || this.source.a(this, this.world, l, i1, j1, k1, f1)) && i1 < 256 && i1 >= 0) { // CraftBukkit - don't wrap explosions hashset.add(new ChunkPosition(l, i1, j1)); } @@ -143,7 +143,7 @@ public class Explosion { if (!event.isCancelled()) { damagee.setLastDamageCause(event); - entity.damageEntity(DamageSource.EXPLOSION, event.getDamage()); + entity.damageEntity(DamageSource.explosion(this), 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, event.getDamage()); + entity.damageEntity(DamageSource.explosion(this), event.getDamage()); entity.motX += d0 * d10; entity.motY += d1 * d10; @@ -272,11 +272,8 @@ public class Explosion { block.dropNaturally(this.world, i, j, k, this.world.getData(i, j, k), event.getYield(), 0); } - if (this.world.setRawTypeIdAndData(i, j, k, 0, 0, this.world.isStatic)) { - this.world.applyPhysics(i, j, k, 0); - } - - block.wasExploded(this.world, i, j, k); + this.world.setTypeIdAndData(i, j, k, 0, 0, 3); + block.wasExploded(this.world, i, j, k, this); } } } @@ -292,8 +289,8 @@ public class Explosion { l = this.world.getTypeId(i, j, k); int i1 = this.world.getTypeId(i, j - 1, k); - if (l == 0 && Block.q[i1] && this.j.nextInt(3) == 0) { - this.world.setTypeId(i, j, k, Block.FIRE.id); + if (l == 0 && Block.s[i1] && this.j.nextInt(3) == 0) { + this.world.setTypeIdUpdate(i, j, k, Block.FIRE.id); } } } @@ -302,4 +299,8 @@ public class Explosion { public Map b() { return this.l; } + + public EntityLiving c() { + return this.source == null ? null : (this.source instanceof EntityTNTPrimed ? ((EntityTNTPrimed) this.source).getSource() : (this.source instanceof EntityLiving ? (EntityLiving) this.source : null)); + } } diff --git a/src/main/java/net/minecraft/server/FoodMetaData.java b/src/main/java/net/minecraft/server/FoodMetaData.java index c311f57e9d..40bf6decf2 100644 --- a/src/main/java/net/minecraft/server/FoodMetaData.java +++ b/src/main/java/net/minecraft/server/FoodMetaData.java @@ -44,7 +44,7 @@ public class FoodMetaData { } } - if (this.foodLevel >= 18 && entityhuman.cd()) { + if (this.foodLevel >= 18 && entityhuman.cm()) { ++this.foodTickTimer; if (this.foodTickTimer >= 80) { // CraftBukkit - added RegainReason diff --git a/src/main/java/net/minecraft/server/IDataManager.java b/src/main/java/net/minecraft/server/IDataManager.java index a91d244ad9..5580893ceb 100644 --- a/src/main/java/net/minecraft/server/IDataManager.java +++ b/src/main/java/net/minecraft/server/IDataManager.java @@ -14,7 +14,7 @@ public interface IDataManager { void saveWorldData(WorldData worlddata); - PlayerFileData getPlayerFileData(); + IPlayerFileData getPlayerFileData(); void a(); diff --git a/src/main/java/net/minecraft/server/IInventory.java b/src/main/java/net/minecraft/server/IInventory.java index 3d3362969a..c77ce9971b 100644 --- a/src/main/java/net/minecraft/server/IInventory.java +++ b/src/main/java/net/minecraft/server/IInventory.java @@ -16,15 +16,19 @@ public interface IInventory { String getName(); + boolean c(); + int getMaxStackSize(); void update(); - boolean a_(EntityHuman entityhuman); + boolean a(EntityHuman entityhuman); void startOpen(); - void f(); + void g(); + + boolean b(int i, ItemStack itemstack); // CraftBukkit start ItemStack[] getContents(); diff --git a/src/main/java/net/minecraft/server/InventoryCraftResult.java b/src/main/java/net/minecraft/server/InventoryCraftResult.java index a24940171b..9e254d8dda 100644 --- a/src/main/java/net/minecraft/server/InventoryCraftResult.java +++ b/src/main/java/net/minecraft/server/InventoryCraftResult.java @@ -46,6 +46,10 @@ public class InventoryCraftResult implements IInventory { return "Result"; } + public boolean c() { + return false; + } + public ItemStack splitStack(int i, int j) { if (this.items[0] != null) { ItemStack itemstack = this.items[0]; @@ -78,11 +82,15 @@ public class InventoryCraftResult implements IInventory { public void update() {} - public boolean a_(EntityHuman entityhuman) { + public boolean a(EntityHuman entityhuman) { return true; } public void startOpen() {} - public void f() {} + public void g() {} + + public boolean b(int i, ItemStack itemstack) { + return true; + } } diff --git a/src/main/java/net/minecraft/server/InventoryCrafting.java b/src/main/java/net/minecraft/server/InventoryCrafting.java index c840cde4dd..6e8ea2f8a8 100644 --- a/src/main/java/net/minecraft/server/InventoryCrafting.java +++ b/src/main/java/net/minecraft/server/InventoryCrafting.java @@ -86,6 +86,10 @@ public class InventoryCrafting implements IInventory { return "container.crafting"; } + public boolean c() { + return false; + } + public ItemStack splitWithoutUpdate(int i) { if (this.items[i] != null) { ItemStack itemstack = this.items[i]; @@ -131,11 +135,15 @@ public class InventoryCrafting implements IInventory { public void update() {} - public boolean a_(EntityHuman entityhuman) { + public boolean a(EntityHuman entityhuman) { return true; } public void startOpen() {} - public void f() {} + public void g() {} + + public boolean b(int i, ItemStack itemstack) { + return true; + } } diff --git a/src/main/java/net/minecraft/server/InventoryEnderChest.java b/src/main/java/net/minecraft/server/InventoryEnderChest.java index 4e379cd763..221f97656f 100644 --- a/src/main/java/net/minecraft/server/InventoryEnderChest.java +++ b/src/main/java/net/minecraft/server/InventoryEnderChest.java @@ -45,7 +45,7 @@ public class InventoryEnderChest extends InventorySubcontainer { // CraftBukkit end public InventoryEnderChest() { - super("container.enderchest", 27); + super("container.enderchest", false, 27); } public void a(TileEntityEnderChest tileentityenderchest) { @@ -69,7 +69,7 @@ public class InventoryEnderChest extends InventorySubcontainer { } } - public NBTTagList g() { + public NBTTagList h() { NBTTagList nbttaglist = new NBTTagList("EnderItems"); for (int i = 0; i < this.getSize(); ++i) { @@ -87,8 +87,8 @@ public class InventoryEnderChest extends InventorySubcontainer { return nbttaglist; } - public boolean a_(EntityHuman entityhuman) { - return this.a != null && !this.a.a(entityhuman) ? false : super.a_(entityhuman); + public boolean a(EntityHuman entityhuman) { + return this.a != null && !this.a.a(entityhuman) ? false : super.a(entityhuman); } public void startOpen() { @@ -99,12 +99,16 @@ public class InventoryEnderChest extends InventorySubcontainer { super.startOpen(); } - public void f() { + public void g() { if (this.a != null) { this.a.b(); } - super.f(); + super.g(); this.a = null; } + + public boolean b(int i, ItemStack itemstack) { + return true; + } } diff --git a/src/main/java/net/minecraft/server/InventoryLargeChest.java b/src/main/java/net/minecraft/server/InventoryLargeChest.java index a13a56427e..3eee4b8f8d 100644 --- a/src/main/java/net/minecraft/server/InventoryLargeChest.java +++ b/src/main/java/net/minecraft/server/InventoryLargeChest.java @@ -73,7 +73,11 @@ public class InventoryLargeChest implements IInventory { } public String getName() { - return this.a; + return this.left.c() ? this.left.getName() : (this.right.c() ? this.right.getName() : this.a); + } + + public boolean c() { + return this.left.c() || this.right.c(); } public ItemStack getItem(int i) { @@ -105,8 +109,8 @@ public class InventoryLargeChest implements IInventory { this.right.update(); } - public boolean a_(EntityHuman entityhuman) { - return this.left.a_(entityhuman) && this.right.a_(entityhuman); + public boolean a(EntityHuman entityhuman) { + return this.left.a(entityhuman) && this.right.a(entityhuman); } public void startOpen() { @@ -114,8 +118,12 @@ public class InventoryLargeChest implements IInventory { this.right.startOpen(); } - public void f() { - this.left.f(); - this.right.f(); + public void g() { + this.left.g(); + this.right.g(); + } + + public boolean b(int i, ItemStack itemstack) { + return true; } } diff --git a/src/main/java/net/minecraft/server/InventoryMerchant.java b/src/main/java/net/minecraft/server/InventoryMerchant.java index 99726746fa..d89bcb30a2 100644 --- a/src/main/java/net/minecraft/server/InventoryMerchant.java +++ b/src/main/java/net/minecraft/server/InventoryMerchant.java @@ -68,7 +68,7 @@ public class InventoryMerchant implements IInventory { itemstack = this.itemsInSlots[i]; this.itemsInSlots[i] = null; if (this.d(i)) { - this.g(); + this.h(); } return itemstack; @@ -79,7 +79,7 @@ public class InventoryMerchant implements IInventory { } if (this.d(i)) { - this.g(); + this.h(); } return itemstack; @@ -111,7 +111,7 @@ public class InventoryMerchant implements IInventory { } if (this.d(i)) { - this.g(); + this.h(); } } @@ -119,23 +119,31 @@ public class InventoryMerchant implements IInventory { return "mob.villager"; } + public boolean c() { + return false; + } + public int getMaxStackSize() { return maxStack; // CraftBukkit } - public boolean a_(EntityHuman entityhuman) { + public boolean a(EntityHuman entityhuman) { return this.merchant.m_() == entityhuman; } public void startOpen() {} - public void f() {} + public void g() {} - public void update() { - this.g(); + public boolean b(int i, ItemStack itemstack) { + return true; } - public void g() { + public void update() { + this.h(); + } + + public void h() { this.recipe = null; ItemStack itemstack = this.itemsInSlots[0]; ItemStack itemstack1 = this.itemsInSlots[1]; @@ -177,6 +185,6 @@ public class InventoryMerchant implements IInventory { public void c(int i) { this.e = i; - this.g(); + this.h(); } } diff --git a/src/main/java/net/minecraft/server/InventorySubcontainer.java b/src/main/java/net/minecraft/server/InventorySubcontainer.java index 94218a7eb9..c288380c5c 100644 --- a/src/main/java/net/minecraft/server/InventorySubcontainer.java +++ b/src/main/java/net/minecraft/server/InventorySubcontainer.java @@ -8,9 +8,11 @@ public abstract class InventorySubcontainer implements IInventory { // CraftBukk private int b; protected ItemStack[] items; // CraftBukkit - protected private List d; + private boolean e; - public InventorySubcontainer(String s, int i) { + public InventorySubcontainer(String s, boolean flag, int i) { this.a = s; + this.e = flag; this.b = i; this.items = new ItemStack[i]; } @@ -70,6 +72,10 @@ public abstract class InventorySubcontainer implements IInventory { // CraftBukk return this.a; } + public boolean c() { + return this.e; + } + public int getMaxStackSize() { return 64; } @@ -82,11 +88,15 @@ public abstract class InventorySubcontainer implements IInventory { // CraftBukk } } - public boolean a_(EntityHuman entityhuman) { + public boolean a(EntityHuman entityhuman) { return true; } public void startOpen() {} - public void f() {} + public void g() {} + + public boolean b(int i, ItemStack itemstack) { + return true; + } } diff --git a/src/main/java/net/minecraft/server/ItemBed.java b/src/main/java/net/minecraft/server/ItemBed.java index 15207f628d..311fa730f1 100644 --- a/src/main/java/net/minecraft/server/ItemBed.java +++ b/src/main/java/net/minecraft/server/ItemBed.java @@ -37,16 +37,16 @@ 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.v(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.v(i + b0, j - 1, k + b1)) { // CraftBukkit start - // world.setTypeIdAndData(i, j, k, blockbed.id, i1); + // world.setTypeIdAndData(i, j, k, blockbed.id, i1, 3); if (!ItemBlock.processBlockPlace(world, entityhuman, null, i, j, k, blockbed.id, i1, clickedX, clickedY, clickedZ)) { return false; } // CraftBukkit end if (world.getTypeId(i, j, k) == blockbed.id) { - world.setTypeIdAndData(i + b0, j, k + b1, blockbed.id, i1 + 8); + world.setTypeIdAndData(i + b0, j, k + b1, blockbed.id, i1 + 8, 3); } --itemstack.count; diff --git a/src/main/java/net/minecraft/server/ItemBlock.java b/src/main/java/net/minecraft/server/ItemBlock.java index 959747645f..c2d19482ff 100644 --- a/src/main/java/net/minecraft/server/ItemBlock.java +++ b/src/main/java/net/minecraft/server/ItemBlock.java @@ -7,7 +7,6 @@ public class ItemBlock extends Item { public ItemBlock(int i) { super(i); this.id = i + 256; - this.c(Block.byId[i + 256].a(2)); } public int g() { @@ -18,7 +17,7 @@ public class ItemBlock extends Item { final int clickedX = i, clickedY = j, clickedZ = k; int i1 = world.getTypeId(i, j, k); - if (i1 == Block.SNOW.id) { + if (i1 == Block.SNOW.id && (world.getData(i, j, k) & 7) < 1) { l = 1; } else if (i1 != Block.VINE.id && i1 != Block.LONG_GRASS.id && i1 != Block.DEAD_BUSH.id) { if (l == 0) { @@ -52,16 +51,16 @@ public class ItemBlock extends Item { return false; } else if (j == 255 && Block.byId[this.id].material.isBuildable()) { return false; - } else if (world.mayPlace(this.id, i, j, k, false, l, entityhuman)) { + } else if (world.mayPlace(this.id, i, j, k, false, l, entityhuman, itemstack)) { Block block = Block.byId[this.id]; int j1 = this.filterData(itemstack.getData()); int k1 = Block.byId[this.id].getPlacedData(world, i, j, k, l, f, f1, f2, j1); // CraftBukkit start - redirect to common function handler /* - if (world.setTypeIdAndData(i, j, k, this.id, k1)) { + if (world.setTypeIdAndData(i, j, k, this.id, k1, 3)) { if (world.getTypeId(i, j, k) == this.id) { - Block.byId[this.id].postPlace(world, i, j, k, entityhuman); + Block.byId[this.id].postPlace(world, i, j, k, entityhuman, itemstack); Block.byId[this.id].postPlace(world, i, j, k, k1); } @@ -80,19 +79,16 @@ public class ItemBlock extends Item { static boolean processBlockPlace(final World world, final EntityHuman entityhuman, final ItemStack itemstack, final int x, final int y, final int z, final int id, final int data, final int clickedX, final int clickedY, final int clickedZ) { org.bukkit.block.BlockState blockstate = org.bukkit.craftbukkit.block.CraftBlockState.getBlockState(world, x, y, z); - world.suppressPhysics = true; world.callingPlaceEvent = true; - world.setRawTypeIdAndData(x, y, z, id, data); + world.setTypeIdAndData(x, y, z, id, data, 3); org.bukkit.event.block.BlockPlaceEvent event = org.bukkit.craftbukkit.event.CraftEventFactory.callBlockPlaceEvent(world, entityhuman, blockstate, clickedX, clickedY, clickedZ); if (event.isCancelled() || !event.canBuild()) { blockstate.update(true); - world.suppressPhysics = false; world.callingPlaceEvent = false; return false; } - world.suppressPhysics = false; world.callingPlaceEvent = false; int newId = world.getTypeId(x, y, z); @@ -107,7 +103,7 @@ public class ItemBlock extends Item { // Skulls don't get block data applied to them if (block != null && block != Block.SKULL) { - block.postPlace(world, x, y, z, entityhuman); + block.postPlace(world, x, y, z, entityhuman, itemstack); block.postPlace(world, x, y, z, newData); world.makeSound((double) ((float) x + 0.5F), (double) ((float) y + 0.5F), (double) ((float) z + 0.5F), block.stepSound.getPlaceSound(), (block.stepSound.getVolume1() + 1.0F) / 2.0F, block.stepSound.getVolume2() * 0.8F); diff --git a/src/main/java/net/minecraft/server/ItemBoat.java b/src/main/java/net/minecraft/server/ItemBoat.java index cb9b38d547..494c4d31eb 100644 --- a/src/main/java/net/minecraft/server/ItemBoat.java +++ b/src/main/java/net/minecraft/server/ItemBoat.java @@ -41,8 +41,8 @@ public class ItemBoat extends Item { for (i = 0; i < list.size(); ++i) { Entity entity = (Entity) list.get(i); - if (entity.L()) { - float f10 = entity.Y(); + if (entity.K()) { + float f10 = entity.X(); AxisAlignedBB axisalignedbb = entity.boundingBox.grow((double) f10, (double) f10, (double) f10); if (axisalignedbb.a(vec3d)) { diff --git a/src/main/java/net/minecraft/server/ItemBow.java b/src/main/java/net/minecraft/server/ItemBow.java index f62ec9a780..ad34840d36 100644 --- a/src/main/java/net/minecraft/server/ItemBow.java +++ b/src/main/java/net/minecraft/server/ItemBow.java @@ -2,6 +2,8 @@ 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 ItemBow(int i) { super(i); this.maxStackSize = 1; @@ -28,7 +30,7 @@ public class ItemBow extends Item { EntityArrow entityarrow = new EntityArrow(world, entityhuman, f * 2.0F); if (f == 1.0F) { - entityarrow.e(true); + entityarrow.a(true); } int k = EnchantmentManager.getEnchantmentLevel(Enchantment.ARROW_DAMAGE.id, itemstack); @@ -60,7 +62,7 @@ public class ItemBow extends Item { // CraftBukkit end itemstack.damage(1, entityhuman); - world.makeSound(entityhuman, "random.bow", 1.0F, 1.0F / (d.nextFloat() * 0.4F + 1.2F) + f * 0.5F); + world.makeSound(entityhuman, "random.bow", 1.0F, 1.0F / (e.nextFloat() * 0.4F + 1.2F) + f * 0.5F); if (flag) { entityarrow.fromPlayer = 2; } else { @@ -79,7 +81,7 @@ public class ItemBow extends Item { } public EnumAnimation b_(ItemStack itemstack) { - return EnumAnimation.e; + return EnumAnimation.BOW; } public ItemStack a(ItemStack itemstack, World world, EntityHuman entityhuman) { diff --git a/src/main/java/net/minecraft/server/ItemBucket.java b/src/main/java/net/minecraft/server/ItemBucket.java index 9a1ee7742a..ecab05b2c7 100644 --- a/src/main/java/net/minecraft/server/ItemBucket.java +++ b/src/main/java/net/minecraft/server/ItemBucket.java @@ -51,7 +51,7 @@ public class ItemBucket extends Item { return itemstack; } // CraftBukkit end - world.setTypeId(i, j, k, 0); + world.setAir(i, j, k); if (entityhuman.abilities.canInstantlyBuild) { return itemstack; } @@ -76,7 +76,7 @@ public class ItemBucket extends Item { return itemstack; } // CraftBukkit end - world.setTypeId(i, j, k, 0); + world.setAir(i, j, k); if (entityhuman.abilities.canInstantlyBuild) { return itemstack; } @@ -177,7 +177,7 @@ public class ItemBucket extends Item { 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); + 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 ea19a3abad..438a69adf8 100644 --- a/src/main/java/net/minecraft/server/ItemDoor.java +++ b/src/main/java/net/minecraft/server/ItemDoor.java @@ -72,8 +72,8 @@ public class ItemDoor extends Item { b0 = 1; } - int i1 = (world.t(i - b0, j, k - b1) ? 1 : 0) + (world.t(i - b0, j + 1, k - b1) ? 1 : 0); - int j1 = (world.t(i + b0, j, k + b1) ? 1 : 0) + (world.t(i + b0, j + 1, k + b1) ? 1 : 0); + int i1 = (world.u(i - b0, j, k - b1) ? 1 : 0) + (world.u(i - b0, j + 1, k - b1) ? 1 : 0); + int j1 = (world.u(i + b0, j, k + b1) ? 1 : 0) + (world.u(i + b0, j + 1, k + b1) ? 1 : 0); boolean flag = world.getTypeId(i - b0, j, k - b1) == block.id || world.getTypeId(i - b0, j + 1, k - b1) == block.id; boolean flag1 = world.getTypeId(i + b0, j, k + b1) == block.id || world.getTypeId(i + b0, j + 1, k + b1) == block.id; boolean flag2 = false; @@ -84,7 +84,6 @@ public class ItemDoor extends Item { flag2 = true; } - world.suppressPhysics = true; // CraftBukkit start if (entityhuman != null) { if(!ItemBlock.processBlockPlace(world, entityhuman, null, i, j, k, block.id, l, clickedX, clickedY, clickedZ)) { @@ -96,14 +95,11 @@ public class ItemDoor extends Item { ((EntityPlayer) entityhuman).playerConnection.sendPacket(new Packet53BlockChange(i, j + 1, k, world)); return true; } - - world.suppressPhysics = true; } else { - world.setTypeIdAndData(i, j, k, block.id, l); + world.setTypeIdAndData(i, j, k, block.id, l, 2); } // CraftBukkit end - world.setTypeIdAndData(i, j + 1, k, block.id, 8 | (flag2 ? 1 : 0)); - world.suppressPhysics = false; + world.setTypeIdAndData(i, j + 1, k, block.id, 8 | (flag2 ? 1 : 0), 2); world.applyPhysics(i, j, k, block.id); world.applyPhysics(i, j + 1, k, block.id); return true; // CraftBukkit diff --git a/src/main/java/net/minecraft/server/ItemDye.java b/src/main/java/net/minecraft/server/ItemDye.java index b93421af64..6e05654e11 100644 --- a/src/main/java/net/minecraft/server/ItemDye.java +++ b/src/main/java/net/minecraft/server/ItemDye.java @@ -8,7 +8,8 @@ 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 int[] b = new int[] { 1973019, 11743532, 3887386, 5320730, 2437522, 8073150, 2651799, 11250603, 4408131, 14188952, 4312372, 14602026, 6719955, 12801229, 15435844, 15790320}; + 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 int[] c = new int[] { 1973019, 11743532, 3887386, 5320730, 2437522, 8073150, 2651799, 11250603, 4408131, 14188952, 4312372, 14602026, 6719955, 12801229, 15435844, 15790320}; public ItemDye(int i) { super(i); @@ -27,112 +28,19 @@ public class ItemDye extends Item { if (!entityhuman.a(i, j, k, l, itemstack)) { return false; } else { - int i1; - int j1; - int k1; - if (itemstack.getData() == 15) { - i1 = world.getTypeId(i, j, k); - if (i1 == Block.SAPLING.id) { + if (a(itemstack, world, i, j, k, entityhuman)) { if (!world.isStatic) { - // CraftBukkit start - Player player = (entityhuman instanceof EntityPlayer) ? (Player) entityhuman.getBukkitEntity() : null; - ((BlockSapling) Block.SAPLING).grow(world, i, j, k, world.random, true, player, itemstack); - //--itemstack.count; - called later if the bonemeal attempt was succesful - // CraftBukkit end - } - - return true; - } - - if (i1 == Block.BROWN_MUSHROOM.id || i1 == Block.RED_MUSHROOM.id) { - // CraftBukkit start - if (!world.isStatic) { - Player player = (entityhuman instanceof EntityPlayer) ? (Player) entityhuman.getBukkitEntity() : null; - ((BlockMushroom) Block.byId[i1]).grow(world, i, j, k, world.random, true, player, itemstack); - //--itemstack.count; - called later if the bonemeal attempt was succesful - // CraftBukkit end - } - - return true; - } - - if (i1 == Block.MELON_STEM.id || i1 == Block.PUMPKIN_STEM.id) { - if (world.getData(i, j, k) == 7) { - return false; - } - - if (!world.isStatic) { - ((BlockStem) Block.byId[i1]).l(world, i, j, k); - --itemstack.count; - } - - return true; - } - - if (i1 > 0 && Block.byId[i1] instanceof BlockCrops) { - if (world.getData(i, j, k) == 7) { - return false; - } - - if (!world.isStatic) { - ((BlockCrops) Block.byId[i1]).c_(world, i, j, k); - --itemstack.count; - } - - return true; - } - - if (i1 == Block.COCOA.id) { - if (!world.isStatic) { - world.setData(i, j, k, 8 | BlockDirectional.e(world.getData(i, j, k))); - --itemstack.count; - } - - return true; - } - - if (i1 == Block.GRASS.id) { - if (!world.isStatic) { - --itemstack.count; - - label133: - for (j1 = 0; j1 < 128; ++j1) { - k1 = i; - int l1 = j + 1; - int i2 = k; - - for (int j2 = 0; j2 < j1 / 16; ++j2) { - k1 += d.nextInt(3) - 1; - l1 += (d.nextInt(3) - 1) * d.nextInt(3) / 2; - i2 += d.nextInt(3) - 1; - if (world.getTypeId(k1, l1 - 1, i2) != Block.GRASS.id || world.t(k1, l1, i2)) { - continue label133; - } - } - - if (world.getTypeId(k1, l1, i2) == 0) { - if (d.nextInt(10) != 0) { - if (Block.LONG_GRASS.d(world, k1, l1, i2)) { - world.setTypeIdAndData(k1, l1, i2, Block.LONG_GRASS.id, 1); - } - } else if (d.nextInt(3) != 0) { - if (Block.YELLOW_FLOWER.d(world, k1, l1, i2)) { - world.setTypeId(k1, l1, i2, Block.YELLOW_FLOWER.id); - } - } else if (Block.RED_ROSE.d(world, k1, l1, i2)) { - world.setTypeId(k1, l1, i2, Block.RED_ROSE.id); - } - } - } + world.triggerEffect(2005, i, j, k, 0); } return true; } } else if (itemstack.getData() == 3) { - i1 = world.getTypeId(i, j, k); - j1 = world.getData(i, j, k); - if (i1 == Block.LOG.id && BlockLog.e(j1) == 3) { + int i1 = world.getTypeId(i, j, k); + int j1 = world.getData(i, j, k); + + if (i1 == Block.LOG.id && BlockLog.d(j1) == 3) { if (l == 0) { return false; } @@ -158,8 +66,8 @@ public class ItemDye extends Item { } if (world.isEmpty(i, j, k)) { - 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); + 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; } @@ -173,10 +81,131 @@ public class ItemDye extends Item { } } + // CraftBukkit start + public static boolean a(ItemStack itemstack, World world, int i, int j, int k) { + return a(itemstack, world, i, j, k, null); + } + + public static boolean a(ItemStack itemstack, World world, int i, int j, int k, EntityHuman entityhuman) { + // CraftBukkit end + int l = world.getTypeId(i, j, k); + + if (l == Block.SAPLING.id) { + if (!world.isStatic) { + if ((double) world.random.nextFloat() < 0.45D) { + // CraftBukkit start + Player player = (entityhuman instanceof EntityPlayer) ? (Player) entityhuman.getBukkitEntity() : null; + ((BlockSapling) Block.SAPLING).grow(world, i, j, k, world.random, true, player, itemstack); + } + + // --itemstack.count; - called later if the bonemeal attempt was succesful + // CraftBukkit end + } + + return true; + } else if (l != Block.BROWN_MUSHROOM.id && l != Block.RED_MUSHROOM.id) { + if (l != Block.MELON_STEM.id && l != Block.PUMPKIN_STEM.id) { + if (l > 0 && Block.byId[l] instanceof BlockCrops) { + if (world.getData(i, j, k) == 7) { + return false; + } else { + if (!world.isStatic) { + ((BlockCrops) Block.byId[l]).e_(world, i, j, k); + --itemstack.count; + } + + return true; + } + } else { + int i1; + int j1; + int k1; + + if (l == Block.COCOA.id) { + i1 = world.getData(i, j, k); + j1 = BlockDirectional.j(i1); + k1 = BlockCocoa.c(i1); + if (k1 >= 2) { + return false; + } else { + if (!world.isStatic) { + ++k1; + world.setData(i, j, k, k1 << 2 | j1, 2); + --itemstack.count; + } + + return true; + } + } else if (l != Block.GRASS.id) { + return false; + } else { + if (!world.isStatic) { + --itemstack.count; + + label102: + for (i1 = 0; i1 < 128; ++i1) { + j1 = i; + k1 = j + 1; + 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; + 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 (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) { + if (Block.YELLOW_FLOWER.f(world, j1, k1, l1)) { + world.setTypeIdUpdate(j1, k1, l1, Block.YELLOW_FLOWER.id); + } + } else if (Block.RED_ROSE.f(world, j1, k1, l1)) { + world.setTypeIdUpdate(j1, k1, l1, Block.RED_ROSE.id); + } + } + } + } + + return true; + } + } + } else if (world.getData(i, j, k) == 7) { + return false; + } else { + if (!world.isStatic) { + ((BlockStem) Block.byId[l]).k(world, i, j, k); + --itemstack.count; + } + + return true; + } + } else { + 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); + } + + //--itemstack.count; - called later if the bonemeal attempt was succesful + // CraftBukkit end + } + + return true; + } + } + public boolean a(ItemStack itemstack, EntityLiving entityliving) { if (entityliving instanceof EntitySheep) { EntitySheep entitysheep = (EntitySheep) entityliving; - int i = BlockCloth.e_(itemstack.getData()); + int i = BlockCloth.g_(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 6705127e80..decf0216bc 100644 --- a/src/main/java/net/minecraft/server/ItemFireball.java +++ b/src/main/java/net/minecraft/server/ItemFireball.java @@ -61,8 +61,8 @@ 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, d.nextFloat() * 0.4F + 0.8F); - world.setTypeId(i, j, k, Block.FIRE.id); + 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.setTypeIdUpdate(i, j, k, Block.FIRE.id); } if (!entityhuman.abilities.canInstantlyBuild) { diff --git a/src/main/java/net/minecraft/server/ItemFishingRod.java b/src/main/java/net/minecraft/server/ItemFishingRod.java index 88a756d795..eb91ce5775 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.bH(); + entityhuman.bK(); } else { // CraftBukkit start PlayerFishEvent playerFishEvent = new PlayerFishEvent((org.bukkit.entity.Player) entityhuman.getBukkitEntity(), null, PlayerFishEvent.State.FISHING); @@ -27,12 +27,12 @@ public class ItemFishingRod extends Item { } // CraftBukkit end - world.makeSound(entityhuman, "random.bow", 0.5F, 0.4F / (d.nextFloat() * 0.4F + 0.8F)); + world.makeSound(entityhuman, "random.bow", 0.5F, 0.4F / (e.nextFloat() * 0.4F + 0.8F)); if (!world.isStatic) { world.addEntity(new EntityFishingHook(world, entityhuman)); } - entityhuman.bH(); + entityhuman.bK(); } return itemstack; diff --git a/src/main/java/net/minecraft/server/ItemFlintAndSteel.java b/src/main/java/net/minecraft/server/ItemFlintAndSteel.java index c12b297ba5..88b28cb3b5 100644 --- a/src/main/java/net/minecraft/server/ItemFlintAndSteel.java +++ b/src/main/java/net/minecraft/server/ItemFlintAndSteel.java @@ -63,8 +63,8 @@ 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, d.nextFloat() * 0.4F + 0.8F); - world.setTypeId(i, j, k, Block.FIRE.id); + 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.setTypeIdUpdate(i, j, k, Block.FIRE.id); // CraftBukkit start org.bukkit.event.block.BlockPlaceEvent placeEvent = org.bukkit.craftbukkit.event.CraftEventFactory.callBlockPlaceEvent(world, entityhuman, blockState, clickedX, clickedY, clickedZ); diff --git a/src/main/java/net/minecraft/server/ItemFood.java b/src/main/java/net/minecraft/server/ItemFood.java index 28fbe430cf..409addf820 100644 --- a/src/main/java/net/minecraft/server/ItemFood.java +++ b/src/main/java/net/minecraft/server/ItemFood.java @@ -5,18 +5,18 @@ public class ItemFood extends Item { public final int a; private final int b; private final float c; - private final boolean co; - private boolean cp; - private int cq; - private int cr; - private int cs; - private float ct; + private final boolean d; + private boolean cu; + private int cv; + private int cw; + private int cx; + private float cy; public ItemFood(int i, int j, float f, boolean flag) { super(i); this.a = 32; this.b = j; - this.co = flag; + this.d = flag; this.c = f; this.a(CreativeModeTab.h); } @@ -45,8 +45,8 @@ public class ItemFood extends Item { } protected void c(ItemStack itemstack, World world, EntityHuman entityhuman) { - if (!world.isStatic && this.cq > 0 && world.random.nextFloat() < this.ct) { - entityhuman.addEffect(new MobEffect(this.cq, this.cr * 20, this.cs)); + if (!world.isStatic && this.cv > 0 && world.random.nextFloat() < this.cy) { + entityhuman.addEffect(new MobEffect(this.cv, this.cw * 20, this.cx)); } } @@ -55,11 +55,11 @@ public class ItemFood extends Item { } public EnumAnimation b_(ItemStack itemstack) { - return EnumAnimation.b; + return EnumAnimation.EAT; } public ItemStack a(ItemStack itemstack, World world, EntityHuman entityhuman) { - if (entityhuman.g(this.cp)) { + if (entityhuman.i(this.cu)) { entityhuman.a(itemstack, this.c_(itemstack)); } @@ -75,19 +75,19 @@ public class ItemFood extends Item { } public boolean i() { - return this.co; + return this.d; } public ItemFood a(int i, int j, int k, float f) { - this.cq = i; - this.cr = j; - this.cs = k; - this.ct = f; + this.cv = i; + this.cw = j; + this.cx = k; + this.cy = f; return this; } public ItemFood j() { - this.cp = true; + this.cu = true; return this; } } diff --git a/src/main/java/net/minecraft/server/ItemHoe.java b/src/main/java/net/minecraft/server/ItemHoe.java index f64db5c274..aa96737e22 100644 --- a/src/main/java/net/minecraft/server/ItemHoe.java +++ b/src/main/java/net/minecraft/server/ItemHoe.java @@ -30,7 +30,7 @@ public class ItemHoe extends Item { return true; } else { // CraftBukkit start - Hoes - blockface -1 for 'SELF' - // world.setTypeId(i, j, k, block.id); + // world.setTypeIdUpdate(i, j, k, block.id); if (!ItemBlock.processBlockPlace(world, entityhuman, null, i, j, k, block.id, 0, clickedX, clickedY, clickedZ)) { return false; } diff --git a/src/main/java/net/minecraft/server/ItemMinecart.java b/src/main/java/net/minecraft/server/ItemMinecart.java index cd06b9b703..b432045680 100644 --- a/src/main/java/net/minecraft/server/ItemMinecart.java +++ b/src/main/java/net/minecraft/server/ItemMinecart.java @@ -2,6 +2,7 @@ package net.minecraft.server; public class ItemMinecart extends Item { + private static final IDispenseBehavior b = new DispenseBehaviorMinecart(); public int a; public ItemMinecart(int i, int j) { @@ -9,12 +10,13 @@ public class ItemMinecart extends Item { this.maxStackSize = 1; this.a = j; this.a(CreativeModeTab.e); + BlockDispenser.a.a(this, b); } 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.e(i1)) { + if (BlockMinecartTrack.d_(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); @@ -24,7 +26,13 @@ public class ItemMinecart extends Item { } // CraftBukkit end - world.addEntity(new EntityMinecart(world, (double) ((float) i + 0.5F), (double) ((float) j + 0.5F), (double) ((float) k + 0.5F), this.a)); + EntityMinecartAbstract entityminecartabstract = EntityMinecartAbstract.a(world, (double) ((float) i + 0.5F), (double) ((float) j + 0.5F), (double) ((float) k + 0.5F), this.a); + + if (itemstack.hasName()) { + entityminecartabstract.a(itemstack.getName()); + } + + world.addEntity(entityminecartabstract); } --itemstack.count; diff --git a/src/main/java/net/minecraft/server/ItemMonsterEgg.java b/src/main/java/net/minecraft/server/ItemMonsterEgg.java index ead857e4ed..a1fe703986 100644 --- a/src/main/java/net/minecraft/server/ItemMonsterEgg.java +++ b/src/main/java/net/minecraft/server/ItemMonsterEgg.java @@ -34,8 +34,16 @@ public class ItemMonsterEgg extends Item { d0 = 0.5D; } - if (a(world, itemstack.getData(), (double) i + 0.5D, (double) j + d0, (double) k + 0.5D) != null && !entityhuman.abilities.canInstantlyBuild) { - --itemstack.count; + Entity entity = a(world, itemstack.getData(), (double) i + 0.5D, (double) j + d0, (double) k + 0.5D); + + if (entity != null) { + if (entity instanceof EntityLiving && itemstack.hasName()) { + ((EntityLiving) entity).setCustomName(itemstack.getName()); + } + + if (!entityhuman.abilities.canInstantlyBuild) { + --itemstack.count; + } } return true; @@ -54,11 +62,11 @@ public class ItemMonsterEgg extends Item { EntityLiving entityliving = (EntityLiving) entity; entity.setPositionRotation(d0, d1, d2, MathHelper.g(world.random.nextFloat() * 360.0F), 0.0F); - entityliving.az = entityliving.yaw; - entityliving.ax = entityliving.yaw; - entityliving.bG(); + entityliving.aA = entityliving.yaw; + entityliving.ay = entityliving.yaw; + entityliving.bJ(); world.addEntity(entity, org.bukkit.event.entity.CreatureSpawnEvent.SpawnReason.SPAWNER_EGG); // CraftBukkit - entityliving.aO(); + entityliving.aR(); } } diff --git a/src/main/java/net/minecraft/server/ItemRedstone.java b/src/main/java/net/minecraft/server/ItemRedstone.java index dee5f0d11c..ad43b412c6 100644 --- a/src/main/java/net/minecraft/server/ItemRedstone.java +++ b/src/main/java/net/minecraft/server/ItemRedstone.java @@ -45,7 +45,7 @@ public class ItemRedstone extends Item { if (Block.REDSTONE_WIRE.canPlace(world, i, j, k)) { // CraftBukkit start // --itemstack.count; - // world.setTypeId(i, j, k, Block.REDSTONE_WIRE.id); + // world.setTypeIdUpdate(i, j, k, Block.REDSTONE_WIRE.id); if (!ItemBlock.processBlockPlace(world, entityhuman, itemstack, i, j, k, Block.REDSTONE_WIRE.id, 0, clickedX, clickedY, clickedZ)) { return false; } diff --git a/src/main/java/net/minecraft/server/ItemReed.java b/src/main/java/net/minecraft/server/ItemReed.java index ab8164c7a1..156218d8f1 100644 --- a/src/main/java/net/minecraft/server/ItemReed.java +++ b/src/main/java/net/minecraft/server/ItemReed.java @@ -13,7 +13,7 @@ public class ItemReed extends Item { final int clickedX = i, clickedY = j, clickedZ = k; // CraftBukkit int i1 = world.getTypeId(i, j, k); - if (i1 == Block.SNOW.id) { + if (i1 == Block.SNOW.id && (world.getData(i, j, k) & 7) < 1) { l = 1; } else if (i1 != Block.VINE.id && i1 != Block.LONG_GRASS.id && i1 != Block.DEAD_BUSH.id) { if (l == 0) { @@ -46,16 +46,16 @@ public class ItemReed extends Item { } else if (itemstack.count == 0) { return false; } else { - if (world.mayPlace(this.id, i, j, k, false, l, (Entity) null)) { + if (world.mayPlace(this.id, i, j, k, false, l, (Entity) null, itemstack)) { Block block = Block.byId[this.id]; int j1 = block.getPlacedData(world, i, j, k, l, f, f1, f2, 0); // CraftBukkit start - redirect to common handler ItemBlock.processBlockPlace(world, entityhuman, itemstack, i, j, k, this.id, j1, clickedX, clickedY, clickedZ); /* - if (world.setTypeIdAndData(i, j, k, this.id, j1)) { + if (world.setTypeIdAndData(i, j, k, this.id, j1, 3)) { if (world.getTypeId(i, j, k) == this.id) { - Block.byId[this.id].postPlace(world, i, j, k, entityhuman); + Block.byId[this.id].postPlace(world, i, j, k, entityhuman, itemstack); Block.byId[this.id].postPlace(world, i, j, k, j1); } diff --git a/src/main/java/net/minecraft/server/ItemSeedFood.java b/src/main/java/net/minecraft/server/ItemSeedFood.java index e14f407b22..7fc09d8680 100644 --- a/src/main/java/net/minecraft/server/ItemSeedFood.java +++ b/src/main/java/net/minecraft/server/ItemSeedFood.java @@ -20,7 +20,7 @@ public class ItemSeedFood extends ItemFood { if (i1 == this.c && world.isEmpty(i, j + 1, k)) { // CraftBukkit start - // world.setTypeId(i, j + 1, k, this.b); + // world.setTypeIdUpdate(i, j + 1, k, this.b); if (!ItemBlock.processBlockPlace(world, entityhuman, null, i, j + 1, k, this.b, 0, clickedX, clickedY, clickedZ)) { return false; } diff --git a/src/main/java/net/minecraft/server/ItemSeeds.java b/src/main/java/net/minecraft/server/ItemSeeds.java index 258613e064..8042681c08 100644 --- a/src/main/java/net/minecraft/server/ItemSeeds.java +++ b/src/main/java/net/minecraft/server/ItemSeeds.java @@ -21,7 +21,7 @@ public class ItemSeeds extends Item { if (i1 == this.b && world.isEmpty(i, j + 1, k)) { // CraftBukkit start - seeds - // world.setTypeId(i, j + 1, k, this.id); + // world.setTypeIdUpdate(i, j + 1, k, this.id); if (!ItemBlock.processBlockPlace(world, entityhuman, null, i, j + 1, k, this.id, 0, clickedX, clickedY, clickedZ)) { return false; } diff --git a/src/main/java/net/minecraft/server/ItemSign.java b/src/main/java/net/minecraft/server/ItemSign.java index 6fa75a3eca..7a4c32d593 100644 --- a/src/main/java/net/minecraft/server/ItemSign.java +++ b/src/main/java/net/minecraft/server/ItemSign.java @@ -45,11 +45,11 @@ public class ItemSign extends Item { if (l == 1) { int i1 = MathHelper.floor((double) ((entityhuman.yaw + 180.0F) * 16.0F / 360.0F) + 0.5D) & 15; - // world.setTypeIdAndData(i, j, k, Block.SIGN_POST.id, i1); + // world.setTypeIdAndData(i, j, k, Block.SIGN_POST.id, i1, 2); block = Block.SIGN_POST; l = i1; } else { - // world.setTypeIdAndData(i, j, k, Block.WALL_SIGN.id, l); + // world.setTypeIdAndData(i, j, k, Block.WALL_SIGN.id, l, 2); block = Block.WALL_SIGN; } if (!ItemBlock.processBlockPlace(world, entityhuman, null, i, j, k, block.id, l, clickedX, clickedY, clickedZ)) { diff --git a/src/main/java/net/minecraft/server/ItemSkull.java b/src/main/java/net/minecraft/server/ItemSkull.java index bd2fe45695..960927225d 100644 --- a/src/main/java/net/minecraft/server/ItemSkull.java +++ b/src/main/java/net/minecraft/server/ItemSkull.java @@ -2,8 +2,8 @@ package net.minecraft.server; public class ItemSkull extends Item { - private static final String[] a = new String[] { "skeleton", "wither", "zombie", "char", "creeper"}; - private static final int[] b = new int[] { 224, 225, 226, 227, 228}; + 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 ItemSkull(int i) { super(i); @@ -45,7 +45,7 @@ public class ItemSkull extends Item { return false; } else { // CraftBukkit start - handle in ItemBlock - // world.setTypeIdAndData(i, j, k, Block.SKULL.id, l); + // world.setTypeIdAndData(i, j, k, Block.SKULL.id, l, 2); if (!ItemBlock.processBlockPlace(world, entityhuman, null, i, j, k, Block.SKULL.id, l, clickedX, clickedY, clickedZ)) { return false; } @@ -84,11 +84,11 @@ public class ItemSkull extends Item { public String d(ItemStack itemstack) { int i = itemstack.getData(); - if (i < 0 || i >= a.length) { + if (i < 0 || i >= b.length) { i = 0; } - return super.getName() + "." + a[i]; + return super.getName() + "." + b[i]; } public String l(ItemStack itemstack) { diff --git a/src/main/java/net/minecraft/server/ItemSnow.java b/src/main/java/net/minecraft/server/ItemSnow.java new file mode 100644 index 0000000000..06cd5ca65a --- /dev/null +++ b/src/main/java/net/minecraft/server/ItemSnow.java @@ -0,0 +1,36 @@ +package net.minecraft.server; + +public class ItemSnow extends ItemBlockWithAuxData { + + public ItemSnow(int i, Block block) { + super(i, block); + } + + 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; + if (itemstack.count == 0) { + return false; + } else if (!entityhuman.a(i, j, k, l, itemstack)) { + return false; + } else { + int i1 = world.getTypeId(i, j, k); + + if (i1 == Block.SNOW.id) { + Block block = Block.byId[this.g()]; + int j1 = world.getData(i, j, k); + int k1 = j1 & 7; + + // CraftBukkit start + // if (k1 <= 6 && world.b(block.b(world, i, j, k)) && world.setData(i, j, k, k1 + 1 | j1 & -8, 2)) { + if (k1 <= 6 && world.b(block.b(world, i, j, k)) && processBlockPlace(world, entityhuman, itemstack, i, j, k, Block.SNOW.id, k1 + 1 | j1 & -8, clickedX, clickedY, clickedZ)) { + // CraftBukkit end + 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 super.interactWith(itemstack, entityhuman, world, i, j, k, l, f, f1, f2); + } + } +} diff --git a/src/main/java/net/minecraft/server/ItemStack.java b/src/main/java/net/minecraft/server/ItemStack.java index 8f0a5ad21b..cd6dd0700a 100644 --- a/src/main/java/net/minecraft/server/ItemStack.java +++ b/src/main/java/net/minecraft/server/ItemStack.java @@ -1,5 +1,7 @@ package net.minecraft.server; +import java.util.Random; + public final class ItemStack { public int count; @@ -39,6 +41,9 @@ public final class ItemStack { this.id = i; this.count = j; this.setData(k); // CraftBukkit + if (this.damage < 0) { + this.damage = 0; + } } public static ItemStack createStack(NBTTagCompound nbttagcompound) { @@ -105,6 +110,10 @@ public final class ItemStack { this.id = nbttagcompound.getShort("id"); this.count = nbttagcompound.getByte("Count"); this.damage = nbttagcompound.getShort("Damage"); + if (this.damage < 0) { + this.damage = 0; + } + if (nbttagcompound.hasKey("tag")) { // CraftBukkit - clear name from compound and make defensive copy as this data may be coming from the save thread this.tag = (NBTTagCompound) nbttagcompound.getCompound("tag").clone().setName(""); @@ -116,22 +125,22 @@ public final class ItemStack { } public boolean isStackable() { - return this.getMaxStackSize() > 1 && (!this.f() || !this.h()); + return this.getMaxStackSize() > 1 && (!this.g() || !this.i()); } - public boolean f() { + public boolean g() { return Item.byId[this.id].getMaxDurability() > 0; } public boolean usesData() { - return Item.byId[this.id].l(); + return Item.byId[this.id].m(); } - public boolean h() { - return this.f() && this.damage > 0; + public boolean i() { + return this.g() && this.damage > 0; } - public int i() { + public int j() { return this.damage; } @@ -140,53 +149,63 @@ public final class ItemStack { } public void setData(int i) { - this.damage = (this.id > 0) && (this.id < 256) && (this.id != Block.ANVIL.id) ? Item.byId[this.id].filterData(i) : i; // CraftBukkit + this.damage = i; + if (this.damage < 0) { + this.damage = 0; + } } - public int k() { + public int l() { return Item.byId[this.id].getMaxDurability(); } - public void damage(int i, EntityLiving entityliving) { - if (this.f()) { - if (i > 0 && entityliving instanceof EntityHuman) { + public boolean isDamaged(int i, Random random) { + if (!this.g()) { + return false; + } else { + if (i > 0) { int j = EnchantmentManager.getEnchantmentLevel(Enchantment.DURABILITY.id, this); int k = 0; for (int l = 0; j > 0 && l < i; ++l) { - if (EnchantmentDurability.a(this, j, entityliving.world.random)) { + if (EnchantmentDurability.a(this, j, random)) { ++k; } } i -= k; if (i <= 0) { - return; + return false; } } - if (!(entityliving instanceof EntityHuman) || !((EntityHuman) entityliving).abilities.canInstantlyBuild) { - this.damage += i; - } + this.damage += i; + return this.damage > this.l(); + } + } - if (this.damage > this.k()) { - entityliving.a(this); - if (entityliving instanceof EntityHuman) { - ((EntityHuman) entityliving).a(StatisticList.F[this.id], 1); + public void damage(int i, EntityLiving entityliving) { + if (!(entityliving instanceof EntityHuman) || !((EntityHuman) entityliving).abilities.canInstantlyBuild) { + if (this.g()) { + if (this.isDamaged(i, entityliving.aE())) { + entityliving.a(this); + if (entityliving instanceof EntityHuman) { + ((EntityHuman) entityliving).a(StatisticList.F[this.id], 1); + } + + --this.count; + if (this.count < 0) { + this.count = 0; + } + + // CraftBukkit start - Check for item breaking + if (this.count == 0 && entityliving instanceof EntityHuman) { + org.bukkit.craftbukkit.event.CraftEventFactory.callPlayerItemBreakEvent((EntityHuman) entityliving, this); + } + // CraftBukkit end + + this.damage = 0; } - - --this.count; - if (this.count < 0) { - this.count = 0; - } - - // CraftBukkit start - Check for item breaking - if (this.count == 0 && entityliving instanceof EntityHuman) { - org.bukkit.craftbukkit.event.CraftEventFactory.callPlayerItemBreakEvent((EntityHuman) entityliving, this); - } - // CraftBukkit end - - this.damage = 0; } } } @@ -270,11 +289,11 @@ public final class ItemStack { Item.byId[this.id].d(this, world, entityhuman); } - public int m() { + public int n() { return this.getItem().c_(this); } - public EnumAnimation n() { + public EnumAnimation o() { return this.getItem().b_(this); } @@ -298,7 +317,7 @@ public final class ItemStack { this.tag = nbttagcompound; } - public String r() { + public String getName() { String s = this.getItem().l(this); if (this.tag != null && this.tag.hasKey("display")) { @@ -314,7 +333,7 @@ public final class ItemStack { public void c(String s) { if (this.tag == null) { - this.tag = new NBTTagCompound(); + this.tag = new NBTTagCompound("tag"); } if (!this.tag.hasKey("display")) { @@ -324,11 +343,11 @@ public final class ItemStack { this.tag.getCompound("display").setString("Name", s); } - public boolean s() { + public boolean hasName() { return this.tag == null ? false : (!this.tag.hasKey("display") ? false : this.tag.getCompound("display").hasKey("Name")); } - public boolean v() { + public boolean w() { return !this.getItem().d_(this) ? false : !this.hasEnchantments(); } @@ -361,11 +380,11 @@ public final class ItemStack { this.tag.set(s, nbtbase); } - public boolean x() { - return this.getItem().x(); + public boolean y() { + return this.getItem().y(); } - public boolean y() { + public boolean z() { return this.f != null; } @@ -373,7 +392,7 @@ public final class ItemStack { this.f = entityitemframe; } - public EntityItemFrame z() { + public EntityItemFrame A() { return this.f; } @@ -383,7 +402,7 @@ public final class ItemStack { public void setRepairCost(int i) { if (!this.hasTag()) { - this.tag = new NBTTagCompound(); + this.tag = new NBTTagCompound("tag"); } this.tag.setInt("RepairCost", i); diff --git a/src/main/java/net/minecraft/server/ItemStep.java b/src/main/java/net/minecraft/server/ItemStep.java index 6c51282f20..67af6d68f4 100644 --- a/src/main/java/net/minecraft/server/ItemStep.java +++ b/src/main/java/net/minecraft/server/ItemStep.java @@ -20,7 +20,7 @@ public class ItemStep extends ItemBlock { } public String d(ItemStack itemstack) { - return this.b.d(itemstack.getData()); + return this.b.c(itemstack.getData()); } public boolean interactWith(ItemStack itemstack, EntityHuman entityhuman, World world, int i, int j, int k, int l, float f, float f1, float f2) { @@ -39,7 +39,8 @@ public class ItemStep extends ItemBlock { if ((l == 1 && !flag || l == 0 && flag) && i1 == this.b.id && k1 == itemstack.getData()) { // CraftBukkit start - world.setTypeIdAndData -> processBlockPlace() - if (world.b(this.c.e(world, i, j, k)) && processBlockPlace(world, entityhuman, null, i, j, k, this.c.id, k1, clickedX, clickedY, clickedZ)) { + // if (world.b(this.c.b(world, i, j, k)) && world.setTypeIdAndData(i, j, k, this.c.id, k1, 3)) { + if (world.b(this.c.b(world, i, j, k)) && processBlockPlace(world, entityhuman, null, i, j, k, this.c.id, k1, clickedX, clickedY, clickedZ)) { // world.makeSound((double) ((float) i + 0.5F), (double) ((float) j + 0.5F), (double) ((float) k + 0.5F), this.c.stepSound.getPlaceSound(), (this.c.stepSound.getVolume1() + 1.0F) / 2.0F, this.c.stepSound.getVolume2() * 0.8F); // CraftBukkit end --itemstack.count; @@ -83,7 +84,8 @@ public class ItemStep extends ItemBlock { if (i1 == this.b.id && k1 == itemstack.getData()) { // CraftBukkit start - world.setTypeIdAndData -> processBlockPlace() - if (world.b(this.c.e(world, i, j, k)) && processBlockPlace(world, entityhuman, null, i, j, k, this.c.id, k1, clickedX, clickedY, clickedZ)) { + // if (world.b(this.c.b(world, i, j, k)) && world.setTypeIdAndData(i, j, k, this.c.id, k1, 3)) { + if (world.b(this.c.b(world, i, j, k)) && processBlockPlace(world, entityhuman, null, i, j, k, this.c.id, k1, clickedX, clickedY, clickedZ)) { // world.makeSound((double) ((float) i + 0.5F), (double) ((float) j + 0.5F), (double) ((float) k + 0.5F, this.c.stepSound.getPlaceSound(), (this.c.stepSound.getVolume1() + 1.0F) / 2.0F, this.c.stepSound.getVolume2() * 0.8F); // CraftBukkit end --itemstack.count; diff --git a/src/main/java/net/minecraft/server/ItemWaterLily.java b/src/main/java/net/minecraft/server/ItemWaterLily.java index 07c5708284..bcee9b811f 100644 --- a/src/main/java/net/minecraft/server/ItemWaterLily.java +++ b/src/main/java/net/minecraft/server/ItemWaterLily.java @@ -28,7 +28,7 @@ public class ItemWaterLily extends ItemWithAuxData { if (world.getMaterial(i, j, k) == Material.WATER && world.getData(i, j, k) == 0 && world.isEmpty(i, j + 1, k)) { // CraftBukkit start - waterlily - // world.setTypeId(i, j + 1, k, Block.WATER_LILY.id); + // world.setTypeIdUpdate(i, j + 1, k, Block.WATER_LILY.id); if (!processBlockPlace(world, entityhuman, null, i, j + 1, k, Block.WATER_LILY.id, 0, clickedX, clickedY, clickedZ)) { return itemstack; } diff --git a/src/main/java/net/minecraft/server/MinecraftServer.java b/src/main/java/net/minecraft/server/MinecraftServer.java index 4bdf8aaa52..d3f3f86efe 100644 --- a/src/main/java/net/minecraft/server/MinecraftServer.java +++ b/src/main/java/net/minecraft/server/MinecraftServer.java @@ -28,51 +28,50 @@ import org.bukkit.event.world.WorldSaveEvent; public abstract class MinecraftServer implements ICommandListener, Runnable, IMojangStatistics { - public static Logger log = Logger.getLogger("Minecraft"); - private static MinecraftServer l = null; + private static MinecraftServer k = null; public Convertable convertable; // CraftBukkit - private final -> public - private final MojangStatisticsGenerator n = new MojangStatisticsGenerator("server", this); + private final MojangStatisticsGenerator m = new MojangStatisticsGenerator("server", this); public File universe; // CraftBukkit - private final -> public - private final List p = new ArrayList(); - private final ICommandHandler q; + private final List o = new ArrayList(); + private final ICommandHandler p; public final MethodProfiler methodProfiler = new MethodProfiler(); private String serverIp; - private int s = -1; - // public WorldServer[] worldServer; // CraftBukkit - removed! - private PlayerList t; + private int r = -1; + public WorldServer[] worldServer; + private PlayerList s; private boolean isRunning = true; private boolean isStopped = false; private int ticks = 0; - public String d; - public int e; + public String c; + public int d; private boolean onlineMode; private boolean spawnAnimals; private boolean spawnNPCs; private boolean pvpMode; private boolean allowFlight; private String motd; - private int D; + private int C; + private long D; private long E; private long F; private long G; - private long H; + 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 final long[] j = new long[100]; - public long[][] k; - private KeyPair I; + public long[][] j; + private KeyPair H; + private String I; private String J; - private String K; private boolean demoMode; + private boolean M; private boolean N; - private boolean O; - private String P = ""; - private boolean Q = false; - private long R; - private String S; - private boolean T; + private String O = ""; + private boolean P = false; + private long Q; + private String R; + private boolean S; // CraftBukkit start public List worlds = new ArrayList(); @@ -88,11 +87,11 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo // CraftBukkit end public MinecraftServer(OptionSet options) { // CraftBukkit - signature file -> OptionSet - l = this; + k = this; // this.universe = file1; // CraftBukkit - this.q = new CommandDispatcher(); + this.p = new CommandDispatcher(); // this.convertable = new WorldLoaderServer(server.getWorldContainer()); // CraftBukkit - moved to DedicatedServer.init - this.al(); + this.am(); // CraftBukkit start this.options = options; @@ -119,46 +118,29 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo public abstract PropertyManager getPropertyManager(); // CraftBukkit end - private void al() { - BlockDispenser.a.a(Item.ARROW, new DispenseBehaviorArrow(this)); - BlockDispenser.a.a(Item.EGG, new DispenseBehaviorEgg(this)); - BlockDispenser.a.a(Item.SNOW_BALL, new DispenseBehaviorSnowBall(this)); - BlockDispenser.a.a(Item.EXP_BOTTLE, new DispenseBehaviorExpBottle(this)); - BlockDispenser.a.a(Item.POTION, new DispenseBehaviorPotion(this)); - BlockDispenser.a.a(Item.MONSTER_EGG, new DispenseBehaviorMonsterEgg(this)); - BlockDispenser.a.a(Item.FIREWORKS, new DispenseBehaviorFireworks(this)); - BlockDispenser.a.a(Item.FIREBALL, new DispenseBehaviorFireball(this)); - DispenseBehaviorMinecart dispensebehaviorminecart = new DispenseBehaviorMinecart(this); - - BlockDispenser.a.a(Item.MINECART, dispensebehaviorminecart); - BlockDispenser.a.a(Item.STORAGE_MINECART, dispensebehaviorminecart); - BlockDispenser.a.a(Item.POWERED_MINECART, dispensebehaviorminecart); - BlockDispenser.a.a(Item.BOAT, new DispenseBehaviorBoat(this)); - DispenseBehaviorFilledBucket dispensebehaviorfilledbucket = new DispenseBehaviorFilledBucket(this); - - BlockDispenser.a.a(Item.LAVA_BUCKET, dispensebehaviorfilledbucket); - BlockDispenser.a.a(Item.WATER_BUCKET, dispensebehaviorfilledbucket); - BlockDispenser.a.a(Item.BUCKET, new DispenseBehaviorEmptyBucket(this)); + private void am() { + DispenserRegistry.a(); } protected abstract boolean init() throws java.net.UnknownHostException; // CraftBukkit - throws UnknownHostException protected void b(String s) { if (this.getConvertable().isConvertable(s)) { - log.info("Converting map!"); + this.getLogger().info("Converting map!"); this.c("menu.convertingLevel"); this.getConvertable().convert(s, new ConvertProgressUpdater(this)); } } protected synchronized void c(String s) { - this.S = s; + this.R = s; } protected void a(String s, String s1, long i, WorldType worldtype, String s2) { this.b(s); this.c("menu.loadingLevel"); - // CraftBukkit - removed world and ticktime arrays + this.worldServer = new WorldServer[3]; + // CraftBukkit - removed ticktime arrays IDataManager idatamanager = this.convertable.a(s, true); WorldData worlddata = idatamanager.getWorldData(); // CraftBukkit start - removed worldsettings @@ -194,10 +176,10 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo if (j == 0) { if (this.M()) { // Strip out DEMO? // CraftBukkit - world = new DemoWorldServer(this, new ServerNBTManager(server.getWorldContainer(), s1, true), s1, dimension, this.methodProfiler); + world = new DemoWorldServer(this, new ServerNBTManager(server.getWorldContainer(), s1, true), s1, dimension, this.methodProfiler, this.getLogger()); } else { // CraftBukkit - world = new WorldServer(this, new ServerNBTManager(server.getWorldContainer(), s1, true), s1, dimension, worldsettings, this.methodProfiler, Environment.getEnvironment(dimension), gen); + world = new WorldServer(this, new ServerNBTManager(server.getWorldContainer(), s1, true), s1, dimension, worldsettings, this.methodProfiler, this.getLogger(), Environment.getEnvironment(dimension), gen); } } else { String dim = "DIM" + dimension; @@ -206,6 +188,7 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo File oldWorld = new File(new File(s), dim); if ((!newWorld.isDirectory()) && (oldWorld.isDirectory())) { + final IConsoleLogManager log = this.getLogger(); log.info("---- Migration of old " + worldType + " folder required ----"); log.info("Unfortunately due to the way that Minecraft implemented multiworld support in 1.6, Bukkit requires that you move your " + worldType + " folder to a new location in order to operate correctly."); log.info("We will move this folder for you, but it will mean that you need to move it back should you wish to stop using Bukkit in the future."); @@ -237,7 +220,7 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo this.c(name); // CraftBukkit - world = new SecondaryWorldServer(this, new ServerNBTManager(server.getWorldContainer(), name, true), name, dimension, worldsettings, this.worlds.get(0), this.methodProfiler, Environment.getEnvironment(dimension), gen); + world = new SecondaryWorldServer(this, new ServerNBTManager(server.getWorldContainer(), name, true), name, dimension, worldsettings, this.worlds.get(0), this.methodProfiler, this.getLogger(), Environment.getEnvironment(dimension), gen); } if (gen != null) { @@ -251,7 +234,7 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo world.getWorldData().setGameType(this.getGamemode()); } this.worlds.add(world); - this.t.setPlayerFileData(this.worlds.toArray(new WorldServer[this.worlds.size()])); + this.s.setPlayerFileData(this.worlds.toArray(new WorldServer[this.worlds.size()])); // CraftBukkit end } @@ -260,8 +243,7 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo } protected void e() { - short short1 = 196; - long i = System.currentTimeMillis(); + long i = System.currentTimeMillis(); // CraftBukkit - current time this.c("menu.generatingTerrain"); byte b0 = 0; @@ -269,15 +251,15 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo // CraftBukkit start for (int j = 0; j < this.worlds.size(); ++j) { WorldServer worldserver = this.worlds.get(j); - log.info("Preparing start region for level " + j + " (Seed: " + worldserver.getSeed() + ")"); + this.getLogger().info("Preparing start region for level " + j + " (Seed: " + worldserver.getSeed() + ")"); if (!worldserver.getWorld().getKeepSpawnInMemory()) { continue; } - // CraftBukkit end + ChunkCoordinates chunkcoordinates = worldserver.getSpawn(); - for (int k = -short1; k <= short1 && this.isRunning(); k += 16) { - for (int l = -short1; l <= short1 && this.isRunning(); l += 16) { + 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) { @@ -285,8 +267,8 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo } if (i1 > i + 1000L) { - int j1 = (short1 * 2 + 1) * (short1 * 2 + 1); - int k1 = (k + short1) * (short1 * 2 + 1) + l + 1; + 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; @@ -296,7 +278,7 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo } } } - + // CraftBukkit end this.j(); } @@ -309,27 +291,27 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo public abstract boolean isHardcore(); protected void a_(String s, int i) { - this.d = s; - this.e = i; - log.info(s + ": " + i + "%"); + this.c = s; + this.d = i; + this.getLogger().info(s + ": " + i + "%"); } protected void j() { - this.d = null; - this.e = 0; + this.c = null; + this.d = 0; this.server.enablePlugins(org.bukkit.plugin.PluginLoadOrder.POSTWORLD); // CraftBukkit } protected void saveChunks(boolean flag) throws ExceptionWorldConflict { // CraftBukkit - added throws - if (!this.O) { + if (!this.N) { // CraftBukkit start for (int j = 0; j < this.worlds.size(); ++j) { WorldServer worldserver = this.worlds.get(j); if (worldserver != null) { if (!flag) { - log.info("Saving chunks for level \'" + worldserver.getWorldData().getName() + "\'/" + worldserver.worldProvider.getName()); + this.getLogger().info("Saving chunks for level \'" + worldserver.getWorldData().getName() + "\'/" + worldserver.worldProvider.getName()); } worldserver.save(true, (IProgressUpdate) null); @@ -344,8 +326,8 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo } public void stop() throws ExceptionWorldConflict { // CraftBukkit - added throws - if (!this.O) { - log.info("Stopping server"); + if (!this.N) { + this.getLogger().info("Stopping server"); // CraftBukkit start if (this.server != null) { this.server.disablePlugins(); @@ -356,13 +338,13 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo this.ae().a(); } - if (this.t != null) { - log.info("Saving players"); - this.t.savePlayers(); - this.t.r(); + if (this.s != null) { + this.getLogger().info("Saving players"); + this.s.savePlayers(); + this.s.r(); } - log.info("Saving worlds"); + this.getLogger().info("Saving worlds"); this.saveChunks(false); /* CraftBukkit start - handled in saveChunks @@ -372,8 +354,8 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo worldserver.saveLevel(); } // CraftBukkit end */ - if (this.n != null && this.n.d()) { - this.n.e(); + if (this.m != null && this.m.d()) { + this.m.e(); } } } @@ -399,19 +381,19 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo if (this.init()) { long i = System.currentTimeMillis(); - for (long j = 0L; this.isRunning; this.Q = true) { + for (long j = 0L; this.isRunning; this.P = true) { long k = System.currentTimeMillis(); long l = k - i; - if (l > 2000L && i - this.R >= 15000L) { + if (l > 2000L && i - this.Q >= 15000L) { if (this.server.getWarnOnOverload()) // CraftBukkit - Added option to suppress warning messages - log.warning("Can\'t keep up! Did the system time change, or is the server overloaded?"); + this.getLogger().warning("Can\'t keep up! Did the system time change, or is the server overloaded?"); l = 2000L; - this.R = i; + this.Q = i; } if (l < 0L) { - log.warning("Time ran backwards! Did the system time change?"); + this.getLogger().warning("Time ran backwards! Did the system time change?"); l = 0L; } @@ -435,7 +417,7 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo } } catch (Throwable throwable) { throwable.printStackTrace(); - log.log(Level.SEVERE, "Encountered an unexpected exception " + throwable.getClass().getSimpleName(), throwable); + this.getLogger().severe("Encountered an unexpected exception " + throwable.getClass().getSimpleName(), throwable); CrashReport crashreport = null; if (throwable instanceof ReportedException) { @@ -446,10 +428,10 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo File file1 = new File(new File(this.o(), "crash-reports"), "crash-" + (new SimpleDateFormat("yyyy-MM-dd_HH.mm.ss")).format(new Date()) + "-server.txt"); - if (crashreport.a(file1)) { - log.severe("This crash report has been saved to: " + file1.getAbsolutePath()); + if (crashreport.a(file1, this.getLogger())) { + this.getLogger().severe("This crash report has been saved to: " + file1.getAbsolutePath()); } else { - log.severe("We were unable to save this crash report to disk."); + this.getLogger().severe("We were unable to save this crash report to disk."); } this.a(crashreport); @@ -484,8 +466,8 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo AxisAlignedBB.a().a(); ++this.ticks; - if (this.T) { - this.T = false; + if (this.S) { + this.S = false; this.methodProfiler.a = true; this.methodProfiler.a(); } @@ -494,29 +476,29 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo this.r(); if ((this.autosavePeriod > 0) && ((this.ticks % this.autosavePeriod) == 0)) { // CraftBukkit this.methodProfiler.a("save"); - this.t.savePlayers(); + this.s.savePlayers(); this.saveChunks(true); this.methodProfiler.b(); } this.methodProfiler.a("tallying"); - this.j[this.ticks % 100] = System.nanoTime() - i; - this.f[this.ticks % 100] = Packet.p - this.E; - this.E = Packet.p; - this.g[this.ticks % 100] = Packet.q - this.F; - this.F = Packet.q; - this.h[this.ticks % 100] = Packet.n - this.G; - this.G = Packet.n; - this.i[this.ticks % 100] = Packet.o - this.H; - this.H = Packet.o; + 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.methodProfiler.b(); this.methodProfiler.a("snooper"); - if (!this.n.d() && this.ticks > 100) { - this.n.a(); + if (!this.m.d() && this.ticks > 100) { + this.m.a(); } if (this.ticks % 6000 == 0) { - this.n.b(); + this.m.b(); } this.methodProfiler.b(); @@ -559,7 +541,7 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo /* Drop global time updates if (this.ticks % 20 == 0) { this.methodProfiler.a("timeSync"); - this.t.a(new Packet4UpdateTime(worldserver.getTime(), worldserver.getDayTime()), worldserver.worldProvider.dimension); + this.s.a(new Packet4UpdateTime(worldserver.getTime(), worldserver.getDayTime()), worldserver.worldProvider.dimension); this.methodProfiler.b(); } // CraftBukkit end */ @@ -591,17 +573,17 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo this.methodProfiler.b(); // } // CraftBukkit - // this.k[i][this.ticks % 100] = System.nanoTime() - j; // CraftBukkit + // this.j[i][this.ticks % 100] = System.nanoTime() - j; // CraftBukkit } this.methodProfiler.c("connection"); this.ae().b(); this.methodProfiler.c("players"); - this.t.tick(); + this.s.tick(); this.methodProfiler.c("tickables"); - for (i = 0; i < this.p.size(); ++i) { - ((IUpdatePlayerListBox) this.p.get(i)).a(); + for (i = 0; i < this.o.size(); ++i) { + ((IUpdatePlayerListBox) this.o.get(i)).a(); } this.methodProfiler.b(); @@ -612,11 +594,12 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo } public void a(IUpdatePlayerListBox iupdateplayerlistbox) { - this.p.add(iupdateplayerlistbox); + this.o.add(iupdateplayerlistbox); } public static void main(final OptionSet options) { // CraftBukkit - replaces main(String[] astring) StatisticList.a(); + IConsoleLogManager iconsolelogmanager = null; try { /* CraftBukkit start - replace everything @@ -668,6 +651,7 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo DedicatedServer dedicatedserver = new DedicatedServer(options); + iconsolelogmanager = dedicatedserver.getLogger(); if (options.has("port")) { int port = (Integer) options.valueOf("port"); if (port > 0) { @@ -705,7 +689,7 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo } if (flag) { - dedicatedserver.an(); + dedicatedserver.ao(); } */ @@ -713,7 +697,11 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo // Runtime.getRuntime().addShutdownHook(new ThreadShutdown(dedicatedserver)); // CraftBukkit end } catch (Exception exception) { - log.log(Level.SEVERE, "Failed to start the minecraft server", exception); + if (iconsolelogmanager != null) { + iconsolelogmanager.severe("Failed to start the minecraft server", exception); + } else { + Logger.getAnonymousLogger().log(Level.SEVERE, "Failed to start the minecraft server", exception); + } } } @@ -726,11 +714,11 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo } public void info(String s) { - log.info(s); + this.getLogger().info(s); } public void warning(String s) { - log.warning(s); + this.getLogger().warning(s); } public WorldServer getWorldServer(int i) { @@ -750,7 +738,7 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo } public int v() { - return this.s; + return this.r; } public String w() { @@ -758,19 +746,19 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo } public String getVersion() { - return "1.4.7"; + return "1.5"; } public int y() { - return this.t.getPlayerCount(); + return this.s.getPlayerCount(); } public int z() { - return this.t.getMaxPlayers(); + return this.s.getMaxPlayers(); } public String[] getPlayers() { - return this.t.d(); + return this.s.d(); } public String getPlugins() { @@ -811,7 +799,7 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo MinecraftServer.this.server.getPluginManager().callEvent(event); // Event changes end ServerCommand servercommand = new ServerCommand(event.getCommand(), RemoteControlCommandListener.instance); - // this.q.a(RemoteControlCommandListener.instance, s); + // this.p.a(RemoteControlCommandListener.instance, s); MinecraftServer.this.server.dispatchServerCommand(MinecraftServer.this.remoteConsole, servercommand); // CraftBukkit return RemoteControlCommandListener.instance.d(); }}; @@ -832,12 +820,12 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo } public void i(String s) { - log.log(Level.SEVERE, s); + this.getLogger().severe(s); } public void j(String s) { if (this.isDebugging()) { - log.log(Level.INFO, s); + this.getLogger().info(s); } } @@ -851,7 +839,7 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo crashreport.g().a("Vec3 Pool Size", (Callable) (new CrashReportVec3DPoolSize(this))); } - if (this.t != null) { + if (this.s != null) { crashreport.g().a("Player Count", (Callable) (new CrashReportPlayerCount(this))); } @@ -866,7 +854,7 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo if (s.startsWith("/")) { s = s.substring(1); boolean flag = !s.contains(" "); - List list = this.q.b(icommandlistener, s); + List list = this.p.b(icommandlistener, s); if (list != null) { Iterator iterator = list.iterator(); @@ -886,7 +874,7 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo } else { String[] astring = s.split(" ", -1); String s2 = astring[astring.length - 1]; - String[] astring1 = this.t.d(); + String[] astring1 = this.s.d(); int i = astring1.length; for (int j = 0; j < i; ++j) { @@ -905,7 +893,7 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo } public static MinecraftServer getServer() { - return l; + return k; } public String getName() { @@ -913,7 +901,7 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo } public void sendMessage(String s) { - log.info(StripColor.a(s)); + this.getLogger().info(StripColor.a(s)); } public boolean a(int i, String s) { @@ -925,43 +913,43 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo } public ICommandHandler getCommandHandler() { - return this.q; + return this.p; } public KeyPair F() { - return this.I; + return this.H; } public int G() { - return this.s; + return this.r; } public void setPort(int i) { - this.s = i; + this.r = i; } public String H() { - return this.J; + return this.I; } public void k(String s) { - this.J = s; + this.I = s; } public boolean I() { - return this.J != null; + return this.I != null; } public String J() { - return this.K; + return this.J; } public void l(String s) { - this.K = s; + this.J = s; } public void a(KeyPair keypair) { - this.I = keypair; + this.H = keypair; } public void c(int i) { @@ -998,7 +986,7 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo } public void c(boolean flag) { - this.N = flag; + this.M = flag; } public Convertable getConvertable() { @@ -1006,7 +994,7 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo } public void P() { - this.O = true; + this.N = true; this.getConvertable().d(); // CraftBukkit start - This needs review, what does it do? (it's new) @@ -1024,11 +1012,11 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo } public String getTexturePack() { - return this.P; + return this.O; } public void setTexturePack(String s) { - this.P = s; + this.O = s; } public void a(MojangStatisticsGenerator mojangstatisticsgenerator) { @@ -1036,14 +1024,14 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo 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.t.getSeenPlayers().length)); + mojangstatisticsgenerator.a("players_seen", Integer.valueOf(this.s.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.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))); + 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))); int i = 0; // CraftBukkit start @@ -1059,8 +1047,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.D)); - mojangstatisticsgenerator.a("world[" + i + "][chunks_loaded]", Integer.valueOf(worldserver.I().getLoadedChunks())); + mojangstatisticsgenerator.a("world[" + i + "][height]", Integer.valueOf(this.C)); + mojangstatisticsgenerator.a("world[" + i + "][chunks_loaded]", Integer.valueOf(worldserver.J().getLoadedChunks())); ++i; // } // CraftBukkit } @@ -1136,11 +1124,11 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo } public int getMaxBuildHeight() { - return this.D; + return this.C; } public void d(int i) { - this.D = i; + this.C = i; } public boolean isStopped() { @@ -1148,11 +1136,11 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo } public PlayerList getPlayerList() { - return this.t; + return this.s; } public void a(PlayerList playerlist) { - this.t = playerlist; + this.s = playerlist; } public void a(EnumGamemode enumgamemode) { @@ -1176,7 +1164,7 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo } public void ai() { - this.T = true; + this.S = true; } public ChunkCoordinates b() { @@ -1187,7 +1175,13 @@ public abstract class MinecraftServer implements ICommandListener, Runnable, IMo return 16; } + public boolean a(World world, int i, int j, int k, EntityHuman entityhuman) { + return false; + } + + public abstract IConsoleLogManager getLogger(); + public static PlayerList a(MinecraftServer minecraftserver) { - return minecraftserver.t; + return minecraftserver.s; } } diff --git a/src/main/java/net/minecraft/server/MobEffectList.java b/src/main/java/net/minecraft/server/MobEffectList.java index 866964985e..f325bef1c5 100644 --- a/src/main/java/net/minecraft/server/MobEffectList.java +++ b/src/main/java/net/minecraft/server/MobEffectList.java @@ -98,8 +98,8 @@ public class MobEffectList { // CraftBukkit end } else if (this.id == HUNGER.id && entityliving instanceof EntityHuman) { ((EntityHuman) entityliving).j(0.025F * (float) (i + 1)); - } else if ((this.id != HEAL.id || entityliving.bA()) && (this.id != HARM.id || !entityliving.bA())) { - if (this.id == HARM.id && !entityliving.bA() || this.id == HEAL.id && entityliving.bA()) { + } 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()) { // CraftBukkit start EntityDamageEvent event = CraftEventFactory.callEntityDamageEvent(null, entityliving, EntityDamageEvent.DamageCause.MAGIC, 6 << i); @@ -122,8 +122,8 @@ public class MobEffectList { // CraftBukkit end int j; - if ((this.id != HEAL.id || entityliving1.bA()) && (this.id != HARM.id || !entityliving1.bA())) { - if (this.id == HARM.id && !entityliving1.bA() || this.id == HEAL.id && entityliving1.bA()) { + 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()) { j = (int) (d0 * (double) (6 << i) + 0.5D); if (entityliving == null) { entityliving1.damageEntity(DamageSource.MAGIC, j); diff --git a/src/main/java/net/minecraft/server/MobSpawnerAbstract.java b/src/main/java/net/minecraft/server/MobSpawnerAbstract.java new file mode 100644 index 0000000000..4ba4735c04 --- /dev/null +++ b/src/main/java/net/minecraft/server/MobSpawnerAbstract.java @@ -0,0 +1,281 @@ +package net.minecraft.server; + +import java.util.ArrayList; +import java.util.Collection; +import java.util.Iterator; +import java.util.List; + +import org.bukkit.event.entity.CreatureSpawnEvent; // CraftBukkit + +public abstract class MobSpawnerAbstract { + + public int spawnDelay = 20; + private String mobName = "Pig"; + private List mobs = null; + private TileEntityMobSpawnerData spawnData = null; + public double c; + public double d = 0.0D; + private int minSpawnDelay = 200; + private int maxSpawnDelay = 800; + private int spawnCount = 4; + private Entity j; + private int maxNearbyEntities = 6; + private int requiredPlayerRange = 16; + private int spawnRange = 4; + + public MobSpawnerAbstract() {} + + public String getMobName() { + if (this.i() == null) { + if (this.mobName.equals("Minecart")) { + this.mobName = "MinecartRideable"; + } + + return this.mobName; + } else { + return this.i().c; + } + } + + public void a(String s) { + this.mobName = s; + } + + public boolean f() { + return this.a().findNearbyPlayer((double) this.b() + 0.5D, (double) this.c() + 0.5D, (double) this.d() + 0.5D, (double) this.requiredPlayerRange) != null; + } + + public void g() { + if (this.f()) { + double d0; + + if (this.a().isStatic) { + double d1 = (double) ((float) this.b() + this.a().random.nextFloat()); + double d2 = (double) ((float) this.c() + this.a().random.nextFloat()); + + d0 = (double) ((float) this.d() + this.a().random.nextFloat()); + this.a().addParticle("smoke", d1, d2, d0, 0.0D, 0.0D, 0.0D); + this.a().addParticle("flame", d1, d2, d0, 0.0D, 0.0D, 0.0D); + if (this.spawnDelay > 0) { + --this.spawnDelay; + } + + this.d = this.c; + this.c = (this.c + (double) (1000.0F / ((float) this.spawnDelay + 200.0F))) % 360.0D; + } else { + if (this.spawnDelay == -1) { + this.j(); + } + + if (this.spawnDelay > 0) { + --this.spawnDelay; + return; + } + + boolean flag = false; + + for (int i = 0; i < this.spawnCount; ++i) { + Entity entity = EntityTypes.createEntityByName(this.getMobName(), this.a()); + + if (entity == null) { + return; + } + + int j = this.a().a(entity.getClass(), AxisAlignedBB.a().a((double) this.b(), (double) this.c(), (double) this.d(), (double) (this.b() + 1), (double) (this.c() + 1), (double) (this.d() + 1)).grow((double) (this.spawnRange * 2), 4.0D, (double) (this.spawnRange * 2))).size(); + + if (j >= this.maxNearbyEntities) { + this.j(); + return; + } + + 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; + + entity.setPositionRotation(d0, d3, d4, this.a().random.nextFloat() * 360.0F, 0.0F); + if (entityliving == null || entityliving.canSpawn()) { + this.a(entity); + this.a().triggerEffect(2004, this.b(), this.c(), this.d(), 0); + if (entityliving != null) { + entityliving.aU(); + } + + flag = true; + } + } + + if (flag) { + this.j(); + } + } + } + } + + public Entity a(Entity entity) { + if (this.i() != null) { + NBTTagCompound nbttagcompound = new NBTTagCompound(); + + entity.d(nbttagcompound); + Iterator iterator = this.i().b.c().iterator(); + + while (iterator.hasNext()) { + NBTBase nbtbase = (NBTBase) iterator.next(); + + nbttagcompound.set(nbtbase.getName(), nbtbase.clone()); + } + + entity.f(nbttagcompound); + if (entity.world != null) { + entity.world.addEntity(entity, CreatureSpawnEvent.SpawnReason.SPAWNER); // CraftBukkit + } + + NBTTagCompound nbttagcompound1; + + for (Entity entity1 = entity; nbttagcompound.hasKey("Riding"); nbttagcompound = nbttagcompound1) { + nbttagcompound1 = nbttagcompound.getCompound("Riding"); + Entity entity2 = EntityTypes.createEntityByName(nbttagcompound1.getString("id"), this.a()); + + if (entity2 != null) { + NBTTagCompound nbttagcompound2 = new NBTTagCompound(); + + entity2.d(nbttagcompound2); + Iterator iterator1 = nbttagcompound1.c().iterator(); + + while (iterator1.hasNext()) { + NBTBase nbtbase1 = (NBTBase) iterator1.next(); + + nbttagcompound2.set(nbtbase1.getName(), nbtbase1.clone()); + } + + entity2.f(nbttagcompound2); + entity2.setPositionRotation(entity1.locX, entity1.locY, entity1.locZ, entity1.yaw, entity1.pitch); + this.a().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); + } + + return entity; + } + + private void j() { + if (this.maxSpawnDelay <= this.minSpawnDelay) { + this.spawnDelay = this.minSpawnDelay; + } else { + int i = this.maxSpawnDelay - this.minSpawnDelay; + + this.spawnDelay = this.minSpawnDelay + this.a().random.nextInt(i); + } + + if (this.mobs != null && this.mobs.size() > 0) { + this.a((TileEntityMobSpawnerData) WeightedRandom.a(this.a().random, (Collection) this.mobs)); + } + + this.a(1); + } + + public void a(NBTTagCompound nbttagcompound) { + this.mobName = nbttagcompound.getString("EntityId"); + this.spawnDelay = nbttagcompound.getShort("Delay"); + if (nbttagcompound.hasKey("SpawnPotentials")) { + this.mobs = new ArrayList(); + NBTTagList nbttaglist = nbttagcompound.getList("SpawnPotentials"); + + for (int i = 0; i < nbttaglist.size(); ++i) { + this.mobs.add(new TileEntityMobSpawnerData(this, (NBTTagCompound) nbttaglist.get(i))); + } + } else { + this.mobs = null; + } + + if (nbttagcompound.hasKey("SpawnData")) { + this.a(new TileEntityMobSpawnerData(this, nbttagcompound.getCompound("SpawnData"), this.mobName)); + } else { + this.a((TileEntityMobSpawnerData) null); + } + + if (nbttagcompound.hasKey("MinSpawnDelay")) { + this.minSpawnDelay = nbttagcompound.getShort("MinSpawnDelay"); + this.maxSpawnDelay = nbttagcompound.getShort("MaxSpawnDelay"); + this.spawnCount = nbttagcompound.getShort("SpawnCount"); + } + + if (nbttagcompound.hasKey("MaxNearbyEntities")) { + this.maxNearbyEntities = nbttagcompound.getShort("MaxNearbyEntities"); + this.requiredPlayerRange = nbttagcompound.getShort("RequiredPlayerRange"); + } + + if (nbttagcompound.hasKey("SpawnRange")) { + this.spawnRange = nbttagcompound.getShort("SpawnRange"); + } + + if (this.a() != null && this.a().isStatic) { + this.j = null; + } + } + + public void b(NBTTagCompound nbttagcompound) { + nbttagcompound.setString("EntityId", this.getMobName()); + nbttagcompound.setShort("Delay", (short) this.spawnDelay); + nbttagcompound.setShort("MinSpawnDelay", (short) this.minSpawnDelay); + nbttagcompound.setShort("MaxSpawnDelay", (short) this.maxSpawnDelay); + nbttagcompound.setShort("SpawnCount", (short) this.spawnCount); + nbttagcompound.setShort("MaxNearbyEntities", (short) this.maxNearbyEntities); + nbttagcompound.setShort("RequiredPlayerRange", (short) this.requiredPlayerRange); + nbttagcompound.setShort("SpawnRange", (short) this.spawnRange); + if (this.i() != null) { + nbttagcompound.setCompound("SpawnData", (NBTTagCompound) this.i().b.clone()); + } + + if (this.i() != null || this.mobs != null && this.mobs.size() > 0) { + NBTTagList nbttaglist = new NBTTagList(); + + if (this.mobs != null && this.mobs.size() > 0) { + Iterator iterator = this.mobs.iterator(); + + while (iterator.hasNext()) { + TileEntityMobSpawnerData tileentitymobspawnerdata = (TileEntityMobSpawnerData) iterator.next(); + + nbttaglist.add(tileentitymobspawnerdata.a()); + } + } else { + nbttaglist.add(this.i().a()); + } + + nbttagcompound.set("SpawnPotentials", nbttaglist); + } + } + + public boolean b(int i) { + if (i == 1 && this.a().isStatic) { + this.spawnDelay = this.minSpawnDelay; + return true; + } else { + return false; + } + } + + public TileEntityMobSpawnerData i() { + return this.spawnData; + } + + public void a(TileEntityMobSpawnerData tileentitymobspawnerdata) { + this.spawnData = tileentitymobspawnerdata; + } + + public abstract void a(int i); + + public abstract World a(); + + public abstract int b(); + + public abstract int c(); + + public abstract int d(); +} diff --git a/src/main/java/net/minecraft/server/NetworkManager.java b/src/main/java/net/minecraft/server/NetworkManager.java index 7c64e9bbb0..1862863c6e 100644 --- a/src/main/java/net/minecraft/server/NetworkManager.java +++ b/src/main/java/net/minecraft/server/NetworkManager.java @@ -21,37 +21,39 @@ public class NetworkManager implements INetworkManager { public static AtomicInteger a = new AtomicInteger(); public static AtomicInteger b = new AtomicInteger(); - private Object h = new Object(); + private final Object h = new Object(); + private final IConsoleLogManager i; public Socket socket; // CraftBukkit - private -> public - private final SocketAddress j; + private final SocketAddress k; private volatile DataInputStream input; private volatile DataOutputStream output; - private volatile boolean m = true; - private volatile boolean n = false; + private volatile boolean n = true; + private volatile boolean o = false; 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 s = false; - private Thread t; + private boolean t = false; private Thread u; - private String v = ""; - private Object[] w; - private int x = 0; + private Thread v; + private String w = ""; + private Object[] x; private int y = 0; + private int z = 0; 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 z = null; - private PrivateKey A = null; + private SecretKey A = null; + private PrivateKey B = null; private int lowPriorityQueueDelay = 50; - public NetworkManager(Socket socket, String s, Connection connection, PrivateKey privatekey) throws IOException { // CraftBukkit - throws IOException - this.A = privatekey; + public NetworkManager(IConsoleLogManager iconsolelogmanager, Socket socket, String s, Connection connection, PrivateKey privatekey) throws IOException { // CraftBukkit - throws IOException + this.B = privatekey; this.socket = socket; - this.j = socket.getRemoteSocketAddress(); + this.i = iconsolelogmanager; + this.k = socket.getRemoteSocketAddress(); this.connection = connection; try { @@ -63,10 +65,10 @@ public class NetworkManager implements INetworkManager { this.input = new DataInputStream(socket.getInputStream()); this.output = new DataOutputStream(new BufferedOutputStream(socket.getOutputStream(), 5120)); - this.u = new NetworkReaderThread(this, s + " read thread"); - this.t = new NetworkWriterThread(this, s + " write thread"); + this.v = new NetworkReaderThread(this, s + " read thread"); + this.u = new NetworkWriterThread(this, s + " write thread"); + this.v.start(); this.u.start(); - this.t.start(); } public void a(Connection connection) { @@ -74,11 +76,11 @@ public class NetworkManager implements INetworkManager { } public void queue(Packet packet) { - if (!this.s) { + if (!this.t) { Object object = this.h; synchronized (this.h) { - this.y += packet.a() + 1; + this.z += packet.a() + 1; this.highPriorityQueue.add(packet); } } @@ -98,14 +100,14 @@ public class NetworkManager implements INetworkManager { Packet.a(packet, this.output); if (packet instanceof Packet252KeyResponse && !this.g) { if (!this.connection.a()) { - this.z = ((Packet252KeyResponse) packet).d(); + this.A = ((Packet252KeyResponse) packet).d(); } this.k(); } aint = d; - i = packet.k(); + i = packet.n(); aint[i] += packet.a() + 1; flag = true; } @@ -117,7 +119,7 @@ public class NetworkManager implements INetworkManager { if (packet != null) { Packet.a(packet, this.output); aint = d; - i = packet.k(); + i = packet.n(); aint[i] += packet.a() + 1; this.lowPriorityQueueDelay = 0; flag = true; @@ -126,7 +128,7 @@ public class NetworkManager implements INetworkManager { return flag; } catch (Exception exception) { - if (!this.n) { + if (!this.o) { this.a(exception); } @@ -142,7 +144,7 @@ public class NetworkManager implements INetworkManager { synchronized (this.h) { while (!list.isEmpty() && packet == null) { packet = (Packet) list.remove(0); - this.y -= packet.a() + 1; + this.z -= packet.a() + 1; if (this.a(packet, flag)) { packet = null; } @@ -167,19 +169,19 @@ public class NetworkManager implements INetworkManager { } packet1 = (Packet) iterator.next(); - } while (packet1.k() != packet.k()); + } while (packet1.n() != packet.n()); return packet.a(packet1); } } public void a() { - if (this.u != null) { - this.u.interrupt(); + if (this.v != null) { + this.v.interrupt(); } - if (this.t != null) { - this.t.interrupt(); + if (this.u != null) { + this.u.interrupt(); } } @@ -187,24 +189,24 @@ public class NetworkManager implements INetworkManager { boolean flag = false; try { - Packet packet = Packet.a(this.input, this.connection.a(), this.socket); + Packet packet = Packet.a(this.i, this.input, this.connection.a(), this.socket); if (packet != null) { if (packet instanceof Packet252KeyResponse && !this.f) { if (this.connection.a()) { - this.z = ((Packet252KeyResponse) packet).a(this.A); + this.A = ((Packet252KeyResponse) packet).a(this.B); } this.j(); } int[] aint = c; - int i = packet.k(); + int i = packet.n(); aint[i] += packet.a() + 1; - if (!this.s) { + if (!this.t) { if (packet.a_() && this.connection.b()) { - this.x = 0; + this.y = 0; packet.handle(this.connection); } else { this.inboundQueue.add(packet); @@ -218,7 +220,7 @@ public class NetworkManager implements INetworkManager { return flag; } catch (Exception exception) { - if (!this.n) { + if (!this.o) { this.a(exception); } @@ -232,11 +234,11 @@ public class NetworkManager implements INetworkManager { } public void a(String s, Object... aobject) { - if (this.m) { - this.n = true; - this.v = s; - this.w = aobject; - this.m = false; + if (this.n) { + this.o = true; + this.w = s; + this.x = aobject; + this.n = false; (new NetworkMasterThread(this)).start(); try { @@ -264,16 +266,16 @@ public class NetworkManager implements INetworkManager { } public void b() { - if (this.y > 2097152) { + if (this.z > 2097152) { this.a("disconnect.overflow", new Object[0]); } if (this.inboundQueue.isEmpty()) { - if (this.x++ == 1200) { + if (this.y++ == 1200) { this.a("disconnect.timeout", new Object[0]); } } else { - this.x = 0; + this.y = 0; } int i = 1000; @@ -282,7 +284,7 @@ public class NetworkManager implements INetworkManager { Packet packet = (Packet) this.inboundQueue.poll(); // CraftBukkit - remove -> poll // CraftBukkit start - if (this.connection instanceof PendingConnection ? ((PendingConnection) this.connection).c : ((PlayerConnection) this.connection).disconnected) { + if (this.connection instanceof PendingConnection ? ((PendingConnection) this.connection).b : ((PlayerConnection) this.connection).disconnected) { continue; } // CraftBukkit end @@ -291,20 +293,20 @@ public class NetworkManager implements INetworkManager { } this.a(); - if (this.n && this.inboundQueue.isEmpty()) { - this.connection.a(this.v, this.w); + if (this.o && this.inboundQueue.isEmpty()) { + this.connection.a(this.w, this.x); } } public SocketAddress getSocketAddress() { - return this.j; + return this.k; } public void d() { - if (!this.s) { + if (!this.t) { this.a(); - this.s = true; - this.u.interrupt(); + this.t = true; + this.v.interrupt(); (new NetworkMonitorThread(this)).start(); } } @@ -313,13 +315,13 @@ public class NetworkManager implements INetworkManager { this.f = true; InputStream inputstream = this.socket.getInputStream(); - this.input = new DataInputStream(MinecraftEncryption.a(this.z, inputstream)); + this.input = new DataInputStream(MinecraftEncryption.a(this.A, inputstream)); } private void k() throws IOException { // CraftBukkit - throws IOException this.output.flush(); this.g = true; - BufferedOutputStream bufferedoutputstream = new BufferedOutputStream(MinecraftEncryption.a(this.z, this.socket.getOutputStream()), 5120); + BufferedOutputStream bufferedoutputstream = new BufferedOutputStream(MinecraftEncryption.a(this.A, this.socket.getOutputStream()), 5120); this.output = new DataOutputStream(bufferedoutputstream); } @@ -333,11 +335,11 @@ public class NetworkManager implements INetworkManager { } static boolean a(NetworkManager networkmanager) { - return networkmanager.m; + return networkmanager.n; } static boolean b(NetworkManager networkmanager) { - return networkmanager.s; + return networkmanager.t; } static boolean c(NetworkManager networkmanager) { @@ -353,7 +355,7 @@ public class NetworkManager implements INetworkManager { } static boolean f(NetworkManager networkmanager) { - return networkmanager.n; + return networkmanager.o; } static void a(NetworkManager networkmanager, Exception exception) { @@ -361,10 +363,10 @@ public class NetworkManager implements INetworkManager { } static Thread g(NetworkManager networkmanager) { - return networkmanager.u; + return networkmanager.v; } static Thread h(NetworkManager networkmanager) { - return networkmanager.t; + return networkmanager.u; } } diff --git a/src/main/java/net/minecraft/server/Packet.java b/src/main/java/net/minecraft/server/Packet.java index 7472d44107..c4212e8351 100644 --- a/src/main/java/net/minecraft/server/Packet.java +++ b/src/main/java/net/minecraft/server/Packet.java @@ -16,11 +16,12 @@ public abstract class Packet { private static Map a = new HashMap(); private static Set b = new HashSet(); private static Set c = new HashSet(); + protected IConsoleLogManager m; public final long timestamp = System.currentTimeMillis(); - public static long n; public static long o; public static long p; public static long q; + public static long r; public boolean lowPriority = false; // CraftBukkit start - calculate packet ID once - used a bunch of times private int packetID; @@ -48,14 +49,14 @@ public abstract class Packet { } } - public static Packet d(int i) { + public static Packet a(IConsoleLogManager iconsolelogmanager, int i) { try { Class oclass = (Class) l.get(i); return oclass == null ? null : (Packet) oclass.newInstance(); } catch (Exception exception) { exception.printStackTrace(); - System.out.println("Skipping packet with id " + i); + iconsolelogmanager.severe("Skipping packet with id " + i); return null; } } @@ -73,16 +74,16 @@ public abstract class Packet { } else { byte[] abyte = new byte[short1]; - datainputstream.read(abyte); + datainputstream.readFully(abyte); return abyte; } } - public final int k() { + public final int n() { return packetID; // ((Integer) a.get(this.getClass())).intValue(); // CraftBukkit } - public static Packet a(DataInputStream datainputstream, boolean flag, Socket socket) throws IOException { // CraftBukkit - throws IOException + public static Packet a(IConsoleLogManager iconsolelogmanager, DataInputStream datainputstream, boolean flag, Socket socket) throws IOException { // CraftBukkit - throws IOException boolean flag1 = false; Packet packet = null; int i = socket.getSoTimeout(); @@ -99,46 +100,46 @@ public abstract class Packet { throw new IOException("Bad packet id " + j); } - packet = d(j); + packet = a(iconsolelogmanager, j); if (packet == null) { throw new IOException("Bad packet id " + j); } + packet.m = iconsolelogmanager; if (packet instanceof Packet254GetInfo) { socket.setSoTimeout(1500); } packet.a(datainputstream); - ++n; - o += (long) packet.a(); + ++o; + p += (long) packet.a(); } catch (EOFException eofexception) { - System.out.println("Reached end of stream"); + iconsolelogmanager.severe("Reached end of stream"); return null; } // CraftBukkit start catch (java.net.SocketTimeoutException exception) { - System.out.println("Read timed out"); + iconsolelogmanager.severe("Read timed out"); return null; } catch (java.net.SocketException exception) { - System.out.println("Connection reset"); + iconsolelogmanager.severe("Connection reset"); return null; } // CraftBukkit end - PacketCounter.a(j, (long) packet.a()); - ++n; - o += (long) packet.a(); + ++o; + p += (long) packet.a(); socket.setSoTimeout(i); return packet; } public static void a(Packet packet, DataOutputStream dataoutputstream) throws IOException { // CraftBukkit - throws IOException - dataoutputstream.write(packet.k()); + dataoutputstream.write(packet.n()); packet.a(dataoutputstream); - ++p; - q += (long) packet.a(); + ++q; + r += (long) packet.a(); } public static void a(String s, DataOutputStream dataoutputstream) throws IOException { // CraftBukkit - throws IOException @@ -218,7 +219,7 @@ public abstract class Packet { dataoutputstream.writeShort(itemstack.getData()); NBTTagCompound nbttagcompound = null; - if (itemstack.getItem().n() || itemstack.getItem().q()) { + if (itemstack.getItem().o() || itemstack.getItem().r()) { nbttagcompound = itemstack.tag; } @@ -300,6 +301,7 @@ public abstract class Packet { a(60, true, false, Packet60Explosion.class); a(61, true, false, Packet61WorldEvent.class); a(62, true, false, Packet62NamedSoundEffect.class); + a(63, true, false, Packet63WorldParticles.class); a(70, true, false, Packet70Bed.class); a(71, true, false, Packet71Weather.class); a(100, true, false, Packet100OpenWindow.class); @@ -320,6 +322,10 @@ public abstract class Packet { a(203, true, true, Packet203TabComplete.class); a(204, false, true, Packet204LocaleAndViewDistance.class); a(205, false, true, Packet205ClientCommand.class); + a(206, true, false, Packet206SetScoreboardObjective.class); + a(207, true, false, Packet207SetScoreboardScore.class); + a(208, true, false, Packet208SetScoreboardDisplayObjective.class); + a(209, true, false, Packet209SetScoreboardTeam.class); a(250, true, true, Packet250CustomPayload.class); a(252, true, true, Packet252KeyResponse.class); a(253, true, false, Packet253KeyRequest.class); diff --git a/src/main/java/net/minecraft/server/PathfinderGoalArrowAttack.java b/src/main/java/net/minecraft/server/PathfinderGoalArrowAttack.java index fe9132d7be..685af68ebf 100644 --- a/src/main/java/net/minecraft/server/PathfinderGoalArrowAttack.java +++ b/src/main/java/net/minecraft/server/PathfinderGoalArrowAttack.java @@ -7,13 +7,21 @@ public class PathfinderGoalArrowAttack extends PathfinderGoal { private final EntityLiving a; private final IRangedEntity b; private EntityLiving c; - private int d = 0; + private int d; private float e; - private int f = 0; + private int f; private int g; - private float h; + 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, float f, int i, int j, float f1) { + this.d = -1; + this.f = 0; if (!(irangedentity instanceof EntityLiving)) { throw new IllegalArgumentException("ArrowAttackGoal requires Mob implements RangedAttackMob"); } else { @@ -21,8 +29,9 @@ public class PathfinderGoalArrowAttack extends PathfinderGoal { this.a = (EntityLiving) irangedentity; this.e = f; this.g = i; - this.h = f1 * f1; - this.d = i / 2; + this.h = j; + this.i = f1; + this.j = f1 * f1; this.a(3); } } @@ -49,12 +58,12 @@ public class PathfinderGoalArrowAttack extends PathfinderGoal { // CraftBukkit end this.c = null; this.f = 0; - this.d = this.g / 2; + this.d = -1; } public void e() { double d0 = this.a.e(this.c.locX, this.c.boundingBox.b, this.c.locZ); - boolean flag = this.a.aA().canSee(this.c); + boolean flag = this.a.aD().canSee(this.c); if (flag) { ++this.f; @@ -62,19 +71,36 @@ public class PathfinderGoalArrowAttack extends PathfinderGoal { this.f = 0; } - if (d0 <= (double) this.h && this.f >= 20) { + if (d0 <= (double) this.j && this.f >= 20) { this.a.getNavigation().g(); } else { this.a.getNavigation().a(this.c, this.e); } this.a.getControllerLook().a(this.c, 30.0F, 30.0F); - this.d = Math.max(this.d - 1, 0); - if (this.d <= 0) { - if (d0 <= (double) this.h && flag) { - this.b.d(this.c); - this.d = this.g; + float f; + + if (--this.d == 0) { + if (d0 > (double) this.j || !flag) { + return; } + + f = MathHelper.sqrt(d0) / this.i; + float f1 = f; + + if (f < 0.1F) { + f1 = 0.1F; + } + + if (f1 > 1.0F) { + f1 = 1.0F; + } + + this.b.a(this.c, f1); + this.d = MathHelper.d(f * (float) (this.h - this.g) + (float) this.g); + } else if (this.d < 0) { + f = MathHelper.sqrt(d0) / this.i; + this.d = MathHelper.d(f * (float) (this.h - this.g) + (float) this.g); } } } diff --git a/src/main/java/net/minecraft/server/PathfinderGoalBreakDoor.java b/src/main/java/net/minecraft/server/PathfinderGoalBreakDoor.java index c4efd2b8d5..86b194cefb 100644 --- a/src/main/java/net/minecraft/server/PathfinderGoalBreakDoor.java +++ b/src/main/java/net/minecraft/server/PathfinderGoalBreakDoor.java @@ -10,7 +10,7 @@ public class PathfinderGoalBreakDoor extends PathfinderGoalDoorInteract { } public boolean a() { - return !super.a() ? false : (!this.a.world.getGameRules().getBoolean("mobGriefing") ? false : !this.e.a_(this.a.world, this.b, this.c, this.d)); + return !super.a() ? false : (!this.a.world.getGameRules().getBoolean("mobGriefing") ? false : !this.e.b_(this.a.world, this.b, this.c, this.d)); } public void c() { @@ -21,17 +21,17 @@ public class PathfinderGoalBreakDoor extends PathfinderGoalDoorInteract { public boolean b() { double d0 = this.a.e((double) this.b, (double) this.c, (double) this.d); - return this.i <= 240 && !this.e.a_(this.a.world, this.b, this.c, this.d) && d0 < 4.0D; + return this.i <= 240 && !this.e.b_(this.a.world, this.b, this.c, this.d) && d0 < 4.0D; } public void d() { super.d(); - this.a.world.g(this.a.id, this.b, this.c, this.d, -1); + this.a.world.f(this.a.id, this.b, this.c, this.d, -1); } public void e() { super.e(); - if (this.a.aB().nextInt(20) == 0) { + if (this.a.aE().nextInt(20) == 0) { this.a.world.triggerEffect(1010, this.b, this.c, this.d, 0); } @@ -39,7 +39,7 @@ public class PathfinderGoalBreakDoor extends PathfinderGoalDoorInteract { int i = (int) ((float) this.i / 240.0F * 10.0F); if (i != this.j) { - this.a.world.g(this.a.id, this.b, this.c, this.d, i); + this.a.world.f(this.a.id, this.b, this.c, this.d, i); this.j = i; } @@ -51,7 +51,7 @@ public class PathfinderGoalBreakDoor extends PathfinderGoalDoorInteract { } // CraftBukkit end - this.a.world.setTypeId(this.b, this.c, this.d, 0); + this.a.world.setAir(this.b, this.c, this.d); this.a.world.triggerEffect(1012, this.b, this.c, this.d, 0); this.a.world.triggerEffect(2001, this.b, this.c, this.d, this.e.id); } diff --git a/src/main/java/net/minecraft/server/PathfinderGoalBreed.java b/src/main/java/net/minecraft/server/PathfinderGoalBreed.java index a2c57a6235..ca544f3697 100644 --- a/src/main/java/net/minecraft/server/PathfinderGoalBreed.java +++ b/src/main/java/net/minecraft/server/PathfinderGoalBreed.java @@ -38,10 +38,10 @@ public class PathfinderGoalBreed extends PathfinderGoal { } public void e() { - this.d.getControllerLook().a(this.e, 10.0F, (float) this.d.bp()); + this.d.getControllerLook().a(this.e, 10.0F, (float) this.d.bs()); this.d.getNavigation().a((EntityLiving) this.e, this.c); ++this.b; - if (this.b == 60) { + if (this.b >= 60 && this.d.e(this.e) < 9.0D) { this.g(); } } @@ -49,17 +49,18 @@ public class PathfinderGoalBreed extends PathfinderGoal { private EntityAnimal f() { float f = 8.0F; List list = this.a.a(this.d.getClass(), this.d.boundingBox.grow((double) f, (double) f, (double) f)); + double d0 = Double.MAX_VALUE; + EntityAnimal entityanimal = null; Iterator iterator = list.iterator(); - EntityAnimal entityanimal; + while (iterator.hasNext()) { + EntityAnimal entityanimal1 = (EntityAnimal) iterator.next(); - do { - if (!iterator.hasNext()) { - return null; + if (this.d.mate(entityanimal1) && this.d.e(entityanimal1) < d0) { + entityanimal = entityanimal1; + d0 = this.d.e(entityanimal1); } - - entityanimal = (EntityAnimal) iterator.next(); - } while (!this.d.mate(entityanimal)); + } return entityanimal; } @@ -75,7 +76,7 @@ public class PathfinderGoalBreed extends PathfinderGoal { 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.aB(); + Random random = this.d.aE(); 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 68ad106398..1feced1a58 100644 --- a/src/main/java/net/minecraft/server/PathfinderGoalEatTile.java +++ b/src/main/java/net/minecraft/server/PathfinderGoalEatTile.java @@ -18,7 +18,7 @@ public class PathfinderGoalEatTile extends PathfinderGoal { } public boolean a() { - if (this.b.aB().nextInt(this.b.isBaby() ? 50 : 1000) != 0) { + if (this.b.aE().nextInt(this.b.isBaby() ? 50 : 1000) != 0) { return false; } else { int i = MathHelper.floor(this.b.locX); @@ -57,17 +57,16 @@ public class PathfinderGoalEatTile extends PathfinderGoal { if (this.c.getTypeId(i, j, k) == Block.LONG_GRASS.id) { // CraftBukkit start if (!CraftEventFactory.callEntityChangeBlockEvent(this.b.getBukkitEntity(), this.b.world.getWorld().getBlockAt(i, j, k), Material.AIR).isCancelled()) { - this.c.triggerEffect(2001, i, j, k, Block.LONG_GRASS.id + 4096); - this.c.setTypeId(i, j, k, 0); - this.b.aH(); + this.c.setAir(i, j, k, false); + this.b.aK(); } // CraftBukkit end } else if (this.c.getTypeId(i, j - 1, k) == Block.GRASS.id) { // CraftBukkit start if (!CraftEventFactory.callEntityChangeBlockEvent(this.b.getBukkitEntity(), this.b.world.getWorld().getBlockAt(i, j - 1, k), Material.DIRT).isCancelled()) { this.c.triggerEffect(2001, i, j - 1, k, Block.GRASS.id); - this.c.setTypeId(i, j - 1, k, Block.DIRT.id); - this.b.aH(); + this.c.setTypeIdAndData(i, j - 1, k, Block.DIRT.id, 0, 2); + this.b.aK(); } // CraftBukkit end } diff --git a/src/main/java/net/minecraft/server/PathfinderGoalMeleeAttack.java b/src/main/java/net/minecraft/server/PathfinderGoalMeleeAttack.java index 016fe8774d..7ccb12d6b2 100644 --- a/src/main/java/net/minecraft/server/PathfinderGoalMeleeAttack.java +++ b/src/main/java/net/minecraft/server/PathfinderGoalMeleeAttack.java @@ -45,7 +45,7 @@ public class PathfinderGoalMeleeAttack extends PathfinderGoal { public boolean b() { EntityLiving entityliving = this.b.getGoalTarget(); - return entityliving == null ? false : (!this.c.isAlive() ? false : (!this.f ? !this.b.getNavigation().f() : this.b.e(MathHelper.floor(this.c.locX), MathHelper.floor(this.c.locY), MathHelper.floor(this.c.locZ)))); + 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)))); } public void c() { @@ -65,8 +65,8 @@ public class PathfinderGoalMeleeAttack extends PathfinderGoal { public void e() { this.b.getControllerLook().a(this.c, 30.0F, 30.0F); - if ((this.f || this.b.aA().canSee(this.c)) && --this.i <= 0) { - this.i = 4 + this.b.aB().nextInt(7); + if ((this.f || this.b.aD().canSee(this.c)) && --this.i <= 0) { + this.i = 4 + this.b.aE().nextInt(7); this.b.getNavigation().a(this.c, this.e); } @@ -76,8 +76,8 @@ public class PathfinderGoalMeleeAttack extends PathfinderGoal { 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.bD() != null) { - this.b.bH(); + if (this.b.bG() != null) { + this.b.bK(); } this.b.m(this.c); diff --git a/src/main/java/net/minecraft/server/PathfinderGoalSit.java b/src/main/java/net/minecraft/server/PathfinderGoalSit.java index a7c32bdde9..031005ed5b 100644 --- a/src/main/java/net/minecraft/server/PathfinderGoalSit.java +++ b/src/main/java/net/minecraft/server/PathfinderGoalSit.java @@ -13,14 +13,14 @@ public class PathfinderGoalSit extends PathfinderGoal { public boolean a() { if (!this.a.isTamed()) { return this.b && this.a.getGoalTarget() == null; // CraftBukkit - Allow sitting for wild animals - } else if (this.a.H()) { + } else if (this.a.G()) { return false; } else if (!this.a.onGround) { return false; } else { EntityLiving entityliving = this.a.getOwner(); - return entityliving == null ? true : (this.a.e(entityliving) < 144.0D && entityliving.aC() != null ? false : this.b); + return entityliving == null ? true : (this.a.e(entityliving) < 144.0D && entityliving.aF() != null ? false : this.b); } } diff --git a/src/main/java/net/minecraft/server/PathfinderGoalTarget.java b/src/main/java/net/minecraft/server/PathfinderGoalTarget.java index c65f3dd70c..1b0340f918 100644 --- a/src/main/java/net/minecraft/server/PathfinderGoalTarget.java +++ b/src/main/java/net/minecraft/server/PathfinderGoalTarget.java @@ -37,7 +37,7 @@ public abstract class PathfinderGoalTarget extends PathfinderGoal { return false; } else { if (this.f) { - if (this.d.aA().canSee(entityliving)) { + if (this.d.aD().canSee(entityliving)) { this.g = 0; } else if (++this.g > 60) { return false; @@ -80,9 +80,9 @@ public abstract class PathfinderGoalTarget extends PathfinderGoal { return false; } - if (!this.d.e(MathHelper.floor(entityliving.locX), MathHelper.floor(entityliving.locY), MathHelper.floor(entityliving.locZ))) { + if (!this.d.d(MathHelper.floor(entityliving.locX), MathHelper.floor(entityliving.locY), MathHelper.floor(entityliving.locZ))) { return false; - } else if (this.f && !this.d.aA().canSee(entityliving)) { + } else if (this.f && !this.d.aD().canSee(entityliving)) { return false; } else { if (this.a) { @@ -134,7 +134,7 @@ public abstract class PathfinderGoalTarget extends PathfinderGoal { } private boolean a(EntityLiving entityliving) { - this.c = 10 + this.d.aB().nextInt(5); + this.c = 10 + this.d.aE().nextInt(5); PathEntity pathentity = this.d.getNavigation().a(entityliving); if (pathentity == null) { diff --git a/src/main/java/net/minecraft/server/PendingConnection.java b/src/main/java/net/minecraft/server/PendingConnection.java index 8413a1527b..5f4bcf2a65 100644 --- a/src/main/java/net/minecraft/server/PendingConnection.java +++ b/src/main/java/net/minecraft/server/PendingConnection.java @@ -14,23 +14,22 @@ import javax.crypto.SecretKey; public class PendingConnection extends Connection { - private byte[] d; - public static Logger logger = Logger.getLogger("Minecraft"); private static Random random = new Random(); - public NetworkManager networkManager; - public boolean c = false; - private MinecraftServer server; - private int g = 0; - private String h = null; - private volatile boolean i = false; + 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; private String loginKey = Long.toString(random.nextLong(), 16); // CraftBukkit - Security fix - private boolean k = false; - private SecretKey l = null; + private boolean j = false; + private SecretKey k = null; 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(socket, s, this, minecraftserver.F().getPrivate()); + this.networkManager = new NetworkManager(minecraftserver.getLogger(), socket, s, this, minecraftserver.F().getPrivate()); this.networkManager.e = 0; } @@ -41,11 +40,11 @@ public class PendingConnection extends Connection { // CraftBukkit end public void c() { - if (this.i) { + if (this.h) { this.d(); } - if (this.g++ == 600) { + if (this.f++ == 600) { this.disconnect("Took too long to log in"); } else { this.networkManager.b(); @@ -54,10 +53,10 @@ public class PendingConnection extends Connection { public void disconnect(String s) { try { - logger.info("Disconnecting " + this.getName() + ": " + s); + this.server.getLogger().info("Disconnecting " + this.getName() + ": " + s); this.networkManager.queue(new Packet255KickDisconnect(s)); this.networkManager.d(); - this.c = true; + this.b = true; } catch (Exception exception) { exception.printStackTrace(); } @@ -67,14 +66,14 @@ public class PendingConnection extends Connection { // CraftBukkit start this.hostname = packet2handshake.c == null ? "" : packet2handshake.c + ':' + packet2handshake.d; // CraftBukkit end - this.h = packet2handshake.f(); - if (!this.h.equals(StripColor.a(this.h))) { + this.g = packet2handshake.f(); + if (!this.g.equals(StripColor.a(this.g))) { this.disconnect("Invalid username!"); } else { PublicKey publickey = this.server.F().getPublic(); - if (packet2handshake.d() != 51) { - if (packet2handshake.d() > 51) { + if (packet2handshake.d() != 60) { + if (packet2handshake.d() > 60) { this.disconnect("Outdated server!"); } else { this.disconnect("Outdated client!"); @@ -91,7 +90,7 @@ public class PendingConnection extends Connection { public void a(Packet252KeyResponse packet252keyresponse) { PrivateKey privatekey = this.server.F().getPrivate(); - this.l = packet252keyresponse.a(privatekey); + this.k = packet252keyresponse.a(privatekey); if (!Arrays.equals(this.d, packet252keyresponse.b(privatekey))) { this.disconnect("Invalid client reply"); } @@ -102,14 +101,14 @@ public class PendingConnection extends Connection { public void a(Packet205ClientCommand packet205clientcommand) { if (packet205clientcommand.a == 0) { if (this.server.getOnlineMode()) { - if (this.k) { + if (this.j) { this.disconnect("Duplicate login"); return; } - this.k = true; + this.j = true; (new ThreadLoginVerifier(this, server.server)).start(); // CraftBukkit - add CraftServer } else { - this.i = true; + this.h = true; } } } @@ -118,7 +117,7 @@ public class PendingConnection extends Connection { public void d() { // CraftBukkit start - EntityPlayer s = this.server.getPlayerList().attemptLogin(this, this.h, this.hostname); + EntityPlayer s = this.server.getPlayerList().attemptLogin(this, this.g, this.hostname); if (s == null) { return; @@ -131,12 +130,12 @@ public class PendingConnection extends Connection { } } - this.c = true; + this.b = true; } public void a(String s, Object[] aobject) { - logger.info(this.getName() + " lost connection"); - this.c = true; + this.server.getLogger().info(this.getName() + " lost connection"); + this.b = true; } public void a(Packet254GetInfo packet254getinfo) { @@ -149,7 +148,7 @@ public class PendingConnection extends Connection { if (packet254getinfo.a == 1) { // CraftBukkit start - fix decompile issues, don't create a list from an array - Object[] list = new Object[] { 1, 51, this.server.getVersion(), pingEvent.getMotd(), playerlist.getPlayerCount(), pingEvent.getMaxPlayers() }; + Object[] list = new Object[] { 1, 60, this.server.getVersion(), pingEvent.getMotd(), playerlist.getPlayerCount(), pingEvent.getMaxPlayers() }; for (Object object : list) { if (s == null) { @@ -178,7 +177,7 @@ public class PendingConnection extends Connection { ((DedicatedServerConnection) this.server.ae()).a(inetaddress); } - this.c = true; + this.b = true; } catch (Exception exception) { exception.printStackTrace(); } @@ -189,7 +188,7 @@ public class PendingConnection extends Connection { } public String getName() { - return this.h != null ? this.h + " [" + this.networkManager.getSocketAddress().toString() + "]" : this.networkManager.getSocketAddress().toString(); + return this.g != null ? this.g + " [" + this.networkManager.getSocketAddress().toString() + "]" : this.networkManager.getSocketAddress().toString(); } public boolean a() { @@ -205,14 +204,14 @@ public class PendingConnection extends Connection { } static SecretKey c(PendingConnection pendingconnection) { - return pendingconnection.l; + return pendingconnection.k; } static String d(PendingConnection pendingconnection) { - return pendingconnection.h; + return pendingconnection.g; } static boolean a(PendingConnection pendingconnection, boolean flag) { - return pendingconnection.i = flag; + return pendingconnection.h = flag; } } diff --git a/src/main/java/net/minecraft/server/PlayerConnection.java b/src/main/java/net/minecraft/server/PlayerConnection.java index 65ec70ad91..aeca924f2b 100644 --- a/src/main/java/net/minecraft/server/PlayerConnection.java +++ b/src/main/java/net/minecraft/server/PlayerConnection.java @@ -6,7 +6,7 @@ import java.io.IOException; import java.util.ArrayList; import java.util.Iterator; import java.util.Random; -import java.util.logging.Logger; +import java.util.concurrent.Callable; // CraftBukkit start import java.io.UnsupportedEncodingException; @@ -49,25 +49,25 @@ import org.bukkit.inventory.InventoryView; // CraftBukkit end public class PlayerConnection extends Connection { - public static Logger logger = Logger.getLogger("Minecraft"); - public INetworkManager networkManager; + + public final INetworkManager networkManager; + private final MinecraftServer minecraftServer; public boolean disconnected = false; - private MinecraftServer minecraftServer; public EntityPlayer player; + private int e; private int f; - private int g; - private boolean h; - private int i; - private long j; - private static Random k = new Random(); - private long l; + private boolean g; + private int h; + 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 int x = 0; private double y; private double z; - private double q; + private double p; public boolean checkMovement = true; // CraftBukkit - private -> public - private IntHashMap s = new IntHashMap(); + private IntHashMap r = new IntHashMap(); public PlayerConnection(MinecraftServer minecraftserver, INetworkManager inetworkmanager, EntityPlayer entityplayer) { this.minecraftServer = minecraftserver; @@ -107,16 +107,16 @@ public class PlayerConnection extends Connection { // CraftBukkit end public void d() { - this.h = false; - ++this.f; + this.g = false; + ++this.e; this.minecraftServer.methodProfiler.a("packetflow"); this.networkManager.b(); this.minecraftServer.methodProfiler.c("keepAlive"); - if ((long) this.f - this.l > 20L) { - this.l = (long) this.f; - this.j = System.nanoTime() / 1000000L; - this.i = k.nextInt(); - this.sendPacket(new Packet0KeepAlive(this.i)); + if ((long) this.e - this.k > 20L) { + this.k = (long) this.e; + this.i = System.nanoTime() / 1000000L; + this.h = j.nextInt(); + this.sendPacket(new Packet0KeepAlive(this.h)); } // CraftBukkit start @@ -139,7 +139,7 @@ public class PlayerConnection extends Connection { public void disconnect(String s) { if (!this.disconnected) { // CraftBukkit start - String leaveMessage = "\u00A7e" + this.player.name + " left the game."; + String leaveMessage = EnumChatFormat.YELLOW + this.player.name + " left the game."; PlayerKickEvent event = new PlayerKickEvent(this.server.getPlayer(this.player), s, leaveMessage); @@ -155,7 +155,7 @@ public class PlayerConnection extends Connection { s = event.getReason(); // CraftBukkit end - this.player.l(); + this.player.k(); this.sendPacket(new Packet255KickDisconnect(s)); this.networkManager.d(); @@ -174,13 +174,13 @@ public class PlayerConnection extends Connection { public void a(Packet10Flying packet10flying) { WorldServer worldserver = this.minecraftServer.getWorldServer(this.player.dimension); - this.h = true; + this.g = true; if (!this.player.viewingCredits) { double d0; if (!this.checkMovement) { d0 = packet10flying.y - this.z; - if (packet10flying.x == this.y && d0 * d0 < 0.01D && packet10flying.z == this.q) { + if (packet10flying.x == this.y && d0 * d0 < 0.01D && packet10flying.z == this.p) { this.checkMovement = true; } } @@ -260,7 +260,7 @@ public class PlayerConnection extends Connection { float f = this.player.yaw; float f1 = this.player.pitch; - this.player.vehicle.V(); + this.player.vehicle.U(); d1 = this.player.locX; d2 = this.player.locY; d3 = this.player.locZ; @@ -294,20 +294,20 @@ public class PlayerConnection extends Connection { } if (this.player.vehicle != null) { - this.player.vehicle.V(); + this.player.vehicle.U(); } this.minecraftServer.getPlayerList().d(this.player); this.y = this.player.locX; this.z = this.player.locY; - this.q = this.player.locZ; + this.p = this.player.locZ; worldserver.playerJoinedWorld(this.player); return; } if (this.player.isSleeping()) { this.player.g(); - this.player.setLocation(this.y, this.z, this.q, this.player.yaw, this.player.pitch); + this.player.setLocation(this.y, this.z, this.p, this.player.yaw, this.player.pitch); worldserver.playerJoinedWorld(this.player); return; } @@ -315,7 +315,7 @@ public class PlayerConnection extends Connection { d0 = this.player.locY; this.y = this.player.locX; this.z = this.player.locY; - this.q = this.player.locZ; + this.p = this.player.locZ; d1 = this.player.locX; d2 = this.player.locY; d3 = this.player.locZ; @@ -333,13 +333,13 @@ public class PlayerConnection extends Connection { d4 = packet10flying.stance - packet10flying.y; if (!this.player.isSleeping() && (d4 > 1.65D || d4 < 0.1D)) { this.disconnect("Illegal stance"); - logger.warning(this.player.name + " had an illegal stance: " + d4); + this.minecraftServer.getLogger().warning(this.player.name + " had an illegal stance: " + d4); return; } if (Math.abs(packet10flying.x) > 3.2E7D || Math.abs(packet10flying.z) > 3.2E7D) { // CraftBukkit - teleport to previous position instead of kicking, players get stuck - this.a(this.y, this.z, this.q, this.player.yaw, this.player.pitch); + this.a(this.y, this.z, this.p, this.player.yaw, this.player.pitch); return; } } @@ -350,8 +350,8 @@ public class PlayerConnection extends Connection { } this.player.g(); - this.player.W = 0.0F; - this.player.setLocation(this.y, this.z, this.q, f2, f3); + this.player.X = 0.0F; + this.player.setLocation(this.y, this.z, this.p, f2, f3); if (!this.checkMovement) { return; } @@ -367,8 +367,8 @@ public class PlayerConnection extends Connection { 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 - logger.warning(this.player.name + " moved too quickly! " + d4 + "," + d6 + "," + d7 + " (" + d8 + ", " + d9 + ", " + d10 + ")"); - this.a(this.y, this.z, this.q, this.player.yaw, this.player.pitch); + this.minecraftServer.getLogger().warning(this.player.name + " moved too quickly! " + d4 + "," + d6 + "," + d7 + " (" + d8 + ", " + d9 + ", " + d10 + ")"); + this.a(this.y, this.z, this.p, this.player.yaw, this.player.pitch); return; } @@ -396,14 +396,14 @@ public class PlayerConnection extends Connection { if (d11 > 0.0625D && !this.player.isSleeping() && !this.player.playerInteractManager.isCreative()) { flag1 = true; - logger.warning(this.player.name + " moved wrongly!"); + this.minecraftServer.getLogger().warning(this.player.name + " moved wrongly!"); } this.player.setLocation(d1, d2, d3, f2, f3); boolean flag2 = worldserver.getCubes(this.player, this.player.boundingBox.clone().shrink((double) f4, (double) f4, (double) f4)).isEmpty(); if (flag && (flag1 || !flag2) && !this.player.isSleeping()) { - this.a(this.y, this.z, this.q, f2, f3); + this.a(this.y, this.z, this.p, f2, f3); return; } @@ -411,15 +411,15 @@ public class PlayerConnection extends Connection { if (!this.minecraftServer.getAllowFlight() && !this.player.abilities.canFly && !worldserver.c(axisalignedbb)) { // CraftBukkit - check abilities instead of creative mode if (d12 >= -0.03125D) { - ++this.g; - if (this.g > 80) { - logger.warning(this.player.name + " was kicked for floating too long!"); + ++this.f; + if (this.f > 80) { + this.minecraftServer.getLogger().warning(this.player.name + " was kicked for floating too long!"); this.disconnect("Flying is not enabled on this server"); return; } } } else { - this.g = 0; + this.f = 0; } this.player.onGround = packet10flying.g; @@ -474,7 +474,7 @@ public class PlayerConnection extends Connection { this.checkMovement = false; this.y = d0; this.z = d1; - this.q = d2; + this.p = d2; this.player.setLocation(d0, d1, d2, f, f1); this.player.playerConnection.sendPacket(new Packet13PlayerLookMove(d0, d1 + 1.6200000047683716D, d1, d2, f, f1, false)); } @@ -494,84 +494,74 @@ public class PlayerConnection extends Connection { // Else we increment the drop count and check the amount. this.dropCount++; if (this.dropCount >= 20) { - logger.warning(this.player.name + " dropped their items too quickly!"); + this.minecraftServer.getLogger().warning(this.player.name + " dropped their items too quickly!"); this.disconnect("You dropped your items too quickly (Hacking?)"); return; } } // CraftBukkit end - this.player.f(false); + this.player.a(false); } else if (packet14blockdig.e == 3) { - this.player.f(true); + this.player.a(true); } else if (packet14blockdig.e == 5) { - this.player.bO(); + this.player.bX(); } else { - int i = this.minecraftServer.getSpawnProtection(); - boolean flag = worldserver.worldProvider.dimension != 0 || this.minecraftServer.getPlayerList().getOPs().isEmpty() || this.minecraftServer.getPlayerList().isOp(this.player.name) || i <= 0 || this.minecraftServer.I(); - boolean flag1 = false; + boolean flag = false; if (packet14blockdig.e == 0) { - flag1 = true; + flag = true; } if (packet14blockdig.e == 1) { - flag1 = true; + flag = true; } if (packet14blockdig.e == 2) { - flag1 = true; + flag = true; } - int j = packet14blockdig.a; - int k = packet14blockdig.b; - int l = packet14blockdig.c; + int i = packet14blockdig.a; + int j = packet14blockdig.b; + int k = packet14blockdig.c; - if (flag1) { - double d0 = this.player.locX - ((double) j + 0.5D); - double d1 = this.player.locY - ((double) k + 0.5D) + 1.5D; - double d2 = this.player.locZ - ((double) l + 0.5D); + if (flag) { + double d0 = this.player.locX - ((double) i + 0.5D); + double d1 = this.player.locY - ((double) j + 0.5D) + 1.5D; + double d2 = this.player.locZ - ((double) k + 0.5D); double d3 = d0 * d0 + d1 * d1 + d2 * d2; if (d3 > 36.0D) { return; } - if (k >= this.minecraftServer.getMaxBuildHeight()) { + if (j >= this.minecraftServer.getMaxBuildHeight()) { return; } } - ChunkCoordinates chunkcoordinates = worldserver.getSpawn(); - int i1 = MathHelper.a(j - chunkcoordinates.x); - int j1 = MathHelper.a(l - chunkcoordinates.z); - - if (i1 > j1) { - j1 = i1; - } - if (packet14blockdig.e == 0) { // CraftBukkit start - if (j1 < this.server.getSpawnRadius() && !flag) { - CraftEventFactory.callPlayerInteractEvent(this.player, Action.LEFT_CLICK_BLOCK, j, k, l, i1, this.player.inventory.getItemInHand()); - this.player.playerConnection.sendPacket(new Packet53BlockChange(j, k, l, worldserver)); + if (!this.minecraftServer.a(worldserver, i, j, k, this.player)) { + this.player.playerInteractManager.dig(i, j, k, packet14blockdig.face); + } else { + CraftEventFactory.callPlayerInteractEvent(this.player, Action.LEFT_CLICK_BLOCK, i, j, k, packet14blockdig.face, this.player.inventory.getItemInHand()); + this.player.playerConnection.sendPacket(new Packet53BlockChange(i, j, k, worldserver)); // Update any tile entity data for this block - TileEntity tileentity = worldserver.getTileEntity(j, k, l); + TileEntity tileentity = worldserver.getTileEntity(i, j, k); if (tileentity != null) { this.player.playerConnection.sendPacket(tileentity.getUpdatePacket()); } // CraftBukkit end - } else { - this.player.playerInteractManager.dig(j, k, l, packet14blockdig.face); } } else if (packet14blockdig.e == 2) { - this.player.playerInteractManager.a(j, k, l); - if (worldserver.getTypeId(j, k, l) != 0) { - this.player.playerConnection.sendPacket(new Packet53BlockChange(j, k, l, worldserver)); + this.player.playerInteractManager.a(i, j, k); + if (worldserver.getTypeId(i, j, k) != 0) { + this.player.playerConnection.sendPacket(new Packet53BlockChange(i, j, k, worldserver)); } } else if (packet14blockdig.e == 1) { - this.player.playerInteractManager.c(j, k, l); - if (worldserver.getTypeId(j, k, l) != 0) { - this.player.playerConnection.sendPacket(new Packet53BlockChange(j, k, l, worldserver)); + this.player.playerInteractManager.c(i, j, k); + if (worldserver.getTypeId(i, j, k) != 0) { + this.player.playerConnection.sendPacket(new Packet53BlockChange(i, j, k, worldserver)); } } } @@ -614,8 +604,6 @@ public class PlayerConnection extends Connection { int j = packet15place.f(); int k = packet15place.g(); int l = packet15place.getFace(); - int i1 = this.minecraftServer.getSpawnProtection(); - boolean flag1 = worldserver.worldProvider.dimension != 0 || this.minecraftServer.getPlayerList().getOPs().isEmpty() || this.minecraftServer.getPlayerList().isOp(this.player.name) || i1 <= 0 || this.minecraftServer.I(); if (packet15place.getFace() == 255) { if (itemstack == null) { @@ -635,27 +623,17 @@ 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("\u00A77Height limit for building is " + this.minecraftServer.getMaxBuildHeight())); + this.player.playerConnection.sendPacket(new Packet3Chat("" + EnumChatFormat.GRAY + "Height limit for building is " + this.minecraftServer.getMaxBuildHeight())); flag = true; } else { - ChunkCoordinates chunkcoordinates = worldserver.getSpawn(); - int j1 = MathHelper.a(i - chunkcoordinates.x); - int k1 = MathHelper.a(k - chunkcoordinates.z); - - if (j1 > k1) { - k1 = j1; - } - // CraftBukkit start - Check if we can actually do something over this large a distance Location eyeLoc = this.getPlayer().getEyeLocation(); if (Math.pow(eyeLoc.getX() - i, 2) + Math.pow(eyeLoc.getY() - j, 2) + Math.pow(eyeLoc.getZ() - k, 2) > PLACE_DISTANCE_SQUARED) { return; } - flag1 = true; // spawn protection moved to ItemBlock!!! - if (j1 > i1 || flag1) { - // CraftBukkit end - this.player.playerInteractManager.interact(this.player, worldserver, itemstack, i, j, k, l, packet15place.j(), packet15place.l(), packet15place.m()); - } + + this.player.playerInteractManager.interact(this.player, worldserver, itemstack, i, j, k, l, packet15place.j(), packet15place.k(), packet15place.l()); + // CraftBukkit end flag = true; } @@ -695,7 +673,7 @@ public class PlayerConnection extends Connection { itemstack = null; } - if (itemstack == null || itemstack.m() == 0) { + if (itemstack == null || itemstack.n() == 0) { this.player.h = true; this.player.inventory.items[this.player.inventory.itemInHandIndex] = ItemStack.b(this.player.inventory.items[this.player.inventory.itemInHandIndex]); Slot slot = this.player.activeContainer.a((IInventory) this.player.inventory, this.player.inventory.itemInHandIndex); @@ -712,7 +690,7 @@ 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 - logger.info(this.player.name + " lost connection: " + s); + this.minecraftServer.getLogger().info(this.player.name + " 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)) { @@ -721,14 +699,14 @@ public class PlayerConnection extends Connection { // CraftBukkit end this.disconnected = true; if (this.minecraftServer.I() && this.player.name.equals(this.minecraftServer.H())) { - logger.info("Stopping singleplayer server as player logged out"); + this.minecraftServer.getLogger().info("Stopping singleplayer server as player logged out"); this.minecraftServer.safeShutdown(); } } public void onUnhandledPacket(Packet packet) { if (this.disconnected) return; // CraftBukkit - logger.warning(this.getClass() + " wasn\'t prepared to deal with a " + packet.getClass()); + this.minecraftServer.getLogger().warning(this.getClass() + " wasn\'t prepared to deal with a " + packet.getClass()); this.disconnect("Protocol error, unexpected packet"); } @@ -763,7 +741,16 @@ public class PlayerConnection extends Connection { } // CraftBukkit end - this.networkManager.queue(packet); + try { + this.networkManager.queue(packet); + } catch (Throwable throwable) { + CrashReport crashreport = CrashReport.a(throwable, "Sending packet"); + CrashReportSystemDetails crashreportsystemdetails = crashreport.a("Packet being sent"); + + crashreportsystemdetails.a("Packet ID", (Callable) (new CrashReportConnectionPacketID(this, packet))); + crashreportsystemdetails.a("Packet class", (Callable) (new CrashReportConnectionPacketClass(this, packet))); + throw new ReportedException(crashreport); + } } public void a(Packet16BlockItemSwitch packet16blockitemswitch) { @@ -777,7 +764,7 @@ public class PlayerConnection extends Connection { this.player.inventory.itemInHandIndex = packet16blockitemswitch.itemInHandIndex; } else { - logger.warning(this.player.name + " tried to set an invalid carried item"); + this.minecraftServer.getLogger().warning(this.player.name + " tried to set an invalid carried item"); this.disconnect("Nope!"); // CraftBukkit } } @@ -885,7 +872,7 @@ public class PlayerConnection extends Connection { public void chat(String s, boolean async) { if (!this.player.dead) { if (s.length() == 0) { - logger.warning(this.player.name + " tried to send an empty message"); + this.minecraftServer.getLogger().warning(this.player.name + " tried to send an empty message"); return; } @@ -976,13 +963,13 @@ public class PlayerConnection extends Connection { } try { - logger.info(event.getPlayer().getName() + " issued server command: " + event.getMessage()); // CraftBukkit + this.minecraftServer.getLogger().info(event.getPlayer().getName() + " issued server command: " + event.getMessage()); // CraftBukkit if (this.server.dispatchCommand(event.getPlayer(), event.getMessage().substring(1))) { return; } } catch (org.bukkit.command.CommandException ex) { player.sendMessage(org.bukkit.ChatColor.RED + "An internal error occurred while attempting to perform this command"); - Logger.getLogger(PlayerConnection.class.getName()).log(Level.SEVERE, null, ex); + java.util.logging.Logger.getLogger(PlayerConnection.class.getName()).log(Level.SEVERE, null, ex); return; } // CraftBukkit end @@ -1026,7 +1013,7 @@ public class PlayerConnection extends Connection { if (event.isCancelled()) return; // CraftBukkit end - this.player.bH(); + this.player.bK(); } } @@ -1128,7 +1115,7 @@ public class PlayerConnection extends Connection { if (packet205clientcommand.a == 1) { if (this.player.viewingCredits) { this.minecraftServer.getPlayerList().changeDimension(this.player, 0, TeleportCause.END_PORTAL); // CraftBukkit - reroute logic through custom portal management - } else if (this.player.p().getWorldData().isHardcore()) { + } else if (this.player.o().getWorldData().isHardcore()) { if (this.minecraftServer.I() && this.player.name.equals(this.minecraftServer.H())) { this.player.playerConnection.disconnect("You have died. Game over, man, it\'s game over!"); this.minecraftServer.P(); @@ -1164,7 +1151,7 @@ public class PlayerConnection extends Connection { this.player.activeContainer.transferTo(this.player.defaultContainer, getPlayer()); // CraftBukkit end - this.player.k(); + this.player.j(); } public void a(Packet102WindowClick packet102windowclick) { @@ -1224,7 +1211,7 @@ public class PlayerConnection extends Connection { this.player.broadcastCarriedItem(); this.player.h = false; } else { - this.s.a(this.player.activeContainer.windowId, Short.valueOf(packet102windowclick.d)); + this.r.a(this.player.activeContainer.windowId, Short.valueOf(packet102windowclick.d)); this.player.playerConnection.sendPacket(new Packet106Transaction(packet102windowclick.a, packet102windowclick.d, false)); this.player.activeContainer.a(this.player, false); ArrayList arraylist = new ArrayList(); @@ -1318,7 +1305,7 @@ public class PlayerConnection extends Connection { public void a(Packet106Transaction packet106transaction) { if (this.player.dead) return; // CraftBukkit - Short oshort = (Short) this.s.get(this.player.activeContainer.windowId); + Short oshort = (Short) this.r.get(this.player.activeContainer.windowId); if (oshort != null && packet106transaction.b == oshort.shortValue() && this.player.activeContainer.windowId == packet106transaction.a && !this.player.activeContainer.c(this.player)) { this.player.activeContainer.a(this.player, true); @@ -1394,8 +1381,8 @@ public class PlayerConnection extends Connection { } public void a(Packet0KeepAlive packet0keepalive) { - if (packet0keepalive.a == this.i) { - int i = (int) (System.nanoTime() / 1000000L - this.j); + if (packet0keepalive.a == this.h) { + int i = (int) (System.nanoTime() / 1000000L - this.i); this.player.ping = (this.player.ping * 3 + i) / 4; } @@ -1464,7 +1451,7 @@ public class PlayerConnection extends Connection { } } catch (Exception exception) { // CraftBukkit start - logger.log(Level.WARNING, this.player.name + " sent invalid MC|BEdit data", exception); + this.minecraftServer.getLogger().warning(this.player.name + " sent invalid MC|BEdit data", exception); this.disconnect("Invalid book data!"); // CraftBukkit end } @@ -1485,7 +1472,7 @@ public class PlayerConnection extends Connection { } } catch (Exception exception1) { // CraftBukkit start - logger.log(Level.WARNING, this.player.name + " sent invalid MC|BSign data", exception1); + this.minecraftServer.getLogger().warning(this.player.name + " sent invalid MC|BSign data", exception1); this.disconnect("Invalid book data!"); // CraftBukkit end } @@ -1499,11 +1486,11 @@ public class PlayerConnection extends Connection { Container container = this.player.activeContainer; if (container instanceof ContainerMerchant) { - ((ContainerMerchant) container).b(i); + ((ContainerMerchant) container).e(i); } } catch (Exception exception2) { // CraftBukkit start - logger.log(Level.WARNING, this.player.name + " sent invalid MC|TrSel data", exception2); + this.minecraftServer.getLogger().warning(this.player.name + " sent invalid MC|TrSel data", exception2); this.disconnect("Invalid trade data!"); // CraftBukkit end } @@ -1529,7 +1516,7 @@ public class PlayerConnection extends Connection { } } catch (Exception exception3) { // CraftBukkit start - logger.log(Level.WARNING, this.player.name + " sent invalid MC|AdvCdm data", exception3); + this.minecraftServer.getLogger().warning(this.player.name + " sent invalid MC|AdvCdm data", exception3); this.disconnect("Invalid CommandBlock data!"); // CraftBukkit end } @@ -1547,7 +1534,7 @@ public class PlayerConnection extends Connection { if (slot.d()) { slot.a(1); - TileEntityBeacon tileentitybeacon = containerbeacon.d(); + TileEntityBeacon tileentitybeacon = containerbeacon.e(); tileentitybeacon.d(i); tileentitybeacon.e(j); @@ -1555,7 +1542,7 @@ public class PlayerConnection extends Connection { } } catch (Exception exception4) { // CraftBukkit start - logger.log(Level.WARNING, this.player.name + " sent invalid MC|Beacon data", exception4); + this.minecraftServer.getLogger().warning(this.player.name + " 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 5faee12248..92e68be252 100644 --- a/src/main/java/net/minecraft/server/PlayerInteractManager.java +++ b/src/main/java/net/minecraft/server/PlayerInteractManager.java @@ -78,7 +78,7 @@ public class PlayerInteractManager { f = block.getDamage(this.player, this.player.world, this.k, this.l, this.m) * (float) (i + 1); j = (int) (f * 10.0F); if (j != this.o) { - this.world.g(this.player.id, this.k, this.l, this.m, j); + this.world.f(this.player.id, this.k, this.l, this.m, j); this.o = j; } @@ -92,7 +92,7 @@ public class PlayerInteractManager { Block block1 = Block.byId[i]; if (block1 == null) { - this.world.g(this.player.id, this.f, this.g, this.h, -1); + this.world.f(this.player.id, this.f, this.g, this.h, -1); this.o = -1; this.d = false; } else { @@ -101,7 +101,7 @@ public class PlayerInteractManager { f = block1.getDamage(this.player, this.player.world, this.f, this.g, this.h) * (float) (l + 1); j = (int) (f * 10.0F); if (j != this.o) { - this.world.g(this.player.id, this.f, this.g, this.h, j); + this.world.f(this.player.id, this.f, this.g, this.h, j); this.o = j; } } @@ -113,7 +113,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.f(i, j, k)) { + if (!this.gamemode.isAdventure() || this.player.e(i, j, k)) { // CraftBukkit start if (event.isCancelled()) { // Let the client know the block still exists @@ -131,7 +131,7 @@ public class PlayerInteractManager { this.breakBlock(i, j, k); } } else { - this.world.douseFire(this.player, i, j, k, l); + this.world.douseFire((EntityHuman) null, i, j, k, l); this.lastDigTick = this.currentTick; float f = 1.0F; int i1 = this.world.getTypeId(i, j, k); @@ -186,7 +186,7 @@ public class PlayerInteractManager { this.h = k; int j1 = (int) (f * 10.0F); - this.world.g(this.player.id, i, j, k, j1); + this.world.f(this.player.id, i, j, k, j1); this.o = j1; } } @@ -205,7 +205,7 @@ public class PlayerInteractManager { if (f >= 0.7F) { this.d = false; - this.world.g(this.player.id, i, j, k, -1); + this.world.f(this.player.id, i, j, k, -1); this.breakBlock(i, j, k); } else if (!this.j) { this.d = false; @@ -225,7 +225,7 @@ public class PlayerInteractManager { public void c(int i, int j, int k) { this.d = false; - this.world.g(this.player.id, this.f, this.g, this.h, -1); + this.world.f(this.player.id, this.f, this.g, this.h, -1); } private boolean d(int i, int j, int k) { @@ -236,7 +236,7 @@ public class PlayerInteractManager { block.a(this.world, i, j, k, l, this.player); } - boolean flag = this.world.setTypeId(i, j, k, 0); + boolean flag = this.world.setAir(i, j, k); if (block != null && flag) { block.postBreak(this.world, i, j, k, l); @@ -264,14 +264,14 @@ public class PlayerInteractManager { event = new BlockBreakEvent(block, this.player.getBukkitEntity()); // Adventure mode pre-cancel - event.setCancelled(this.gamemode.isAdventure() && !this.player.f(i, j, k)); + event.setCancelled(this.gamemode.isAdventure() && !this.player.e(i, j, k)); // Calculate default block experience Block nmsBlock = Block.byId[block.getTypeId()]; - if (nmsBlock != null && !event.isCancelled() && !this.isCreative() && this.player.b(nmsBlock)) { + if (nmsBlock != null && !event.isCancelled() && !this.isCreative() && this.player.a(nmsBlock)) { // Copied from Block.a(world, entityhuman, int, int, int, int) - if (!(nmsBlock.s_() && EnchantmentManager.hasSilkTouchEnchantment(this.player))) { + if (!(nmsBlock.r_() && EnchantmentManager.hasSilkTouchEnchantment(this.player))) { int data = block.getData(); int bonusLevel = EnchantmentManager.getBonusBlockLootEnchantmentLevel(this.player); @@ -314,13 +314,13 @@ public class PlayerInteractManager { if (this.isCreative()) { this.player.playerConnection.sendPacket(new Packet53BlockChange(i, j, k, this.world)); } else { - ItemStack itemstack = this.player.bS(); - boolean flag1 = this.player.b(Block.byId[l]); + ItemStack itemstack = this.player.cb(); + 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.bT(); + this.player.cc(); } } @@ -331,7 +331,7 @@ public class PlayerInteractManager { // CraftBukkit start - drop event experience if (flag && event != null) { - Block.byId[l].f(this.world, i, j, k, event.getExpToDrop()); + Block.byId[l].j(this.world, i, j, k, event.getExpToDrop()); } // CraftBukkit end @@ -344,13 +344,13 @@ public class PlayerInteractManager { int j = itemstack.getData(); ItemStack itemstack1 = itemstack.a(world, entityhuman); - if (itemstack1 == itemstack && (itemstack1 == null || itemstack1.count == i && itemstack1.m() <= 0 && itemstack1.getData() == j)) { + if (itemstack1 == itemstack && (itemstack1 == null || itemstack1.count == i && itemstack1.n() <= 0 && itemstack1.getData() == j)) { return false; } else { entityhuman.inventory.items[entityhuman.inventory.itemInHandIndex] = itemstack1; if (this.isCreative()) { itemstack1.count = i; - if (itemstack1.f()) { + if (itemstack1.g()) { itemstack1.setData(j); } } @@ -359,7 +359,7 @@ public class PlayerInteractManager { entityhuman.inventory.items[entityhuman.inventory.itemInHandIndex] = null; } - if (!entityhuman.bM()) { + if (!entityhuman.bV()) { ((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 f40b1e98ae..63da3ad459 100644 --- a/src/main/java/net/minecraft/server/PlayerInventory.java +++ b/src/main/java/net/minecraft/server/PlayerInventory.java @@ -1,5 +1,7 @@ package net.minecraft.server; +import java.util.concurrent.Callable; + // CraftBukkit start import java.util.List; @@ -97,7 +99,7 @@ public class PlayerInventory implements IInventory { } // CraftBukkit end - public int i() { + public int j() { for (int i = 0; i < this.items.length; ++i) { if (this.items[i] == null) { return i; @@ -138,7 +140,7 @@ public class PlayerInventory implements IInventory { int k; if (itemstack.getMaxStackSize() == 1) { - k = this.i(); + k = this.j(); if (k < 0) { return j; } else { @@ -151,7 +153,7 @@ public class PlayerInventory implements IInventory { } else { k = this.firstPartial(itemstack); if (k < 0) { - k = this.i(); + k = this.j(); } if (k < 0) { @@ -186,7 +188,7 @@ public class PlayerInventory implements IInventory { } } - public void j() { + public void k() { for (int i = 0; i < this.items.length; ++i) { if (this.items[i] != null) { this.items[i].a(this.player.world, this.player, i, this.itemInHandIndex == i); @@ -215,32 +217,46 @@ public class PlayerInventory implements IInventory { } public boolean pickup(ItemStack itemstack) { - int i; - - if (itemstack.h()) { - i = this.i(); - if (i >= 0) { - this.items[i] = ItemStack.b(itemstack); - this.items[i].b = 5; - itemstack.count = 0; - return true; - } else if (this.player.abilities.canInstantlyBuild) { - itemstack.count = 0; - return true; - } else { - return false; - } + if (itemstack == null) { + return false; } else { - do { - i = itemstack.count; - itemstack.count = this.e(itemstack); - } while (itemstack.count > 0 && itemstack.count < i); + try { + int i; - if (itemstack.count == i && this.player.abilities.canInstantlyBuild) { - itemstack.count = 0; - return true; - } else { - return itemstack.count < i; + if (itemstack.i()) { + i = this.j(); + if (i >= 0) { + this.items[i] = ItemStack.b(itemstack); + this.items[i].b = 5; + itemstack.count = 0; + return true; + } else if (this.player.abilities.canInstantlyBuild) { + itemstack.count = 0; + return true; + } else { + return false; + } + } else { + do { + i = itemstack.count; + itemstack.count = this.e(itemstack); + } while (itemstack.count > 0 && itemstack.count < i); + + if (itemstack.count == i && this.player.abilities.canInstantlyBuild) { + itemstack.count = 0; + return true; + } else { + return itemstack.count < i; + } + } + } catch (Throwable throwable) { + CrashReport crashreport = CrashReport.a(throwable, "Adding item to inventory"); + CrashReportSystemDetails crashreportsystemdetails = crashreport.a("Item being added"); + + crashreportsystemdetails.a("Item ID", Integer.valueOf(itemstack.id)); + crashreportsystemdetails.a("Item data", Integer.valueOf(itemstack.getData())); + crashreportsystemdetails.a("Item name", (Callable) (new CrashReportItemName(this, itemstack))); + throw new ReportedException(crashreport); } } } @@ -377,6 +393,10 @@ public class PlayerInventory implements IInventory { return "container.inventory"; } + public boolean c() { + return false; + } + public int getMaxStackSize() { return maxStack; } @@ -401,12 +421,12 @@ public class PlayerInventory implements IInventory { return this.armor[i]; } - public int k() { + public int l() { int i = 0; for (int j = 0; j < this.armor.length; ++j) { if (this.armor[j] != null && this.armor[j].getItem() instanceof ItemArmor) { - int k = ((ItemArmor) this.armor[j].getItem()).b; + int k = ((ItemArmor) this.armor[j].getItem()).c; i += k; } @@ -431,7 +451,7 @@ public class PlayerInventory implements IInventory { } } - public void l() { + public void m() { int i; for (i = 0; i < this.items.length; ++i) { @@ -466,7 +486,7 @@ public class PlayerInventory implements IInventory { return this.g; } - public boolean a_(EntityHuman entityhuman) { + public boolean a(EntityHuman entityhuman) { return this.player.dead ? false : entityhuman.e(this.player) <= 64.0D; } @@ -490,7 +510,11 @@ public class PlayerInventory implements IInventory { public void startOpen() {} - public void f() {} + public void g() {} + + public boolean b(int i, ItemStack itemstack) { + return true; + } public void b(PlayerInventory playerinventory) { int i; diff --git a/src/main/java/net/minecraft/server/PlayerList.java b/src/main/java/net/minecraft/server/PlayerList.java index e857612aee..585595d245 100644 --- a/src/main/java/net/minecraft/server/PlayerList.java +++ b/src/main/java/net/minecraft/server/PlayerList.java @@ -8,8 +8,9 @@ import java.util.Collections; import java.util.HashSet; import java.util.Iterator; import java.util.List; +import java.util.Map; import java.util.Set; -import java.util.logging.Logger; +import java.util.Map.Entry; // CraftBukkit start import org.bukkit.Location; @@ -32,21 +33,20 @@ import org.bukkit.Bukkit; public abstract class PlayerList { - private static final SimpleDateFormat e = new SimpleDateFormat("yyyy-MM-dd \'at\' HH:mm:ss z"); - public static final Logger a = Logger.getLogger("Minecraft"); + private static final SimpleDateFormat d = new SimpleDateFormat("yyyy-MM-dd \'at\' HH:mm:ss z"); private final MinecraftServer server; public final List players = new java.util.concurrent.CopyOnWriteArrayList(); // CraftBukkit - ArrayList -> CopyOnWriteArrayList: Iterator safety private final BanList banByName = new BanList(new File("banned-players.txt")); private final BanList banByIP = new BanList(new File("banned-ips.txt")); private Set operators = new HashSet(); private Set whitelist = new java.util.LinkedHashSet(); // CraftBukkit - HashSet -> LinkedHashSet - public PlayerFileData playerFileData; // CraftBukkit - private -> public + public IPlayerFileData playerFileData; // CraftBukkit - private -> public public boolean hasWhitelist; // CraftBukkit - private -> public protected int maxPlayers; - protected int d; - private EnumGamemode m; - private boolean n; - private int o = 0; + protected int c; + private EnumGamemode l; + private boolean m; + private int n = 0; // CraftBukkit start private CraftServer cserver; @@ -64,7 +64,8 @@ public abstract class PlayerList { } public void a(INetworkManager inetworkmanager, EntityPlayer entityplayer) { - this.a(entityplayer); + NBTTagCompound nbttagcompound = this.a(entityplayer); + entityplayer.spawnIn(this.server.getWorldServer(entityplayer.dimension)); entityplayer.playerInteractManager.a((WorldServer) entityplayer.world); String s = "local"; @@ -74,7 +75,7 @@ public abstract class PlayerList { } // CraftBukkit - add world and location to 'logged in' message. - a.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.name + "[" + 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(); @@ -93,8 +94,9 @@ public abstract class PlayerList { playerconnection.sendPacket(new Packet6SpawnPosition(chunkcoordinates.x, chunkcoordinates.y, chunkcoordinates.z)); playerconnection.sendPacket(new Packet202Abilities(entityplayer.abilities)); playerconnection.sendPacket(new Packet16BlockItemSwitch(entityplayer.inventory.itemInHandIndex)); + this.a((ScoreboardServer) worldserver.getScoreboard(), entityplayer); this.b(entityplayer, worldserver); - // this.sendAll(new Packet3Chat("\u00A7e" + entityplayer.name + " joined the game.")); // CraftBukkit - handled in event + // this.sendAll(new Packet3Chat(EnumChatFormat.YELLOW + entityplayer.getScoreboardDisplayName() + EnumChatFormat.YELLOW + " joined the game.")); // CraftBukkit - handled in event this.c(entityplayer); playerconnection.a(entityplayer.locX, entityplayer.locY, entityplayer.locZ, entityplayer.yaw, entityplayer.pitch); this.server.ae().a(playerconnection); @@ -112,6 +114,44 @@ public abstract class PlayerList { } entityplayer.syncInventory(); + if (nbttagcompound != null && nbttagcompound.hasKey("Riding")) { + Entity entity = EntityTypes.a(nbttagcompound.getCompound("Riding"), worldserver); + + if (entity != null) { + entity.p = true; + worldserver.addEntity(entity); + entityplayer.mount(entity); + entity.p = false; + } + } + } + + protected void a(ScoreboardServer scoreboardserver, EntityPlayer entityplayer) { + HashSet hashset = new HashSet(); + Iterator iterator = scoreboardserver.g().iterator(); + + while (iterator.hasNext()) { + ScoreboardTeam scoreboardteam = (ScoreboardTeam) iterator.next(); + + entityplayer.playerConnection.sendPacket(new Packet209SetScoreboardTeam(scoreboardteam, 0)); + } + + for (int i = 0; i < 3; ++i) { + ScoreboardObjective scoreboardobjective = scoreboardserver.a(i); + + if (scoreboardobjective != null && !hashset.contains(scoreboardobjective)) { + List list = scoreboardserver.d(scoreboardobjective); + Iterator iterator1 = list.iterator(); + + while (iterator1.hasNext()) { + Packet packet = (Packet) iterator1.next(); + + entityplayer.playerConnection.sendPacket(packet); + } + + hashset.add(scoreboardobjective); + } + } } public void setPlayerFileData(WorldServer[] aworldserver) { @@ -120,7 +160,7 @@ public abstract class PlayerList { } public void a(EntityPlayer entityplayer, WorldServer worldserver) { - WorldServer worldserver1 = entityplayer.p(); + WorldServer worldserver1 = entityplayer.o(); if (worldserver != null) { worldserver.getPlayerChunkMap().removePlayer(entityplayer); @@ -134,14 +174,19 @@ public abstract class PlayerList { return PlayerChunkMap.getFurthestViewableBlock(this.o()); } - public void a(EntityPlayer entityplayer) { + public NBTTagCompound a(EntityPlayer entityplayer) { NBTTagCompound nbttagcompound = this.server.worlds.get(0).getWorldData().i(); // CraftBukkit + NBTTagCompound nbttagcompound1; if (entityplayer.getName().equals(this.server.H()) && nbttagcompound != null) { - entityplayer.e(nbttagcompound); + entityplayer.f(nbttagcompound); + nbttagcompound1 = nbttagcompound; + System.out.println("loading single player"); } else { - this.playerFileData.load(entityplayer); + nbttagcompound1 = this.playerFileData.load(entityplayer); } + + return nbttagcompound1; } protected void b(EntityPlayer entityplayer) { @@ -198,7 +243,7 @@ public abstract class PlayerList { } public void d(EntityPlayer entityplayer) { - entityplayer.p().getPlayerChunkMap().movePlayer(entityplayer); + entityplayer.o().getPlayerChunkMap().movePlayer(entityplayer); } public String disconnect(EntityPlayer entityplayer) { // CraftBukkit - return string @@ -211,7 +256,12 @@ public abstract class PlayerList { // CraftBukkit end this.b(entityplayer); - WorldServer worldserver = entityplayer.p(); + WorldServer worldserver = entityplayer.o(); + + if (entityplayer.vehicle != null) { + worldserver.kill(entityplayer.vehicle); + System.out.println("removing player mount"); + } worldserver.kill(entityplayer); worldserver.getPlayerChunkMap().removePlayer(entityplayer); @@ -248,7 +298,7 @@ public abstract class PlayerList { String s1 = "You are banned from this server!\nReason: " + banentry.getReason(); if (banentry.getExpires() != null) { - s1 = s1 + "\nYour ban will be removed on " + e.format(banentry.getExpires()); + s1 = s1 + "\nYour ban will be removed on " + d.format(banentry.getExpires()); } event.disallow(PlayerLoginEvent.Result.KICK_BANNED, s1); @@ -264,7 +314,7 @@ public abstract class PlayerList { String s3 = "Your IP address is banned from this server!\nReason: " + banentry1.getReason(); if (banentry1.getExpires() != null) { - s3 = s3 + "\nYour ban will be removed on " + e.format(banentry1.getExpires()); + s3 = s3 + "\nYour ban will be removed on " + d.format(banentry1.getExpires()); } event.disallow(PlayerLoginEvent.Result.KICK_BANNED, s3); @@ -327,9 +377,9 @@ public abstract class PlayerList { public EntityPlayer moveToWorld(EntityPlayer entityplayer, int i, boolean flag, Location location, boolean avoidSuffocation) { // CraftBukkit end - entityplayer.p().getTracker().untrackPlayer(entityplayer); - // entityplayer.p().getTracker().untrackEntity(entityplayer); // CraftBukkit - entityplayer.p().getPlayerChunkMap().removePlayer(entityplayer); + entityplayer.o().getTracker().untrackPlayer(entityplayer); + // entityplayer.o().getTracker().untrackEntity(entityplayer); // CraftBukkit + entityplayer.o().getPlayerChunkMap().removePlayer(entityplayer); this.players.remove(entityplayer); this.server.getWorldServer(entityplayer.dimension).removeEntity(entityplayer); ChunkCoordinates chunkcoordinates = entityplayer.getBed(); @@ -411,6 +461,7 @@ public abstract class PlayerList { } // entityplayer1.syncInventory(); // CraftBukkit end + entityplayer1.setHealth(entityplayer1.getHealth()); // CraftBukkit start - don't fire on respawn if (fromWorld != location.getWorld()) { @@ -651,13 +702,13 @@ public abstract class PlayerList { } public void tick() { - if (++this.o > 600) { - this.o = 0; + if (++this.n > 600) { + this.n = 0; } /* CraftBukkit start - remove updating of lag to players -- it spams way to much on big servers. - if (this.o < this.players.size()) { - EntityPlayer entityplayer = (EntityPlayer) this.players.get(this.o); + if (this.n < this.players.size()) { + EntityPlayer entityplayer = (EntityPlayer) this.players.get(this.n); this.sendAll(new Packet201PlayerInfo(entityplayer.name, true, entityplayer.ping)); } @@ -741,7 +792,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.n; + return this.operators.contains(s.trim().toLowerCase()) || this.server.I() && this.server.worlds.get(0).getWorldData().allowCommands() && this.server.H().equalsIgnoreCase(s) || this.m; } public EntityPlayer f(String s) { @@ -760,7 +811,7 @@ public abstract class PlayerList { return entityplayer; } - public List a(ChunkCoordinates chunkcoordinates, int i, int j, int k, int l, int i1, int j1) { + public List a(ChunkCoordinates chunkcoordinates, int i, int j, int k, int l, int i1, int j1, Map map, String s, String s1) { if (this.players.isEmpty()) { return null; } else { @@ -773,6 +824,32 @@ public abstract class PlayerList { 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 (s1 != null) { + flag1 = s1.startsWith("!"); + if (flag1) { + s1 = s1.substring(1); + } + + ScoreboardTeam scoreboardteam = entityplayer.getScoreboardTeam(); + String s2 = scoreboardteam == null ? "" : scoreboardteam.b(); + + if (flag1 == s1.equalsIgnoreCase(s2)) { + continue; + } + } if (chunkcoordinates != null && (i > 0 || j > 0)) { float f = chunkcoordinates.e(entityplayer.b()); @@ -782,7 +859,7 @@ public abstract class PlayerList { } } - if ((l == EnumGamemode.NONE.a() || l == entityplayer.playerInteractManager.getGameMode().a()) && (i1 <= 0 || entityplayer.expLevel >= i1) && entityplayer.expLevel <= j1) { + 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); } } @@ -803,6 +880,49 @@ public abstract class PlayerList { } } + private boolean a(EntityHuman entityhuman, Map map) { + if (map != null && map.size() != 0) { + Iterator iterator = map.entrySet().iterator(); + + Entry entry; + boolean flag; + int i; + + do { + if (!iterator.hasNext()) { + return true; + } + + entry = (Entry) iterator.next(); + String s = (String) entry.getKey(); + + flag = false; + if (s.endsWith("_min") && s.length() > 4) { + flag = true; + s = s.substring(0, s.length() - 4); + } + + Scoreboard scoreboard = entityhuman.getScoreboard(); + ScoreboardObjective scoreboardobjective = scoreboard.b(s); + + if (scoreboardobjective == null) { + return false; + } + + ScoreboardScore scoreboardscore = entityhuman.getScoreboard().a(entityhuman.getLocalizedName(), scoreboardobjective); + + i = scoreboardscore.c(); + if (i < ((Integer) entry.getValue()).intValue() && flag) { + return false; + } + } while (i <= ((Integer) entry.getValue()).intValue() || flag); + + return false; + } else { + return true; + } + } + public void sendPacketNearby(double d0, double d1, double d2, double d3, int i, Packet packet) { this.sendPacketNearby((EntityHuman) null, d0, d1, d2, d3, i, packet); } @@ -854,7 +974,7 @@ public abstract class PlayerList { public void b(EntityPlayer entityplayer, WorldServer worldserver) { entityplayer.playerConnection.sendPacket(new Packet4UpdateTime(worldserver.getTime(), worldserver.getDayTime())); - if (worldserver.N()) { + if (worldserver.O()) { entityplayer.playerConnection.sendPacket(new Packet70Bed(1, 0)); } } @@ -892,7 +1012,7 @@ public abstract class PlayerList { while (iterator.hasNext()) { EntityPlayer entityplayer = (EntityPlayer) iterator.next(); - if (entityplayer.q().equals(s)) { + if (entityplayer.p().equals(s)) { arraylist.add(entityplayer); } } @@ -901,7 +1021,7 @@ public abstract class PlayerList { } public int o() { - return this.d; + return this.c; } public MinecraftServer getServer() { @@ -915,8 +1035,8 @@ public abstract class PlayerList { private void a(EntityPlayer entityplayer, EntityPlayer entityplayer1, World world) { if (entityplayer1 != null) { entityplayer.playerInteractManager.setGameMode(entityplayer1.playerInteractManager.getGameMode()); - } else if (this.m != null) { - entityplayer.playerInteractManager.setGameMode(this.m); + } else if (this.l != null) { + entityplayer.playerInteractManager.setGameMode(this.l); } entityplayer.playerInteractManager.b(world.getWorldData().getGameType()); diff --git a/src/main/java/net/minecraft/server/PortalTravelAgent.java b/src/main/java/net/minecraft/server/PortalTravelAgent.java index cb5a0ada00..5eafb576ac 100644 --- a/src/main/java/net/minecraft/server/PortalTravelAgent.java +++ b/src/main/java/net/minecraft/server/PortalTravelAgent.java @@ -54,7 +54,7 @@ public class PortalTravelAgent { int i2 = k + i1 * b1 - l * b0; boolean flag = j1 < 0; - this.a.setTypeId(k1, l1, i2, flag ? Block.OBSIDIAN.id : 0); + this.a.setTypeIdUpdate(k1, l1, i2, flag ? Block.OBSIDIAN.id : 0); } } } @@ -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.P() - 1; i2 >= 0; --i2) { + for (int i2 = this.a.Q() - 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.at(); + int k2 = entity.as(); 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.P() - 1; k2 >= 0; --k2) { + for (k2 = this.a.Q() - 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.P() - 1; k2 >= 0; --k2) { + for (k2 = this.a.Q() - 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.P() - 10) { - i1 = this.a.P() - 10; + if (i1 > this.a.Q() - 10) { + i1 = this.a.Q() - 10; } j5 = i1; @@ -484,27 +484,23 @@ public class PortalTravelAgent { j3 = j5 + l2; i4 = j2 + (i3 - 1) * l5 - k2 * k5; flag = l2 < 0; - this.a.setTypeId(k3, j3, i4, flag ? Block.OBSIDIAN.id : 0); + this.a.setTypeIdUpdate(k3, j3, i4, flag ? Block.OBSIDIAN.id : 0); } } } } for (k2 = 0; k2 < 4; ++k2) { - this.a.suppressPhysics = true; - for (i3 = 0; i3 < 4; ++i3) { for (l2 = -1; l2 < 4; ++l2) { k3 = i5 + (i3 - 1) * k5; j3 = j5 + l2; i4 = j2 + (i3 - 1) * l5; flag = i3 == 0 || i3 == 3 || l2 == -1 || l2 == 3; - this.a.setTypeId(k3, j3, i4, flag ? Block.OBSIDIAN.id : Block.PORTAL.id); + this.a.setTypeIdAndData(k3, j3, i4, flag ? Block.OBSIDIAN.id : Block.PORTAL.id, 0, 2); } } - this.a.suppressPhysics = false; - for (i3 = 0; i3 < 4; ++i3) { for (l2 = -1; l2 < 4; ++l2) { k3 = i5 + (i3 - 1) * k5; diff --git a/src/main/java/net/minecraft/server/PropertyManager.java b/src/main/java/net/minecraft/server/PropertyManager.java index 8c0ef99990..03aa2190a6 100644 --- a/src/main/java/net/minecraft/server/PropertyManager.java +++ b/src/main/java/net/minecraft/server/PropertyManager.java @@ -12,12 +12,13 @@ import joptsimple.OptionSet; // CraftBukkit public class PropertyManager { - public static Logger a = Logger.getLogger("Minecraft"); - public Properties properties = new Properties(); // CraftBukkit - private -> public - private File c; + public final Properties properties = new Properties(); // CraftBukkit - private -> public + private final IConsoleLogManager loggingAgent; + private final File c; - public PropertyManager(File file1) { + public PropertyManager(File file1, IConsoleLogManager iconsolelogmanager) { this.c = file1; + this.loggingAgent = iconsolelogmanager; if (file1.exists()) { FileInputStream fileinputstream = null; @@ -25,7 +26,7 @@ public class PropertyManager { fileinputstream = new FileInputStream(file1); this.properties.load(fileinputstream); } catch (Exception exception) { - a.log(Level.WARNING, "Failed to load " + file1, exception); + iconsolelogmanager.warning("Failed to load " + file1, exception); this.a(); } finally { if (fileinputstream != null) { @@ -37,7 +38,7 @@ public class PropertyManager { } } } else { - a.log(Level.WARNING, file1 + " does not exist"); + iconsolelogmanager.warning(file1 + " does not exist"); this.a(); } } @@ -45,8 +46,8 @@ public class PropertyManager { // CraftBukkit start private OptionSet options = null; - public PropertyManager(final OptionSet options) { - this((File) options.valueOf("config")); + public PropertyManager(final OptionSet options, IConsoleLogManager iconsolelogmanager) { + this((File) options.valueOf("config"), iconsolelogmanager); this.options = options; } @@ -61,7 +62,7 @@ public class PropertyManager { // CraftBukkit end public void a() { - a.log(Level.INFO, "Generating new properties file"); + this.loggingAgent.info("Generating new properties file"); this.savePropertiesFile(); } @@ -77,7 +78,7 @@ public class PropertyManager { fileoutputstream = new FileOutputStream(this.c); this.properties.store(fileoutputstream, "Minecraft server properties"); } catch (Exception exception) { - a.log(Level.WARNING, "Failed to save " + this.c, exception); + this.loggingAgent.warning("Failed to save " + this.c, exception); this.a(); } finally { if (fileoutputstream != null) { diff --git a/src/main/java/net/minecraft/server/RecipeArmorDye.java b/src/main/java/net/minecraft/server/RecipeArmorDye.java index 3735aa7a28..0b89265aff 100644 --- a/src/main/java/net/minecraft/server/RecipeArmorDye.java +++ b/src/main/java/net/minecraft/server/RecipeArmorDye.java @@ -63,6 +63,7 @@ public class RecipeArmorDye extends ShapelessRecipes implements IRecipe { // Cra } itemstack = itemstack1.cloneItemStack(); + itemstack.count = 1; if (itemarmor.a(itemstack1)) { l = itemarmor.b(itemstack); f = (float) (l >> 16 & 255) / 255.0F; @@ -80,7 +81,7 @@ public class RecipeArmorDye extends ShapelessRecipes implements IRecipe { // Cra return null; } - float[] afloat = EntitySheep.d[BlockCloth.e_(itemstack1.getData())]; + float[] afloat = EntitySheep.d[BlockCloth.g_(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/RecipeFireworks.java b/src/main/java/net/minecraft/server/RecipeFireworks.java index abed268ec5..43caa90518 100644 --- a/src/main/java/net/minecraft/server/RecipeFireworks.java +++ b/src/main/java/net/minecraft/server/RecipeFireworks.java @@ -92,7 +92,7 @@ public class RecipeFireworks extends ShapelessRecipes implements IRecipe { // Cr if (itemstack2 != null) { if (itemstack2.id == Item.INK_SACK.id) { - arraylist.add(Integer.valueOf(ItemDye.b[itemstack2.getData()])); + arraylist.add(Integer.valueOf(ItemDye.c[itemstack2.getData()])); } else if (itemstack2.id == Item.GLOWSTONE_DUST.id) { nbttagcompound1.setBoolean("Flicker", true); } else if (itemstack2.id == Item.DIAMOND.id) { @@ -128,7 +128,7 @@ public class RecipeFireworks extends ShapelessRecipes implements IRecipe { // Cr if (itemstack3 != null) { if (itemstack3.id == Item.INK_SACK.id) { - arraylist1.add(Integer.valueOf(ItemDye.b[itemstack3.getData()])); + arraylist1.add(Integer.valueOf(ItemDye.c[itemstack3.getData()])); } else if (itemstack3.id == Item.FIREWORKS_CHARGE.id) { this.a = itemstack3.cloneItemStack(); this.a.count = 1; diff --git a/src/main/java/net/minecraft/server/RecipeMapClone.java b/src/main/java/net/minecraft/server/RecipeMapClone.java index 7224c7af5b..97539ecdd0 100644 --- a/src/main/java/net/minecraft/server/RecipeMapClone.java +++ b/src/main/java/net/minecraft/server/RecipeMapClone.java @@ -62,8 +62,8 @@ public class RecipeMapClone extends ShapelessRecipes implements IRecipe { // Cra if (itemstack != null && i >= 1) { ItemStack itemstack2 = new ItemStack(Item.MAP, i + 1, itemstack.getData()); - if (itemstack.s()) { - itemstack2.c(itemstack.r()); + if (itemstack.hasName()) { + itemstack2.c(itemstack.getName()); } return itemstack2; diff --git a/src/main/java/net/minecraft/server/RecipesFurnace.java b/src/main/java/net/minecraft/server/RecipesFurnace.java index 7abc461204..fe56cde5ce 100644 --- a/src/main/java/net/minecraft/server/RecipesFurnace.java +++ b/src/main/java/net/minecraft/server/RecipesFurnace.java @@ -28,9 +28,11 @@ public class RecipesFurnace { 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); this.registerRecipe(Item.POTATO.id, new ItemStack(Item.POTATO_BAKED), 0.35F); + this.registerRecipe(Block.NETHERRACK.id, new ItemStack(Item.NETHER_BRICK), 0.1F); this.registerRecipe(Block.COAL_ORE.id, new ItemStack(Item.COAL), 0.1F); this.registerRecipe(Block.REDSTONE_ORE.id, new ItemStack(Item.REDSTONE), 0.7F); this.registerRecipe(Block.LAPIS_ORE.id, new ItemStack(Item.INK_SACK, 1, 4), 0.2F); + this.registerRecipe(Block.QUARTZ_ORE.id, new ItemStack(Item.QUARTZ), 0.2F); } public void registerRecipe(int i, ItemStack itemstack, float f) { diff --git a/src/main/java/net/minecraft/server/SecondaryWorldServer.java b/src/main/java/net/minecraft/server/SecondaryWorldServer.java index 0032fae3d0..94a2f05d21 100644 --- a/src/main/java/net/minecraft/server/SecondaryWorldServer.java +++ b/src/main/java/net/minecraft/server/SecondaryWorldServer.java @@ -2,10 +2,11 @@ package net.minecraft.server; public class SecondaryWorldServer extends WorldServer { // CraftBukkit start - Changed signature - public SecondaryWorldServer(MinecraftServer minecraftserver, IDataManager idatamanager, String s, int i, WorldSettings worldsettings, WorldServer worldserver, MethodProfiler methodprofiler, org.bukkit.World.Environment env, org.bukkit.generator.ChunkGenerator gen) { - super(minecraftserver, idatamanager, s, i, worldsettings, methodprofiler, env, gen); + public SecondaryWorldServer(MinecraftServer minecraftserver, IDataManager idatamanager, String s, int i, WorldSettings worldsettings, WorldServer worldserver, MethodProfiler methodprofiler, IConsoleLogManager iconsolelogmanager, org.bukkit.World.Environment env, org.bukkit.generator.ChunkGenerator gen) { + super(minecraftserver, idatamanager, s, i, worldsettings, methodprofiler, iconsolelogmanager, env, gen); // CraftBukkit end this.worldMaps = worldserver.worldMaps; + this.scoreboard = worldserver.getScoreboard(); // this.worldData = new SecondaryWorldData(worldserver.getWorldData()); // CraftBukkit - use unique worlddata } diff --git a/src/main/java/net/minecraft/server/ShapedRecipes.java b/src/main/java/net/minecraft/server/ShapedRecipes.java index 52f8ee747a..a70b8285af 100644 --- a/src/main/java/net/minecraft/server/ShapedRecipes.java +++ b/src/main/java/net/minecraft/server/ShapedRecipes.java @@ -124,7 +124,7 @@ public class ShapedRecipes implements IRecipe { return false; } - if (itemstack.getData() != -1 && itemstack.getData() != itemstack1.getData()) { + if (itemstack.getData() != 32767 && itemstack.getData() != itemstack1.getData()) { return false; } } diff --git a/src/main/java/net/minecraft/server/ShapelessRecipes.java b/src/main/java/net/minecraft/server/ShapelessRecipes.java index 3c08c2a67b..fbdad80798 100644 --- a/src/main/java/net/minecraft/server/ShapelessRecipes.java +++ b/src/main/java/net/minecraft/server/ShapelessRecipes.java @@ -51,7 +51,7 @@ public class ShapelessRecipes implements IRecipe { while (iterator.hasNext()) { ItemStack itemstack1 = (ItemStack) iterator.next(); - if (itemstack.id == itemstack1.id && (itemstack1.getData() == -1 || itemstack.getData() == itemstack1.getData())) { + if (itemstack.id == itemstack1.id && (itemstack1.getData() == 32767 || itemstack.getData() == itemstack1.getData())) { flag = true; arraylist.remove(itemstack1); break; diff --git a/src/main/java/net/minecraft/server/SpawnerCreature.java b/src/main/java/net/minecraft/server/SpawnerCreature.java index 9b3e262618..2d1a37239b 100644 --- a/src/main/java/net/minecraft/server/SpawnerCreature.java +++ b/src/main/java/net/minecraft/server/SpawnerCreature.java @@ -21,7 +21,7 @@ public final class SpawnerCreature { 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.P() : chunk.h() + 16 - 1); + int i1 = world.random.nextInt(chunk == null ? world.Q() : chunk.h() + 16 - 1); return new ChunkPosition(k, i1, l); } @@ -105,7 +105,7 @@ public final class SpawnerCreature { int l1 = chunkposition.y; int i2 = chunkposition.z; - if (!worldserver.t(k1, l1, i2) && worldserver.getMaterial(k1, l1, i2) == enumcreaturetype.c()) { + if (!worldserver.u(k1, l1, i2) && worldserver.getMaterial(k1, l1, i2) == enumcreaturetype.c()) { int j2 = 0; int k2 = 0; @@ -158,7 +158,7 @@ public final class SpawnerCreature { a(entityliving, worldserver, f, f1, f2); worldserver.addEntity(entityliving, SpawnReason.NATURAL); // CraftBukkit end - if (j2 >= entityliving.bv()) { + if (j2 >= entityliving.by()) { continue label110; } } @@ -189,18 +189,18 @@ public final class SpawnerCreature { public static boolean a(EnumCreatureType enumcreaturetype, World world, int i, int j, int k) { if (enumcreaturetype.c() == Material.WATER) { - return world.getMaterial(i, j, k).isLiquid() && world.getMaterial(i, j - 1, k).isLiquid() && !world.t(i, j + 1, k); - } else if (!world.v(i, j - 1, k)) { + return world.getMaterial(i, j, k).isLiquid() && world.getMaterial(i, j - 1, k).isLiquid() && !world.u(i, j + 1, k); + } else if (!world.w(i, j - 1, k)) { return false; } else { int l = world.getTypeId(i, j - 1, k); - return l != Block.BEDROCK.id && !world.t(i, j, k) && !world.getMaterial(i, j, k).isLiquid() && !world.t(i, j + 1, k); + return l != Block.BEDROCK.id && !world.u(i, j, k) && !world.getMaterial(i, j, k).isLiquid() && !world.u(i, j + 1, k); } } private static void a(EntityLiving entityliving, World world, float f, float f1, float f2) { - entityliving.bG(); + entityliving.bJ(); } public static void a(World world, BiomeBase biomebase, int i, int j, int k, int l, Random random) { diff --git a/src/main/java/net/minecraft/server/ThreadCommandReader.java b/src/main/java/net/minecraft/server/ThreadCommandReader.java index 64eaa4ca35..489e184601 100644 --- a/src/main/java/net/minecraft/server/ThreadCommandReader.java +++ b/src/main/java/net/minecraft/server/ThreadCommandReader.java @@ -39,7 +39,7 @@ class ThreadCommandReader extends Thread { } } catch (IOException ioexception) { // CraftBukkit - MinecraftServer.log.log(java.util.logging.Level.SEVERE, null, ioexception); + java.util.logging.Logger.getLogger("").log(java.util.logging.Level.SEVERE, null, ioexception); } } } diff --git a/src/main/java/net/minecraft/server/TileEntity.java b/src/main/java/net/minecraft/server/TileEntity.java index d8eb6b9184..db3fc42e2e 100644 --- a/src/main/java/net/minecraft/server/TileEntity.java +++ b/src/main/java/net/minecraft/server/TileEntity.java @@ -10,7 +10,7 @@ public class TileEntity { private static Map a = new HashMap(); private static Map b = new HashMap(); - public World world; // CraftBukkit - protected -> public + protected World world; public int x; public int y; public int z; @@ -33,6 +33,10 @@ public class TileEntity { this.world = world; } + public World getWorld() { + return this.world; + } + public boolean o() { return this.world != null; } @@ -56,7 +60,7 @@ public class TileEntity { } } - public void g() {} + public void h() {} public static TileEntity c(NBTTagCompound nbttagcompound) { TileEntity tileentity = null; @@ -74,7 +78,7 @@ public class TileEntity { if (tileentity != null) { tileentity.a(nbttagcompound); } else { - System.out.println("Skipping TileEntity with id " + nbttagcompound.getString("id")); + MinecraftServer.getServer().getLogger().warning("Skipping TileEntity with id " + nbttagcompound.getString("id")); } return tileentity; @@ -92,6 +96,9 @@ public class TileEntity { if (this.world != null) { this.p = this.world.getData(this.x, this.y, this.z); this.world.b(this.x, this.y, this.z, this); + if (this.q() != null) { + this.world.m(this.x, this.y, this.z, this.q().id); + } } } @@ -119,16 +126,20 @@ public class TileEntity { this.o = false; } - public void b(int i, int j) {} + public boolean b(int i, int j) { + return false; + } - public void h() { + public void i() { this.q = null; this.p = -1; } public void a(CrashReportSystemDetails crashreportsystemdetails) { crashreportsystemdetails.a("Name", (Callable) (new CrashReportTileEntityName(this))); - CrashReportSystemDetails.a(crashreportsystemdetails, this.x, this.y, this.z, this.q.id, this.p); + CrashReportSystemDetails.a(crashreportsystemdetails, this.x, this.y, this.z, this.q().id, this.p()); + crashreportsystemdetails.a("Actual block type", (Callable) (new CrashReportTileEntityType(this))); + crashreportsystemdetails.a("Actual block data value", (Callable) (new CrashReportTileEntityData(this))); } static Map t() { @@ -141,6 +152,7 @@ public class TileEntity { a(TileEntityEnderChest.class, "EnderChest"); a(TileEntityRecordPlayer.class, "RecordPlayer"); a(TileEntityDispenser.class, "Trap"); + a(TileEntityDropper.class, "Dropper"); a(TileEntitySign.class, "Sign"); a(TileEntityMobSpawner.class, "MobSpawner"); a(TileEntityNote.class, "Music"); @@ -151,6 +163,9 @@ public class TileEntity { a(TileEntityCommand.class, "Control"); a(TileEntityBeacon.class, "Beacon"); a(TileEntitySkull.class, "Skull"); + a(TileEntityLightDetector.class, "DLDetector"); + a(TileEntityHopper.class, "Hopper"); + a(TileEntityComparator.class, "Comparator"); } // CraftBukkit start diff --git a/src/main/java/net/minecraft/server/TileEntityBeacon.java b/src/main/java/net/minecraft/server/TileEntityBeacon.java index 9c19453f97..693792934d 100644 --- a/src/main/java/net/minecraft/server/TileEntityBeacon.java +++ b/src/main/java/net/minecraft/server/TileEntityBeacon.java @@ -4,8 +4,6 @@ import java.util.Iterator; import java.util.List; // CraftBukkit start -import java.util.List; - import org.bukkit.craftbukkit.entity.CraftHumanEntity; import org.bukkit.entity.HumanEntity; // CraftBukkit end @@ -18,6 +16,7 @@ public class TileEntityBeacon extends TileEntity implements IInventory { private int f; private int g; private ItemStack h; + private String i; // CraftBukkit start public List transaction = new java.util.ArrayList(); private int maxStack = MAX_STACK; @@ -45,7 +44,7 @@ public class TileEntityBeacon extends TileEntity implements IInventory { public TileEntityBeacon() {} - public void g() { + public void h() { if (this.world.getTime() % 80L == 0L) { this.v(); this.u(); @@ -54,7 +53,7 @@ public class TileEntityBeacon extends TileEntity implements IInventory { private void u() { if (this.d && this.e > 0 && !this.world.isStatic && this.f > 0) { - double d0 = (double) (this.e * 8 + 8); + double d0 = (double) (this.e * 10 + 10); byte b0 = 0; if (this.e >= 4 && this.f == this.g) { @@ -62,6 +61,8 @@ public class TileEntityBeacon extends TileEntity implements IInventory { } AxisAlignedBB axisalignedbb = AxisAlignedBB.a().a((double) this.x, (double) this.y, (double) this.z, (double) (this.x + 1), (double) (this.y + 1), (double) (this.z + 1)).grow(d0, d0, d0); + + axisalignedbb.e = (double) this.world.getHeight(); List list = this.world.a(EntityHuman.class, axisalignedbb); Iterator iterator = list.iterator(); @@ -84,7 +85,7 @@ public class TileEntityBeacon extends TileEntity implements IInventory { } private void v() { - if (!this.world.k(this.x, this.y + 1, this.z)) { + if (!this.world.l(this.x, this.y + 1, this.z)) { this.d = false; this.e = 0; } else { @@ -122,15 +123,15 @@ public class TileEntityBeacon extends TileEntity implements IInventory { } } - public int i() { + public int j() { return this.f; } - public int j() { + public int k() { return this.g; } - public int k() { + public int l() { return this.e; } @@ -234,18 +235,30 @@ public class TileEntityBeacon extends TileEntity implements IInventory { } public String getName() { - return "container.beacon"; + return this.c() ? this.i : "container.beacon"; + } + + public boolean c() { + return this.i != null && this.i.length() > 0; + } + + public void a(String s) { + this.i = s; } public int getMaxStackSize() { return maxStack; // CraftBukkit } - public boolean a_(EntityHuman entityhuman) { + public boolean a(EntityHuman entityhuman) { return this.world.getTileEntity(this.x, this.y, this.z) != this ? false : entityhuman.e((double) this.x + 0.5D, (double) this.y + 0.5D, (double) this.z + 0.5D) <= 64.0D; } public void startOpen() {} - public void f() {} + public void g() {} + + public boolean b(int i, ItemStack itemstack) { + return itemstack.id == Item.EMERALD.id || itemstack.id == Item.DIAMOND.id || itemstack.id == Item.GOLD_INGOT.id || itemstack.id == Item.IRON_INGOT.id; + } } diff --git a/src/main/java/net/minecraft/server/TileEntityBrewingStand.java b/src/main/java/net/minecraft/server/TileEntityBrewingStand.java index f047c856c5..8d77f12d47 100644 --- a/src/main/java/net/minecraft/server/TileEntityBrewingStand.java +++ b/src/main/java/net/minecraft/server/TileEntityBrewingStand.java @@ -8,18 +8,19 @@ import org.bukkit.entity.HumanEntity; import org.bukkit.event.inventory.BrewEvent; // CraftBukkit end -public class TileEntityBrewingStand extends TileEntity implements IInventory { +public class TileEntityBrewingStand extends TileEntity implements IWorldInventory { public ItemStack[] items = new ItemStack[4]; // CraftBukkit private -> public public int brewTime; // CraftBukkit private -> public private int c; private int d; + private String e; public TileEntityBrewingStand() {} // CraftBukkit start public List transaction = new java.util.ArrayList(); - private int maxStack = 1; + private int maxStack = 64; public void onOpen(CraftHumanEntity who) { transaction.add(who); @@ -43,50 +44,58 @@ public class TileEntityBrewingStand extends TileEntity implements IInventory { // CraftBukkit end public String getName() { - return "container.brewing"; + return this.c() ? this.e : "container.brewing"; + } + + public boolean c() { + return this.e != null && this.e.length() > 0; + } + + public void a(String s) { + this.e = s; } public int getSize() { return this.items.length; } - public void g() { + public void h() { if (this.brewTime > 0) { --this.brewTime; if (this.brewTime == 0) { this.u(); this.update(); - } else if (!this.k()) { + } else if (!this.l()) { this.brewTime = 0; this.update(); } else if (this.d != this.items[3].id) { this.brewTime = 0; this.update(); } - } else if (this.k()) { + } else if (this.l()) { this.brewTime = 400; this.d = this.items[3].id; } - int i = this.i(); + int i = this.j(); if (i != this.c) { this.c = i; - this.world.setData(this.x, this.y, this.z, i); + this.world.setData(this.x, this.y, this.z, i, 2); } - super.g(); + super.h(); } public int x_() { return this.brewTime; } - private boolean k() { + private boolean l() { if (this.items[3] != null && this.items[3].count > 0) { ItemStack itemstack = this.items[3]; - if (!Item.byId[itemstack.id].v()) { + if (!Item.byId[itemstack.id].w()) { return false; } else { boolean flag = false; @@ -94,15 +103,15 @@ public class TileEntityBrewingStand extends TileEntity implements IInventory { for (int i = 0; i < 3; ++i) { if (this.items[i] != null && this.items[i].id == Item.POTION.id) { int j = this.items[i].getData(); - int k = this.b(j, itemstack); + int k = this.c(j, itemstack); - if (!ItemPotion.g(j) && ItemPotion.g(k)) { + if (!ItemPotion.f(j) && ItemPotion.f(k)) { flag = true; break; } - List list = Item.POTION.f(j); - List list1 = Item.POTION.f(k); + 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) { flag = true; @@ -119,7 +128,7 @@ public class TileEntityBrewingStand extends TileEntity implements IInventory { } private void u() { - if (this.k()) { + if (this.l()) { ItemStack itemstack = this.items[3]; // CraftBukkit start - fire BREW event @@ -135,22 +144,22 @@ public class TileEntityBrewingStand extends TileEntity implements IInventory { for (int i = 0; i < 3; ++i) { if (this.items[i] != null && this.items[i].id == Item.POTION.id) { int j = this.items[i].getData(); - int k = this.b(j, itemstack); - List list = Item.POTION.f(j); - List list1 = Item.POTION.f(k); + int k = this.c(j, itemstack); + List list = Item.POTION.c(j); + List list1 = Item.POTION.c(k); if ((j <= 0 || list != list1) && (list == null || !list.equals(list1) && list1 != null)) { if (j != k) { this.items[i].setData(k); } - } else if (!ItemPotion.g(j) && ItemPotion.g(k)) { + } else if (!ItemPotion.f(j) && ItemPotion.f(k)) { this.items[i].setData(k); } } } - if (Item.byId[itemstack.id].s()) { - this.items[3] = new ItemStack(Item.byId[itemstack.id].r()); + if (Item.byId[itemstack.id].t()) { + this.items[3] = new ItemStack(Item.byId[itemstack.id].s()); } else { --this.items[3].count; if (this.items[3].count <= 0) { @@ -160,8 +169,8 @@ public class TileEntityBrewingStand extends TileEntity implements IInventory { } } - private int b(int i, ItemStack itemstack) { - return itemstack == null ? i : (Item.byId[itemstack.id].v() ? PotionBrewer.a(i, Item.byId[itemstack.id].u()) : i); + 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); } public void a(NBTTagCompound nbttagcompound) { @@ -180,6 +189,9 @@ public class TileEntityBrewingStand extends TileEntity implements IInventory { } this.brewTime = nbttagcompound.getShort("BrewTime"); + if (nbttagcompound.hasKey("CustomName")) { + this.e = nbttagcompound.getString("CustomName"); + } } public void b(NBTTagCompound nbttagcompound) { @@ -198,6 +210,9 @@ public class TileEntityBrewingStand extends TileEntity implements IInventory { } nbttagcompound.set("Items", nbttaglist); + if (this.c()) { + nbttagcompound.setString("CustomName", this.e); + } } public ItemStack getItem(int i) { @@ -236,15 +251,19 @@ public class TileEntityBrewingStand extends TileEntity implements IInventory { return this.maxStack; // CraftBukkit } - public boolean a_(EntityHuman entityhuman) { + public boolean a(EntityHuman entityhuman) { return this.world.getTileEntity(this.x, this.y, this.z) != this ? false : entityhuman.e((double) this.x + 0.5D, (double) this.y + 0.5D, (double) this.z + 0.5D) <= 64.0D; } public void startOpen() {} - public void f() {} + public void g() {} - public int i() { + 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; + } + + public int j() { int i = 0; for (int j = 0; j < 3; ++j) { @@ -255,4 +274,12 @@ public class TileEntityBrewingStand extends TileEntity implements IInventory { return i; } + + public int c(int i) { + return i == 1 ? 3 : 0; + } + + public int d(int i) { + return i == 1 ? 1 : 3; + } } diff --git a/src/main/java/net/minecraft/server/TileEntityChest.java b/src/main/java/net/minecraft/server/TileEntityChest.java index 4f002501e6..b179ddf2af 100644 --- a/src/main/java/net/minecraft/server/TileEntityChest.java +++ b/src/main/java/net/minecraft/server/TileEntityChest.java @@ -20,6 +20,8 @@ public class TileEntityChest extends TileEntity implements IInventory { public float g; public int h; private int ticks; + private int r = -1; + private String s; public TileEntityChest() {} @@ -100,7 +102,15 @@ public class TileEntityChest extends TileEntity implements IInventory { } public String getName() { - return "container.chest"; + return this.c() ? this.s : "container.chest"; + } + + public boolean c() { + return this.s != null && this.s.length() > 0; + } + + public void a(String s) { + this.s = s; } public void a(NBTTagCompound nbttagcompound) { @@ -108,6 +118,9 @@ public class TileEntityChest extends TileEntity implements IInventory { NBTTagList nbttaglist = nbttagcompound.getList("Items"); this.items = new ItemStack[this.getSize()]; + if (nbttagcompound.hasKey("CustomName")) { + this.s = nbttagcompound.getString("CustomName"); + } for (int i = 0; i < nbttaglist.size(); ++i) { NBTTagCompound nbttagcompound1 = (NBTTagCompound) nbttaglist.get(i); @@ -134,19 +147,22 @@ public class TileEntityChest extends TileEntity implements IInventory { } nbttagcompound.set("Items", nbttaglist); + if (this.c()) { + nbttagcompound.setString("CustomName", this.s); + } } public int getMaxStackSize() { return maxStack; // CraftBukkit } - public boolean a_(EntityHuman entityhuman) { + public boolean a(EntityHuman entityhuman) { if (this.world == null) return true; // CraftBukkit return this.world.getTileEntity(this.x, this.y, this.z) != this ? false : entityhuman.e((double) this.x + 0.5D, (double) this.y + 0.5D, (double) this.z + 0.5D) <= 64.0D; } - public void h() { - super.h(); + public void i() { + super.i(); this.a = false; } @@ -155,52 +171,52 @@ public class TileEntityChest extends TileEntity implements IInventory { this.a = false; } else if (this.a) { switch (i) { - case 0: - if (this.e != tileentitychest) { - this.a = false; - } - break; + case 0: + if (this.e != tileentitychest) { + this.a = false; + } + break; - case 1: - if (this.d != tileentitychest) { - this.a = false; - } - break; + case 1: + if (this.d != tileentitychest) { + this.a = false; + } + break; - case 2: - if (this.b != tileentitychest) { - this.a = false; - } - break; + case 2: + if (this.b != tileentitychest) { + this.a = false; + } + break; - case 3: - if (this.c != tileentitychest) { - this.a = false; - } + case 3: + if (this.c != tileentitychest) { + this.a = false; + } } } } - public void i() { + public void j() { if (!this.a) { this.a = true; this.b = null; this.c = null; this.d = null; this.e = null; - if (this.world.getTypeId(this.x - 1, this.y, this.z) == Block.CHEST.id) { + if (this.a(this.x - 1, this.y, this.z)) { this.d = (TileEntityChest) this.world.getTileEntity(this.x - 1, this.y, this.z); } - if (this.world.getTypeId(this.x + 1, this.y, this.z) == Block.CHEST.id) { + if (this.a(this.x + 1, this.y, this.z)) { this.c = (TileEntityChest) this.world.getTileEntity(this.x + 1, this.y, this.z); } - if (this.world.getTypeId(this.x, this.y, this.z - 1) == Block.CHEST.id) { + if (this.a(this.x, this.y, this.z - 1)) { this.b = (TileEntityChest) this.world.getTileEntity(this.x, this.y, this.z - 1); } - if (this.world.getTypeId(this.x, this.y, this.z + 1) == Block.CHEST.id) { + if (this.a(this.x, this.y, this.z + 1)) { this.e = (TileEntityChest) this.world.getTileEntity(this.x, this.y, this.z + 1); } @@ -209,11 +225,11 @@ public class TileEntityChest extends TileEntity implements IInventory { } if (this.e != null) { - this.e.a(this, 1); + this.e.a(this, 2); } if (this.c != null) { - this.c.a(this, 2); + this.c.a(this, 1); } if (this.d != null) { @@ -222,10 +238,16 @@ public class TileEntityChest extends TileEntity implements IInventory { } } - public void g() { - super.g(); + private boolean a(int i, int j, int k) { + Block block = Block.byId[this.world.getTypeId(i, j, k)]; + + return block != null && block instanceof BlockChest ? ((BlockChest) block).a == this.l() : false; + } + + public void h() { + super.h(); if (this.world == null) return; // CraftBukkit - this.i(); + this.j(); ++this.ticks; float f; @@ -239,9 +261,9 @@ public class TileEntityChest extends TileEntity implements IInventory { EntityHuman entityhuman = (EntityHuman) iterator.next(); if (entityhuman.activeContainer instanceof ContainerChest) { - IInventory iinventory = ((ContainerChest) entityhuman.activeContainer).d(); + IInventory iinventory = ((ContainerChest) entityhuman.activeContainer).e(); - if (iinventory == this || iinventory instanceof InventoryLargeChest && ((InventoryLargeChest) iinventory).a(this)) { + if (iinventory == this || iinventory instanceof InventoryLargeChest && ((InventoryLargeChest) iinventory).a((IInventory) this)) { ++this.h; } } @@ -303,27 +325,56 @@ public class TileEntityChest extends TileEntity implements IInventory { } } - public void b(int i, int j) { + public boolean b(int i, int j) { if (i == 1) { this.h = j; + return true; + } else { + return super.b(i, j); } } public void startOpen() { + if (this.h < 0) { + this.h = 0; + } + ++this.h; if (this.world == null) return; // CraftBukkit - this.world.playNote(this.x, this.y, this.z, Block.CHEST.id, 1, this.h); + this.world.playNote(this.x, this.y, this.z, this.q().id, 1, this.h); + this.world.applyPhysics(this.x, this.y, this.z, this.q().id); + this.world.applyPhysics(this.x, this.y - 1, this.z, this.q().id); } - public void f() { - --this.h; - if (this.world == null) return; // CraftBukkit - this.world.playNote(this.x, this.y, this.z, Block.CHEST.id, 1, this.h); + public void g() { + if (this.q() != null && this.q() instanceof BlockChest) { + --this.h; + if (this.world == null) return; // CraftBukkit + this.world.playNote(this.x, this.y, this.z, this.q().id, 1, this.h); + this.world.applyPhysics(this.x, this.y, this.z, this.q().id); + this.world.applyPhysics(this.x, this.y - 1, this.z, this.q().id); + } + } + + public boolean b(int i, ItemStack itemstack) { + return true; } public void w_() { super.w_(); - this.h(); this.i(); + this.j(); + } + + public int l() { + if (this.r == -1) { + if (this.world == null || !(this.q() instanceof BlockChest)) { + return 0; + } + + this.r = ((BlockChest) this.q()).a; + } + + return this.r; } } diff --git a/src/main/java/net/minecraft/server/TileEntityCommand.java b/src/main/java/net/minecraft/server/TileEntityCommand.java index 4ff401b057..f05573d1ae 100644 --- a/src/main/java/net/minecraft/server/TileEntityCommand.java +++ b/src/main/java/net/minecraft/server/TileEntityCommand.java @@ -8,29 +8,35 @@ import com.google.common.base.Joiner; public class TileEntityCommand extends TileEntity implements ICommandListener { - private String a = ""; + private int a = 0; + private String b = ""; + private String c = "@"; + // CraftBukkit start private final org.bukkit.command.BlockCommandSender sender; public TileEntityCommand() { sender = new org.bukkit.craftbukkit.command.CraftBlockCommandSender(this); } + // CraftBukkit end public void b(String s) { - this.a = s; + this.b = s; this.update(); } - public void a(World world) { - if (!world.isStatic) { + public int a(World world) { + if (world.isStatic) { + return 0; + } else { MinecraftServer minecraftserver = MinecraftServer.getServer(); if (minecraftserver != null && minecraftserver.getEnableCommandBlock()) { // CraftBukkit start - handle command block as console org.bukkit.command.SimpleCommandMap commandMap = minecraftserver.server.getCommandMap(); Joiner joiner = Joiner.on(" "); - String command = this.a; - if (this.a.startsWith("/")) { - command = this.a.substring(1); + String command = this.b; + if (this.b.startsWith("/")) { + command = this.b.substring(1); } String[] args = command.split(" "); ArrayList commands = new ArrayList(); @@ -39,17 +45,17 @@ public class TileEntityCommand extends TileEntity implements ICommandListener { if (args[0].equalsIgnoreCase("stop") || args[0].equalsIgnoreCase("kick") || args[0].equalsIgnoreCase("op") || args[0].equalsIgnoreCase("deop") || args[0].equalsIgnoreCase("ban") || args[0].equalsIgnoreCase("ban-ip") || args[0].equalsIgnoreCase("pardon") || args[0].equalsIgnoreCase("pardon-ip") || args[0].equalsIgnoreCase("reload")) { - return; + return 0; } // make sure this is a valid command if (commandMap.getCommand(args[0]) == null) { - return; + return 0; } // if the world has no players don't run if (this.world.players.isEmpty()) { - return; + return 0; } commands.add(args); @@ -68,11 +74,22 @@ public class TileEntityCommand extends TileEntity implements ICommandListener { } } + int completed = 0; + // now dispatch all of the commands we ended up with for (int i = 0; i < commands.size(); i++) { - commandMap.dispatch(sender, joiner.join(Arrays.asList(commands.get(i)))); + try { + if (commandMap.dispatch(sender, joiner.join(Arrays.asList(commands.get(i))))) { + completed++; + } + } catch (Throwable exception) { + minecraftserver.getLogger().warning(String.format("CommandBlock at (%d,%d,%d) failed to handle command", this.x, this.y, this.z), exception); + } } // CraftBukkit end + return completed; + } else { + return 0; } } } @@ -97,7 +114,11 @@ public class TileEntityCommand extends TileEntity implements ICommandListener { // CraftBukkit end public String getName() { - return "@"; + return this.c; + } + + public void c(String s) { + this.c = s; } public void sendMessage(String s) {} @@ -112,12 +133,18 @@ public class TileEntityCommand extends TileEntity implements ICommandListener { public void b(NBTTagCompound nbttagcompound) { super.b(nbttagcompound); - nbttagcompound.setString("Command", this.a); + nbttagcompound.setString("Command", this.b); + nbttagcompound.setInt("SuccessCount", this.a); + nbttagcompound.setString("CustomName", this.c); } public void a(NBTTagCompound nbttagcompound) { super.a(nbttagcompound); - this.a = nbttagcompound.getString("Command"); + this.b = nbttagcompound.getString("Command"); + this.a = nbttagcompound.getInt("SuccessCount"); + if (nbttagcompound.hasKey("CustomName")) { + this.c = nbttagcompound.getString("CustomName"); + } } public ChunkCoordinates b() { @@ -130,4 +157,12 @@ public class TileEntityCommand extends TileEntity implements ICommandListener { this.b(nbttagcompound); return new Packet132TileEntityData(this.x, this.y, this.z, 2, nbttagcompound); } + + public int d() { + return this.a; + } + + public void a(int i) { + this.a = i; + } } diff --git a/src/main/java/net/minecraft/server/TileEntityDispenser.java b/src/main/java/net/minecraft/server/TileEntityDispenser.java index c0a6970471..347672087f 100644 --- a/src/main/java/net/minecraft/server/TileEntityDispenser.java +++ b/src/main/java/net/minecraft/server/TileEntityDispenser.java @@ -12,7 +12,8 @@ import org.bukkit.entity.HumanEntity; public class TileEntityDispenser extends TileEntity implements IInventory { private ItemStack[] items = new ItemStack[9]; - private Random b = new Random(); + private Random c = new Random(); + protected String a; // CraftBukkit start public List transaction = new java.util.ArrayList(); @@ -83,12 +84,12 @@ public class TileEntityDispenser extends TileEntity implements IInventory { } } - public int i() { + public int j() { int i = -1; int j = 1; for (int k = 0; k < this.items.length; ++k) { - if (this.items[k] != null && this.b.nextInt(j++) == 0) { + if (this.items[k] != null && this.c.nextInt(j++) == 0) { if (this.items[k].count == 0) continue; // CraftBukkit i = k; } @@ -109,7 +110,7 @@ public class TileEntityDispenser extends TileEntity implements IInventory { public int addItem(ItemStack itemstack) { for (int i = 0; i < this.items.length; ++i) { if (this.items[i] == null || this.items[i].id == 0) { - this.items[i] = itemstack; + this.setItem(i, itemstack); return i; } } @@ -118,7 +119,15 @@ public class TileEntityDispenser extends TileEntity implements IInventory { } public String getName() { - return "container.dispenser"; + return this.c() ? this.a : "container.dispenser"; + } + + public void a(String s) { + this.a = s; + } + + public boolean c() { + return this.a != null; } public void a(NBTTagCompound nbttagcompound) { @@ -135,6 +144,10 @@ public class TileEntityDispenser extends TileEntity implements IInventory { this.items[j] = ItemStack.createStack(nbttagcompound1); } } + + if (nbttagcompound.hasKey("CustomName")) { + this.a = nbttagcompound.getString("CustomName"); + } } public void b(NBTTagCompound nbttagcompound) { @@ -152,17 +165,24 @@ public class TileEntityDispenser extends TileEntity implements IInventory { } nbttagcompound.set("Items", nbttaglist); + if (this.c()) { + nbttagcompound.setString("CustomName", this.a); + } } public int getMaxStackSize() { return maxStack; // CraftBukkit } - public boolean a_(EntityHuman entityhuman) { + public boolean a(EntityHuman entityhuman) { return this.world.getTileEntity(this.x, this.y, this.z) != this ? false : entityhuman.e((double) this.x + 0.5D, (double) this.y + 0.5D, (double) this.z + 0.5D) <= 64.0D; } public void startOpen() {} - public void f() {} + public void g() {} + + public boolean b(int i, ItemStack itemstack) { + return true; + } } diff --git a/src/main/java/net/minecraft/server/TileEntityFurnace.java b/src/main/java/net/minecraft/server/TileEntityFurnace.java index d9745ba814..b8f1d3e9db 100644 --- a/src/main/java/net/minecraft/server/TileEntityFurnace.java +++ b/src/main/java/net/minecraft/server/TileEntityFurnace.java @@ -10,12 +10,13 @@ import org.bukkit.event.inventory.FurnaceSmeltEvent; import org.bukkit.craftbukkit.entity.CraftHumanEntity; // CraftBukkit end -public class TileEntityFurnace extends TileEntity implements IInventory { +public class TileEntityFurnace extends TileEntity implements IWorldInventory { private ItemStack[] items = new ItemStack[3]; public int burnTime = 0; public int ticksForCurrentFuel = 0; public int cookTime = 0; + private String e; // CraftBukkit start private int lastTick = (int) (System.currentTimeMillis() / 50); @@ -93,7 +94,15 @@ public class TileEntityFurnace extends TileEntity implements IInventory { } public String getName() { - return "container.furnace"; + return this.c() ? this.e : "container.furnace"; + } + + public boolean c() { + return this.e != null && this.e.length() > 0; + } + + public void a(String s) { + this.e = s; } public void a(NBTTagCompound nbttagcompound) { @@ -114,6 +123,9 @@ public class TileEntityFurnace extends TileEntity implements IInventory { this.burnTime = nbttagcompound.getShort("BurnTime"); this.cookTime = nbttagcompound.getShort("CookTime"); this.ticksForCurrentFuel = fuelTime(this.items[1]); + if (nbttagcompound.hasKey("CustomName")) { + this.e = nbttagcompound.getString("CustomName"); + } } public void b(NBTTagCompound nbttagcompound) { @@ -133,6 +145,9 @@ public class TileEntityFurnace extends TileEntity implements IInventory { } nbttagcompound.set("Items", nbttaglist); + if (this.c()) { + nbttagcompound.setString("CustomName", this.e); + } } public int getMaxStackSize() { @@ -143,7 +158,7 @@ public class TileEntityFurnace extends TileEntity implements IInventory { return this.burnTime > 0; } - public void g() { + public void h() { boolean flag = this.burnTime > 0; boolean flag1 = false; @@ -189,7 +204,7 @@ public class TileEntityFurnace extends TileEntity implements IInventory { if (this.items[1] != null) { --this.items[1].count; if (this.items[1].count == 0) { - Item item = this.items[1].getItem().r(); + Item item = this.items[1].getItem().s(); this.items[1] = item != null ? new ItemStack(item) : null; } @@ -292,11 +307,23 @@ public class TileEntityFurnace extends TileEntity implements IInventory { return fuelTime(itemstack) > 0; } - public boolean a_(EntityHuman entityhuman) { + public boolean a(EntityHuman entityhuman) { return this.world.getTileEntity(this.x, this.y, this.z) != this ? false : entityhuman.e((double) this.x + 0.5D, (double) this.y + 0.5D, (double) this.z + 0.5D) <= 64.0D; } public void startOpen() {} - public void f() {} + public void g() {} + + public boolean b(int i, ItemStack itemstack) { + return i == 2 ? false : (i == 1 ? isFuel(itemstack) : true); + } + + public int c(int i) { + return i == 0 ? 2 : (i == 1 ? 0 : 1); + } + + public int d(int i) { + return 1; + } } diff --git a/src/main/java/net/minecraft/server/TileEntityHopper.java b/src/main/java/net/minecraft/server/TileEntityHopper.java new file mode 100644 index 0000000000..c9ece0aa06 --- /dev/null +++ b/src/main/java/net/minecraft/server/TileEntityHopper.java @@ -0,0 +1,417 @@ +package net.minecraft.server; + +import java.util.List; + +// CraftBukkit start +import org.bukkit.craftbukkit.entity.CraftHumanEntity; +import org.bukkit.entity.HumanEntity; +// CraftBukkit end + +public class TileEntityHopper extends TileEntity implements IHopper { + + private ItemStack[] a = new ItemStack[5]; + private String b; + private int c = -1; + + // CraftBukkit start + public List transaction = new java.util.ArrayList(); + private int maxStack = MAX_STACK; + + public ItemStack[] getContents() { + return this.a; + } + + public void onOpen(CraftHumanEntity who) { + transaction.add(who); + } + + public void onClose(CraftHumanEntity who) { + transaction.remove(who); + } + + public List getViewers() { + return transaction; + } + + public void setMaxStackSize(int size) { + maxStack = size; + } + // CraftBukkit end + + + public TileEntityHopper() {} + + public void a(NBTTagCompound nbttagcompound) { + super.a(nbttagcompound); + NBTTagList nbttaglist = nbttagcompound.getList("Items"); + + this.a = new ItemStack[this.getSize()]; + if (nbttagcompound.hasKey("CustomName")) { + this.b = nbttagcompound.getString("CustomName"); + } + + this.c = nbttagcompound.getInt("TransferCooldown"); + + for (int i = 0; i < nbttaglist.size(); ++i) { + NBTTagCompound nbttagcompound1 = (NBTTagCompound) nbttaglist.get(i); + byte b0 = nbttagcompound1.getByte("Slot"); + + if (b0 >= 0 && b0 < this.a.length) { + this.a[b0] = ItemStack.createStack(nbttagcompound1); + } + } + } + + public void b(NBTTagCompound nbttagcompound) { + super.b(nbttagcompound); + NBTTagList nbttaglist = new NBTTagList(); + + for (int i = 0; i < this.a.length; ++i) { + if (this.a[i] != null) { + NBTTagCompound nbttagcompound1 = new NBTTagCompound(); + + nbttagcompound1.setByte("Slot", (byte) i); + this.a[i].save(nbttagcompound1); + nbttaglist.add(nbttagcompound1); + } + } + + nbttagcompound.set("Items", nbttaglist); + nbttagcompound.setInt("TransferCooldown", this.c); + if (this.c()) { + nbttagcompound.setString("CustomName", this.b); + } + } + + public void update() { + super.update(); + } + + public int getSize() { + return this.a.length; + } + + public ItemStack getItem(int i) { + return this.a[i]; + } + + public ItemStack splitStack(int i, int j) { + if (this.a[i] != null) { + ItemStack itemstack; + + if (this.a[i].count <= j) { + itemstack = this.a[i]; + this.a[i] = null; + return itemstack; + } else { + itemstack = this.a[i].a(j); + if (this.a[i].count == 0) { + this.a[i] = null; + } + + return itemstack; + } + } else { + return null; + } + } + + public ItemStack splitWithoutUpdate(int i) { + if (this.a[i] != null) { + ItemStack itemstack = this.a[i]; + + this.a[i] = null; + return itemstack; + } else { + return null; + } + } + + public void setItem(int i, ItemStack itemstack) { + this.a[i] = itemstack; + if (itemstack != null && itemstack.count > this.getMaxStackSize()) { + itemstack.count = this.getMaxStackSize(); + } + } + + public String getName() { + return this.c() ? this.b : "container.hopper"; + } + + public boolean c() { + return this.b != null && this.b.length() > 0; + } + + public void a(String s) { + this.b = s; + } + + public int getMaxStackSize() { + return 64; + } + + public boolean a(EntityHuman entityhuman) { + return this.world.getTileEntity(this.x, this.y, this.z) != this ? false : entityhuman.e((double) this.x + 0.5D, (double) this.y + 0.5D, (double) this.z + 0.5D) <= 64.0D; + } + + public void startOpen() {} + + public void g() {} + + public boolean b(int i, ItemStack itemstack) { + return true; + } + + public void h() { + if (this.world != null && !this.world.isStatic) { + --this.c; + if (!this.l()) { + this.c(0); + this.j(); + } + } + } + + public boolean j() { + if (this.world != null && !this.world.isStatic) { + if (!this.l() && BlockHopper.d(this.p())) { + boolean flag = this.u() | a((IHopper) this); + + if (flag) { + this.c(8); + this.update(); + return true; + } + } + + return false; + } else { + return false; + } + } + + private boolean u() { + int i = a(this, -1); + boolean flag = false; + + if (i > -1) { + IInventory iinventory = this.v(); + + if (iinventory != null) { + ItemStack itemstack = this.getItem(i).cloneItemStack(); + ItemStack itemstack1 = a(iinventory, this.splitStack(i, 1), Facing.OPPOSITE_FACING[BlockHopper.c(this.p())]); + + if (itemstack1 != null && itemstack1.count != 0) { + this.setItem(i, itemstack); + } else { + flag |= true; + iinventory.update(); + } + } + } + + return flag; + } + + public static boolean a(IHopper ihopper) { + boolean flag = false; + IInventory iinventory = b(ihopper); + + if (iinventory != null) { + byte b0 = 0; + int i = 0; + int j = iinventory.getSize(); + + if (iinventory instanceof IWorldInventory && b0 > -1) { + IWorldInventory iworldinventory = (IWorldInventory) iinventory; + + i = iworldinventory.c(b0); + j = Math.min(j, i + iworldinventory.d(b0)); + } + + for (int k = i; k < j && !flag; ++k) { + ItemStack itemstack = iinventory.getItem(k); + + if (itemstack != null) { + ItemStack itemstack1 = itemstack.cloneItemStack(); + ItemStack itemstack2 = a(ihopper, iinventory.splitStack(k, 1), -1); + + if (itemstack2 != null && itemstack2.count != 0) { + iinventory.setItem(k, itemstack1); + } else { + flag |= true; + iinventory.update(); + } + } + } + } else { + EntityItem entityitem = a(ihopper.getWorld(), ihopper.aA(), ihopper.aB() + 1.0D, ihopper.aC()); + + if (entityitem != null) { + flag |= a((IInventory) ihopper, entityitem); + } + } + + return flag; + } + + public static boolean a(IInventory iinventory, EntityItem entityitem) { + boolean flag = false; + + if (entityitem == null) { + return false; + } else { + ItemStack itemstack = entityitem.getItemStack().cloneItemStack(); + ItemStack itemstack1 = a(iinventory, itemstack, -1); + + if (itemstack1 != null && itemstack1.count != 0) { + entityitem.setItemStack(itemstack1); + } else { + flag = true; + entityitem.die(); + } + + return flag; + } + } + + public static int a(IInventory iinventory, int i) { + int j = 0; + int k = iinventory.getSize(); + + if (iinventory instanceof IWorldInventory && i > -1) { + IWorldInventory iworldinventory = (IWorldInventory) iinventory; + + j = iworldinventory.c(i); + k = Math.min(k, j + iworldinventory.d(i)); + } + + for (int l = j; l < k; ++l) { + if (iinventory.getItem(l) != null) { + return l; + } + } + + return -1; + } + + public static ItemStack a(IInventory iinventory, ItemStack itemstack, int i) { + int j = 0; + int k = iinventory.getSize(); + + if (iinventory instanceof IWorldInventory && i > -1) { + IWorldInventory iworldinventory = (IWorldInventory) iinventory; + + j = iworldinventory.c(i); + k = Math.min(k, j + iworldinventory.d(i)); + } + + for (int l = j; l < k && itemstack != null && itemstack.count > 0; ++l) { + ItemStack itemstack1 = iinventory.getItem(l); + + if (iinventory.b(l, itemstack)) { + boolean flag = false; + + if (itemstack1 == null) { + iinventory.setItem(l, itemstack); + itemstack = null; + flag = true; + } else if (a(itemstack1, itemstack)) { + int i1 = itemstack.getMaxStackSize() - itemstack1.count; + int j1 = Math.min(itemstack.count, i1); + + itemstack.count -= j1; + itemstack1.count += j1; + flag = j1 > 0; + } + + if (flag) { + if (iinventory instanceof TileEntityHopper) { + ((TileEntityHopper) iinventory).c(8); + } + + iinventory.update(); + } + } + } + + if (itemstack != null && itemstack.count == 0) { + itemstack = null; + } + + return itemstack; + } + + private IInventory v() { + int i = BlockHopper.c(this.p()); + + return b(this.getWorld(), (double) (this.x + Facing.b[i]), (double) (this.y + Facing.c[i]), (double) (this.z + Facing.d[i])); + } + + public static IInventory b(IHopper ihopper) { + return b(ihopper.getWorld(), ihopper.aA(), ihopper.aB() + 1.0D, ihopper.aC()); + } + + public static EntityItem a(World world, double d0, double d1, double d2) { + List list = world.a(EntityItem.class, AxisAlignedBB.a().a(d0, d1, d2, d0 + 1.0D, d1 + 1.0D, d2 + 1.0D), IEntitySelector.a); + + return list.size() > 0 ? (EntityItem) list.get(0) : null; + } + + public static IInventory b(World world, double d0, double d1, double d2) { + IInventory iinventory = null; + int i = MathHelper.floor(d0); + int j = MathHelper.floor(d1); + int k = MathHelper.floor(d2); + + if (iinventory == null) { + TileEntity tileentity = world.getTileEntity(i, j, k); + + if (tileentity != null && tileentity instanceof IInventory) { + iinventory = (IInventory) tileentity; + if (iinventory instanceof TileEntityChest) { + int l = world.getTypeId(i, j, k); + Block block = Block.byId[l]; + + if (block instanceof BlockChest) { + iinventory = ((BlockChest) block).g_(world, i, j, k); + } + } + } + } + + if (iinventory == null) { + List list = world.getEntities((Entity) null, AxisAlignedBB.a().a(d0, d1, d2, d0 + 1.0D, d1 + 1.0D, d2 + 1.0D), IEntitySelector.b); + + if (list != null && list.size() > 0) { + iinventory = (IInventory) list.get(world.random.nextInt(list.size())); + } + } + + return iinventory; + } + + private static boolean a(ItemStack itemstack, ItemStack itemstack1) { + return itemstack.id != itemstack1.id ? false : (itemstack.getData() != itemstack1.getData() ? false : (itemstack.count > itemstack.getMaxStackSize() ? false : ItemStack.equals(itemstack, itemstack1))); + } + + public double aA() { + return (double) this.x; + } + + public double aB() { + return (double) this.y; + } + + public double aC() { + return (double) this.z; + } + + public void c(int i) { + this.c = i; + } + + public boolean l() { + return this.c > 0; + } +} diff --git a/src/main/java/net/minecraft/server/TileEntityMobSpawner.java b/src/main/java/net/minecraft/server/TileEntityMobSpawner.java deleted file mode 100644 index e415b6a7ca..0000000000 --- a/src/main/java/net/minecraft/server/TileEntityMobSpawner.java +++ /dev/null @@ -1,233 +0,0 @@ -package net.minecraft.server; - -import java.util.ArrayList; -import java.util.Collection; -import java.util.Iterator; -import java.util.List; - -public class TileEntityMobSpawner extends TileEntity { - - public int spawnDelay = -1; - public String mobName = "Pig"; // CraftBukkit - private -> public - private List mobs = null; - private TileEntityMobSpawnerData spawnData = null; - public double b; - public double c = 0.0D; - private int minSpawnDelay = 200; - private int maxSpawnDelay = 800; - private int spawnCount = 4; - private Entity j; - private int maxNearbyEntities = 6; - private int requiredPlayerRange = 16; - private int spawnRange = 4; - - public TileEntityMobSpawner() { - this.spawnDelay = 20; - } - - public String getMobName() { - return this.spawnData == null ? this.mobName : this.spawnData.c; - } - - public void a(String s) { - this.mobName = s; - } - - public boolean b() { - return this.world.findNearbyPlayer((double) this.x + 0.5D, (double) this.y + 0.5D, (double) this.z + 0.5D, (double) this.requiredPlayerRange) != null; - } - - public void g() { - if (this.b()) { - double d0; - - if (this.world.isStatic) { - double d1 = (double) ((float) this.x + this.world.random.nextFloat()); - double d2 = (double) ((float) this.y + this.world.random.nextFloat()); - - d0 = (double) ((float) this.z + this.world.random.nextFloat()); - this.world.addParticle("smoke", d1, d2, d0, 0.0D, 0.0D, 0.0D); - this.world.addParticle("flame", d1, d2, d0, 0.0D, 0.0D, 0.0D); - if (this.spawnDelay > 0) { - --this.spawnDelay; - } - - this.c = this.b; - this.b = (this.b + (double) (1000.0F / ((float) this.spawnDelay + 200.0F))) % 360.0D; - } else { - if (this.spawnDelay == -1) { - this.e(); - } - - if (this.spawnDelay > 0) { - --this.spawnDelay; - return; - } - - boolean flag = false; - - for (int i = 0; i < this.spawnCount; ++i) { - Entity entity = EntityTypes.createEntityByName(this.getMobName(), this.world); - - if (entity == null) { - return; - } - - int j = this.world.a(entity.getClass(), AxisAlignedBB.a().a((double) this.x, (double) this.y, (double) this.z, (double) (this.x + 1), (double) (this.y + 1), (double) (this.z + 1)).grow((double) (this.spawnRange * 2), 4.0D, (double) (this.spawnRange * 2))).size(); - - if (j >= this.maxNearbyEntities) { - this.e(); - return; - } - - if (entity != null) { - d0 = (double) this.x + (this.world.random.nextDouble() - this.world.random.nextDouble()) * (double) this.spawnRange; - double d3 = (double) (this.y + this.world.random.nextInt(3) - 1); - double d4 = (double) this.z + (this.world.random.nextDouble() - this.world.random.nextDouble()) * (double) this.spawnRange; - EntityLiving entityliving = entity instanceof EntityLiving ? (EntityLiving) entity : null; - - entity.setPositionRotation(d0, d3, d4, this.world.random.nextFloat() * 360.0F, 0.0F); - if (entityliving == null || entityliving.canSpawn()) { - this.a(entity); - this.world.addEntity(entity, org.bukkit.event.entity.CreatureSpawnEvent.SpawnReason.SPAWNER); // CraftBukkit - this.world.triggerEffect(2004, this.x, this.y, this.z, 0); - if (entityliving != null) { - entityliving.aR(); - } - - flag = true; - } - } - } - - if (flag) { - this.e(); - } - } - - super.g(); - } - } - - public void a(Entity entity) { - if (this.spawnData != null) { - NBTTagCompound nbttagcompound = new NBTTagCompound(); - - entity.c(nbttagcompound); - Iterator iterator = this.spawnData.b.c().iterator(); - - while (iterator.hasNext()) { - NBTBase nbtbase = (NBTBase) iterator.next(); - - nbttagcompound.set(nbtbase.getName(), nbtbase.clone()); - } - - entity.e(nbttagcompound); - } else if (entity instanceof EntityLiving && entity.world != null) { - ((EntityLiving) entity).bG(); - } - } - - private void e() { - if (this.maxSpawnDelay <= this.minSpawnDelay) { - this.spawnDelay = this.minSpawnDelay; - } else { - this.spawnDelay = this.minSpawnDelay + this.world.random.nextInt(this.maxSpawnDelay - this.minSpawnDelay); - } - - if (this.mobs != null && this.mobs.size() > 0) { - this.spawnData = (TileEntityMobSpawnerData) WeightedRandom.a(this.world.random, (Collection) this.mobs); - this.world.notify(this.x, this.y, this.z); - } - - this.world.playNote(this.x, this.y, this.z, this.q().id, 1, 0); - } - - public void a(NBTTagCompound nbttagcompound) { - super.a(nbttagcompound); - this.mobName = nbttagcompound.getString("EntityId"); - this.spawnDelay = nbttagcompound.getShort("Delay"); - if (nbttagcompound.hasKey("SpawnPotentials")) { - this.mobs = new ArrayList(); - NBTTagList nbttaglist = nbttagcompound.getList("SpawnPotentials"); - - for (int i = 0; i < nbttaglist.size(); ++i) { - this.mobs.add(new TileEntityMobSpawnerData(this, (NBTTagCompound) nbttaglist.get(i))); - } - } else { - this.mobs = null; - } - - if (nbttagcompound.hasKey("SpawnData")) { - this.spawnData = new TileEntityMobSpawnerData(this, nbttagcompound.getCompound("SpawnData"), this.mobName); - } else { - this.spawnData = null; - } - - if (nbttagcompound.hasKey("MinSpawnDelay")) { - this.minSpawnDelay = nbttagcompound.getShort("MinSpawnDelay"); - this.maxSpawnDelay = nbttagcompound.getShort("MaxSpawnDelay"); - this.spawnCount = nbttagcompound.getShort("SpawnCount"); - } - - if (nbttagcompound.hasKey("MaxNearbyEntities")) { - this.maxNearbyEntities = nbttagcompound.getShort("MaxNearbyEntities"); - this.requiredPlayerRange = nbttagcompound.getShort("RequiredPlayerRange"); - } - - if (nbttagcompound.hasKey("SpawnRange")) { - this.spawnRange = nbttagcompound.getShort("SpawnRange"); - } - - if (this.world != null && this.world.isStatic) { - this.j = null; - } - } - - public void b(NBTTagCompound nbttagcompound) { - super.b(nbttagcompound); - nbttagcompound.setString("EntityId", this.getMobName()); - nbttagcompound.setShort("Delay", (short) this.spawnDelay); - nbttagcompound.setShort("MinSpawnDelay", (short) this.minSpawnDelay); - nbttagcompound.setShort("MaxSpawnDelay", (short) this.maxSpawnDelay); - nbttagcompound.setShort("SpawnCount", (short) this.spawnCount); - nbttagcompound.setShort("MaxNearbyEntities", (short) this.maxNearbyEntities); - nbttagcompound.setShort("RequiredPlayerRange", (short) this.requiredPlayerRange); - nbttagcompound.setShort("SpawnRange", (short) this.spawnRange); - if (this.spawnData != null) { - nbttagcompound.setCompound("SpawnData", (NBTTagCompound) this.spawnData.b.clone()); - } - - if (this.spawnData != null || this.mobs != null && this.mobs.size() > 0) { - NBTTagList nbttaglist = new NBTTagList(); - - if (this.mobs != null && this.mobs.size() > 0) { - Iterator iterator = this.mobs.iterator(); - - while (iterator.hasNext()) { - TileEntityMobSpawnerData tileentitymobspawnerdata = (TileEntityMobSpawnerData) iterator.next(); - - nbttaglist.add(tileentitymobspawnerdata.a()); - } - } else { - nbttaglist.add(this.spawnData.a()); - } - - nbttagcompound.set("SpawnPotentials", nbttaglist); - } - } - - public Packet getUpdatePacket() { - NBTTagCompound nbttagcompound = new NBTTagCompound(); - - this.b(nbttagcompound); - nbttagcompound.remove("SpawnPotentials"); - return new Packet132TileEntityData(this.x, this.y, this.z, 1, nbttagcompound); - } - - public void b(int i, int j) { - if (i == 1 && this.world.isStatic) { - this.spawnDelay = this.minSpawnDelay; - } - } -} diff --git a/src/main/java/net/minecraft/server/TileEntityPiston.java b/src/main/java/net/minecraft/server/TileEntityPiston.java index becd33ec5d..74d9c5d3f6 100644 --- a/src/main/java/net/minecraft/server/TileEntityPiston.java +++ b/src/main/java/net/minecraft/server/TileEntityPiston.java @@ -79,24 +79,26 @@ public class TileEntityPiston extends TileEntity { public void f() { if (this.g < 1.0F && this.world != null) { this.g = this.f = 1.0F; - this.world.r(this.x, this.y, this.z); + this.world.s(this.x, this.y, this.z); this.w_(); if (this.world.getTypeId(this.x, this.y, this.z) == Block.PISTON_MOVING.id) { - this.world.setTypeIdAndData(this.x, this.y, this.z, this.a, this.b); + this.world.setTypeIdAndData(this.x, this.y, this.z, this.a, this.b, 3); + this.world.g(this.x, this.y, this.z, this.a); } } } - public void g() { + public void h() { if (this.world == null) return; // CraftBukkit this.g = this.f; if (this.g >= 1.0F) { this.a(1.0F, 0.25F); - this.world.r(this.x, this.y, this.z); + this.world.s(this.x, this.y, this.z); this.w_(); if (this.world.getTypeId(this.x, this.y, this.z) == Block.PISTON_MOVING.id) { - this.world.setTypeIdAndData(this.x, this.y, this.z, this.a, this.b); + this.world.setTypeIdAndData(this.x, this.y, this.z, this.a, this.b, 3); + this.world.g(this.x, this.y, this.z, this.a); } } else { this.f += 0.5F; diff --git a/src/main/java/net/minecraft/server/Village.java b/src/main/java/net/minecraft/server/Village.java index c8822ce9f2..5e9336bcac 100644 --- a/src/main/java/net/minecraft/server/Village.java +++ b/src/main/java/net/minecraft/server/Village.java @@ -72,7 +72,7 @@ public class Village { } private boolean b(int i, int j, int k, int l, int i1, int j1) { - if (!this.world.v(i, j - 1, k)) { + if (!this.world.w(i, j - 1, k)) { return false; } else { int k1 = i - l / 2; @@ -81,7 +81,7 @@ public class Village { for (int i2 = k1; i2 < k1 + l; ++i2) { for (int j2 = j; j2 < j + i1; ++j2) { for (int k2 = l1; k2 < l1 + j1; ++k2) { - if (this.world.t(i2, j2, k2)) { + if (this.world.u(i2, j2, k2)) { return false; } } diff --git a/src/main/java/net/minecraft/server/VillageSiege.java b/src/main/java/net/minecraft/server/VillageSiege.java index b3e9687ea9..2deb8161f8 100644 --- a/src/main/java/net/minecraft/server/VillageSiege.java +++ b/src/main/java/net/minecraft/server/VillageSiege.java @@ -139,7 +139,7 @@ public class VillageSiege { try { entityzombie = new EntityZombie(this.world); - entityzombie.bG(); + entityzombie.bJ(); entityzombie.setVillager(false); } catch (Exception exception) { exception.printStackTrace(); diff --git a/src/main/java/net/minecraft/server/World.java b/src/main/java/net/minecraft/server/World.java index c3dc4a4ea6..9c398156df 100644 --- a/src/main/java/net/minecraft/server/World.java +++ b/src/main/java/net/minecraft/server/World.java @@ -44,12 +44,12 @@ public abstract class World implements IBlockAccess { protected float o; protected float p; public int q = 0; - public boolean suppressPhysics = false; + // public boolean suppressPhysics = false; // CraftBukkit (removed in vanilla) public boolean callingPlaceEvent = false; // CraftBukkit public int difficulty; public Random random = new Random(); public WorldProvider worldProvider; // CraftBukkit - remove final - protected List v = new ArrayList(); + protected List u = new ArrayList(); public IChunkProvider chunkProvider; // CraftBukkit - protected -> public protected final IDataManager dataManager; public WorldData worldData; // CraftBukkit - protected -> public @@ -60,8 +60,10 @@ public abstract class World implements IBlockAccess { public final MethodProfiler methodProfiler; private final Vec3DPool J = new Vec3DPool(300, 2000); private final Calendar K = Calendar.getInstance(); - private UnsafeList L = new UnsafeList(); // CraftBukkit - ArrayList -> UnsafeList - private boolean M; + protected Scoreboard scoreboard = new Scoreboard(); + private final IConsoleLogManager logAgent; + private UnsafeList M = new UnsafeList(); // CraftBukkit - ArrayList -> UnsafeList + private boolean N; // CraftBukkit start - public, longhashset public boolean allowMonsters = true; public boolean allowAnimals = true; @@ -69,9 +71,8 @@ public abstract class World implements IBlockAccess { public long ticksPerAnimalSpawns; public long ticksPerMonsterSpawns; // CraftBukkit end - private int N; + private int O; int[] H; - private List O; public boolean isStatic; public BiomeBase getBiome(int i, int j) { @@ -109,20 +110,20 @@ public abstract class World implements IBlockAccess { } // Changed signature - public World(IDataManager idatamanager, String s, WorldSettings worldsettings, WorldProvider worldprovider, MethodProfiler methodprofiler, ChunkGenerator gen, org.bukkit.World.Environment env) { + public World(IDataManager idatamanager, String s, WorldSettings worldsettings, WorldProvider worldprovider, MethodProfiler methodprofiler, IConsoleLogManager iconsolelogmanager, ChunkGenerator gen, org.bukkit.World.Environment env) { this.generator = gen; this.world = new CraftWorld((WorldServer) this, gen, env); this.ticksPerAnimalSpawns = this.getServer().getTicksPerAnimalSpawns(); // CraftBukkit this.ticksPerMonsterSpawns = this.getServer().getTicksPerMonsterSpawns(); // CraftBukkit // CraftBukkit end - this.N = this.random.nextInt(12000); + this.O = this.random.nextInt(12000); this.H = new int['\u8000']; - this.O = new UnsafeList(); // CraftBukkit - ArrayList -> UnsafeList this.isStatic = false; this.dataManager = idatamanager; this.methodProfiler = methodprofiler; this.worldMaps = new WorldMapCollection(idatamanager); + this.logAgent = iconsolelogmanager; this.worldData = idatamanager.getWorldData(); if (worldprovider != null) { this.worldProvider = worldprovider; @@ -168,7 +169,7 @@ public abstract class World implements IBlockAccess { this.villages.a(this); } - this.x(); + this.y(); this.a(); this.getServer().addWorld(this.world); // CraftBukkit @@ -216,10 +217,6 @@ public abstract class World implements IBlockAccess { } } - public int b(int i, int j, int k) { - return i >= -30000000 && k >= -30000000 && i < 30000000 && k < 30000000 ? (j < 0 ? 0 : (j >= 256 ? 0 : this.getChunkAt(i >> 4, k >> 4).b(i & 15, j, k & 15))) : 0; - } - public boolean isEmpty(int i, int j, int k) { return this.getTypeId(i, j, k) == 0; } @@ -227,7 +224,7 @@ public abstract class World implements IBlockAccess { public boolean isTileEntity(int i, int j, int k) { int l = this.getTypeId(i, j, k); - return Block.byId[l] != null && Block.byId[l].u(); + return Block.byId[l] != null && Block.byId[l].t(); } public int e(int i, int j, int k) { @@ -241,10 +238,10 @@ public abstract class World implements IBlockAccess { } public boolean areChunksLoaded(int i, int j, int k, int l) { - return this.d(i - l, j - l, k - l, i + l, j + l, k + l); + return this.e(i - l, j - l, k - l, i + l, j + l, k + l); } - public boolean d(int i, int j, int k, int l, int i1, int j1) { + public boolean e(int i, int j, int k, int l, int i1, int j1) { if (i1 >= 0 && j < 256) { i >>= 4; k >>= 4; @@ -289,11 +286,7 @@ public abstract class World implements IBlockAccess { } // CraftBukkit end - public boolean setRawTypeIdAndData(int i, int j, int k, int l, int i1) { - return this.setRawTypeIdAndData(i, j, k, l, i1, true); - } - - public boolean setRawTypeIdAndData(int i, int j, int k, int l, int i1, boolean flag) { + public boolean setTypeIdAndData(int i, int j, int k, int l, int i1, int j1) { if (i >= -30000000 && k >= -30000000 && i < 30000000 && k < 30000000) { if (j < 0) { return false; @@ -301,37 +294,30 @@ public abstract class World implements IBlockAccess { return false; } else { Chunk chunk = this.getChunkAt(i >> 4, k >> 4); - boolean flag1 = chunk.a(i & 15, j, k & 15, l, i1); + int k1 = 0; - this.methodProfiler.a("checkLight"); - this.z(i, j, k); - this.methodProfiler.b(); - if (flag && flag1 && (this.isStatic || chunk.seenByPlayer)) { - this.notify(i, j, k); + if ((j1 & 1) != 0) { + k1 = chunk.getTypeId(i & 15, j, k & 15); } - return flag1; - } - } else { - return false; - } - } - - public boolean setRawTypeId(int i, int j, int k, int l) { - if (i >= -30000000 && k >= -30000000 && i < 30000000 && k < 30000000) { - if (j < 0) { - return false; - } else if (j >= 256) { - return false; - } else { - Chunk chunk = this.getChunkAt(i >> 4, k >> 4); - boolean flag = chunk.a(i & 15, j, k & 15, l); + boolean flag = chunk.a(i & 15, j, k & 15, l, i1); this.methodProfiler.a("checkLight"); - this.z(i, j, k); + this.A(i, j, k); this.methodProfiler.b(); - if (flag && (this.isStatic || chunk.seenByPlayer)) { - this.notify(i, j, k); + if (flag) { + if ((j1 & 2) != 0 && (!this.isStatic || (j1 & 4) == 0)) { + this.notify(i, j, k); + } + + if (!this.isStatic && (j1 & 1) != 0) { + this.update(i, j, k, k1); + Block block = Block.byId[l]; + + if (block != null && block.q_()) { + this.m(i, j, k, l); + } + } } return flag; @@ -365,13 +351,7 @@ public abstract class World implements IBlockAccess { } } - public void setData(int i, int j, int k, int l) { - if (this.setRawData(i, j, k, l)) { - this.update(i, j, k, this.getTypeId(i, j, k)); - } - } - - public boolean setRawData(int i, int j, int k, int l) { + public boolean setData(int i, int j, int k, int l, int i1) { if (i >= -30000000 && k >= -30000000 && i < 30000000 && k < 30000000) { if (j < 0) { return false; @@ -379,12 +359,25 @@ public abstract class World implements IBlockAccess { return false; } else { Chunk chunk = this.getChunkAt(i >> 4, k >> 4); - int i1 = i & 15; - int j1 = k & 15; - boolean flag = chunk.b(i1, j, j1, l); + int j1 = i & 15; + int k1 = k & 15; + boolean flag = chunk.b(j1, j, k1, l); - if (flag && (this.isStatic || chunk.seenByPlayer && Block.u[chunk.getTypeId(i1, j, j1) & 4095])) { - this.notify(i, j, k); + if (flag) { + int l1 = chunk.getTypeId(j1, j, k1); + + if ((i1 & 2) != 0 && (!this.isStatic || (i1 & 4) == 0)) { + this.notify(i, j, k); + } + + if (!this.isStatic && (i1 & 1) != 0) { + this.update(i, j, k, l1); + Block block = Block.byId[l1]; + + if (block != null && block.q_()) { + this.m(i, j, k, l1); + } + } } return flag; @@ -394,27 +387,34 @@ public abstract class World implements IBlockAccess { } } - public boolean setTypeId(int i, int j, int k, int l) { - if (this.setRawTypeId(i, j, k, l)) { - this.update(i, j, k, l); - return true; + public boolean setAir(int i, int j, int k) { + return this.setTypeIdAndData(i, j, k, 0, 0, 3); + } + + public boolean setAir(int i, int j, int k, boolean flag) { + int l = this.getTypeId(i, j, k); + + if (l > 0) { + int i1 = this.getData(i, j, k); + + this.triggerEffect(2001, i, j, k, l + (i1 << 12)); + if (flag) { + Block.byId[l].c(this, i, j, k, i1, 0); + } + + return this.setTypeIdAndData(i, j, k, 0, 0, 3); } else { return false; } } - public boolean setTypeIdAndData(int i, int j, int k, int l, int i1) { - if (this.setRawTypeIdAndData(i, j, k, l, i1)) { - this.update(i, j, k, l); - return true; - } else { - return false; - } + public boolean setTypeIdUpdate(int i, int j, int k, int l) { + return this.setTypeIdAndData(i, j, k, l, 0, 3); } public void notify(int i, int j, int k) { - for (int l = 0; l < this.v.size(); ++l) { - ((IWorldAccess) this.v.get(l)).a(i, j, k); + for (int l = 0; l < this.u.size(); ++l) { + ((IWorldAccess) this.u.get(l)).a(i, j, k); } } @@ -422,7 +422,7 @@ public abstract class World implements IBlockAccess { this.applyPhysics(i, j, k, l); } - public void g(int i, int j, int k, int l) { + public void e(int i, int j, int k, int l) { int i1; if (k > l) { @@ -437,32 +437,52 @@ public abstract class World implements IBlockAccess { } } - this.e(i, k, j, i, l, j); + this.g(i, k, j, i, l, j); } - public void j(int i, int j, int k) { - for (int l = 0; l < this.v.size(); ++l) { - ((IWorldAccess) this.v.get(l)).a(i, j, k, i, j, k); - } - } - - public void e(int i, int j, int k, int l, int i1, int j1) { - for (int k1 = 0; k1 < this.v.size(); ++k1) { - ((IWorldAccess) this.v.get(k1)).a(i, j, k, l, i1, j1); + public void g(int i, int j, int k, int l, int i1, int j1) { + for (int k1 = 0; k1 < this.u.size(); ++k1) { + ((IWorldAccess) this.u.get(k1)).a(i, j, k, l, i1, j1); } } public void applyPhysics(int i, int j, int k, int l) { - this.m(i - 1, j, k, l); - this.m(i + 1, j, k, l); - this.m(i, j - 1, k, l); - this.m(i, j + 1, k, l); - this.m(i, j, k - 1, l); - this.m(i, j, k + 1, l); + this.g(i - 1, j, k, l); + this.g(i + 1, j, k, l); + this.g(i, j - 1, k, l); + this.g(i, j + 1, k, l); + this.g(i, j, k - 1, l); + this.g(i, j, k + 1, l); } - private void m(int i, int j, int k, int l) { - if (!this.suppressPhysics && !this.isStatic) { + public void c(int i, int j, int k, int l, int i1) { + if (i1 != 4) { + this.g(i - 1, j, k, l); + } + + if (i1 != 5) { + this.g(i + 1, j, k, l); + } + + if (i1 != 0) { + this.g(i, j - 1, k, l); + } + + if (i1 != 1) { + this.g(i, j + 1, k, l); + } + + if (i1 != 2) { + this.g(i, j, k - 1, l); + } + + if (i1 != 3) { + this.g(i, j, k + 1, l); + } + } + + public void g(int i, int j, int k, int l) { + if (!this.isStatic) { int i1 = this.getTypeId(i, j, k); Block block = Block.byId[i1]; @@ -501,11 +521,15 @@ public abstract class World implements IBlockAccess { } } - public boolean k(int i, int j, int k) { + public boolean a(int i, int j, int k, int l) { + return false; + } + + public boolean l(int i, int j, int k) { return this.getChunkAt(i >> 4, k >> 4).d(i & 15, j, k & 15); } - public int l(int i, int j, int k) { + public int m(int i, int j, int k) { if (j < 0) { return 0; } else { @@ -518,20 +542,20 @@ public abstract class World implements IBlockAccess { } public int getLightLevel(int i, int j, int k) { - return this.a(i, j, k, true); + return this.b(i, j, k, true); } - public int a(int i, int j, int k, boolean flag) { + public int b(int i, int j, int k, boolean flag) { if (i >= -30000000 && k >= -30000000 && i < 30000000 && k < 30000000) { if (flag) { int l = this.getTypeId(i, j, k); - if (l == Block.STEP.id || l == Block.WOOD_STEP.id || l == Block.SOIL.id || l == Block.COBBLESTONE_STAIRS.id || l == Block.WOOD_STAIRS.id) { - int i1 = this.a(i, j + 1, k, false); - int j1 = this.a(i + 1, j, k, false); - int k1 = this.a(i - 1, j, k, false); - int l1 = this.a(i, j, k + 1, false); - int i2 = this.a(i, j, k - 1, false); + if (Block.w[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); + int l1 = this.b(i, j, k + 1, false); + int i2 = this.b(i, j, k - 1, false); if (j1 > i1) { i1 = j1; @@ -633,8 +657,8 @@ public abstract class World implements IBlockAccess { chunk.a(enumskyblock, i & 15, j, k & 15, l); - for (int i1 = 0; i1 < this.v.size(); ++i1) { - ((IWorldAccess) this.v.get(i1)).b(i, j, k); + for (int i1 = 0; i1 < this.u.size(); ++i1) { + ((IWorldAccess) this.u.get(i1)).b(i, j, k); } } } @@ -642,13 +666,13 @@ public abstract class World implements IBlockAccess { } } - public void o(int i, int j, int k) { - for (int l = 0; l < this.v.size(); ++l) { - ((IWorldAccess) this.v.get(l)).b(i, j, k); + public void p(int i, int j, int k) { + for (int l = 0; l < this.u.size(); ++l) { + ((IWorldAccess) this.u.get(l)).b(i, j, k); } } - public float p(int i, int j, int k) { + public float q(int i, int j, int k) { return this.worldProvider.g[this.getLightLevel(i, j, k)]; } @@ -677,7 +701,7 @@ public abstract class World implements IBlockAccess { int l1 = this.getData(l, i1, j1); Block block = Block.byId[k1]; - if ((!flag1 || block == null || block.e(this, l, i1, j1) != null) && k1 > 0 && block.a(l1, flag)) { + if ((!flag1 || block == null || block.b(this, l, i1, j1) != null) && k1 > 0 && block.a(l1, flag)) { MovingObjectPosition movingobjectposition = block.a(this, l, i1, j1, vec3d, vec3d1); if (movingobjectposition != null) { @@ -805,7 +829,7 @@ public abstract class World implements IBlockAccess { int j2 = this.getData(l, i1, j1); Block block1 = Block.byId[i2]; - if ((!flag1 || block1 == null || block1.e(this, l, i1, j1) != null) && i2 > 0 && block1.a(j2, flag)) { + if ((!flag1 || block1 == null || block1.b(this, l, i1, j1) != null) && i2 > 0 && block1.a(j2, flag)) { MovingObjectPosition movingobjectposition1 = block1.a(this, l, i1, j1, vec3d, vec3d1); if (movingobjectposition1 != null) { @@ -827,24 +851,24 @@ public abstract class World implements IBlockAccess { public void makeSound(Entity entity, String s, float f, float f1) { if (entity != null && s != null) { - for (int i = 0; i < this.v.size(); ++i) { - ((IWorldAccess) this.v.get(i)).a(s, entity.locX, entity.locY - (double) entity.height, entity.locZ, f, f1); + for (int i = 0; i < this.u.size(); ++i) { + ((IWorldAccess) this.u.get(i)).a(s, entity.locX, entity.locY - (double) entity.height, entity.locZ, f, f1); } } } public void a(EntityHuman entityhuman, String s, float f, float f1) { if (entityhuman != null && s != null) { - for (int i = 0; i < this.v.size(); ++i) { - ((IWorldAccess) this.v.get(i)).a(entityhuman, s, entityhuman.locX, entityhuman.locY - (double) entityhuman.height, entityhuman.locZ, f, f1); + for (int i = 0; i < this.u.size(); ++i) { + ((IWorldAccess) this.u.get(i)).a(entityhuman, s, entityhuman.locX, entityhuman.locY - (double) entityhuman.height, entityhuman.locZ, f, f1); } } } public void makeSound(double d0, double d1, double d2, String s, float f, float f1) { if (s != null) { - for (int i = 0; i < this.v.size(); ++i) { - ((IWorldAccess) this.v.get(i)).a(s, d0, d1, d2, f, f1); + for (int i = 0; i < this.u.size(); ++i) { + ((IWorldAccess) this.u.get(i)).a(s, d0, d1, d2, f, f1); } } } @@ -852,14 +876,14 @@ public abstract class World implements IBlockAccess { public void a(double d0, double d1, double d2, String s, float f, float f1, boolean flag) {} public void a(String s, int i, int j, int k) { - for (int l = 0; l < this.v.size(); ++l) { - ((IWorldAccess) this.v.get(l)).a(s, i, j, k); + for (int l = 0; l < this.u.size(); ++l) { + ((IWorldAccess) this.u.get(l)).a(s, i, j, k); } } public void addParticle(String s, double d0, double d1, double d2, double d3, double d4, double d5) { - for (int i = 0; i < this.v.size(); ++i) { - ((IWorldAccess) this.v.get(i)).a(s, d0, d1, d2, d3, d4, d5); + for (int i = 0; i < this.u.size(); ++i) { + ((IWorldAccess) this.u.get(i)).a(s, d0, d1, d2, d3, d4, d5); } } @@ -879,7 +903,7 @@ public abstract class World implements IBlockAccess { int i = MathHelper.floor(entity.locX / 16.0D); int j = MathHelper.floor(entity.locZ / 16.0D); - boolean flag = false; + boolean flag = entity.p; if (entity instanceof EntityHuman) { flag = true; @@ -931,16 +955,16 @@ public abstract class World implements IBlockAccess { } protected void a(Entity entity) { - for (int i = 0; i < this.v.size(); ++i) { - ((IWorldAccess) this.v.get(i)).a(entity); + for (int i = 0; i < this.u.size(); ++i) { + ((IWorldAccess) this.u.get(i)).a(entity); } entity.valid = true; // CraftBukkit } protected void b(Entity entity) { - for (int i = 0; i < this.v.size(); ++i) { - ((IWorldAccess) this.v.get(i)).b(entity); + for (int i = 0; i < this.u.size(); ++i) { + ((IWorldAccess) this.u.get(i)).b(entity); } entity.valid = false; // CraftBukkit @@ -969,10 +993,10 @@ public abstract class World implements IBlockAccess { this.everyoneSleeping(); } - int i = entity.ai; - int j = entity.ak; + int i = entity.aj; + int j = entity.al; - if (entity.ah && this.isChunkLoaded(i, j)) { + if (entity.ai && this.isChunkLoaded(i, j)) { this.getChunkAt(i, j).b(entity); } @@ -981,11 +1005,11 @@ public abstract class World implements IBlockAccess { } public void addIWorldAccess(IWorldAccess iworldaccess) { - this.v.add(iworldaccess); + this.u.add(iworldaccess); } public List getCubes(Entity entity, AxisAlignedBB axisalignedbb) { - this.L.clear(); + this.M.clear(); int i = MathHelper.floor(axisalignedbb.a); int j = MathHelper.floor(axisalignedbb.d + 1.0D); int k = MathHelper.floor(axisalignedbb.b); @@ -1000,7 +1024,7 @@ public abstract class World implements IBlockAccess { Block block = Block.byId[this.getTypeId(k1, i2, l1)]; if (block != null) { - block.a(this, k1, i2, l1, axisalignedbb, this.L, entity); + block.a(this, k1, i2, l1, axisalignedbb, this.M, entity); } } } @@ -1011,23 +1035,23 @@ public abstract class World implements IBlockAccess { List list = this.getEntities(entity, axisalignedbb.grow(d0, d0, d0)); for (int j2 = 0; j2 < list.size(); ++j2) { - AxisAlignedBB axisalignedbb1 = ((Entity) list.get(j2)).E(); + AxisAlignedBB axisalignedbb1 = ((Entity) list.get(j2)).D(); if (axisalignedbb1 != null && axisalignedbb1.a(axisalignedbb)) { - this.L.add(axisalignedbb1); + this.M.add(axisalignedbb1); } axisalignedbb1 = entity.g((Entity) list.get(j2)); if (axisalignedbb1 != null && axisalignedbb1.a(axisalignedbb)) { - this.L.add(axisalignedbb1); + this.M.add(axisalignedbb1); } } - return this.L; + return this.M; } public List a(AxisAlignedBB axisalignedbb) { - this.L.clear(); + this.M.clear(); int i = MathHelper.floor(axisalignedbb.a); int j = MathHelper.floor(axisalignedbb.d + 1.0D); int k = MathHelper.floor(axisalignedbb.b); @@ -1042,14 +1066,14 @@ public abstract class World implements IBlockAccess { Block block = Block.byId[this.getTypeId(k1, i2, l1)]; if (block != null) { - block.a(this, k1, i2, l1, axisalignedbb, this.L, (Entity) null); + block.a(this, k1, i2, l1, axisalignedbb, this.M, (Entity) null); } } } } } - return this.L; + return this.M; } public int a(float f) { @@ -1065,8 +1089,8 @@ public abstract class World implements IBlockAccess { } f2 = 1.0F - f2; - f2 = (float) ((double) f2 * (1.0D - (double) (this.j(f) * 5.0F) / 16.0D)); f2 = (float) ((double) f2 * (1.0D - (double) (this.i(f) * 5.0F) / 16.0D)); + f2 = (float) ((double) f2 * (1.0D - (double) (this.h(f) * 5.0F) / 16.0D)); f2 = 1.0F - f2; return (int) (f2 * 11.0F); } @@ -1075,6 +1099,16 @@ public abstract class World implements IBlockAccess { return this.worldProvider.a(this.worldData.getDayTime(), f); } + public int v() { + return this.worldProvider.a(this.worldData.getDayTime()); + } + + public float d(float f) { + float f1 = this.c(f); + + return f1 * 3.1415927F * 2.0F; + } + public int h(int i, int j) { return this.getChunkAtWorldCoords(i, j).d(i & 15, j & 15); } @@ -1100,7 +1134,7 @@ public abstract class World implements IBlockAccess { public void a(int i, int j, int k, int l, int i1, int j1) {} - public void b(int i, int j, int k, int l, int i1) {} + public void b(int i, int j, int k, int l, int i1, int j1) {} public void tickEntities() { this.methodProfiler.a("entities"); @@ -1126,7 +1160,7 @@ public abstract class World implements IBlockAccess { try { ++entity.ticksLived; - entity.j_(); + entity.l_(); } catch (Throwable throwable) { crashreport = CrashReport.a(throwable, "Ticking entity"); crashreportsystemdetails = crashreport.a("Entity being ticked"); @@ -1152,9 +1186,9 @@ public abstract class World implements IBlockAccess { for (i = 0; i < this.f.size(); ++i) { entity = (Entity) this.f.get(i); - j = entity.ai; - k = entity.ak; - if (entity.ah && this.isChunkLoaded(j, k)) { + j = entity.aj; + k = entity.al; + if (entity.ai && this.isChunkLoaded(j, k)) { this.getChunkAt(j, k).b(entity); } } @@ -1192,12 +1226,7 @@ public abstract class World implements IBlockAccess { } catch (Throwable throwable1) { crashreport = CrashReport.a(throwable1, "Ticking entity"); crashreportsystemdetails = crashreport.a("Entity being ticked"); - if (entity == null) { - crashreportsystemdetails.a("Entity", "~~NULL~~"); - } else { - entity.a(crashreportsystemdetails); - } - + entity.a(crashreportsystemdetails); throw new ReportedException(crashreport); } } @@ -1205,9 +1234,9 @@ public abstract class World implements IBlockAccess { this.methodProfiler.b(); this.methodProfiler.a("remove"); if (entity.dead) { - j = entity.ai; - k = entity.ak; - if (entity.ah && this.isChunkLoaded(j, k)) { + j = entity.aj; + k = entity.al; + if (entity.ai && this.isChunkLoaded(j, k)) { this.getChunkAt(j, k).b(entity); } @@ -1219,7 +1248,7 @@ public abstract class World implements IBlockAccess { } this.methodProfiler.c("tileEntities"); - this.M = true; + this.N = true; Iterator iterator = this.tileEntityList.iterator(); while (iterator.hasNext()) { @@ -1233,16 +1262,11 @@ public abstract class World implements IBlockAccess { if (!tileentity.r() && tileentity.o() && this.isLoaded(tileentity.x, tileentity.y, tileentity.z)) { try { - tileentity.g(); + tileentity.h(); } catch (Throwable throwable2) { crashreport = CrashReport.a(throwable2, "Ticking tile entity"); crashreportsystemdetails = crashreport.a("Tile entity being ticked"); - if (tileentity == null) { - crashreportsystemdetails.a("Tile entity", "~~NULL~~"); - } else { - tileentity.a(crashreportsystemdetails); - } - + tileentity.a(crashreportsystemdetails); throw new ReportedException(crashreport); } } @@ -1259,7 +1283,7 @@ public abstract class World implements IBlockAccess { } } - this.M = false; + this.N = false; if (!this.b.isEmpty()) { this.tileEntityList.removeAll(this.b); this.b.clear(); @@ -1302,7 +1326,7 @@ public abstract class World implements IBlockAccess { } public void a(Collection collection) { - if (this.M) { + if (this.N) { this.a.addAll(collection); } else { this.tileEntityList.addAll(collection); @@ -1318,32 +1342,32 @@ public abstract class World implements IBlockAccess { int j = MathHelper.floor(entity.locZ); byte b0 = 32; - if (!flag || this.d(i - b0, 0, j - b0, i + b0, 0, j + b0)) { - entity.T = entity.locX; - entity.U = entity.locY; - entity.V = entity.locZ; + if (!flag || this.e(i - b0, 0, j - b0, i + b0, 0, j + b0)) { + entity.U = entity.locX; + entity.V = entity.locY; + entity.W = entity.locZ; entity.lastYaw = entity.yaw; entity.lastPitch = entity.pitch; - if (flag && entity.ah) { + if (flag && entity.ai) { if (entity.vehicle != null) { - entity.U(); + entity.T(); } else { ++entity.ticksLived; - entity.j_(); + entity.l_(); } } this.methodProfiler.a("chunkCheck"); if (Double.isNaN(entity.locX) || Double.isInfinite(entity.locX)) { - entity.locX = entity.T; + entity.locX = entity.U; } if (Double.isNaN(entity.locY) || Double.isInfinite(entity.locY)) { - entity.locY = entity.U; + entity.locY = entity.V; } if (Double.isNaN(entity.locZ) || Double.isInfinite(entity.locZ)) { - entity.locZ = entity.V; + entity.locZ = entity.W; } if (Double.isNaN((double) entity.pitch) || Double.isInfinite((double) entity.pitch)) { @@ -1358,21 +1382,21 @@ public abstract class World implements IBlockAccess { int l = MathHelper.floor(entity.locY / 16.0D); int i1 = MathHelper.floor(entity.locZ / 16.0D); - if (!entity.ah || entity.ai != k || entity.aj != l || entity.ak != i1) { - if (entity.ah && this.isChunkLoaded(entity.ai, entity.ak)) { - this.getChunkAt(entity.ai, entity.ak).a(entity, entity.aj); + if (!entity.ai || entity.aj != k || entity.ak != l || entity.al != i1) { + if (entity.ai && this.isChunkLoaded(entity.aj, entity.al)) { + this.getChunkAt(entity.aj, entity.al).a(entity, entity.ak); } if (this.isChunkLoaded(k, i1)) { - entity.ah = true; + entity.ai = true; this.getChunkAt(k, i1).a(entity); } else { - entity.ah = false; + entity.ai = false; } } this.methodProfiler.b(); - if (flag && entity.ah && entity.passenger != null) { + if (flag && entity.ai && entity.passenger != null) { if (!entity.passenger.dead && entity.passenger.vehicle == entity) { this.playerJoinedWorld(entity.passenger); } else { @@ -1479,7 +1503,7 @@ public abstract class World implements IBlockAccess { int i1 = MathHelper.floor(axisalignedbb.c); int j1 = MathHelper.floor(axisalignedbb.f + 1.0D); - if (this.d(i, k, i1, j, l, j1)) { + if (this.e(i, k, i1, j, l, j1)) { for (int k1 = i; k1 < j; ++k1) { for (int l1 = k; l1 < l; ++l1) { for (int i2 = i1; i2 < j1; ++i2) { @@ -1504,7 +1528,7 @@ public abstract class World implements IBlockAccess { int i1 = MathHelper.floor(axisalignedbb.c); int j1 = MathHelper.floor(axisalignedbb.f + 1.0D); - if (!this.d(i, k, i1, j, l, j1)) { + if (!this.e(i, k, i1, j, l, j1)) { return false; } else { boolean flag = false; @@ -1516,7 +1540,7 @@ public abstract class World implements IBlockAccess { Block block = Block.byId[this.getTypeId(k1, l1, i2)]; if (block != null && block.material == material) { - double d0 = (double) ((float) (l1 + 1) - BlockFluids.e(this.getData(k1, l1, i2))); + double d0 = (double) ((float) (l1 + 1) - BlockFluids.d(this.getData(k1, l1, i2))); if ((double) l >= d0) { flag = true; @@ -1527,7 +1551,7 @@ public abstract class World implements IBlockAccess { } } - if (vec3d.b() > 0.0D) { + if (vec3d.b() > 0.0D && entity.aw()) { vec3d = vec3d.a(); double d1 = 0.014D; @@ -1665,7 +1689,7 @@ public abstract class World implements IBlockAccess { if (this.getTypeId(i, j, k) == Block.FIRE.id) { this.a(entityhuman, 1004, i, j, k, 0); - this.setTypeId(i, j, k, 0); + this.setAir(i, j, k); return true; } else { return false; @@ -1673,38 +1697,62 @@ public abstract class World implements IBlockAccess { } public TileEntity getTileEntity(int i, int j, int k) { - if (j >= 256) { - return null; - } else { - Chunk chunk = this.getChunkAt(i >> 4, k >> 4); + if (j >= 0 && j < 256) { + TileEntity tileentity = null; + int l; + TileEntity tileentity1; - if (chunk == null) { - return null; - } else { - TileEntity tileentity = chunk.e(i & 15, j, k & 15); - - if (tileentity == null) { - for (int l = 0; l < this.a.size(); ++l) { - TileEntity tileentity1 = (TileEntity) this.a.get(l); - - if (!tileentity1.r() && tileentity1.x == i && tileentity1.y == j && tileentity1.z == k) { - tileentity = tileentity1; - break; - } + if (this.N) { + for (l = 0; l < this.a.size(); ++l) { + tileentity1 = (TileEntity) this.a.get(l); + if (!tileentity1.r() && tileentity1.x == i && tileentity1.y == j && tileentity1.z == k) { + tileentity = tileentity1; + break; } } - - return tileentity; } + + if (tileentity == null) { + Chunk chunk = this.getChunkAt(i >> 4, k >> 4); + + if (chunk != null) { + tileentity = chunk.e(i & 15, j, k & 15); + } + } + + if (tileentity == null) { + for (l = 0; l < this.a.size(); ++l) { + tileentity1 = (TileEntity) this.a.get(l); + if (!tileentity1.r() && tileentity1.x == i && tileentity1.y == j && tileentity1.z == k) { + tileentity = tileentity1; + break; + } + } + } + + return tileentity; + } else { + return null; } } public void setTileEntity(int i, int j, int k, TileEntity tileentity) { if (tileentity != null && !tileentity.r()) { - if (this.M) { + if (this.N) { tileentity.x = i; tileentity.y = j; tileentity.z = k; + Iterator iterator = this.a.iterator(); + + while (iterator.hasNext()) { + TileEntity tileentity1 = (TileEntity) iterator.next(); + + if (tileentity1.x == i && tileentity1.y == j && tileentity1.z == k) { + tileentity1.w_(); + iterator.remove(); + } + } + this.a.add(tileentity); } else { this.tileEntityList.add(tileentity); @@ -1717,10 +1765,10 @@ public abstract class World implements IBlockAccess { } } - public void r(int i, int j, int k) { + public void s(int i, int j, int k) { TileEntity tileentity = this.getTileEntity(i, j, k); - if (tileentity != null && this.M) { + if (tileentity != null && this.N) { tileentity.w_(); this.a.remove(tileentity); } else { @@ -1741,21 +1789,21 @@ public abstract class World implements IBlockAccess { this.b.add(tileentity); } - public boolean s(int i, int j, int k) { + public boolean t(int i, int j, int k) { Block block = Block.byId[this.getTypeId(i, j, k)]; return block == null ? false : block.c(); } - public boolean t(int i, int j, int k) { - return Block.i(this.getTypeId(i, j, k)); + public boolean u(int i, int j, int k) { + return Block.l(this.getTypeId(i, j, k)); } - public boolean u(int i, int j, int k) { + public boolean v(int i, int j, int k) { int l = this.getTypeId(i, j, k); if (l != 0 && Block.byId[l] != null) { - AxisAlignedBB axisalignedbb = Block.byId[l].e(this, i, j, k); + AxisAlignedBB axisalignedbb = Block.byId[l].b(this, i, j, k); return axisalignedbb != null && axisalignedbb.b() >= 1.0D; } else { @@ -1763,13 +1811,13 @@ public abstract class World implements IBlockAccess { } } - public boolean v(int i, int j, int k) { + public boolean w(int i, int j, int k) { Block block = Block.byId[this.getTypeId(i, j, k)]; - return block == null ? false : (block.material.k() && block.b() ? true : (block instanceof BlockStairs ? (this.getData(i, j, k) & 4) == 4 : (block instanceof BlockStepAbstract ? (this.getData(i, j, k) & 8) == 8 : false))); + return block == null ? false : (block.material.k() && block.b() ? true : (block instanceof BlockStairs ? (this.getData(i, j, k) & 4) == 4 : (block instanceof BlockStepAbstract ? (this.getData(i, j, k) & 8) == 8 : (block instanceof BlockHopper ? true : (block instanceof BlockSnow ? (this.getData(i, j, k) & 7) == 7 : false))))); } - public boolean b(int i, int j, int k, boolean flag) { + public boolean c(int i, int j, int k, boolean flag) { if (i >= -30000000 && k >= -30000000 && i < 30000000 && k < 30000000) { Chunk chunk = this.chunkProvider.getOrCreateChunk(i >> 4, k >> 4); @@ -1785,7 +1833,7 @@ public abstract class World implements IBlockAccess { } } - public void x() { + public void y() { int i = this.a(1.0F); if (i != this.j) { @@ -1890,11 +1938,11 @@ public abstract class World implements IBlockAccess { } } - public void y() { + public void z() { this.worldData.setWeatherDuration(1); } - protected void z() { + protected void A() { // this.chunkTickList.clear(); // CraftBukkit - removed this.methodProfiler.a("buildList"); @@ -1924,8 +1972,8 @@ public abstract class World implements IBlockAccess { } this.methodProfiler.b(); - if (this.N > 0) { - --this.N; + if (this.O > 0) { + --this.O; } this.methodProfiler.a("playerCheckLight"); @@ -1936,7 +1984,7 @@ public abstract class World implements IBlockAccess { k = MathHelper.floor(entityhuman.locY) + this.random.nextInt(11) - 5; int j1 = MathHelper.floor(entityhuman.locZ) + this.random.nextInt(11) - 5; - this.z(j, k, j1); + this.A(j, k, j1); } this.methodProfiler.b(); @@ -1944,7 +1992,7 @@ public abstract class World implements IBlockAccess { protected void a(int i, int j, Chunk chunk) { this.methodProfiler.c("moodSound"); - if (this.N == 0 && !this.isStatic) { + if (this.O == 0 && !this.isStatic) { this.k = this.k * 3 + 1013904223; int k = this.k >> 2; int l = k & 15; @@ -1954,12 +2002,12 @@ public abstract class World implements IBlockAccess { l += i; i1 += j; - if (k1 == 0 && this.l(l, j1, i1) <= this.random.nextInt(8) && this.b(EnumSkyBlock.SKY, l, j1, i1) <= 0) { + if (k1 == 0 && this.m(l, j1, i1) <= this.random.nextInt(8) && this.b(EnumSkyBlock.SKY, l, j1, i1) <= 0) { EntityHuman entityhuman = this.findNearbyPlayer((double) l + 0.5D, (double) j1 + 0.5D, (double) i1 + 0.5D, 8.0D); if (entityhuman != null && entityhuman.e((double) l + 0.5D, (double) j1 + 0.5D, (double) i1 + 0.5D) > 4.0D) { this.makeSound((double) l + 0.5D, (double) j1 + 0.5D, (double) i1 + 0.5D, "ambient.cave.cave", 0.7F, 0.8F + this.random.nextFloat() * 0.2F); - this.N = this.random.nextInt(12000) + 6000; + this.O = this.random.nextInt(12000) + 6000; } } } @@ -1969,18 +2017,18 @@ public abstract class World implements IBlockAccess { } protected void g() { - this.z(); - } - - public boolean w(int i, int j, int k) { - return this.c(i, j, k, false); + this.A(); } public boolean x(int i, int j, int k) { - return this.c(i, j, k, true); + return this.d(i, j, k, false); } - public boolean c(int i, int j, int k, boolean flag) { + public boolean y(int i, int j, int k) { + return this.d(i, j, k, true); + } + + public boolean d(int i, int j, int k, boolean flag) { BiomeBase biomebase = this.getBiome(i, k); float f = biomebase.j(); @@ -2023,7 +2071,7 @@ public abstract class World implements IBlockAccess { } } - public boolean y(int i, int j, int k) { + public boolean z(int i, int j, int k) { BiomeBase biomebase = this.getBiome(i, k); float f = biomebase.j(); @@ -2043,7 +2091,7 @@ public abstract class World implements IBlockAccess { } } - public void z(int i, int j, int k) { + public void A(int i, int j, int k) { if (!this.worldProvider.f) { this.c(EnumSkyBlock.SKY, i, j, k); } @@ -2051,85 +2099,45 @@ public abstract class World implements IBlockAccess { this.c(EnumSkyBlock.BLOCK, i, j, k); } - private int b(int i, int j, int k, int l, int i1, int j1) { - int k1 = 0; - - if (this.k(j, k, l)) { - k1 = 15; + private int a(int i, int j, int k, EnumSkyBlock enumskyblock) { + if (enumskyblock == EnumSkyBlock.SKY && this.l(i, j, k)) { + return 15; } else { - if (j1 == 0) { + int l = this.getTypeId(i, j, k); + int i1 = enumskyblock == EnumSkyBlock.SKY ? 0 : Block.lightEmission[l]; + int j1 = Block.lightBlock[l]; + + if (j1 >= 15 && Block.lightEmission[l] > 0) { j1 = 1; } - int l1 = this.b(EnumSkyBlock.SKY, j - 1, k, l) - j1; - int i2 = this.b(EnumSkyBlock.SKY, j + 1, k, l) - j1; - int j2 = this.b(EnumSkyBlock.SKY, j, k - 1, l) - j1; - int k2 = this.b(EnumSkyBlock.SKY, j, k + 1, l) - j1; - int l2 = this.b(EnumSkyBlock.SKY, j, k, l - 1) - j1; - int i3 = this.b(EnumSkyBlock.SKY, j, k, l + 1) - j1; - - if (l1 > k1) { - k1 = l1; + if (j1 < 1) { + j1 = 1; } - if (i2 > k1) { - k1 = i2; - } + if (j1 >= 15) { + return 0; + } else if (i1 >= 14) { + return i1; + } else { + for (int k1 = 0; k1 < 6; ++k1) { + int l1 = i + Facing.b[k1]; + int i2 = j + Facing.c[k1]; + int j2 = k + Facing.d[k1]; + int k2 = this.b(enumskyblock, l1, i2, j2) - j1; - if (j2 > k1) { - k1 = j2; - } + if (k2 > i1) { + i1 = k2; + } - if (k2 > k1) { - k1 = k2; - } + if (i1 >= 14) { + return i1; + } + } - if (l2 > k1) { - k1 = l2; - } - - if (i3 > k1) { - k1 = i3; + return i1; } } - - return k1; - } - - private int g(int i, int j, int k, int l, int i1, int j1) { - int k1 = Block.lightEmission[i1]; - int l1 = this.b(EnumSkyBlock.BLOCK, j - 1, k, l) - j1; - int i2 = this.b(EnumSkyBlock.BLOCK, j + 1, k, l) - j1; - int j2 = this.b(EnumSkyBlock.BLOCK, j, k - 1, l) - j1; - int k2 = this.b(EnumSkyBlock.BLOCK, j, k + 1, l) - j1; - int l2 = this.b(EnumSkyBlock.BLOCK, j, k, l - 1) - j1; - int i3 = this.b(EnumSkyBlock.BLOCK, j, k, l + 1) - j1; - - if (l1 > k1) { - k1 = l1; - } - - if (i2 > k1) { - k1 = i2; - } - - if (j2 > k1) { - k1 = j2; - } - - if (k2 > k1) { - k1 = k2; - } - - if (l2 > k1) { - k1 = l2; - } - - if (i3 > k1) { - k1 = i3; - } - - return k1; } public void c(EnumSkyBlock enumskyblock, int i, int j, int k) { @@ -2139,23 +2147,9 @@ public abstract class World implements IBlockAccess { this.methodProfiler.a("getBrightness"); int j1 = this.b(enumskyblock, i, j, k); - boolean flag = false; - int k1 = this.getTypeId(i, j, k); - int l1 = this.b(i, j, k); - - if (l1 == 0) { - l1 = 1; - } - - boolean flag1 = false; + int k1 = this.a(i, j, k, enumskyblock); + int l1; int i2; - - if (enumskyblock == EnumSkyBlock.SKY) { - i2 = this.b(j1, i, j, k, k1, l1); - } else { - i2 = this.g(j1, i, j, k, k1, l1); - } - int j2; int k2; int l2; @@ -2163,58 +2157,35 @@ public abstract class World implements IBlockAccess { int j3; int k3; int l3; - int i4; - if (i2 > j1) { + if (k1 > j1) { this.H[i1++] = 133152; - } else if (i2 < j1) { - if (enumskyblock != EnumSkyBlock.BLOCK) { - ; - } - - this.H[i1++] = 133152 + (j1 << 18); + } else if (k1 < j1) { + this.H[i1++] = 133152 | j1 << 18; while (l < i1) { - k1 = this.H[l++]; - l1 = (k1 & 63) - 32 + i; - i2 = (k1 >> 6 & 63) - 32 + j; - j2 = (k1 >> 12 & 63) - 32 + k; - k2 = k1 >> 18 & 15; - l2 = this.b(enumskyblock, l1, i2, j2); - if (l2 == k2) { - this.b(enumskyblock, l1, i2, j2, 0); - if (k2 > 0) { - i3 = l1 - i; - k3 = i2 - j; - j3 = j2 - k; - if (i3 < 0) { - i3 = -i3; - } + l1 = this.H[l++]; + i2 = (l1 & 63) - 32 + i; + j2 = (l1 >> 6 & 63) - 32 + j; + k2 = (l1 >> 12 & 63) - 32 + k; + l2 = l1 >> 18 & 15; + i3 = this.b(enumskyblock, i2, j2, k2); + if (i3 == l2) { + this.b(enumskyblock, i2, j2, k2, 0); + if (l2 > 0) { + j3 = MathHelper.a(i2 - i); + l3 = MathHelper.a(j2 - j); + k3 = MathHelper.a(k2 - k); + if (j3 + l3 + k3 < 17) { + for (int i4 = 0; i4 < 6; ++i4) { + int j4 = i2 + Facing.b[i4]; + int k4 = j2 + Facing.c[i4]; + int l4 = k2 + Facing.d[i4]; + int i5 = Math.max(1, Block.lightBlock[this.getTypeId(j4, k4, l4)]); - if (k3 < 0) { - k3 = -k3; - } - - if (j3 < 0) { - j3 = -j3; - } - - if (i3 + k3 + j3 < 17) { - for (i4 = 0; i4 < 6; ++i4) { - l3 = i4 % 2 * 2 - 1; - int j4 = l1 + i4 / 2 % 3 / 2 * l3; - int k4 = i2 + (i4 / 2 + 1) % 3 / 2 * l3; - int l4 = j2 + (i4 / 2 + 2) % 3 / 2 * l3; - - l2 = this.b(enumskyblock, j4, k4, l4); - int i5 = Block.lightBlock[this.getTypeId(j4, k4, l4)]; - - if (i5 == 0) { - i5 = 1; - } - - if (l2 == k2 - i5 && i1 < this.H.length) { - this.H[i1++] = j4 - i + 32 + (k4 - j + 32 << 6) + (l4 - k + 32 << 12) + (k2 - i5 << 18); + i3 = this.b(enumskyblock, j4, k4, l4); + if (i3 == l2 - i5 && i1 < this.H.length) { + this.H[i1++] = j4 - i + 32 | k4 - j + 32 << 6 | l4 - k + 32 << 12 | l2 - i5 << 18; } } } @@ -2229,66 +2200,43 @@ public abstract class World implements IBlockAccess { this.methodProfiler.a("checkedPosition < toCheckCount"); while (l < i1) { - k1 = this.H[l++]; - l1 = (k1 & 63) - 32 + i; - i2 = (k1 >> 6 & 63) - 32 + j; - j2 = (k1 >> 12 & 63) - 32 + k; - k2 = this.b(enumskyblock, l1, i2, j2); - l2 = this.getTypeId(l1, i2, j2); - i3 = Block.lightBlock[l2]; - if (i3 == 0) { - i3 = 1; - } + l1 = this.H[l++]; + i2 = (l1 & 63) - 32 + i; + j2 = (l1 >> 6 & 63) - 32 + j; + k2 = (l1 >> 12 & 63) - 32 + k; + l2 = this.b(enumskyblock, i2, j2, k2); + i3 = this.a(i2, j2, k2, enumskyblock); + if (i3 != l2) { + this.b(enumskyblock, i2, j2, k2, i3); + if (i3 > l2) { + j3 = Math.abs(i2 - i); + l3 = Math.abs(j2 - j); + k3 = Math.abs(k2 - k); + boolean flag = i1 < this.H.length - 6; - boolean flag2 = false; - - if (enumskyblock == EnumSkyBlock.SKY) { - k3 = this.b(k2, l1, i2, j2, l2, i3); - } else { - k3 = this.g(k2, l1, i2, j2, l2, i3); - } - - if (k3 != k2) { - this.b(enumskyblock, l1, i2, j2, k3); - if (k3 > k2) { - j3 = l1 - i; - i4 = i2 - j; - l3 = j2 - k; - if (j3 < 0) { - j3 = -j3; - } - - if (i4 < 0) { - i4 = -i4; - } - - if (l3 < 0) { - l3 = -l3; - } - - if (j3 + i4 + l3 < 17 && i1 < this.H.length - 6) { - if (this.b(enumskyblock, l1 - 1, i2, j2) < k3) { - this.H[i1++] = l1 - 1 - i + 32 + (i2 - j + 32 << 6) + (j2 - k + 32 << 12); + if (j3 + l3 + k3 < 17 && flag) { + if (this.b(enumskyblock, i2 - 1, j2, k2) < i3) { + this.H[i1++] = i2 - 1 - i + 32 + (j2 - j + 32 << 6) + (k2 - k + 32 << 12); } - if (this.b(enumskyblock, l1 + 1, i2, j2) < k3) { - this.H[i1++] = l1 + 1 - i + 32 + (i2 - j + 32 << 6) + (j2 - k + 32 << 12); + if (this.b(enumskyblock, i2 + 1, j2, k2) < i3) { + this.H[i1++] = i2 + 1 - i + 32 + (j2 - j + 32 << 6) + (k2 - k + 32 << 12); } - if (this.b(enumskyblock, l1, i2 - 1, j2) < k3) { - this.H[i1++] = l1 - i + 32 + (i2 - 1 - j + 32 << 6) + (j2 - k + 32 << 12); + if (this.b(enumskyblock, i2, j2 - 1, k2) < i3) { + this.H[i1++] = i2 - i + 32 + (j2 - 1 - j + 32 << 6) + (k2 - k + 32 << 12); } - if (this.b(enumskyblock, l1, i2 + 1, j2) < k3) { - this.H[i1++] = l1 - i + 32 + (i2 + 1 - j + 32 << 6) + (j2 - k + 32 << 12); + if (this.b(enumskyblock, i2, j2 + 1, k2) < i3) { + this.H[i1++] = i2 - i + 32 + (j2 + 1 - j + 32 << 6) + (k2 - k + 32 << 12); } - if (this.b(enumskyblock, l1, i2, j2 - 1) < k3) { - this.H[i1++] = l1 - i + 32 + (i2 - j + 32 << 6) + (j2 - 1 - k + 32 << 12); + if (this.b(enumskyblock, i2, j2, k2 - 1) < i3) { + this.H[i1++] = i2 - i + 32 + (j2 - j + 32 << 6) + (k2 - 1 - k + 32 << 12); } - if (this.b(enumskyblock, l1, i2, j2 + 1) < k3) { - this.H[i1++] = l1 - i + 32 + (i2 - j + 32 << 6) + (j2 + 1 - k + 32 << 12); + if (this.b(enumskyblock, i2, j2, k2 + 1) < i3) { + this.H[i1++] = i2 - i + 32 + (j2 - j + 32 << 6) + (k2 + 1 - k + 32 << 12); } } } @@ -2308,7 +2256,11 @@ public abstract class World implements IBlockAccess { } public List getEntities(Entity entity, AxisAlignedBB axisalignedbb) { - this.O.clear(); + return this.getEntities(entity, axisalignedbb, (IEntitySelector) null); + } + + public List getEntities(Entity entity, AxisAlignedBB axisalignedbb, IEntitySelector ientityselector) { + ArrayList arraylist = new ArrayList(); int i = MathHelper.floor((axisalignedbb.a - 2.0D) / 16.0D); int j = MathHelper.floor((axisalignedbb.d + 2.0D) / 16.0D); int k = MathHelper.floor((axisalignedbb.c - 2.0D) / 16.0D); @@ -2317,12 +2269,12 @@ public abstract class World implements IBlockAccess { for (int i1 = i; i1 <= j; ++i1) { for (int j1 = k; j1 <= l; ++j1) { if (this.isChunkLoaded(i1, j1)) { - this.getChunkAt(i1, j1).a(entity, axisalignedbb, this.O); + this.getChunkAt(i1, j1).a(entity, axisalignedbb, arraylist, ientityselector); } } } - return this.O; + return arraylist; } public List a(Class oclass, AxisAlignedBB axisalignedbb) { @@ -2408,11 +2360,11 @@ public abstract class World implements IBlockAccess { this.f.addAll(list); } - public boolean mayPlace(int i, int j, int k, int l, boolean flag, int i1, Entity entity) { + public boolean mayPlace(int i, int j, int k, int l, boolean flag, int i1, Entity entity, ItemStack itemstack) { int j1 = this.getTypeId(j, k, l); Block block = Block.byId[j1]; Block block1 = Block.byId[i]; - AxisAlignedBB axisalignedbb = block1.e(this, j, k, l); + AxisAlignedBB axisalignedbb = block1.b(this, j, k, l); if (flag) { axisalignedbb = null; @@ -2428,7 +2380,7 @@ public abstract class World implements IBlockAccess { } // CraftBukkit - defaultReturn = block != null && block.material == Material.ORIENTABLE && block1 == Block.ANVIL ? true : i > 0 && block == null && block1.canPlace(this, j, k, l, i1); + defaultReturn = block != null && block.material == Material.ORIENTABLE && block1 == Block.ANVIL ? true : i > 0 && block == null && block1.canPlace(this, j, k, l, i1, itemstack); } // CraftBukkit start @@ -2477,28 +2429,78 @@ public abstract class World implements IBlockAccess { return pathentity; } - public boolean isBlockFacePowered(int i, int j, int k, int l) { + public int getBlockPower(int i, int j, int k, int l) { int i1 = this.getTypeId(i, j, k); - return i1 == 0 ? false : Block.byId[i1].c(this, i, j, k, l); + return i1 == 0 ? 0 : Block.byId[i1].c(this, i, j, k, l); } - public boolean isBlockPowered(int i, int j, int k) { - return this.isBlockFacePowered(i, j - 1, k, 0) ? true : (this.isBlockFacePowered(i, j + 1, k, 1) ? true : (this.isBlockFacePowered(i, j, k - 1, 2) ? true : (this.isBlockFacePowered(i, j, k + 1, 3) ? true : (this.isBlockFacePowered(i - 1, j, k, 4) ? true : this.isBlockFacePowered(i + 1, j, k, 5))))); + public int getBlockPower(int i, int j, int k) { + byte b0 = 0; + int l = Math.max(b0, this.getBlockPower(i, j - 1, k, 0)); + + if (l >= 15) { + return l; + } else { + l = Math.max(l, this.getBlockPower(i, j + 1, k, 1)); + if (l >= 15) { + return l; + } else { + l = Math.max(l, this.getBlockPower(i, j, k - 1, 2)); + if (l >= 15) { + return l; + } else { + l = Math.max(l, this.getBlockPower(i, j, k + 1, 3)); + if (l >= 15) { + return l; + } else { + l = Math.max(l, this.getBlockPower(i - 1, j, k, 4)); + if (l >= 15) { + return l; + } else { + l = Math.max(l, this.getBlockPower(i + 1, j, k, 5)); + return l >= 15 ? l : l; + } + } + } + } + } } - public boolean isBlockFaceIndirectlyPowered(int i, int j, int k, int l) { - if (this.t(i, j, k)) { - return this.isBlockPowered(i, j, k); + public boolean isBlockFacePowered(int i, int j, int k, int l) { + return this.getBlockFacePower(i, j, k, l) > 0; + } + + public int getBlockFacePower(int i, int j, int k, int l) { + if (this.u(i, j, k)) { + return this.getBlockPower(i, j, k); } else { int i1 = this.getTypeId(i, j, k); - return i1 == 0 ? false : Block.byId[i1].b(this, i, j, k, l); + return i1 == 0 ? 0 : Block.byId[i1].b(this, i, j, k, l); } } public boolean isBlockIndirectlyPowered(int i, int j, int k) { - return this.isBlockFaceIndirectlyPowered(i, j - 1, k, 0) ? true : (this.isBlockFaceIndirectlyPowered(i, j + 1, k, 1) ? true : (this.isBlockFaceIndirectlyPowered(i, j, k - 1, 2) ? true : (this.isBlockFaceIndirectlyPowered(i, j, k + 1, 3) ? true : (this.isBlockFaceIndirectlyPowered(i - 1, j, k, 4) ? true : this.isBlockFaceIndirectlyPowered(i + 1, j, k, 5))))); + return this.getBlockFacePower(i, j - 1, k, 0) > 0 ? true : (this.getBlockFacePower(i, j + 1, k, 1) > 0 ? true : (this.getBlockFacePower(i, j, k - 1, 2) > 0 ? true : (this.getBlockFacePower(i, j, k + 1, 3) > 0 ? true : (this.getBlockFacePower(i - 1, j, k, 4) > 0 ? true : this.getBlockFacePower(i + 1, j, k, 5) > 0)))); + } + + public int getHighestNeighborSignal(int i, int j, int k) { + int l = 0; + + for (int i1 = 0; i1 < 6; ++i1) { + int j1 = this.getBlockFacePower(i + Facing.b[i1], j + Facing.c[i1], k + Facing.d[i1], i1); + + if (j1 >= 15) { + return 15; + } + + if (j1 > l) { + l = j1; + } + } + + return l; } public EntityHuman findNearbyPlayer(Entity entity, double d0) { @@ -2552,7 +2554,7 @@ public abstract class World implements IBlockAccess { } if (entityhuman1.isInvisible()) { - float f = entityhuman1.bR(); + float f = entityhuman1.ca(); if (f < 0.1F) { f = 0.1F; @@ -2581,7 +2583,7 @@ public abstract class World implements IBlockAccess { return null; } - public void D() throws ExceptionWorldConflict { // CraftBukkit - added throws + public void E() throws ExceptionWorldConflict { // CraftBukkit - added throws this.dataManager.checkSession(); } @@ -2611,7 +2613,7 @@ public abstract class World implements IBlockAccess { public void broadcastEntityEffect(Entity entity, byte b0) {} - public IChunkProvider I() { + public IChunkProvider J() { return this.chunkProvider; } @@ -2645,26 +2647,26 @@ public abstract class World implements IBlockAccess { } // CraftBukkit end - public float i(float f) { - return (this.o + (this.p - this.o) * f) * this.j(f); + public float h(float f) { + return (this.o + (this.p - this.o) * f) * this.i(f); } - public float j(float f) { + public float i(float f) { return this.m + (this.n - this.m) * f; } - public boolean M() { - return (double) this.i(1.0F) > 0.9D; - } - public boolean N() { - return (double) this.j(1.0F) > 0.2D; + return (double) this.h(1.0F) > 0.9D; } - public boolean D(int i, int j, int k) { - if (!this.N()) { + public boolean O() { + return (double) this.i(1.0F) > 0.2D; + } + + public boolean F(int i, int j, int k) { + if (!this.O()) { return false; - } else if (!this.k(i, j, k)) { + } else if (!this.l(i, j, k)) { return false; } else if (this.h(i, k) > j) { return false; @@ -2675,7 +2677,7 @@ public abstract class World implements IBlockAccess { } } - public boolean E(int i, int j, int k) { + public boolean G(int i, int j, int k) { BiomeBase biomebase = this.getBiome(i, k); return biomebase.e(); @@ -2693,9 +2695,9 @@ public abstract class World implements IBlockAccess { return this.worldMaps.a(s); } - public void e(int i, int j, int k, int l, int i1) { - for (int j1 = 0; j1 < this.v.size(); ++j1) { - ((IWorldAccess) this.v.get(j1)).a(i, j, k, l, i1); + public void d(int i, int j, int k, int l, int i1) { + for (int j1 = 0; j1 < this.u.size(); ++j1) { + ((IWorldAccess) this.u.get(j1)).a(i, j, k, l, i1); } } @@ -2705,8 +2707,8 @@ public abstract class World implements IBlockAccess { public void a(EntityHuman entityhuman, int i, int j, int k, int l, int i1) { try { - for (int j1 = 0; j1 < this.v.size(); ++j1) { - ((IWorldAccess) this.v.get(j1)).a(entityhuman, i, j, k, l, i1); + for (int j1 = 0; j1 < this.u.size(); ++j1) { + ((IWorldAccess) this.u.get(j1)).a(entityhuman, i, j, k, l, i1); } } catch (Throwable throwable) { CrashReport crashreport = CrashReport.a(throwable, "Playing level event"); @@ -2724,15 +2726,15 @@ public abstract class World implements IBlockAccess { return 256; } - public int P() { + public int Q() { return this.worldProvider.f ? 128 : 256; } - public IUpdatePlayerListBox a(EntityMinecart entityminecart) { + public IUpdatePlayerListBox a(EntityMinecartAbstract entityminecartabstract) { return null; } - public Random F(int i, int j, int k) { + public Random H(int i, int j, int k) { long l = (long) i * 341873128712L + (long) j * 132897987541L + this.getWorldData().getSeed() + (long) k; this.random.setSeed(l); @@ -2740,7 +2742,7 @@ public abstract class World implements IBlockAccess { } public ChunkPosition b(String s, int i, int j, int k) { - return this.I().findNearestMapFeature(this, s, i, j, k); + return this.J().findNearestMapFeature(this, s, i, j, k); } public CrashReportSystemDetails a(CrashReport crashreport) { @@ -2759,9 +2761,9 @@ public abstract class World implements IBlockAccess { return crashreportsystemdetails; } - public void g(int i, int j, int k, int l, int i1) { - for (int j1 = 0; j1 < this.v.size(); ++j1) { - IWorldAccess iworldaccess = (IWorldAccess) this.v.get(j1); + public void f(int i, int j, int k, int l, int i1) { + for (int j1 = 0; j1 < this.u.size(); ++j1) { + IWorldAccess iworldaccess = (IWorldAccess) this.u.get(j1); iworldaccess.b(i, j, k, l, i1); } @@ -2771,11 +2773,43 @@ public abstract class World implements IBlockAccess { return this.J; } - public Calendar T() { + public Calendar U() { if (this.getTime() % 600L == 0L) { this.K.setTimeInMillis(System.currentTimeMillis()); } return this.K; } + + public Scoreboard getScoreboard() { + return this.scoreboard; + } + + public void m(int i, int j, int k, int l) { + for (int i1 = 0; i1 < 4; ++i1) { + int j1 = i + Direction.a[i1]; + int k1 = k + Direction.b[i1]; + int l1 = this.getTypeId(j1, j, k1); + + if (l1 != 0) { + Block block = Block.byId[l1]; + + if (Block.REDSTONE_COMPARATOR_OFF.g(l1)) { + block.doPhysics(this, j1, j, k1, l); + } else if (Block.l(l1)) { + j1 += Direction.a[i1]; + k1 += Direction.b[i1]; + l1 = this.getTypeId(j1, j, k1); + block = Block.byId[l1]; + if (Block.REDSTONE_COMPARATOR_OFF.g(l1)) { + block.doPhysics(this, j1, j, k1, l); + } + } + } + } + } + + public IConsoleLogManager getLogger() { + return this.logAgent; + } } diff --git a/src/main/java/net/minecraft/server/WorldGenForest.java b/src/main/java/net/minecraft/server/WorldGenForest.java index 2ca7a7fffc..da137e3a28 100644 --- a/src/main/java/net/minecraft/server/WorldGenForest.java +++ b/src/main/java/net/minecraft/server/WorldGenForest.java @@ -70,8 +70,12 @@ public class WorldGenForest extends WorldGenerator implements BlockSapling.TreeG for (int k2 = k - k1; k2 <= k + k1; ++k2) { int l2 = k2 - k; - if ((Math.abs(j2) != k1 || Math.abs(l2) != k1 || random.nextInt(2) != 0 && j1 != 0) && !Block.q[world.getTypeId(l1, i2, k2)]) { - this.setTypeAndData(world, l1, i2, k2, Block.LEAVES.id, 2); + if (Math.abs(j2) != k1 || Math.abs(l2) != k1 || random.nextInt(2) != 0 && j1 != 0) { + int i3 = world.getTypeId(l1, i2, k2); + + if (i3 == 0 || i3 == Block.LEAVES.id) { + this.setTypeAndData(world, l1, i2, k2, Block.LEAVES.id, 2); + } } } } diff --git a/src/main/java/net/minecraft/server/WorldGenGroundBush.java b/src/main/java/net/minecraft/server/WorldGenGroundBush.java index b0a5a7ef2a..b598d28ecc 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.q[world.getTypeId(i2, j1, k2)]) { + if ((Math.abs(j2) != l1 || Math.abs(l2) != l1 || random.nextInt(2) != 0) && !Block.s[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 9f00271ece..249976e435 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.q[world.getTypeId(i2, k1, k2)]) { + if ((l2 != 0 || j >= j + i1 - 1) && !Block.s[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.q[l1]) { + if (!Block.s[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/WorldGenMegaTree.java b/src/main/java/net/minecraft/server/WorldGenMegaTree.java index a49bcf4fb6..957b3e47d3 100644 --- a/src/main/java/net/minecraft/server/WorldGenMegaTree.java +++ b/src/main/java/net/minecraft/server/WorldGenMegaTree.java @@ -63,10 +63,10 @@ public class WorldGenMegaTree extends WorldGenerator implements BlockSapling.Tre } else { i1 = world.getTypeId(i, j - 1, k); if ((i1 == Block.GRASS.id || i1 == Block.DIRT.id) && j < 256 - l - 1) { - world.setRawTypeId(i, j - 1, k, Block.DIRT.id); - world.setRawTypeId(i + 1, j - 1, k, Block.DIRT.id); - world.setRawTypeId(i, j - 1, k + 1, Block.DIRT.id); - world.setRawTypeId(i + 1, j - 1, k + 1, Block.DIRT.id); + world.setTypeIdAndData(i, j - 1, k, Block.DIRT.id, 0); + world.setTypeIdAndData(i + 1, j - 1, k, Block.DIRT.id, 0); + world.setTypeIdAndData(i, j - 1, k + 1, Block.DIRT.id, 0); + world.setTypeIdAndData(i + 1, j - 1, k + 1, Block.DIRT.id, 0); this.a(world, i, k, j + l, 2, random); for (int i2 = j + l - 2 - random.nextInt(4); i2 > j + l / 2; i2 -= 2 + random.nextInt(4)) { @@ -167,8 +167,12 @@ public class WorldGenMegaTree extends WorldGenerator implements BlockSapling.Tre for (int j2 = j - k1; j2 <= j + k1 + 1; ++j2) { int k2 = j2 - j; - if ((i2 >= 0 || k2 >= 0 || i2 * i2 + k2 * k2 <= k1 * k1) && (i2 <= 0 && k2 <= 0 || i2 * i2 + k2 * k2 <= (k1 + 1) * (k1 + 1)) && (random.nextInt(4) != 0 || i2 * i2 + k2 * k2 <= (k1 - 1) * (k1 - 1)) && !Block.q[world.getTypeId(l1, i1, j2)]) { - this.setTypeAndData(world, l1, i1, j2, Block.LEAVES.id, this.c); + if ((i2 >= 0 || k2 >= 0 || i2 * i2 + k2 * k2 <= k1 * k1) && (i2 <= 0 && k2 <= 0 || i2 * i2 + k2 * k2 <= (k1 + 1) * (k1 + 1)) && (random.nextInt(4) != 0 || i2 * i2 + k2 * k2 <= (k1 - 1) * (k1 - 1))) { + int l2 = world.getTypeId(l1, i1, j2); + + if (l2 == 0 || l2 == Block.LEAVES.id) { + this.setTypeAndData(world, l1, i1, j2, Block.LEAVES.id, this.c); + } } } } diff --git a/src/main/java/net/minecraft/server/WorldGenSwampTree.java b/src/main/java/net/minecraft/server/WorldGenSwampTree.java index bdf85d8b99..6f78c0abe9 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.q[world.getTypeId(l1, j2, k2)]) { + if ((Math.abs(i2) != k1 || Math.abs(l2) != k1 || random.nextInt(2) != 0 && j1 != 0) && !Block.s[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 1c5792579d..5e75f6f8da 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.q[world.getTypeId(j2, i2, i3)]) { + if ((Math.abs(k2) != l2 || Math.abs(j3) != l2 || l2 <= 0) && !Block.s[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 40ae1664c2..79f5df80cc 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.q[world.getTypeId(i3, j3, l3)]) { + if ((Math.abs(k3) != k2 || Math.abs(i4) != k2 || k2 <= 0) && !Block.s[world.getTypeId(i3, j3, l3)]) { this.setTypeAndData(world, i3, j3, l3, Block.LEAVES.id, 1); } } diff --git a/src/main/java/net/minecraft/server/WorldGenTrees.java b/src/main/java/net/minecraft/server/WorldGenTrees.java index d0d49bff9f..4d8b04f233 100644 --- a/src/main/java/net/minecraft/server/WorldGenTrees.java +++ b/src/main/java/net/minecraft/server/WorldGenTrees.java @@ -86,8 +86,12 @@ public class WorldGenTrees extends WorldGenerator implements BlockSapling.TreeGe for (int l2 = k - i2; l2 <= k + i2; ++l2) { int i3 = l2 - k; - if ((Math.abs(k2) != i2 || Math.abs(i3) != i2 || random.nextInt(2) != 0 && k1 != 0) && world.isEmpty(j2, j1, l2)) { - this.setTypeAndData(world, j2, j1, l2, Block.LEAVES.id, this.d); + if (Math.abs(k2) != i2 || Math.abs(i3) != i2 || random.nextInt(2) != 0 && k1 != 0) { + int j3 = world.getTypeId(j2, j1, l2); + + if (j3 == 0 || j3 == Block.LEAVES.id) { + this.setTypeAndData(world, j2, j1, l2, Block.LEAVES.id, this.d); + } } } } diff --git a/src/main/java/net/minecraft/server/WorldGenerator.java b/src/main/java/net/minecraft/server/WorldGenerator.java index 506a1c6ac2..320a1944e0 100644 --- a/src/main/java/net/minecraft/server/WorldGenerator.java +++ b/src/main/java/net/minecraft/server/WorldGenerator.java @@ -7,7 +7,6 @@ import org.bukkit.BlockChangeDelegate; // CraftBukkit public abstract class WorldGenerator { private final boolean a; - private int b = 1; public WorldGenerator() { this.a = false; @@ -31,7 +30,7 @@ public abstract class WorldGenerator { if (this.a) { world.setTypeIdAndData(i, j, k, l, i1); } else { - world.setRawTypeIdAndData(i, j, k, l, i1); + world.setTypeIdAndData(i, j, k, l, i1); } } } diff --git a/src/main/java/net/minecraft/server/WorldMap.java b/src/main/java/net/minecraft/server/WorldMap.java index a154401e90..fd009002f2 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.y())) { - if (!itemstack.y() && worldmaphumantracker1.trackee.dimension == this.map) { + if (!worldmaphumantracker1.trackee.dead && (worldmaphumantracker1.trackee.inventory.c(itemstack) || itemstack.z())) { + if (!itemstack.z() && 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.y()) { - this.a(1, entityhuman.world, "frame-" + itemstack.z().id, (double) itemstack.z().x, (double) itemstack.z().z, (double) (itemstack.z().direction * 90)); + 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)); } } diff --git a/src/main/java/net/minecraft/server/WorldMapHumanTracker.java b/src/main/java/net/minecraft/server/WorldMapHumanTracker.java index 8d05888b14..bf3e6feb94 100644 --- a/src/main/java/net/minecraft/server/WorldMapHumanTracker.java +++ b/src/main/java/net/minecraft/server/WorldMapHumanTracker.java @@ -60,7 +60,7 @@ public class WorldMapHumanTracker { } // CraftBukkit end - boolean flag = !itemstack.y(); + boolean flag = !itemstack.z(); 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 ddd979ccdb..e0ae71a82b 100644 --- a/src/main/java/net/minecraft/server/WorldNBTStorage.java +++ b/src/main/java/net/minecraft/server/WorldNBTStorage.java @@ -16,14 +16,13 @@ import java.util.UUID; import org.bukkit.craftbukkit.entity.CraftPlayer; // CraftBukkit end -public class WorldNBTStorage implements IDataManager, PlayerFileData { +public class WorldNBTStorage implements IDataManager, IPlayerFileData { - private static final Logger log = Logger.getLogger("Minecraft"); private final File baseDir; private final File playerDir; private final File dataDir; private final long sessionId = System.currentTimeMillis(); - private final String f; + private final String e; private UUID uuid = null; // CraftBukkit public WorldNBTStorage(File file1, String s, boolean flag) { @@ -32,7 +31,7 @@ public class WorldNBTStorage implements IDataManager, PlayerFileData { this.playerDir = new File(this.baseDir, "players"); this.dataDir = new File(this.baseDir, "data"); this.dataDir.mkdirs(); - this.f = s; + this.e = s; if (flag) { this.playerDir.mkdirs(); } @@ -174,7 +173,7 @@ public class WorldNBTStorage implements IDataManager, PlayerFileData { try { NBTTagCompound nbttagcompound = new NBTTagCompound(); - entityhuman.d(nbttagcompound); + entityhuman.e(nbttagcompound); File file1 = new File(this.playerDir, entityhuman.name + ".dat.tmp"); File file2 = new File(this.playerDir, entityhuman.name + ".dat"); @@ -185,11 +184,11 @@ public class WorldNBTStorage implements IDataManager, PlayerFileData { file1.renameTo(file2); } catch (Exception exception) { - log.warning("Failed to save player data for " + entityhuman.name); + MinecraftServer.getServer().getLogger().warning("Failed to save player data for " + entityhuman.name); } } - public void load(EntityHuman entityhuman) { + public NBTTagCompound load(EntityHuman entityhuman) { NBTTagCompound nbttagcompound = this.getPlayerData(entityhuman.name); if (nbttagcompound != null) { @@ -199,8 +198,10 @@ public class WorldNBTStorage implements IDataManager, PlayerFileData { player.setFirstPlayed(new File(playerDir, entityhuman.name + ".dat").lastModified()); } // CraftBukkit end - entityhuman.e(nbttagcompound); + entityhuman.f(nbttagcompound); } + + return nbttagcompound; } public NBTTagCompound getPlayerData(String s) { @@ -211,13 +212,13 @@ public class WorldNBTStorage implements IDataManager, PlayerFileData { return NBTCompressedStreamTools.a((InputStream) (new FileInputStream(file1))); } } catch (Exception exception) { - log.warning("Failed to load player data for " + s); + MinecraftServer.getServer().getLogger().warning("Failed to load player data for " + s); } return null; } - public PlayerFileData getPlayerFileData() { + public IPlayerFileData getPlayerFileData() { return this; } @@ -240,7 +241,7 @@ public class WorldNBTStorage implements IDataManager, PlayerFileData { } public String g() { - return this.f; + return this.e; } // CraftBukkit start diff --git a/src/main/java/net/minecraft/server/WorldServer.java b/src/main/java/net/minecraft/server/WorldServer.java index 3f73ef9776..d99b6a3b21 100644 --- a/src/main/java/net/minecraft/server/WorldServer.java +++ b/src/main/java/net/minecraft/server/WorldServer.java @@ -34,13 +34,14 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate 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 IntHashMap entitiesById; // CraftBukkit start public final int dimension; - public WorldServer(MinecraftServer minecraftserver, IDataManager idatamanager, String s, int i, WorldSettings worldsettings, MethodProfiler methodprofiler, org.bukkit.World.Environment env, org.bukkit.generator.ChunkGenerator gen) { - super(idatamanager, s, worldsettings, WorldProvider.byDimension(env.getId()), methodprofiler, gen, env); + public WorldServer(MinecraftServer minecraftserver, IDataManager idatamanager, String s, int i, WorldSettings worldsettings, MethodProfiler methodprofiler, IConsoleLogManager iconsolelogmanager, org.bukkit.World.Environment env, org.bukkit.generator.ChunkGenerator gen) { + super(idatamanager, s, worldsettings, WorldProvider.byDimension(env.getId()), methodprofiler, iconsolelogmanager, gen, env); this.dimension = i; this.pvpMode = minecraftserver.getPvP(); // CraftBukkit end @@ -60,6 +61,16 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate } this.P = new org.bukkit.craftbukkit.CraftTravelAgent(this); // CraftBukkit + this.scoreboard = new ScoreboardServer(minecraftserver); + ScoreboardSaveData scoreboardsavedata = (ScoreboardSaveData) this.worldMaps.get(ScoreboardSaveData.class, "scoreboard"); + + if (scoreboardsavedata == null) { + scoreboardsavedata = new ScoreboardSaveData(); + this.worldMaps.a("scoreboard", scoreboardsavedata); + } + + scoreboardsavedata.a(this.scoreboard); + ((ScoreboardServer) this.scoreboard).a(scoreboardsavedata); } // CraftBukkit start @@ -106,15 +117,15 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate } private TileEntity fixTileEntity(int x, int y, int z, int type, TileEntity found) { - getServer().getLogger().severe("Block at " + x + "," + y + "," + z + " is " + org.bukkit.Material.getMaterial(type).toString() + " but has " + found + ". " + this.getServer().getLogger().severe("Block at " + x + "," + y + "," + z + " is " + org.bukkit.Material.getMaterial(type).toString() + " but has " + found + ". " + "Bukkit will attempt to fix this, but there may be additional damage that we cannot recover."); if (Block.byId[type] instanceof BlockContainer) { - TileEntity replacement = ((BlockContainer) Block.byId[type]).a(this); - setTileEntity(x, y, z, replacement); + TileEntity replacement = ((BlockContainer) Block.byId[type]).b(this); + this.setTileEntity(x, y, z, replacement); return replacement; } else { - getServer().getLogger().severe("Don't know how to fix for this type... Can't do anything! :("); + this.getServer().getLogger().severe("Don't know how to fix for this type... Can't do anything! :("); return found; } } @@ -165,7 +176,6 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate this.j = j; } - this.V(); this.worldData.setTime(this.worldData.getTime() + 1L); this.worldData.setDayTime(this.worldData.getDayTime() + 1L); this.methodProfiler.c("tickPending"); @@ -180,13 +190,13 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate this.methodProfiler.c("portalForcer"); this.P.a(this.getTime()); this.methodProfiler.b(); - this.V(); + this.Y(); this.getWorld().processChunkGC(); // CraftBukkit } public BiomeMeta a(EnumCreatureType enumcreaturetype, int i, int j, int k) { - List list = this.I().getMobsFor(enumcreaturetype, i, j, k); + List list = this.J().getMobsFor(enumcreaturetype, i, j, k); return list != null && !list.isEmpty() ? (BiomeMeta) WeightedRandom.a(this.random, (Collection) list) : null; } @@ -217,10 +227,10 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate } } - this.U(); + this.X(); } - private void U() { + private void X() { // CraftBukkit start WeatherChangeEvent weather = new WeatherChangeEvent(this.getWorld(), false); this.getServer().getPluginManager().callEvent(weather); @@ -293,13 +303,13 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate int k1; int l1; - if (this.random.nextInt(100000) == 0 && this.N() && this.M()) { + if (this.random.nextInt(100000) == 0 && this.O() && this.N()) { this.k = this.k * 3 + 1013904223; i1 = this.k >> 2; j1 = k + (i1 & 15); k1 = l + (i1 >> 8 & 15); l1 = this.h(j1, k1); - if (this.D(j1, l1, k1)) { + if (this.F(j1, l1, k1)) { this.strikeLightning(new EntityLightning(this, (double) j1, (double) l1, (double) k1)); } } @@ -313,7 +323,7 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate j1 = i1 & 15; k1 = i1 >> 8 & 15; l1 = this.h(j1 + k, k1 + l); - if (this.x(j1 + k, l1 - 1, k1 + l)) { + if (this.y(j1 + k, l1 - 1, k1 + l)) { // CraftBukkit start BlockState blockState = this.getWorld().getBlockAt(j1 + k, l1 - 1, k1 + l).getState(); blockState.setTypeId(Block.ICE.id); @@ -326,7 +336,7 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate // CraftBukkit end } - if (this.N() && this.y(j1 + k, l1, k1 + l)) { + if (this.O() && 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); @@ -339,13 +349,13 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate // CraftBukkit end } - if (this.N()) { + if (this.O()) { BiomeBase biomebase = this.getBiome(j1 + k, k1 + l); if (biomebase.d()) { i2 = this.getTypeId(j1 + k, l1 - 1, k1 + l); if (i2 != 0) { - Block.byId[i2].f(this, j1 + k, l1 - 1, k1 + l); + Block.byId[i2].g(this, j1 + k, l1 - 1, k1 + l); } } } @@ -373,7 +383,7 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate if (block != null && block.isTicking()) { ++i; - block.b(this, k2 + k, i3 + chunksection.d(), l2 + l, this.random); + block.a(this, k2 + k, i3 + chunksection.d(), l2 + l, this.random); } } } @@ -383,21 +393,27 @@ 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); + } + public void a(int i, int j, int k, int l, int i1) { this.a(i, j, k, l, i1, 0); } public void a(int i, int j, int k, int l, int i1, int j1) { NextTickListEntry nextticklistentry = new NextTickListEntry(i, j, k, l); - byte b0 = 8; + byte b0 = 0; if (this.d && l > 0) { if (Block.byId[l].l()) { - if (this.d(nextticklistentry.a - b0, nextticklistentry.b - b0, nextticklistentry.c - b0, nextticklistentry.a + b0, nextticklistentry.b + b0, nextticklistentry.c + b0)) { + 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); if (k1 == nextticklistentry.d && k1 > 0) { - Block.byId[k1].b(this, nextticklistentry.a, nextticklistentry.b, nextticklistentry.c, this.random); + Block.byId[k1].a(this, nextticklistentry.a, nextticklistentry.b, nextticklistentry.c, this.random); } } @@ -407,7 +423,7 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate i1 = 1; } - if (this.d(i - b0, j - b0, k - b0, i + b0, j + b0, k + b0)) { + if (this.e(i - b0, j - b0, k - b0, i + b0, j + b0, k + b0)) { if (l > 0) { nextticklistentry.a((long) i1 + this.worldData.getTime()); nextticklistentry.a(j1); @@ -420,9 +436,10 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate } } - public void b(int i, int j, int k, int l, int i1) { + public void b(int i, int j, int k, int l, int i1, int j1) { NextTickListEntry nextticklistentry = new NextTickListEntry(i, j, k, l); + nextticklistentry.a(j1); if (l > 0) { nextticklistentry.a((long) i1 + this.worldData.getTime()); } @@ -465,23 +482,36 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate // CraftBukkit end } - for (int j = 0; j < i; ++j) { - NextTickListEntry nextticklistentry = (NextTickListEntry) this.M.first(); + this.methodProfiler.a("cleaning"); + NextTickListEntry nextticklistentry; + + for (int j = 0; j < i; ++j) { + nextticklistentry = (NextTickListEntry) this.M.first(); if (!flag && nextticklistentry.e > this.worldData.getTime()) { break; } this.M.remove(nextticklistentry); this.L.remove(nextticklistentry); - byte b0 = 8; + this.T.add(nextticklistentry); + } - if (this.d(nextticklistentry.a - b0, nextticklistentry.b - b0, nextticklistentry.c - b0, nextticklistentry.a + b0, nextticklistentry.b + b0, nextticklistentry.c + b0)) { + this.methodProfiler.b(); + this.methodProfiler.a("ticking"); + Iterator iterator = this.T.iterator(); + + while (iterator.hasNext()) { + nextticklistentry = (NextTickListEntry) iterator.next(); + iterator.remove(); + byte b0 = 0; + + if (this.e(nextticklistentry.a - b0, nextticklistentry.b - b0, nextticklistentry.c - b0, nextticklistentry.a + b0, nextticklistentry.b + b0, nextticklistentry.c + b0)) { int k = this.getTypeId(nextticklistentry.a, nextticklistentry.b, nextticklistentry.c); - if (k == nextticklistentry.d && k > 0) { + if (k > 0 && Block.b(k, nextticklistentry.d)) { try { - Block.byId[k].b(this, nextticklistentry.a, nextticklistentry.b, nextticklistentry.c, this.random); + Block.byId[k].a(this, nextticklistentry.a, nextticklistentry.b, nextticklistentry.c, this.random); } catch (Throwable throwable) { CrashReport crashreport = CrashReport.a(throwable, "Exception while ticking a block"); CrashReportSystemDetails crashreportsystemdetails = crashreport.a("Block being ticked"); @@ -498,9 +528,13 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate throw new ReportedException(crashreport); } } + } else { + this.a(nextticklistentry.a, nextticklistentry.b, nextticklistentry.c, nextticklistentry.d, 0); } } + this.methodProfiler.b(); + this.T.clear(); return !this.M.isEmpty(); } } @@ -508,26 +542,38 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate public List a(Chunk chunk, boolean flag) { ArrayList arraylist = null; ChunkCoordIntPair chunkcoordintpair = chunk.l(); - int i = chunkcoordintpair.x << 4; - int j = i + 16; - int k = chunkcoordintpair.z << 4; - int l = k + 16; - Iterator iterator = this.M.iterator(); + int i = (chunkcoordintpair.x << 4) - 2; + int j = i + 16 + 2; + int k = (chunkcoordintpair.z << 4) - 2; + int l = k + 16 + 2; - while (iterator.hasNext()) { - NextTickListEntry nextticklistentry = (NextTickListEntry) iterator.next(); + for (int i1 = 0; i1 < 2; ++i1) { + Iterator iterator; - if (nextticklistentry.a >= i && nextticklistentry.a < j && nextticklistentry.c >= k && nextticklistentry.c < l) { - if (flag) { - this.L.remove(nextticklistentry); - iterator.remove(); + if (i1 == 0) { + iterator = this.M.iterator(); + } else { + iterator = this.T.iterator(); + if (!this.T.isEmpty()) { + System.out.println(this.T.size()); } + } - if (arraylist == null) { - arraylist = new ArrayList(); + while (iterator.hasNext()) { + NextTickListEntry nextticklistentry = (NextTickListEntry) iterator.next(); + + if (nextticklistentry.a >= i && nextticklistentry.a < j && nextticklistentry.c >= k && nextticklistentry.c < l) { + if (flag) { + this.L.remove(nextticklistentry); + iterator.remove(); + } + + if (arraylist == null) { + arraylist = new ArrayList(); + } + + arraylist.add(nextticklistentry); } - - arraylist.add(nextticklistentry); } } @@ -593,15 +639,7 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate } public boolean a(EntityHuman entityhuman, int i, int j, int k) { - int l = MathHelper.a(i - this.worldData.c()); - int i1 = MathHelper.a(k - this.worldData.e()); - - if (l > i1) { - i1 = l; - } - - // CraftBukkit - Configurable spawn protection - return i1 > this.getServer().getSpawnRadius() || this.server.getPlayerList().isOp(entityhuman.name) || this.server.I(); + return !this.server.a(this, i, j, k, entityhuman); } protected void a(WorldSettings worldsettings) { @@ -655,7 +693,7 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate i = chunkposition.x; k = chunkposition.z; } else { - System.out.println("Unable to find spawn biome"); + this.getLogger().warning("Unable to find spawn biome"); } int l = 0; @@ -711,7 +749,7 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate } protected void a() throws ExceptionWorldConflict { // CraftBukkit - added throws - this.D(); + this.E(); this.dataManager.saveWorldData(this.worldData, this.server.getPlayerList().q()); this.worldMaps.a(); } @@ -719,7 +757,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.ao(); + Entity[] aentity = entity.an(); if (aentity != null) { for (int i = 0; i < aentity.length; ++i) { @@ -731,7 +769,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.ao(); + Entity[] aentity = entity.an(); if (aentity != null) { for (int i = 0; i < aentity.length; ++i) { @@ -818,7 +856,7 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate } - private void V() { + private void Y() { while (!this.Q[this.R].isEmpty()) { int i = this.R; @@ -841,12 +879,7 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate private boolean a(NoteBlockData noteblockdata) { int i = this.getTypeId(noteblockdata.a(), noteblockdata.b(), noteblockdata.c()); - if (i == noteblockdata.f()) { - Block.byId[i].b(this, noteblockdata.a(), noteblockdata.b(), noteblockdata.c(), noteblockdata.d(), noteblockdata.e()); - return true; - } else { - return false; - } + return i == noteblockdata.f() ? Block.byId[i].b(this, noteblockdata.a(), noteblockdata.b(), noteblockdata.c(), noteblockdata.d(), noteblockdata.e()) : false; } public void saveLevel() { @@ -854,10 +887,10 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate } protected void n() { - boolean flag = this.N(); + boolean flag = this.O(); super.n(); - if (flag != this.N()) { + if (flag != this.O()) { // CraftBukkit start - only sending weather packets to those affected for (int i = 0; i < this.players.size(); ++i) { if (((EntityPlayer) this.players.get(i)).world == this) { @@ -883,4 +916,22 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate public PortalTravelAgent s() { return this.P; } + + // CraftBukkit start - Compatibility methods for BlockChangeDelegate + public boolean setRawTypeId(int x, int y, int z, int typeId) { + return this.setTypeIdAndData(x, y, z, typeId, 0, 4); + } + + public boolean setRawTypeIdAndData(int x, int y, int z, int typeId, int data) { + return this.setTypeIdAndData(x, y, z, typeId, data, 4); + } + + public boolean setTypeId(int x, int y, int z, int typeId) { + return this.setTypeIdAndData(x, y, z, typeId, 0, 3); + } + + public boolean setTypeIdAndData(int x, int y, int z, int typeId, int data) { + return this.setTypeIdAndData(x, y, z, typeId, data, 3); + } + // CraftBukkit end } diff --git a/src/main/java/org/bukkit/craftbukkit/CraftServer.java b/src/main/java/org/bukkit/craftbukkit/CraftServer.java index e7c0760fd4..377502265e 100644 --- a/src/main/java/org/bukkit/craftbukkit/CraftServer.java +++ b/src/main/java/org/bukkit/craftbukkit/CraftServer.java @@ -522,7 +522,7 @@ public final class CraftServer implements Server { public void reload() { configuration = YamlConfiguration.loadConfiguration(getConfigFile()); - PropertyManager config = new PropertyManager(console.options); + PropertyManager config = new PropertyManager(console.options, console.getLogger()); ((DedicatedServer) console).propertyManager = config; @@ -707,7 +707,7 @@ public final class CraftServer implements Server { } while(used); boolean hardcore = false; - WorldServer internal = new WorldServer(console, new ServerNBTManager(getWorldContainer(), name, true), name, dimension, new WorldSettings(creator.seed(), EnumGamemode.a(getDefaultGameMode().getValue()), generateStructures, hardcore, type), console.methodProfiler, creator.environment(), generator); + WorldServer internal = new WorldServer(console, new ServerNBTManager(getWorldContainer(), name, true), name, dimension, new WorldSettings(creator.seed(), EnumGamemode.a(getDefaultGameMode().getValue()), generateStructures, hardcore, type), console.methodProfiler, console.getLogger(), creator.environment(), generator); if (!(worlds.containsKey(name.toLowerCase()))) { return null; @@ -830,7 +830,7 @@ public final class CraftServer implements Server { } public Logger getLogger() { - return MinecraftServer.log; + return console.getLogger().getLogger(); } public ConsoleReader getReader() { diff --git a/src/main/java/org/bukkit/craftbukkit/CraftWorld.java b/src/main/java/org/bukkit/craftbukkit/CraftWorld.java index 6e364b1a82..9218f074fe 100644 --- a/src/main/java/org/bukkit/craftbukkit/CraftWorld.java +++ b/src/main/java/org/bukkit/craftbukkit/CraftWorld.java @@ -861,11 +861,17 @@ public class CraftWorld implements World { } } else if (Minecart.class.isAssignableFrom(clazz)) { if (PoweredMinecart.class.isAssignableFrom(clazz)) { - entity = new EntityMinecart(world, x, y, z, CraftMinecart.Type.PoweredMinecart.getId()); + entity = new EntityMinecartFurnace(world, x, y, z); } else if (StorageMinecart.class.isAssignableFrom(clazz)) { - entity = new EntityMinecart(world, x, y, z, CraftMinecart.Type.StorageMinecart.getId()); + entity = new EntityMinecartChest(world, x, y, z); + } else if (MinecartTNT.class.isAssignableFrom(clazz)) { + entity = new EntityMinecartTNT(world, x, y, z); + } else if (MinecartHopper.class.isAssignableFrom(clazz)) { + entity = new EntityMinecartHopper(world, x, y, z); + } else if (MinecartMobSpawner.class.isAssignableFrom(clazz)) { + entity = new EntityMinecartMobSpawner(world, x, y, z); } else { - entity = new EntityMinecart(world, x, y, z, CraftMinecart.Type.Minecart.getId()); + entity = new EntityMinecartRideable(world, x, y, z); } } else if (EnderSignal.class.isAssignableFrom(clazz)) { entity = new EntityEnderSignal(world, x, y, z); @@ -989,7 +995,7 @@ public class CraftWorld implements World { entity = null; } } else if (TNTPrimed.class.isAssignableFrom(clazz)) { - entity = new EntityTNTPrimed(world, x, y, z); + entity = new EntityTNTPrimed(world, x, y, z, null); } else if (ExperienceOrb.class.isAssignableFrom(clazz)) { entity = new EntityExperienceOrb(world, x, y, z, 0); } else if (Weather.class.isAssignableFrom(clazz)) { @@ -1102,7 +1108,7 @@ public class CraftWorld implements World { block.setType(org.bukkit.Material.AIR); // not sure what this does, seems to have something to do with the 'base' material of a block. // For example, WOODEN_STAIRS does something with WOOD in this method - net.minecraft.server.Block.byId[blockId].wasExploded(this.world, blockX, blockY, blockZ); + net.minecraft.server.Block.byId[blockId].wasExploded(this.world, blockX, blockY, blockZ, null); } public void sendPluginMessage(Plugin source, String channel, byte[] message) { diff --git a/src/main/java/org/bukkit/craftbukkit/block/CraftBlock.java b/src/main/java/org/bukkit/craftbukkit/block/CraftBlock.java index 91677bbefb..1e4953dc63 100644 --- a/src/main/java/org/bukkit/craftbukkit/block/CraftBlock.java +++ b/src/main/java/org/bukkit/craftbukkit/block/CraftBlock.java @@ -7,6 +7,7 @@ import java.util.List; import net.minecraft.server.BiomeBase; import net.minecraft.server.BlockRedstoneWire; +import net.minecraft.server.Direction; import net.minecraft.server.EnumSkyBlock; import net.minecraft.server.NBTTagCompound; import net.minecraft.server.TileEntitySkull; @@ -84,14 +85,14 @@ public class CraftBlock implements Block { } public void setData(final byte data) { - chunk.getHandle().world.setData(x, y, z, data); + chunk.getHandle().world.setData(x, y, z, data, 3); } public void setData(final byte data, boolean applyPhysics) { if (applyPhysics) { - chunk.getHandle().world.setData(x, y, z, data); + chunk.getHandle().world.setData(x, y, z, data, 3); } else { - chunk.getHandle().world.setRawData(x, y, z, data); + chunk.getHandle().world.setData(x, y, z, data, 4); } } @@ -104,22 +105,22 @@ public class CraftBlock implements Block { } public boolean setTypeId(final int type) { - return chunk.getHandle().world.setTypeId(x, y, z, type); + return chunk.getHandle().world.setTypeIdAndData(x, y, z, type, getData(), 3); } public boolean setTypeId(final int type, final boolean applyPhysics) { if (applyPhysics) { return setTypeId(type); } else { - return chunk.getHandle().world.setRawTypeId(x, y, z, type); + return chunk.getHandle().world.setTypeIdAndData(x, y, z, type, getData(), 4); } } public boolean setTypeIdAndData(final int type, final byte data, final boolean applyPhysics) { if (applyPhysics) { - return chunk.getHandle().world.setTypeIdAndData(x, y, z, type, data); + return chunk.getHandle().world.setTypeIdAndData(x, y, z, type, data, 3); } else { - boolean success = chunk.getHandle().world.setRawTypeIdAndData(x, y, z, type, data); + boolean success = chunk.getHandle().world.setTypeIdAndData(x, y, z, type, data, 4); if (success) { chunk.getHandle().world.notify(x, y, z); } @@ -294,7 +295,7 @@ public class CraftBlock implements Block { } public boolean isBlockPowered() { - return chunk.getHandle().world.isBlockPowered(x, y, z); + return chunk.getHandle().world.getBlockPower(x, y, z) > 0; } public boolean isBlockIndirectlyPowered() { @@ -320,7 +321,14 @@ public class CraftBlock implements Block { } public boolean isBlockFaceIndirectlyPowered(BlockFace face) { - return chunk.getHandle().world.isBlockFaceIndirectlyPowered(x, y, z, blockFaceToNotch(face)); + int power = chunk.getHandle().world.getBlockFacePower(x, y, z, blockFaceToNotch(face)); + + Block relative = getRelative(face); + if (relative.getType() == Material.REDSTONE_WIRE) { + return Math.max(power, relative.getData()) > 0; + } + + return power > 0; } public int getBlockPower(BlockFace face) { diff --git a/src/main/java/org/bukkit/craftbukkit/block/CraftCreatureSpawner.java b/src/main/java/org/bukkit/craftbukkit/block/CraftCreatureSpawner.java index fd2e6ba2d4..554eee9cfb 100644 --- a/src/main/java/org/bukkit/craftbukkit/block/CraftCreatureSpawner.java +++ b/src/main/java/org/bukkit/craftbukkit/block/CraftCreatureSpawner.java @@ -21,16 +21,16 @@ public class CraftCreatureSpawner extends CraftBlockState implements CreatureSpa @Deprecated public CreatureType getCreatureType() { - return CreatureType.fromName(spawner.mobName); + return CreatureType.fromName(spawner.a().getMobName()); } public EntityType getSpawnedType() { - return EntityType.fromName(spawner.mobName); + return EntityType.fromName(spawner.a().getMobName()); } @Deprecated public void setCreatureType(CreatureType creatureType) { - spawner.mobName = creatureType.getName(); + spawner.a().a(creatureType.getName()); } public void setSpawnedType(EntityType entityType) { @@ -38,12 +38,12 @@ public class CraftCreatureSpawner extends CraftBlockState implements CreatureSpa throw new IllegalArgumentException("Can't spawn EntityType " + entityType + " from mobspawners!"); } - spawner.mobName = entityType.getName(); + spawner.a().a(entityType.getName()); } @Deprecated public String getCreatureTypeId() { - return spawner.mobName; + return spawner.a().getMobName(); } @Deprecated @@ -52,7 +52,7 @@ public class CraftCreatureSpawner extends CraftBlockState implements CreatureSpa } public String getCreatureTypeName() { - return spawner.mobName; + return spawner.a().getMobName(); } public void setCreatureTypeByName(String creatureType) { @@ -65,11 +65,11 @@ public class CraftCreatureSpawner extends CraftBlockState implements CreatureSpa } public int getDelay() { - return spawner.spawnDelay; + return spawner.a().spawnDelay; } public void setDelay(int delay) { - spawner.spawnDelay = delay; + spawner.a().spawnDelay = delay; } } diff --git a/src/main/java/org/bukkit/craftbukkit/block/CraftJukebox.java b/src/main/java/org/bukkit/craftbukkit/block/CraftJukebox.java index c6ac158906..16960292ce 100644 --- a/src/main/java/org/bukkit/craftbukkit/block/CraftJukebox.java +++ b/src/main/java/org/bukkit/craftbukkit/block/CraftJukebox.java @@ -23,7 +23,7 @@ public class CraftJukebox extends CraftBlockState implements Jukebox { } public Material getPlaying() { - ItemStack record = jukebox.record; + ItemStack record = jukebox.getRecord(); if (record == null) { return Material.AIR; } @@ -33,15 +33,15 @@ public class CraftJukebox extends CraftBlockState implements Jukebox { public void setPlaying(Material record) { if (record == null || Item.byId[record.getId()] == null) { record = Material.AIR; - jukebox.record = null; + jukebox.setRecord(null); } else { - jukebox.record = new ItemStack(Item.byId[record.getId()], 1); + jukebox.setRecord(new ItemStack(Item.byId[record.getId()], 1)); } jukebox.update(); if (record == Material.AIR) { - world.getHandle().setData(getX(), getY(), getZ(), 0); + world.getHandle().setData(getX(), getY(), getZ(), 0, 3); } else { - world.getHandle().setData(getX(), getY(), getZ(), 1); + world.getHandle().setData(getX(), getY(), getZ(), 1, 3); } world.playEffect(getLocation(), Effect.RECORD_PLAY, record.getId()); } diff --git a/src/main/java/org/bukkit/craftbukkit/command/CraftBlockCommandSender.java b/src/main/java/org/bukkit/craftbukkit/command/CraftBlockCommandSender.java index 89be6326f0..9c3848d8a5 100644 --- a/src/main/java/org/bukkit/craftbukkit/command/CraftBlockCommandSender.java +++ b/src/main/java/org/bukkit/craftbukkit/command/CraftBlockCommandSender.java @@ -16,7 +16,7 @@ public class CraftBlockCommandSender extends ServerCommandSender implements Bloc } public Block getBlock() { - return commandBlock.world.getWorld().getBlockAt(commandBlock.x, commandBlock.y, commandBlock.z); + return commandBlock.getWorld().getWorld().getBlockAt(commandBlock.x, commandBlock.y, commandBlock.z); } public void sendMessage(String message) { diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftEntity.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftEntity.java index 99a8891b84..f88092e155 100644 --- a/src/main/java/org/bukkit/craftbukkit/entity/CraftEntity.java +++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftEntity.java @@ -136,13 +136,14 @@ public abstract class CraftEntity implements org.bukkit.entity.Entity { if (entity instanceof EntityLightning) { return new CraftLightningStrike(server, (EntityLightning) entity); } else { return new CraftWeather(server, (EntityWeather) entity); } } - else if (entity instanceof EntityMinecart) { - EntityMinecart mc = (EntityMinecart) entity; - if (mc.type == CraftMinecart.Type.StorageMinecart.getId()) { return new CraftStorageMinecart(server, mc); } - else if (mc.type == CraftMinecart.Type.PoweredMinecart.getId()) { return new CraftPoweredMinecart(server, mc); } - else { return new CraftMinecart(server, mc); } - } - else if (entity instanceof EntityHanging) { + else if (entity instanceof EntityMinecartAbstract) { + if (entity instanceof EntityMinecartFurnace) { return new CraftPoweredMinecart(server, (EntityMinecartFurnace) entity); } + else if (entity instanceof EntityMinecartChest) { return new CraftStorageMinecart(server, (EntityMinecartChest) entity); } + else if (entity instanceof EntityMinecartTNT) { return new CraftMinecartTNT(server, (EntityMinecartTNT) entity); } + else if (entity instanceof EntityMinecartHopper) { return new CraftMinecartHopper(server, (EntityMinecartHopper) entity); } + else if (entity instanceof EntityMinecartMobSpawner) { return new CraftMinecartMobSpawner(server, (EntityMinecartMobSpawner) entity); } + else { return new CraftMinecart(server, (EntityMinecartRideable) entity); } + } else if (entity instanceof EntityHanging) { if (entity instanceof EntityPainting) { return new CraftPainting(server, (EntityPainting) entity); } else if (entity instanceof EntityItemFrame) { return new CraftItemFrame(server, (EntityItemFrame) entity); } else { return new CraftHanging(server, (EntityHanging) entity); } @@ -302,7 +303,7 @@ public abstract class CraftEntity implements org.bukkit.entity.Entity { } public UUID getUniqueId() { - return getHandle().uniqueId; + return getHandle().uniqueID; } public int getTicksLived() { diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftHumanEntity.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftHumanEntity.java index 9068a454c9..e79e5384a6 100644 --- a/src/main/java/org/bukkit/craftbukkit/entity/CraftHumanEntity.java +++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftHumanEntity.java @@ -238,7 +238,7 @@ public class CraftHumanEntity extends CraftLivingEntity implements HumanEntity { String title = container.getBukkitView().getTitle(); int size = container.getBukkitView().getTopInventory().getSize(); - player.playerConnection.sendPacket(new Packet100OpenWindow(container.windowId, windowType, title, size)); + player.playerConnection.sendPacket(new Packet100OpenWindow(container.windowId, windowType, title, size, true)); getHandle().activeContainer = container; getHandle().activeContainer.addSlotListener(player); } @@ -270,7 +270,7 @@ public class CraftHumanEntity extends CraftLivingEntity implements HumanEntity { if (location == null) { location = getLocation(); } - getHandle().startEnchanting(location.getBlockX(), location.getBlockY(), location.getBlockZ()); + getHandle().startEnchanting(location.getBlockX(), location.getBlockY(), location.getBlockZ(), null); if (force) { getHandle().activeContainer.checkReachable = false; } @@ -303,7 +303,7 @@ public class CraftHumanEntity extends CraftLivingEntity implements HumanEntity { int windowType = CraftContainer.getNotchInventoryType(type); String title = inventory.getTitle(); int size = inventory.getTopInventory().getSize(); - player.playerConnection.sendPacket(new Packet100OpenWindow(container.windowId, windowType, title, size)); + player.playerConnection.sendPacket(new Packet100OpenWindow(container.windowId, windowType, title, size, false)); player.activeContainer = container; player.activeContainer.addSlotListener(player); } @@ -313,7 +313,7 @@ public class CraftHumanEntity extends CraftLivingEntity implements HumanEntity { } public boolean isBlocking() { - return getHandle().bh(); + return getHandle().bk(); // Should be isBlocking } public boolean setWindowProperty(InventoryView.Property prop, int value) { diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftItemFrame.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftItemFrame.java index ef95acd676..f69480cf1f 100644 --- a/src/main/java/org/bukkit/craftbukkit/entity/CraftItemFrame.java +++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftItemFrame.java @@ -50,7 +50,7 @@ public class CraftItemFrame extends CraftHanging implements ItemFrame { public void setRotation(Rotation rotation) { Validate.notNull(rotation, "Rotation cannot be null"); - getHandle().g(toInteger(rotation)); + getHandle().b(toInteger(rotation)); // Should be setRotation } static int toInteger(Rotation rotation) { diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftLivingEntity.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftLivingEntity.java index 23a89b0f7c..1678db1c3b 100644 --- a/src/main/java/org/bukkit/craftbukkit/entity/CraftLivingEntity.java +++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftLivingEntity.java @@ -325,7 +325,7 @@ public class CraftLivingEntity extends CraftEntity implements LivingEntity { } public boolean hasLineOfSight(Entity other) { - return getHandle().aA().canSee(((CraftEntity) other).getHandle()); // az should be getEntitySenses + return getHandle().aD().canSee(((CraftEntity) other).getHandle()); // az should be getEntitySenses } public boolean getRemoveWhenFarAway() { @@ -356,4 +356,30 @@ public class CraftLivingEntity extends CraftEntity implements LivingEntity { return super.teleport(location, cause); } + + public void setCustomName(String name) { + if (name == null) { + name = ""; + } + + getHandle().setCustomName(name); + } + + public String getCustomName() { + String name = getHandle().getCustomName(); + + if (name == null || name.length() == 0) { + return null; + } + + return name; + } + + public void setCustomNameVisible(boolean flag) { + getHandle().setCustomNameVisible(flag); + } + + public boolean getCustomNameVisible() { + return getHandle().getCustomNameVisible(); + } } diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftMinecart.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftMinecart.java index 807bd2cf2b..73e807e1f0 100644 --- a/src/main/java/org/bukkit/craftbukkit/entity/CraftMinecart.java +++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftMinecart.java @@ -1,33 +1,13 @@ package org.bukkit.craftbukkit.entity; -import net.minecraft.server.EntityMinecart; +import net.minecraft.server.EntityMinecartAbstract; import org.bukkit.craftbukkit.CraftServer; import org.bukkit.entity.EntityType; import org.bukkit.entity.Minecart; import org.bukkit.util.Vector; public class CraftMinecart extends CraftVehicle implements Minecart { - /** - * Stores the minecart type id, which is used by Minecraft to differentiate - * minecart types. Here we use subclasses. - */ - public enum Type { - Minecart(0), - StorageMinecart(1), - PoweredMinecart(2); - - private final int id; - - private Type(int id) { - this.id = id; - } - - public int getId() { - return id; - } - } - - public CraftMinecart(CraftServer server, EntityMinecart entity) { + public CraftMinecart(CraftServer server, EntityMinecartAbstract entity) { super(server, entity); } @@ -74,8 +54,8 @@ public class CraftMinecart extends CraftVehicle implements Minecart { } @Override - public EntityMinecart getHandle() { - return (EntityMinecart) entity; + public EntityMinecartAbstract getHandle() { + return (EntityMinecartAbstract) entity; } @Override diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftMinecartHopper.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftMinecartHopper.java new file mode 100644 index 0000000000..67fcbb47b5 --- /dev/null +++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftMinecartHopper.java @@ -0,0 +1,16 @@ +package org.bukkit.craftbukkit.entity; + +import net.minecraft.server.EntityMinecartHopper; +import org.bukkit.craftbukkit.CraftServer; +import org.bukkit.entity.EntityType; +import org.bukkit.entity.MinecartHopper; + +final class CraftMinecartHopper extends CraftMinecart implements MinecartHopper { + CraftMinecartHopper(CraftServer server, EntityMinecartHopper entity) { + super(server, entity); + } + + public EntityType getType() { + return EntityType.MINECART_HOPPER; + } +} diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftMinecartMobSpawner.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftMinecartMobSpawner.java new file mode 100644 index 0000000000..83be050b25 --- /dev/null +++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftMinecartMobSpawner.java @@ -0,0 +1,16 @@ +package org.bukkit.craftbukkit.entity; + +import net.minecraft.server.EntityMinecartMobSpawner; +import org.bukkit.craftbukkit.CraftServer; +import org.bukkit.entity.EntityType; +import org.bukkit.entity.MinecartMobSpawner; + +final class CraftMinecartMobSpawner extends CraftMinecart implements MinecartMobSpawner { + CraftMinecartMobSpawner(CraftServer server, EntityMinecartMobSpawner entity) { + super(server, entity); + } + + public EntityType getType() { + return EntityType.MINECART_MOB_SPAWNER; + } +} diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftMinecartTNT.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftMinecartTNT.java new file mode 100644 index 0000000000..861b01fe11 --- /dev/null +++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftMinecartTNT.java @@ -0,0 +1,11 @@ +package org.bukkit.craftbukkit.entity; + +import net.minecraft.server.EntityMinecartTNT; +import org.bukkit.craftbukkit.CraftServer; +import org.bukkit.entity.MinecartTNT; + +final class CraftMinecartTNT extends CraftMinecart implements MinecartTNT { + CraftMinecartTNT(CraftServer server, EntityMinecartTNT entity) { + super(server, entity); + } +} diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftPoweredMinecart.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftPoweredMinecart.java index b261a0f137..a07829e2ee 100644 --- a/src/main/java/org/bukkit/craftbukkit/entity/CraftPoweredMinecart.java +++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftPoweredMinecart.java @@ -1,12 +1,13 @@ package org.bukkit.craftbukkit.entity; import org.bukkit.craftbukkit.entity.CraftMinecart; -import net.minecraft.server.EntityMinecart; +import net.minecraft.server.EntityMinecartFurnace; import org.bukkit.craftbukkit.CraftServer; +import org.bukkit.entity.EntityType; import org.bukkit.entity.PoweredMinecart; public class CraftPoweredMinecart extends CraftMinecart implements PoweredMinecart { - public CraftPoweredMinecart(CraftServer server, EntityMinecart entity) { + public CraftPoweredMinecart(CraftServer server, EntityMinecartFurnace entity) { super(server, entity); } @@ -14,4 +15,8 @@ public class CraftPoweredMinecart extends CraftMinecart implements PoweredMineca public String toString() { return "CraftPoweredMinecart"; } + + public EntityType getType() { + return EntityType.MINECART_FURNACE; + } } diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftStorageMinecart.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftStorageMinecart.java index e7338a6c5d..ef86e41353 100644 --- a/src/main/java/org/bukkit/craftbukkit/entity/CraftStorageMinecart.java +++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftStorageMinecart.java @@ -1,16 +1,17 @@ package org.bukkit.craftbukkit.entity; -import net.minecraft.server.EntityMinecart; +import net.minecraft.server.EntityMinecartChest; -import org.bukkit.inventory.Inventory; -import org.bukkit.craftbukkit.inventory.CraftInventory; import org.bukkit.craftbukkit.CraftServer; +import org.bukkit.craftbukkit.inventory.CraftInventory; +import org.bukkit.entity.EntityType; import org.bukkit.entity.StorageMinecart; +import org.bukkit.inventory.Inventory; public class CraftStorageMinecart extends CraftMinecart implements StorageMinecart { private final CraftInventory inventory; - public CraftStorageMinecart(CraftServer server, EntityMinecart entity) { + public CraftStorageMinecart(CraftServer server, EntityMinecartChest entity) { super(server, entity); inventory = new CraftInventory(entity); } @@ -23,4 +24,8 @@ public class CraftStorageMinecart extends CraftMinecart implements StorageMineca public String toString() { return "CraftStorageMinecart{" + "inventory=" + inventory + '}'; } + + public EntityType getType() { + return EntityType.MINECART_CHEST; + } } diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftContainer.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftContainer.java index 1f136deefb..0b38125ca0 100644 --- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftContainer.java +++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftContainer.java @@ -85,7 +85,7 @@ public class CraftContainer extends Container { setupSlots(top, bottom); } int size = getSize(); - player.getHandle().playerConnection.sendPacket(new Packet100OpenWindow(this.windowId, type, cachedTitle, size)); + player.getHandle().playerConnection.sendPacket(new Packet100OpenWindow(this.windowId, type, cachedTitle, size, true)); player.updateInventory(); } return true; diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftInventoryCustom.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftInventoryCustom.java index 6fb6cb8b89..efb289693e 100644 --- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftInventoryCustom.java +++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftInventoryCustom.java @@ -108,7 +108,7 @@ public class CraftInventoryCustom extends CraftInventory { public void update() {} - public boolean a_(EntityHuman entityhuman) { + public boolean a(EntityHuman entityhuman) { return true; } @@ -132,8 +132,6 @@ public class CraftInventoryCustom extends CraftInventory { return type; } - public void f() {} - public void g() {} public InventoryHolder getOwner() { @@ -141,5 +139,13 @@ public class CraftInventoryCustom extends CraftInventory { } public void startOpen() {} + + public boolean c() { + return false; + } + + public boolean b(int i, ItemStack itemstack) { + return true; + } } } diff --git a/src/test/java/org/bukkit/DyeColorsTest.java b/src/test/java/org/bukkit/DyeColorsTest.java index 2ce79456cd..8e252c0d49 100644 --- a/src/test/java/org/bukkit/DyeColorsTest.java +++ b/src/test/java/org/bukkit/DyeColorsTest.java @@ -41,7 +41,7 @@ public class DyeColorsTest extends AbstractTestingBase { @Test public void checkFireworkColor() { Color color = dye.getFireworkColor(); - int nmsColor = ItemDye.b[dye.getDyeData()]; + int nmsColor = ItemDye.c[dye.getDyeData()]; assertThat(color, is(Color.fromRGB(nmsColor))); } } diff --git a/src/test/java/org/bukkit/PerMaterialTest.java b/src/test/java/org/bukkit/PerMaterialTest.java index da2b46c14a..f55920bf68 100644 --- a/src/test/java/org/bukkit/PerMaterialTest.java +++ b/src/test/java/org/bukkit/PerMaterialTest.java @@ -122,7 +122,7 @@ public class PerMaterialTest extends AbstractTestingBase { @Test public void isOccluding() { if (material.isBlock()) { - assertThat(material.isOccluding(), is(Block.i(material.getId()))); + assertThat(material.isOccluding(), is(Block.l(material.getId()))); } else { assertFalse(material.isOccluding()); }