Fixed magma slimes from being nonspawnable

Dieser Commit ist enthalten in:
Nathan Adams 2011-11-28 05:08:28 +00:00
Ursprung 4b87704c5a
Commit 99771b7b72
2 geänderte Dateien mit 10 neuen und 2 gelöschten Zeilen

Datei anzeigen

@ -734,7 +734,11 @@ public class CraftWorld implements World {
} else if (Skeleton.class.isAssignableFrom(clazz)) {
entity = new EntitySkeleton(world);
} else if (Slime.class.isAssignableFrom(clazz)) {
entity = new EntitySlime(world);
if (MagmaCube.class.isAssignableFrom(clazz)) {
entity = new EntityLavaSlime(world);
} else {
entity = new EntitySlime(world);
}
} else if (Spider.class.isAssignableFrom(clazz)) {
if (CaveSpider.class.isAssignableFrom(clazz)) {
entity = new EntityCaveSpider(world);

Datei anzeigen

@ -15,6 +15,7 @@ import java.util.List;
import java.util.Map;
import java.util.UUID;
import org.bukkit.Bukkit;
import org.bukkit.entity.MagmaCube;
public abstract class CraftEntity implements org.bukkit.entity.Entity {
private static final Map<String, CraftPlayer> players = new MapMaker().softValues().makeMap();
@ -79,7 +80,10 @@ public abstract class CraftEntity implements org.bukkit.entity.Entity {
else { return new CraftCreature(server, (EntityCreature) entity); }
}
// Slimes are a special (and broken) case
else if (entity instanceof EntitySlime) { return new CraftSlime(server, (EntitySlime) entity); }
else if (entity instanceof EntitySlime) {
if (entity instanceof MagmaCube) { return new CraftMagmaCube(server, (EntityLavaSlime) entity); }
else { return new CraftSlime(server, (EntitySlime) entity); }
}
// Flying
else if (entity instanceof EntityFlying) {
if (entity instanceof EntityGhast) { return new CraftGhast(server, (EntityGhast) entity); }