2012-10-25 05:53:23 +02:00
|
|
|
package net.minecraft.server;
|
|
|
|
|
|
|
|
import java.util.Random;
|
|
|
|
|
|
|
|
// CraftBukkit start
|
|
|
|
import org.bukkit.craftbukkit.util.BlockStateListPopulator;
|
|
|
|
import org.bukkit.event.entity.CreatureSpawnEvent.SpawnReason;
|
|
|
|
// CraftBukkit end
|
|
|
|
|
|
|
|
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);
|
|
|
|
}
|
|
|
|
|
|
|
|
public int d() {
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
public boolean c() {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
public boolean b() {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void updateShape(IBlockAccess iblockaccess, int i, int j, int k) {
|
|
|
|
int l = iblockaccess.getData(i, j, k) & 7;
|
|
|
|
|
|
|
|
switch (l) {
|
|
|
|
case 1:
|
|
|
|
default:
|
|
|
|
this.a(0.25F, 0.0F, 0.25F, 0.75F, 0.5F, 0.75F);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 2:
|
|
|
|
this.a(0.25F, 0.25F, 0.5F, 0.75F, 0.75F, 1.0F);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 3:
|
|
|
|
this.a(0.25F, 0.25F, 0.0F, 0.75F, 0.75F, 0.5F);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 4:
|
|
|
|
this.a(0.5F, 0.25F, 0.25F, 1.0F, 0.75F, 0.75F);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 5:
|
|
|
|
this.a(0.0F, 0.25F, 0.25F, 0.5F, 0.75F, 0.75F);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public AxisAlignedBB e(World world, int i, int j, int k) {
|
|
|
|
this.updateShape(world, i, j, k);
|
|
|
|
return super.e(world, i, j, k);
|
|
|
|
}
|
|
|
|
|
|
|
|
public void postPlace(World world, int i, int j, int k, EntityLiving entityliving) {
|
|
|
|
int l = MathHelper.floor((double) (entityliving.yaw * 4.0F / 360.0F) + 2.5D) & 3;
|
|
|
|
|
|
|
|
world.setData(i, j, k, l);
|
|
|
|
}
|
|
|
|
|
|
|
|
public TileEntity a(World world) {
|
|
|
|
return new TileEntitySkull();
|
|
|
|
}
|
|
|
|
|
|
|
|
public int getDropData(World world, int i, int j, int k) {
|
|
|
|
TileEntity tileentity = world.getTileEntity(i, j, k);
|
|
|
|
|
2012-11-06 13:05:28 +01:00
|
|
|
return tileentity != null && tileentity instanceof TileEntitySkull ? ((TileEntitySkull) tileentity).getSkullType() : super.getDropData(world, i, j, k);
|
2012-10-25 05:53:23 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public int getDropData(int i) {
|
|
|
|
return i;
|
|
|
|
}
|
|
|
|
|
2012-11-15 02:52:40 +01:00
|
|
|
// CraftBukkit start - special case dropping so we can get info from the tile entity
|
|
|
|
public void dropNaturally(World world, int i, int j, int k, int l, float f, int i1) {
|
|
|
|
if (world.random.nextFloat() < f) {
|
|
|
|
ItemStack itemstack = new ItemStack(Item.SKULL.id, 1, this.getDropData(world, i, j, k));
|
|
|
|
TileEntitySkull tileentityskull = (TileEntitySkull) world.getTileEntity(i, j, k);
|
|
|
|
|
|
|
|
if (tileentityskull.getSkullType() == 3 && tileentityskull.getExtraType() != null && tileentityskull.getExtraType().length() > 0) {
|
|
|
|
itemstack.setTag(new NBTTagCompound());
|
|
|
|
itemstack.getTag().setString("SkullOwner", tileentityskull.getExtraType());
|
|
|
|
}
|
|
|
|
|
|
|
|
this.b(world, i, j, k, itemstack);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// CraftBukkit end
|
2012-10-25 05:53:23 +02:00
|
|
|
|
|
|
|
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);
|
|
|
|
}
|
|
|
|
|
|
|
|
super.a(world, i, j, k, l, entityhuman);
|
|
|
|
}
|
|
|
|
|
|
|
|
public void remove(World world, int i, int j, int k, int l, int i1) {
|
|
|
|
if (!world.isStatic) {
|
2012-11-15 02:52:40 +01:00
|
|
|
/* CraftBukkit start - drop item in code above, not here
|
2012-10-25 05:53:23 +02:00
|
|
|
if ((i1 & 8) == 0) {
|
2012-11-06 13:05:28 +01:00
|
|
|
ItemStack itemstack = new ItemStack(Item.SKULL.id, 1, this.getDropData(world, i, j, k));
|
|
|
|
TileEntitySkull tileentityskull = (TileEntitySkull) world.getTileEntity(i, j, k);
|
|
|
|
|
|
|
|
if (tileentityskull.getSkullType() == 3 && tileentityskull.getExtraType() != null && tileentityskull.getExtraType().length() > 0) {
|
|
|
|
itemstack.setTag(new NBTTagCompound());
|
|
|
|
itemstack.getTag().setString("SkullOwner", tileentityskull.getExtraType());
|
|
|
|
}
|
|
|
|
|
|
|
|
this.b(world, i, j, k, itemstack);
|
2012-10-25 05:53:23 +02:00
|
|
|
}
|
2012-10-29 04:04:45 +01:00
|
|
|
// CraftBukkit end */
|
2012-10-25 05:53:23 +02:00
|
|
|
|
|
|
|
super.remove(world, i, j, k, l, i1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public int getDropType(int i, Random random, int j) {
|
|
|
|
return Item.SKULL.id;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void a(World world, int i, int j, int k, TileEntitySkull tileentityskull) {
|
2012-11-06 13:05:28 +01:00
|
|
|
if (tileentityskull.getSkullType() == 1 && j >= 2 && world.difficulty > 0) {
|
2012-10-25 05:53:23 +02:00
|
|
|
int l = Block.SOUL_SAND.id;
|
|
|
|
|
|
|
|
int i1;
|
|
|
|
EntityWither entitywither;
|
|
|
|
int j1;
|
|
|
|
|
|
|
|
for (i1 = -2; i1 <= 0; ++i1) {
|
|
|
|
if (world.getTypeId(i, j - 1, k + i1) == l && world.getTypeId(i, j - 1, k + i1 + 1) == l && world.getTypeId(i, j - 2, k + i1 + 1) == l && world.getTypeId(i, j - 1, k + i1 + 2) == l && this.d(world, i, j, k + i1, 1) && this.d(world, i, j, k + i1 + 1, 1) && this.d(world, i, j, k + i1 + 2, 1)) {
|
|
|
|
// 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);
|
|
|
|
|
|
|
|
blockList.setTypeId(i, j, k + i1, 0);
|
|
|
|
blockList.setTypeId(i, j, k + i1 + 1, 0);
|
|
|
|
blockList.setTypeId(i, j, k + i1 + 2, 0);
|
|
|
|
blockList.setTypeId(i, j - 1, k + i1, 0);
|
|
|
|
blockList.setTypeId(i, j - 1, k + i1 + 1, 0);
|
|
|
|
blockList.setTypeId(i, j - 1, k + i1 + 2, 0);
|
|
|
|
blockList.setTypeId(i, j - 2, k + i1 + 1, 0);
|
|
|
|
|
|
|
|
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.aw = 90.0F;
|
|
|
|
entitywither.m();
|
|
|
|
|
|
|
|
if (world.addEntity(entitywither, SpawnReason.BUILD_WITHER)) {
|
|
|
|
blockList.updateList();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
for (j1 = 0; j1 < 120; ++j1) {
|
|
|
|
world.addParticle("snowballpoof", (double) i + world.random.nextDouble(), (double) (j - 2) + world.random.nextDouble() * 3.9D, (double) (k + i1 + 1) + world.random.nextDouble(), 0.0D, 0.0D, 0.0D);
|
|
|
|
}
|
|
|
|
// CraftBukkit end
|
|
|
|
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i1 = -2; i1 <= 0; ++i1) {
|
|
|
|
if (world.getTypeId(i + i1, j - 1, k) == l && world.getTypeId(i + i1 + 1, j - 1, k) == l && world.getTypeId(i + i1 + 1, j - 2, k) == l && world.getTypeId(i + i1 + 2, j - 1, k) == l && this.d(world, i + i1, j, k, 1) && this.d(world, i + i1 + 1, j, k, 1) && this.d(world, i + i1 + 2, j, k, 1)) {
|
|
|
|
// 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);
|
|
|
|
|
|
|
|
blockList.setTypeId(i + i1, j, k, 0);
|
|
|
|
blockList.setTypeId(i + i1 + 1, j, k, 0);
|
|
|
|
blockList.setTypeId(i + i1 + 2, j, k, 0);
|
|
|
|
blockList.setTypeId(i + i1, j - 1, k, 0);
|
|
|
|
blockList.setTypeId(i + i1 + 1, j - 1, k, 0);
|
|
|
|
blockList.setTypeId(i + i1 + 2, j - 1, k, 0);
|
|
|
|
blockList.setTypeId(i + i1 + 1, j - 2, k, 0);
|
|
|
|
|
|
|
|
if (!world.isStatic) {
|
|
|
|
entitywither = new EntityWither(world);
|
|
|
|
entitywither.setPositionRotation((double) (i + i1) + 1.5D, (double) j - 1.45D, (double) k + 0.5D, 0.0F, 0.0F);
|
|
|
|
entitywither.m();
|
|
|
|
|
|
|
|
if (world.addEntity(entitywither, SpawnReason.BUILD_WITHER)) {
|
|
|
|
blockList.updateList();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
for (j1 = 0; j1 < 120; ++j1) {
|
|
|
|
world.addParticle("snowballpoof", (double) (i + i1 + 1) + world.random.nextDouble(), (double) (j - 2) + world.random.nextDouble() * 3.9D, (double) k + world.random.nextDouble(), 0.0D, 0.0D, 0.0D);
|
|
|
|
}
|
|
|
|
// CraftBukkit end
|
|
|
|
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private boolean d(World world, int i, int j, int k, int l) {
|
|
|
|
if (world.getTypeId(i, j, k) != this.id) {
|
|
|
|
return false;
|
|
|
|
} else {
|
|
|
|
TileEntity tileentity = world.getTileEntity(i, j, k);
|
|
|
|
|
2012-11-06 13:05:28 +01:00
|
|
|
return tileentity != null && tileentity instanceof TileEntitySkull ? ((TileEntitySkull) tileentity).getSkullType() == l : false;
|
2012-10-25 05:53:23 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|