mirror of
https://github.com/CitizensDev/Citizens2.git
synced 2025-01-19 22:51:48 +01:00
Bugfixes
This commit is contained in:
parent
ab3e917f37
commit
8cae31cc88
@ -2,6 +2,9 @@ package net.citizensnpcs;
|
|||||||
|
|
||||||
import net.citizensnpcs.Settings.Setting;
|
import net.citizensnpcs.Settings.Setting;
|
||||||
import net.citizensnpcs.api.CitizensAPI;
|
import net.citizensnpcs.api.CitizensAPI;
|
||||||
|
import net.citizensnpcs.api.event.NPCCombustByBlockEvent;
|
||||||
|
import net.citizensnpcs.api.event.NPCCombustByEntityEvent;
|
||||||
|
import net.citizensnpcs.api.event.NPCCombustEvent;
|
||||||
import net.citizensnpcs.api.event.NPCDamageByBlockEvent;
|
import net.citizensnpcs.api.event.NPCDamageByBlockEvent;
|
||||||
import net.citizensnpcs.api.event.NPCDamageByEntityEvent;
|
import net.citizensnpcs.api.event.NPCDamageByEntityEvent;
|
||||||
import net.citizensnpcs.api.event.NPCDamageEvent;
|
import net.citizensnpcs.api.event.NPCDamageEvent;
|
||||||
@ -24,6 +27,9 @@ import org.bukkit.craftbukkit.entity.CraftPlayer;
|
|||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
import org.bukkit.event.EventHandler;
|
import org.bukkit.event.EventHandler;
|
||||||
import org.bukkit.event.Listener;
|
import org.bukkit.event.Listener;
|
||||||
|
import org.bukkit.event.entity.EntityCombustByBlockEvent;
|
||||||
|
import org.bukkit.event.entity.EntityCombustByEntityEvent;
|
||||||
|
import org.bukkit.event.entity.EntityCombustEvent;
|
||||||
import org.bukkit.event.entity.EntityDamageByBlockEvent;
|
import org.bukkit.event.entity.EntityDamageByBlockEvent;
|
||||||
import org.bukkit.event.entity.EntityDamageByEntityEvent;
|
import org.bukkit.event.entity.EntityDamageByEntityEvent;
|
||||||
import org.bukkit.event.entity.EntityDamageEvent;
|
import org.bukkit.event.entity.EntityDamageEvent;
|
||||||
@ -79,6 +85,22 @@ public class EventListen implements Listener {
|
|||||||
/*
|
/*
|
||||||
* Entity events
|
* Entity events
|
||||||
*/
|
*/
|
||||||
|
@EventHandler
|
||||||
|
public void onEntityCombust(EntityCombustEvent event) {
|
||||||
|
NPC npc = npcRegistry.getNPC(event.getEntity());
|
||||||
|
if (npc == null)
|
||||||
|
return;
|
||||||
|
if (event instanceof EntityCombustByEntityEvent) {
|
||||||
|
Bukkit.getPluginManager().callEvent(
|
||||||
|
new NPCCombustByEntityEvent((EntityCombustByEntityEvent) event, npc));
|
||||||
|
} else if (event instanceof EntityCombustByBlockEvent) {
|
||||||
|
Bukkit.getPluginManager().callEvent(
|
||||||
|
new NPCCombustByBlockEvent((EntityCombustByBlockEvent) event, npc));
|
||||||
|
} else {
|
||||||
|
Bukkit.getPluginManager().callEvent(new NPCCombustEvent(event, npc));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@EventHandler
|
@EventHandler
|
||||||
public void onEntityDamage(EntityDamageEvent event) {
|
public void onEntityDamage(EntityDamageEvent event) {
|
||||||
if (!npcRegistry.isNPC(event.getEntity()))
|
if (!npcRegistry.isNPC(event.getEntity()))
|
||||||
|
@ -4,7 +4,7 @@ import java.lang.reflect.Constructor;
|
|||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
import net.citizensnpcs.api.npc.NPC;
|
import net.citizensnpcs.api.npc.NPC;
|
||||||
import net.citizensnpcs.util.NMSReflection;
|
import net.citizensnpcs.util.NMS;
|
||||||
import net.minecraft.server.Block;
|
import net.minecraft.server.Block;
|
||||||
import net.minecraft.server.EntityLiving;
|
import net.minecraft.server.EntityLiving;
|
||||||
import net.minecraft.server.World;
|
import net.minecraft.server.World;
|
||||||
@ -21,7 +21,7 @@ public abstract class CitizensMobNPC extends CitizensNPC {
|
|||||||
super(id, name);
|
super(id, name);
|
||||||
this.constructor = getConstructor(clazz);
|
this.constructor = getConstructor(clazz);
|
||||||
|
|
||||||
NMSReflection.registerEntityClass(clazz);
|
NMS.registerEntityClass(clazz);
|
||||||
}
|
}
|
||||||
|
|
||||||
private EntityLiving createEntityFromClass(World world) {
|
private EntityLiving createEntityFromClass(World world) {
|
||||||
|
@ -12,7 +12,7 @@ import net.citizensnpcs.api.ai.event.NavigationCompleteEvent;
|
|||||||
import net.citizensnpcs.api.ai.event.NavigationReplaceEvent;
|
import net.citizensnpcs.api.ai.event.NavigationReplaceEvent;
|
||||||
import net.citizensnpcs.api.util.DataKey;
|
import net.citizensnpcs.api.util.DataKey;
|
||||||
import net.citizensnpcs.npc.CitizensNPC;
|
import net.citizensnpcs.npc.CitizensNPC;
|
||||||
import net.citizensnpcs.util.NMSReflection;
|
import net.citizensnpcs.util.NMS;
|
||||||
|
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.Location;
|
import org.bukkit.Location;
|
||||||
@ -48,21 +48,11 @@ public class CitizensNavigator implements Navigator {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public NavigatorParameters getLocalParameters() {
|
public NavigatorParameters getLocalParameters() {
|
||||||
|
if (localParams == defaultParams)
|
||||||
|
throw new IllegalStateException("not navigating");
|
||||||
return localParams;
|
return localParams;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public float getPathfindingRange() {
|
|
||||||
return defaultParams.range();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public float getSpeed() {
|
|
||||||
if (defaultParams.speed() == UNINITIALISED_SPEED)
|
|
||||||
throw new IllegalStateException("NPC has not been spawned");
|
|
||||||
return defaultParams.speed();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Location getTargetAsLocation() {
|
public Location getTargetAsLocation() {
|
||||||
return isNavigating() ? executing.getTargetAsLocation() : null;
|
return isNavigating() ? executing.getTargetAsLocation() : null;
|
||||||
@ -86,7 +76,7 @@ public class CitizensNavigator implements Navigator {
|
|||||||
|
|
||||||
public void onSpawn() {
|
public void onSpawn() {
|
||||||
if (defaultParams.speed() == UNINITIALISED_SPEED)
|
if (defaultParams.speed() == UNINITIALISED_SPEED)
|
||||||
defaultParams.speed(NMSReflection.getSpeedFor(npc.getHandle()));
|
defaultParams.speed(NMS.getSpeedFor(npc.getHandle()));
|
||||||
updatePathfindingRange();
|
updatePathfindingRange();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -95,20 +85,6 @@ public class CitizensNavigator implements Navigator {
|
|||||||
root.setDouble("pathfinding-range", defaultParams.range());
|
root.setDouble("pathfinding-range", defaultParams.range());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public void setPathfindingRange(float newRange) {
|
|
||||||
defaultParams.range(newRange);
|
|
||||||
if (isNavigating())
|
|
||||||
localParams.range(newRange);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void setSpeed(float speed) {
|
|
||||||
defaultParams.speed(speed);
|
|
||||||
if (isNavigating())
|
|
||||||
localParams.speed(speed);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void setTarget(LivingEntity target, boolean aggressive) {
|
public void setTarget(LivingEntity target, boolean aggressive) {
|
||||||
if (!npc.isSpawned())
|
if (!npc.isSpawned())
|
||||||
@ -156,7 +132,7 @@ public class CitizensNavigator implements Navigator {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void updatePathfindingRange() {
|
private void updatePathfindingRange() {
|
||||||
NMSReflection.updatePathfindingRange(npc, localParams.range());
|
NMS.updatePathfindingRange(npc, localParams.range());
|
||||||
}
|
}
|
||||||
|
|
||||||
private static int UNINITIALISED_SPEED = Integer.MIN_VALUE;
|
private static int UNINITIALISED_SPEED = Integer.MIN_VALUE;
|
||||||
|
@ -5,7 +5,7 @@ import net.citizensnpcs.api.npc.NPC;
|
|||||||
import net.citizensnpcs.npc.CitizensMobNPC;
|
import net.citizensnpcs.npc.CitizensMobNPC;
|
||||||
import net.citizensnpcs.npc.CitizensNPC;
|
import net.citizensnpcs.npc.CitizensNPC;
|
||||||
import net.citizensnpcs.npc.ai.NPCHolder;
|
import net.citizensnpcs.npc.ai.NPCHolder;
|
||||||
import net.citizensnpcs.util.NMSReflection;
|
import net.citizensnpcs.util.NMS;
|
||||||
import net.citizensnpcs.util.Util;
|
import net.citizensnpcs.util.Util;
|
||||||
import net.minecraft.server.EntityBlaze;
|
import net.minecraft.server.EntityBlaze;
|
||||||
import net.minecraft.server.World;
|
import net.minecraft.server.World;
|
||||||
@ -35,10 +35,17 @@ public class CitizensBlazeNPC extends CitizensMobNPC {
|
|||||||
super(world);
|
super(world);
|
||||||
this.npc = (CitizensNPC) npc;
|
this.npc = (CitizensNPC) npc;
|
||||||
if (npc != null) {
|
if (npc != null) {
|
||||||
NMSReflection.clearGoals(goalSelector, targetSelector);
|
NMS.clearGoals(goalSelector, targetSelector);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void bb() {
|
||||||
|
if (npc == null)
|
||||||
|
super.bb();
|
||||||
|
// check despawn method, we only want to despawn on chunk unload.
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void be() {
|
public void be() {
|
||||||
if (npc != null)
|
if (npc != null)
|
||||||
|
@ -5,7 +5,7 @@ import net.citizensnpcs.api.npc.NPC;
|
|||||||
import net.citizensnpcs.npc.CitizensMobNPC;
|
import net.citizensnpcs.npc.CitizensMobNPC;
|
||||||
import net.citizensnpcs.npc.CitizensNPC;
|
import net.citizensnpcs.npc.CitizensNPC;
|
||||||
import net.citizensnpcs.npc.ai.NPCHolder;
|
import net.citizensnpcs.npc.ai.NPCHolder;
|
||||||
import net.citizensnpcs.util.NMSReflection;
|
import net.citizensnpcs.util.NMS;
|
||||||
import net.citizensnpcs.util.Util;
|
import net.citizensnpcs.util.Util;
|
||||||
import net.minecraft.server.EntityCaveSpider;
|
import net.minecraft.server.EntityCaveSpider;
|
||||||
import net.minecraft.server.World;
|
import net.minecraft.server.World;
|
||||||
@ -14,7 +14,6 @@ import org.bukkit.entity.CaveSpider;
|
|||||||
import org.bukkit.util.Vector;
|
import org.bukkit.util.Vector;
|
||||||
|
|
||||||
public class CitizensCaveSpiderNPC extends CitizensMobNPC {
|
public class CitizensCaveSpiderNPC extends CitizensMobNPC {
|
||||||
|
|
||||||
public CitizensCaveSpiderNPC(int id, String name) {
|
public CitizensCaveSpiderNPC(int id, String name) {
|
||||||
super(id, name, EntityCaveSpiderNPC.class);
|
super(id, name, EntityCaveSpiderNPC.class);
|
||||||
}
|
}
|
||||||
@ -27,14 +26,25 @@ public class CitizensCaveSpiderNPC extends CitizensMobNPC {
|
|||||||
public static class EntityCaveSpiderNPC extends EntityCaveSpider implements NPCHolder {
|
public static class EntityCaveSpiderNPC extends EntityCaveSpider implements NPCHolder {
|
||||||
private final CitizensNPC npc;
|
private final CitizensNPC npc;
|
||||||
|
|
||||||
|
public EntityCaveSpiderNPC(World world) {
|
||||||
|
this(world, null);
|
||||||
|
}
|
||||||
|
|
||||||
public EntityCaveSpiderNPC(World world, NPC npc) {
|
public EntityCaveSpiderNPC(World world, NPC npc) {
|
||||||
super(world);
|
super(world);
|
||||||
this.npc = (CitizensNPC) npc;
|
this.npc = (CitizensNPC) npc;
|
||||||
if (npc != null) {
|
if (npc != null) {
|
||||||
NMSReflection.clearGoals(goalSelector, targetSelector);
|
NMS.clearGoals(goalSelector, targetSelector);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void bb() {
|
||||||
|
if (npc == null)
|
||||||
|
super.bb();
|
||||||
|
// check despawn method, we only want to despawn on chunk unload.
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void bc() {
|
public void bc() {
|
||||||
super.bc();
|
super.bc();
|
||||||
@ -45,9 +55,11 @@ public class CitizensCaveSpiderNPC extends CitizensMobNPC {
|
|||||||
public void be() {
|
public void be() {
|
||||||
if (npc == null)
|
if (npc == null)
|
||||||
super.be();
|
super.be();
|
||||||
else
|
else {
|
||||||
|
NMS.updateAI(this);
|
||||||
npc.update();
|
npc.update();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void collide(net.minecraft.server.Entity entity) {
|
public void collide(net.minecraft.server.Entity entity) {
|
||||||
|
@ -5,7 +5,7 @@ import net.citizensnpcs.api.npc.NPC;
|
|||||||
import net.citizensnpcs.npc.CitizensMobNPC;
|
import net.citizensnpcs.npc.CitizensMobNPC;
|
||||||
import net.citizensnpcs.npc.CitizensNPC;
|
import net.citizensnpcs.npc.CitizensNPC;
|
||||||
import net.citizensnpcs.npc.ai.NPCHolder;
|
import net.citizensnpcs.npc.ai.NPCHolder;
|
||||||
import net.citizensnpcs.util.NMSReflection;
|
import net.citizensnpcs.util.NMS;
|
||||||
import net.citizensnpcs.util.Util;
|
import net.citizensnpcs.util.Util;
|
||||||
import net.minecraft.server.EntityChicken;
|
import net.minecraft.server.EntityChicken;
|
||||||
import net.minecraft.server.World;
|
import net.minecraft.server.World;
|
||||||
@ -35,7 +35,7 @@ public class CitizensChickenNPC extends CitizensMobNPC {
|
|||||||
super(world);
|
super(world);
|
||||||
this.npc = (CitizensNPC) npc;
|
this.npc = (CitizensNPC) npc;
|
||||||
if (npc != null) {
|
if (npc != null) {
|
||||||
NMSReflection.clearGoals(goalSelector, targetSelector);
|
NMS.clearGoals(goalSelector, targetSelector);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -5,7 +5,7 @@ import net.citizensnpcs.api.npc.NPC;
|
|||||||
import net.citizensnpcs.npc.CitizensMobNPC;
|
import net.citizensnpcs.npc.CitizensMobNPC;
|
||||||
import net.citizensnpcs.npc.CitizensNPC;
|
import net.citizensnpcs.npc.CitizensNPC;
|
||||||
import net.citizensnpcs.npc.ai.NPCHolder;
|
import net.citizensnpcs.npc.ai.NPCHolder;
|
||||||
import net.citizensnpcs.util.NMSReflection;
|
import net.citizensnpcs.util.NMS;
|
||||||
import net.citizensnpcs.util.Util;
|
import net.citizensnpcs.util.Util;
|
||||||
import net.minecraft.server.EntityCow;
|
import net.minecraft.server.EntityCow;
|
||||||
import net.minecraft.server.World;
|
import net.minecraft.server.World;
|
||||||
@ -35,7 +35,7 @@ public class CitizensCowNPC extends CitizensMobNPC {
|
|||||||
super(world);
|
super(world);
|
||||||
this.npc = (CitizensNPC) npc;
|
this.npc = (CitizensNPC) npc;
|
||||||
if (npc != null) {
|
if (npc != null) {
|
||||||
NMSReflection.clearGoals(goalSelector, targetSelector);
|
NMS.clearGoals(goalSelector, targetSelector);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -5,7 +5,7 @@ import net.citizensnpcs.api.npc.NPC;
|
|||||||
import net.citizensnpcs.npc.CitizensMobNPC;
|
import net.citizensnpcs.npc.CitizensMobNPC;
|
||||||
import net.citizensnpcs.npc.CitizensNPC;
|
import net.citizensnpcs.npc.CitizensNPC;
|
||||||
import net.citizensnpcs.npc.ai.NPCHolder;
|
import net.citizensnpcs.npc.ai.NPCHolder;
|
||||||
import net.citizensnpcs.util.NMSReflection;
|
import net.citizensnpcs.util.NMS;
|
||||||
import net.citizensnpcs.util.Util;
|
import net.citizensnpcs.util.Util;
|
||||||
import net.minecraft.server.EntityCreeper;
|
import net.minecraft.server.EntityCreeper;
|
||||||
import net.minecraft.server.EntityLightning;
|
import net.minecraft.server.EntityLightning;
|
||||||
@ -36,7 +36,7 @@ public class CitizensCreeperNPC extends CitizensMobNPC {
|
|||||||
super(world);
|
super(world);
|
||||||
this.npc = (CitizensNPC) npc;
|
this.npc = (CitizensNPC) npc;
|
||||||
if (npc != null) {
|
if (npc != null) {
|
||||||
NMSReflection.clearGoals(goalSelector, targetSelector);
|
NMS.clearGoals(goalSelector, targetSelector);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -46,6 +46,13 @@ public class CitizensCreeperNPC extends CitizensMobNPC {
|
|||||||
super.a(entitylightning);
|
super.a(entitylightning);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void bb() {
|
||||||
|
if (npc == null)
|
||||||
|
super.bb();
|
||||||
|
// check despawn method, we only want to despawn on chunk unload.
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void bc() {
|
public void bc() {
|
||||||
super.bc();
|
super.bc();
|
||||||
|
@ -5,7 +5,7 @@ import net.citizensnpcs.api.npc.NPC;
|
|||||||
import net.citizensnpcs.npc.CitizensMobNPC;
|
import net.citizensnpcs.npc.CitizensMobNPC;
|
||||||
import net.citizensnpcs.npc.CitizensNPC;
|
import net.citizensnpcs.npc.CitizensNPC;
|
||||||
import net.citizensnpcs.npc.ai.NPCHolder;
|
import net.citizensnpcs.npc.ai.NPCHolder;
|
||||||
import net.citizensnpcs.util.NMSReflection;
|
import net.citizensnpcs.util.NMS;
|
||||||
import net.citizensnpcs.util.Util;
|
import net.citizensnpcs.util.Util;
|
||||||
import net.minecraft.server.EntityEnderDragon;
|
import net.minecraft.server.EntityEnderDragon;
|
||||||
import net.minecraft.server.World;
|
import net.minecraft.server.World;
|
||||||
@ -31,10 +31,17 @@ public class CitizensEnderDragonNPC extends CitizensMobNPC {
|
|||||||
super(world);
|
super(world);
|
||||||
this.npc = (CitizensNPC) npc;
|
this.npc = (CitizensNPC) npc;
|
||||||
if (npc != null) {
|
if (npc != null) {
|
||||||
NMSReflection.clearGoals(goalSelector, targetSelector);
|
NMS.clearGoals(goalSelector, targetSelector);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void bb() {
|
||||||
|
if (npc == null)
|
||||||
|
super.bb();
|
||||||
|
// check despawn method, we only want to despawn on chunk unload.
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void be() {
|
public void be() {
|
||||||
if (npc == null)
|
if (npc == null)
|
||||||
@ -80,6 +87,5 @@ public class CitizensEnderDragonNPC extends CitizensMobNPC {
|
|||||||
public NPC getNPC() {
|
public NPC getNPC() {
|
||||||
return npc;
|
return npc;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -8,7 +8,7 @@ import net.citizensnpcs.npc.CitizensMobNPC;
|
|||||||
import net.citizensnpcs.npc.CitizensNPC;
|
import net.citizensnpcs.npc.CitizensNPC;
|
||||||
import net.citizensnpcs.npc.ai.NPCHolder;
|
import net.citizensnpcs.npc.ai.NPCHolder;
|
||||||
import net.citizensnpcs.util.Messaging;
|
import net.citizensnpcs.util.Messaging;
|
||||||
import net.citizensnpcs.util.NMSReflection;
|
import net.citizensnpcs.util.NMS;
|
||||||
import net.citizensnpcs.util.Util;
|
import net.citizensnpcs.util.Util;
|
||||||
import net.minecraft.server.EntityEnderman;
|
import net.minecraft.server.EntityEnderman;
|
||||||
import net.minecraft.server.World;
|
import net.minecraft.server.World;
|
||||||
@ -47,9 +47,9 @@ public class CitizensEndermanNPC extends CitizensMobNPC implements Equipable {
|
|||||||
|
|
||||||
ItemStack set = hand;
|
ItemStack set = hand;
|
||||||
if (set.getType() != Material.AIR) {
|
if (set.getType() != Material.AIR) {
|
||||||
if (hand.getAmount() > 1)
|
if (hand.getAmount() > 1) {
|
||||||
hand.setAmount(hand.getAmount() - 1);
|
hand.setAmount(hand.getAmount() - 1);
|
||||||
else
|
} else
|
||||||
hand = null;
|
hand = null;
|
||||||
equipper.setItemInHand(hand);
|
equipper.setItemInHand(hand);
|
||||||
set.setAmount(1);
|
set.setAmount(1);
|
||||||
@ -73,15 +73,21 @@ public class CitizensEndermanNPC extends CitizensMobNPC implements Equipable {
|
|||||||
super(world);
|
super(world);
|
||||||
this.npc = (CitizensNPC) npc;
|
this.npc = (CitizensNPC) npc;
|
||||||
if (npc != null) {
|
if (npc != null) {
|
||||||
NMSReflection.clearGoals(goalSelector, targetSelector);
|
NMS.clearGoals(goalSelector, targetSelector);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void bc() {
|
public void bb() {
|
||||||
if (npc == null)
|
if (npc == null)
|
||||||
|
super.bb();
|
||||||
|
// check despawn method, we only want to despawn on chunk unload.
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void bc() {
|
||||||
super.bc();
|
super.bc();
|
||||||
else
|
if (npc != null)
|
||||||
npc.update();
|
npc.update();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -89,9 +95,11 @@ public class CitizensEndermanNPC extends CitizensMobNPC implements Equipable {
|
|||||||
public void be() {
|
public void be() {
|
||||||
if (npc == null)
|
if (npc == null)
|
||||||
super.be();
|
super.be();
|
||||||
else
|
else {
|
||||||
|
NMS.updateAI(this);
|
||||||
npc.update();
|
npc.update();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void collide(net.minecraft.server.Entity entity) {
|
public void collide(net.minecraft.server.Entity entity) {
|
||||||
@ -105,6 +113,10 @@ public class CitizensEndermanNPC extends CitizensMobNPC implements Equipable {
|
|||||||
public void d() {
|
public void d() {
|
||||||
if (npc == null)
|
if (npc == null)
|
||||||
super.d();
|
super.d();
|
||||||
|
else {
|
||||||
|
NMS.updateAI(this);
|
||||||
|
npc.update();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -5,7 +5,7 @@ import net.citizensnpcs.api.npc.NPC;
|
|||||||
import net.citizensnpcs.npc.CitizensMobNPC;
|
import net.citizensnpcs.npc.CitizensMobNPC;
|
||||||
import net.citizensnpcs.npc.CitizensNPC;
|
import net.citizensnpcs.npc.CitizensNPC;
|
||||||
import net.citizensnpcs.npc.ai.NPCHolder;
|
import net.citizensnpcs.npc.ai.NPCHolder;
|
||||||
import net.citizensnpcs.util.NMSReflection;
|
import net.citizensnpcs.util.NMS;
|
||||||
import net.citizensnpcs.util.Util;
|
import net.citizensnpcs.util.Util;
|
||||||
import net.minecraft.server.EntityGhast;
|
import net.minecraft.server.EntityGhast;
|
||||||
import net.minecraft.server.World;
|
import net.minecraft.server.World;
|
||||||
@ -35,10 +35,17 @@ public class CitizensGhastNPC extends CitizensMobNPC {
|
|||||||
super(world);
|
super(world);
|
||||||
this.npc = (CitizensNPC) npc;
|
this.npc = (CitizensNPC) npc;
|
||||||
if (npc != null) {
|
if (npc != null) {
|
||||||
NMSReflection.clearGoals(goalSelector, targetSelector);
|
NMS.clearGoals(goalSelector, targetSelector);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void bb() {
|
||||||
|
if (npc == null)
|
||||||
|
super.bb();
|
||||||
|
// check despawn method, we only want to despawn on chunk unload.
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void be() {
|
public void be() {
|
||||||
if (npc != null)
|
if (npc != null)
|
||||||
|
@ -5,7 +5,7 @@ import net.citizensnpcs.api.npc.NPC;
|
|||||||
import net.citizensnpcs.npc.CitizensMobNPC;
|
import net.citizensnpcs.npc.CitizensMobNPC;
|
||||||
import net.citizensnpcs.npc.CitizensNPC;
|
import net.citizensnpcs.npc.CitizensNPC;
|
||||||
import net.citizensnpcs.npc.ai.NPCHolder;
|
import net.citizensnpcs.npc.ai.NPCHolder;
|
||||||
import net.citizensnpcs.util.NMSReflection;
|
import net.citizensnpcs.util.NMS;
|
||||||
import net.citizensnpcs.util.Util;
|
import net.citizensnpcs.util.Util;
|
||||||
import net.minecraft.server.EntityGiantZombie;
|
import net.minecraft.server.EntityGiantZombie;
|
||||||
import net.minecraft.server.World;
|
import net.minecraft.server.World;
|
||||||
@ -31,10 +31,17 @@ public class CitizensGiantNPC extends CitizensMobNPC {
|
|||||||
super(world);
|
super(world);
|
||||||
this.npc = (CitizensNPC) npc;
|
this.npc = (CitizensNPC) npc;
|
||||||
if (npc != null) {
|
if (npc != null) {
|
||||||
NMSReflection.clearGoals(goalSelector, targetSelector);
|
NMS.clearGoals(goalSelector, targetSelector);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void bb() {
|
||||||
|
if (npc == null)
|
||||||
|
super.bb();
|
||||||
|
// check despawn method, we only want to despawn on chunk unload.
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void be() {
|
public void be() {
|
||||||
if (npc == null)
|
if (npc == null)
|
||||||
|
@ -5,7 +5,7 @@ import net.citizensnpcs.api.npc.NPC;
|
|||||||
import net.citizensnpcs.npc.CitizensMobNPC;
|
import net.citizensnpcs.npc.CitizensMobNPC;
|
||||||
import net.citizensnpcs.npc.CitizensNPC;
|
import net.citizensnpcs.npc.CitizensNPC;
|
||||||
import net.citizensnpcs.npc.ai.NPCHolder;
|
import net.citizensnpcs.npc.ai.NPCHolder;
|
||||||
import net.citizensnpcs.util.NMSReflection;
|
import net.citizensnpcs.util.NMS;
|
||||||
import net.citizensnpcs.util.Util;
|
import net.citizensnpcs.util.Util;
|
||||||
import net.minecraft.server.EntityIronGolem;
|
import net.minecraft.server.EntityIronGolem;
|
||||||
import net.minecraft.server.World;
|
import net.minecraft.server.World;
|
||||||
@ -31,10 +31,17 @@ public class CitizensIronGolemNPC extends CitizensMobNPC {
|
|||||||
super(world);
|
super(world);
|
||||||
this.npc = (CitizensNPC) npc;
|
this.npc = (CitizensNPC) npc;
|
||||||
if (npc != null) {
|
if (npc != null) {
|
||||||
NMSReflection.clearGoals(goalSelector, targetSelector);
|
NMS.clearGoals(goalSelector, targetSelector);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void bb() {
|
||||||
|
if (npc == null)
|
||||||
|
super.bb();
|
||||||
|
// check despawn method, we only want to despawn on chunk unload.
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void bc() {
|
public void bc() {
|
||||||
super.bc();
|
super.bc();
|
||||||
|
@ -5,7 +5,7 @@ import net.citizensnpcs.api.npc.NPC;
|
|||||||
import net.citizensnpcs.npc.CitizensMobNPC;
|
import net.citizensnpcs.npc.CitizensMobNPC;
|
||||||
import net.citizensnpcs.npc.CitizensNPC;
|
import net.citizensnpcs.npc.CitizensNPC;
|
||||||
import net.citizensnpcs.npc.ai.NPCHolder;
|
import net.citizensnpcs.npc.ai.NPCHolder;
|
||||||
import net.citizensnpcs.util.NMSReflection;
|
import net.citizensnpcs.util.NMS;
|
||||||
import net.citizensnpcs.util.Util;
|
import net.citizensnpcs.util.Util;
|
||||||
import net.minecraft.server.EntityMagmaCube;
|
import net.minecraft.server.EntityMagmaCube;
|
||||||
import net.minecraft.server.World;
|
import net.minecraft.server.World;
|
||||||
@ -36,10 +36,17 @@ public class CitizensMagmaCubeNPC extends CitizensMobNPC {
|
|||||||
this.npc = (CitizensNPC) npc;
|
this.npc = (CitizensNPC) npc;
|
||||||
if (npc != null) {
|
if (npc != null) {
|
||||||
setSize(3);
|
setSize(3);
|
||||||
NMSReflection.clearGoals(goalSelector, targetSelector);
|
NMS.clearGoals(goalSelector, targetSelector);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void bb() {
|
||||||
|
if (npc == null)
|
||||||
|
super.bb();
|
||||||
|
// check despawn method, we only want to despawn on chunk unload.
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void bc() {
|
public void bc() {
|
||||||
super.bc();
|
super.bc();
|
||||||
@ -49,10 +56,12 @@ public class CitizensMagmaCubeNPC extends CitizensMobNPC {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void be() {
|
public void be() {
|
||||||
if (npc != null)
|
if (npc == null)
|
||||||
npc.update();
|
|
||||||
else
|
|
||||||
super.be();
|
super.be();
|
||||||
|
else {
|
||||||
|
NMS.updateAI(this);
|
||||||
|
npc.update();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -5,7 +5,7 @@ import net.citizensnpcs.api.npc.NPC;
|
|||||||
import net.citizensnpcs.npc.CitizensMobNPC;
|
import net.citizensnpcs.npc.CitizensMobNPC;
|
||||||
import net.citizensnpcs.npc.CitizensNPC;
|
import net.citizensnpcs.npc.CitizensNPC;
|
||||||
import net.citizensnpcs.npc.ai.NPCHolder;
|
import net.citizensnpcs.npc.ai.NPCHolder;
|
||||||
import net.citizensnpcs.util.NMSReflection;
|
import net.citizensnpcs.util.NMS;
|
||||||
import net.citizensnpcs.util.Util;
|
import net.citizensnpcs.util.Util;
|
||||||
import net.minecraft.server.EntityMushroomCow;
|
import net.minecraft.server.EntityMushroomCow;
|
||||||
import net.minecraft.server.World;
|
import net.minecraft.server.World;
|
||||||
@ -35,7 +35,7 @@ public class CitizensMushroomCowNPC extends CitizensMobNPC {
|
|||||||
super(world);
|
super(world);
|
||||||
this.npc = (CitizensNPC) npc;
|
this.npc = (CitizensNPC) npc;
|
||||||
if (npc != null) {
|
if (npc != null) {
|
||||||
NMSReflection.clearGoals(goalSelector, targetSelector);
|
NMS.clearGoals(goalSelector, targetSelector);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -5,7 +5,7 @@ import net.citizensnpcs.api.npc.NPC;
|
|||||||
import net.citizensnpcs.npc.CitizensMobNPC;
|
import net.citizensnpcs.npc.CitizensMobNPC;
|
||||||
import net.citizensnpcs.npc.CitizensNPC;
|
import net.citizensnpcs.npc.CitizensNPC;
|
||||||
import net.citizensnpcs.npc.ai.NPCHolder;
|
import net.citizensnpcs.npc.ai.NPCHolder;
|
||||||
import net.citizensnpcs.util.NMSReflection;
|
import net.citizensnpcs.util.NMS;
|
||||||
import net.citizensnpcs.util.Util;
|
import net.citizensnpcs.util.Util;
|
||||||
import net.minecraft.server.EntityOcelot;
|
import net.minecraft.server.EntityOcelot;
|
||||||
import net.minecraft.server.World;
|
import net.minecraft.server.World;
|
||||||
@ -35,10 +35,17 @@ public class CitizensOcelotNPC extends CitizensMobNPC {
|
|||||||
super(world);
|
super(world);
|
||||||
this.npc = (CitizensNPC) npc;
|
this.npc = (CitizensNPC) npc;
|
||||||
if (npc != null) {
|
if (npc != null) {
|
||||||
NMSReflection.clearGoals(goalSelector, targetSelector);
|
NMS.clearGoals(goalSelector, targetSelector);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void bb() {
|
||||||
|
if (npc == null)
|
||||||
|
super.bb();
|
||||||
|
// check despawn method, we only want to despawn on chunk unload.
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void bc() {
|
public void bc() {
|
||||||
super.bc();
|
super.bc();
|
||||||
|
@ -8,7 +8,7 @@ import net.citizensnpcs.npc.CitizensNPC;
|
|||||||
import net.citizensnpcs.npc.ai.NPCHolder;
|
import net.citizensnpcs.npc.ai.NPCHolder;
|
||||||
import net.citizensnpcs.trait.Saddle;
|
import net.citizensnpcs.trait.Saddle;
|
||||||
import net.citizensnpcs.util.Messaging;
|
import net.citizensnpcs.util.Messaging;
|
||||||
import net.citizensnpcs.util.NMSReflection;
|
import net.citizensnpcs.util.NMS;
|
||||||
import net.citizensnpcs.util.StringHelper;
|
import net.citizensnpcs.util.StringHelper;
|
||||||
import net.citizensnpcs.util.Util;
|
import net.citizensnpcs.util.Util;
|
||||||
import net.minecraft.server.EntityLightning;
|
import net.minecraft.server.EntityLightning;
|
||||||
@ -62,7 +62,7 @@ public class CitizensPigNPC extends CitizensMobNPC implements Equipable {
|
|||||||
super(world);
|
super(world);
|
||||||
this.npc = (CitizensNPC) npc;
|
this.npc = (CitizensNPC) npc;
|
||||||
if (npc != null) {
|
if (npc != null) {
|
||||||
NMSReflection.clearGoals(goalSelector, targetSelector);
|
NMS.clearGoals(goalSelector, targetSelector);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -5,7 +5,7 @@ import net.citizensnpcs.api.npc.NPC;
|
|||||||
import net.citizensnpcs.npc.CitizensMobNPC;
|
import net.citizensnpcs.npc.CitizensMobNPC;
|
||||||
import net.citizensnpcs.npc.CitizensNPC;
|
import net.citizensnpcs.npc.CitizensNPC;
|
||||||
import net.citizensnpcs.npc.ai.NPCHolder;
|
import net.citizensnpcs.npc.ai.NPCHolder;
|
||||||
import net.citizensnpcs.util.NMSReflection;
|
import net.citizensnpcs.util.NMS;
|
||||||
import net.citizensnpcs.util.Util;
|
import net.citizensnpcs.util.Util;
|
||||||
import net.minecraft.server.EntityPigZombie;
|
import net.minecraft.server.EntityPigZombie;
|
||||||
import net.minecraft.server.World;
|
import net.minecraft.server.World;
|
||||||
@ -35,10 +35,17 @@ public class CitizensPigZombieNPC extends CitizensMobNPC {
|
|||||||
super(world);
|
super(world);
|
||||||
this.npc = (CitizensNPC) npc;
|
this.npc = (CitizensNPC) npc;
|
||||||
if (npc != null) {
|
if (npc != null) {
|
||||||
NMSReflection.clearGoals(goalSelector, targetSelector);
|
NMS.clearGoals(goalSelector, targetSelector);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void bb() {
|
||||||
|
if (npc == null)
|
||||||
|
super.bb();
|
||||||
|
// check despawn method, we only want to despawn on chunk unload.
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void bc() {
|
public void bc() {
|
||||||
super.bc();
|
super.bc();
|
||||||
@ -48,10 +55,12 @@ public class CitizensPigZombieNPC extends CitizensMobNPC {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void be() {
|
public void be() {
|
||||||
if (npc != null)
|
if (npc == null)
|
||||||
npc.update();
|
|
||||||
else
|
|
||||||
super.be();
|
super.be();
|
||||||
|
else {
|
||||||
|
NMS.updateAI(this);
|
||||||
|
npc.update();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -9,7 +9,7 @@ import net.citizensnpcs.npc.ai.NPCHolder;
|
|||||||
import net.citizensnpcs.trait.Sheared;
|
import net.citizensnpcs.trait.Sheared;
|
||||||
import net.citizensnpcs.trait.WoolColor;
|
import net.citizensnpcs.trait.WoolColor;
|
||||||
import net.citizensnpcs.util.Messaging;
|
import net.citizensnpcs.util.Messaging;
|
||||||
import net.citizensnpcs.util.NMSReflection;
|
import net.citizensnpcs.util.NMS;
|
||||||
import net.citizensnpcs.util.StringHelper;
|
import net.citizensnpcs.util.StringHelper;
|
||||||
import net.citizensnpcs.util.Util;
|
import net.citizensnpcs.util.Util;
|
||||||
import net.minecraft.server.EntitySheep;
|
import net.minecraft.server.EntitySheep;
|
||||||
@ -73,7 +73,7 @@ public class CitizensSheepNPC extends CitizensMobNPC implements Equipable {
|
|||||||
super(world);
|
super(world);
|
||||||
this.npc = (CitizensNPC) npc;
|
this.npc = (CitizensNPC) npc;
|
||||||
if (npc != null) {
|
if (npc != null) {
|
||||||
NMSReflection.clearGoals(goalSelector, targetSelector);
|
NMS.clearGoals(goalSelector, targetSelector);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -5,7 +5,7 @@ import net.citizensnpcs.api.npc.NPC;
|
|||||||
import net.citizensnpcs.npc.CitizensMobNPC;
|
import net.citizensnpcs.npc.CitizensMobNPC;
|
||||||
import net.citizensnpcs.npc.CitizensNPC;
|
import net.citizensnpcs.npc.CitizensNPC;
|
||||||
import net.citizensnpcs.npc.ai.NPCHolder;
|
import net.citizensnpcs.npc.ai.NPCHolder;
|
||||||
import net.citizensnpcs.util.NMSReflection;
|
import net.citizensnpcs.util.NMS;
|
||||||
import net.citizensnpcs.util.Util;
|
import net.citizensnpcs.util.Util;
|
||||||
import net.minecraft.server.EntitySilverfish;
|
import net.minecraft.server.EntitySilverfish;
|
||||||
import net.minecraft.server.World;
|
import net.minecraft.server.World;
|
||||||
@ -35,10 +35,17 @@ public class CitizensSilverfishNPC extends CitizensMobNPC {
|
|||||||
super(world);
|
super(world);
|
||||||
this.npc = (CitizensNPC) npc;
|
this.npc = (CitizensNPC) npc;
|
||||||
if (npc != null) {
|
if (npc != null) {
|
||||||
NMSReflection.clearGoals(goalSelector, targetSelector);
|
NMS.clearGoals(goalSelector, targetSelector);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void bb() {
|
||||||
|
if (npc == null)
|
||||||
|
super.bb();
|
||||||
|
// check despawn method, we only want to despawn on chunk unload.
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void bc() {
|
public void bc() {
|
||||||
super.bc();
|
super.bc();
|
||||||
@ -50,9 +57,11 @@ public class CitizensSilverfishNPC extends CitizensMobNPC {
|
|||||||
public void be() {
|
public void be() {
|
||||||
if (npc == null)
|
if (npc == null)
|
||||||
super.be();
|
super.be();
|
||||||
else
|
else {
|
||||||
|
NMS.updateAI(this);
|
||||||
npc.update();
|
npc.update();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void collide(net.minecraft.server.Entity entity) {
|
public void collide(net.minecraft.server.Entity entity) {
|
||||||
|
@ -5,7 +5,7 @@ import net.citizensnpcs.api.npc.NPC;
|
|||||||
import net.citizensnpcs.npc.CitizensMobNPC;
|
import net.citizensnpcs.npc.CitizensMobNPC;
|
||||||
import net.citizensnpcs.npc.CitizensNPC;
|
import net.citizensnpcs.npc.CitizensNPC;
|
||||||
import net.citizensnpcs.npc.ai.NPCHolder;
|
import net.citizensnpcs.npc.ai.NPCHolder;
|
||||||
import net.citizensnpcs.util.NMSReflection;
|
import net.citizensnpcs.util.NMS;
|
||||||
import net.citizensnpcs.util.Util;
|
import net.citizensnpcs.util.Util;
|
||||||
import net.minecraft.server.EntitySkeleton;
|
import net.minecraft.server.EntitySkeleton;
|
||||||
import net.minecraft.server.World;
|
import net.minecraft.server.World;
|
||||||
@ -35,10 +35,17 @@ public class CitizensSkeletonNPC extends CitizensMobNPC {
|
|||||||
super(world);
|
super(world);
|
||||||
this.npc = (CitizensNPC) npc;
|
this.npc = (CitizensNPC) npc;
|
||||||
if (npc != null) {
|
if (npc != null) {
|
||||||
NMSReflection.clearGoals(goalSelector, targetSelector);
|
NMS.clearGoals(goalSelector, targetSelector);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void bb() {
|
||||||
|
if (npc == null)
|
||||||
|
super.bb();
|
||||||
|
// check despawn method, we only want to despawn on chunk unload.
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void bc() {
|
public void bc() {
|
||||||
super.bc();
|
super.bc();
|
||||||
|
@ -5,7 +5,7 @@ import net.citizensnpcs.api.npc.NPC;
|
|||||||
import net.citizensnpcs.npc.CitizensMobNPC;
|
import net.citizensnpcs.npc.CitizensMobNPC;
|
||||||
import net.citizensnpcs.npc.CitizensNPC;
|
import net.citizensnpcs.npc.CitizensNPC;
|
||||||
import net.citizensnpcs.npc.ai.NPCHolder;
|
import net.citizensnpcs.npc.ai.NPCHolder;
|
||||||
import net.citizensnpcs.util.NMSReflection;
|
import net.citizensnpcs.util.NMS;
|
||||||
import net.citizensnpcs.util.Util;
|
import net.citizensnpcs.util.Util;
|
||||||
import net.minecraft.server.EntitySlime;
|
import net.minecraft.server.EntitySlime;
|
||||||
import net.minecraft.server.World;
|
import net.minecraft.server.World;
|
||||||
@ -36,10 +36,17 @@ public class CitizensSlimeNPC extends CitizensMobNPC {
|
|||||||
this.npc = (CitizensNPC) npc;
|
this.npc = (CitizensNPC) npc;
|
||||||
if (npc != null) {
|
if (npc != null) {
|
||||||
setSize(3);
|
setSize(3);
|
||||||
NMSReflection.clearGoals(goalSelector, targetSelector);
|
NMS.clearGoals(goalSelector, targetSelector);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void bb() {
|
||||||
|
if (npc == null)
|
||||||
|
super.bb();
|
||||||
|
// check despawn method, we only want to despawn on chunk unload.
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void bc() {
|
public void bc() {
|
||||||
super.bc();
|
super.bc();
|
||||||
@ -51,8 +58,10 @@ public class CitizensSlimeNPC extends CitizensMobNPC {
|
|||||||
public void be() {
|
public void be() {
|
||||||
if (npc == null)
|
if (npc == null)
|
||||||
super.be();
|
super.be();
|
||||||
else
|
else {
|
||||||
npc.update();
|
npc.update();
|
||||||
|
NMS.updateAI(this);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -5,7 +5,7 @@ import net.citizensnpcs.api.npc.NPC;
|
|||||||
import net.citizensnpcs.npc.CitizensMobNPC;
|
import net.citizensnpcs.npc.CitizensMobNPC;
|
||||||
import net.citizensnpcs.npc.CitizensNPC;
|
import net.citizensnpcs.npc.CitizensNPC;
|
||||||
import net.citizensnpcs.npc.ai.NPCHolder;
|
import net.citizensnpcs.npc.ai.NPCHolder;
|
||||||
import net.citizensnpcs.util.NMSReflection;
|
import net.citizensnpcs.util.NMS;
|
||||||
import net.citizensnpcs.util.Util;
|
import net.citizensnpcs.util.Util;
|
||||||
import net.minecraft.server.EntitySnowman;
|
import net.minecraft.server.EntitySnowman;
|
||||||
import net.minecraft.server.World;
|
import net.minecraft.server.World;
|
||||||
@ -31,13 +31,21 @@ public class CitizensSnowmanNPC extends CitizensMobNPC {
|
|||||||
super(world);
|
super(world);
|
||||||
this.npc = (CitizensNPC) npc;
|
this.npc = (CitizensNPC) npc;
|
||||||
if (npc != null) {
|
if (npc != null) {
|
||||||
NMSReflection.clearGoals(goalSelector, targetSelector);
|
NMS.clearGoals(goalSelector, targetSelector);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void bb() {
|
||||||
|
if (npc == null)
|
||||||
|
super.bb();
|
||||||
|
// check despawn method, we only want to despawn on chunk unload.
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void bc() {
|
public void bc() {
|
||||||
super.bc();
|
super.bc();
|
||||||
|
if (npc != null)
|
||||||
npc.update();
|
npc.update();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -5,7 +5,7 @@ import net.citizensnpcs.api.npc.NPC;
|
|||||||
import net.citizensnpcs.npc.CitizensMobNPC;
|
import net.citizensnpcs.npc.CitizensMobNPC;
|
||||||
import net.citizensnpcs.npc.CitizensNPC;
|
import net.citizensnpcs.npc.CitizensNPC;
|
||||||
import net.citizensnpcs.npc.ai.NPCHolder;
|
import net.citizensnpcs.npc.ai.NPCHolder;
|
||||||
import net.citizensnpcs.util.NMSReflection;
|
import net.citizensnpcs.util.NMS;
|
||||||
import net.citizensnpcs.util.Util;
|
import net.citizensnpcs.util.Util;
|
||||||
import net.minecraft.server.EntitySpider;
|
import net.minecraft.server.EntitySpider;
|
||||||
import net.minecraft.server.World;
|
import net.minecraft.server.World;
|
||||||
@ -34,10 +34,17 @@ public class CitizensSpiderNPC extends CitizensMobNPC {
|
|||||||
super(world);
|
super(world);
|
||||||
this.npc = (CitizensNPC) npc;
|
this.npc = (CitizensNPC) npc;
|
||||||
if (npc != null) {
|
if (npc != null) {
|
||||||
NMSReflection.clearGoals(goalSelector, targetSelector);
|
NMS.clearGoals(goalSelector, targetSelector);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void bb() {
|
||||||
|
if (npc == null)
|
||||||
|
super.bb();
|
||||||
|
// check despawn method, we only want to despawn on chunk unload.
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void bc() {
|
public void bc() {
|
||||||
super.bc();
|
super.bc();
|
||||||
@ -49,9 +56,11 @@ public class CitizensSpiderNPC extends CitizensMobNPC {
|
|||||||
public void be() {
|
public void be() {
|
||||||
if (npc == null)
|
if (npc == null)
|
||||||
super.be();
|
super.be();
|
||||||
else
|
else {
|
||||||
|
NMS.updateAI(this);
|
||||||
npc.update();
|
npc.update();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void collide(net.minecraft.server.Entity entity) {
|
public void collide(net.minecraft.server.Entity entity) {
|
||||||
|
@ -5,7 +5,7 @@ import net.citizensnpcs.api.npc.NPC;
|
|||||||
import net.citizensnpcs.npc.CitizensMobNPC;
|
import net.citizensnpcs.npc.CitizensMobNPC;
|
||||||
import net.citizensnpcs.npc.CitizensNPC;
|
import net.citizensnpcs.npc.CitizensNPC;
|
||||||
import net.citizensnpcs.npc.ai.NPCHolder;
|
import net.citizensnpcs.npc.ai.NPCHolder;
|
||||||
import net.citizensnpcs.util.NMSReflection;
|
import net.citizensnpcs.util.NMS;
|
||||||
import net.citizensnpcs.util.Util;
|
import net.citizensnpcs.util.Util;
|
||||||
import net.minecraft.server.EntitySquid;
|
import net.minecraft.server.EntitySquid;
|
||||||
import net.minecraft.server.World;
|
import net.minecraft.server.World;
|
||||||
@ -35,10 +35,17 @@ public class CitizensSquidNPC extends CitizensMobNPC {
|
|||||||
super(world);
|
super(world);
|
||||||
this.npc = (CitizensNPC) npc;
|
this.npc = (CitizensNPC) npc;
|
||||||
if (npc != null) {
|
if (npc != null) {
|
||||||
NMSReflection.clearGoals(goalSelector, targetSelector);
|
NMS.clearGoals(goalSelector, targetSelector);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void bb() {
|
||||||
|
if (npc == null)
|
||||||
|
super.bb();
|
||||||
|
// check despawn method, we only want to despawn on chunk unload.
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void be() {
|
public void be() {
|
||||||
if (npc != null)
|
if (npc != null)
|
||||||
|
@ -5,7 +5,7 @@ import net.citizensnpcs.api.npc.NPC;
|
|||||||
import net.citizensnpcs.npc.CitizensMobNPC;
|
import net.citizensnpcs.npc.CitizensMobNPC;
|
||||||
import net.citizensnpcs.npc.CitizensNPC;
|
import net.citizensnpcs.npc.CitizensNPC;
|
||||||
import net.citizensnpcs.npc.ai.NPCHolder;
|
import net.citizensnpcs.npc.ai.NPCHolder;
|
||||||
import net.citizensnpcs.util.NMSReflection;
|
import net.citizensnpcs.util.NMS;
|
||||||
import net.citizensnpcs.util.Util;
|
import net.citizensnpcs.util.Util;
|
||||||
import net.minecraft.server.EntityHuman;
|
import net.minecraft.server.EntityHuman;
|
||||||
import net.minecraft.server.EntityVillager;
|
import net.minecraft.server.EntityVillager;
|
||||||
@ -36,10 +36,17 @@ public class CitizensVillagerNPC extends CitizensMobNPC {
|
|||||||
super(world);
|
super(world);
|
||||||
this.npc = (CitizensNPC) npc;
|
this.npc = (CitizensNPC) npc;
|
||||||
if (npc != null) {
|
if (npc != null) {
|
||||||
NMSReflection.clearGoals(goalSelector, targetSelector);
|
NMS.clearGoals(goalSelector, targetSelector);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void bb() {
|
||||||
|
if (npc == null)
|
||||||
|
super.bb();
|
||||||
|
// check despawn method, we only want to despawn on chunk unload.
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void bc() {
|
public void bc() {
|
||||||
super.bc();
|
super.bc();
|
||||||
|
@ -5,7 +5,7 @@ import net.citizensnpcs.api.npc.NPC;
|
|||||||
import net.citizensnpcs.npc.CitizensMobNPC;
|
import net.citizensnpcs.npc.CitizensMobNPC;
|
||||||
import net.citizensnpcs.npc.CitizensNPC;
|
import net.citizensnpcs.npc.CitizensNPC;
|
||||||
import net.citizensnpcs.npc.ai.NPCHolder;
|
import net.citizensnpcs.npc.ai.NPCHolder;
|
||||||
import net.citizensnpcs.util.NMSReflection;
|
import net.citizensnpcs.util.NMS;
|
||||||
import net.citizensnpcs.util.Util;
|
import net.citizensnpcs.util.Util;
|
||||||
import net.minecraft.server.EntityWolf;
|
import net.minecraft.server.EntityWolf;
|
||||||
import net.minecraft.server.World;
|
import net.minecraft.server.World;
|
||||||
@ -35,10 +35,17 @@ public class CitizensWolfNPC extends CitizensMobNPC {
|
|||||||
super(world);
|
super(world);
|
||||||
this.npc = (CitizensNPC) npc;
|
this.npc = (CitizensNPC) npc;
|
||||||
if (npc != null) {
|
if (npc != null) {
|
||||||
NMSReflection.clearGoals(goalSelector, targetSelector);
|
NMS.clearGoals(goalSelector, targetSelector);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void bb() {
|
||||||
|
if (npc == null)
|
||||||
|
super.bb();
|
||||||
|
// check despawn method, we only want to despawn on chunk unload.
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void bc() {
|
public void bc() {
|
||||||
super.bc();
|
super.bc();
|
||||||
|
@ -5,7 +5,7 @@ import net.citizensnpcs.api.npc.NPC;
|
|||||||
import net.citizensnpcs.npc.CitizensMobNPC;
|
import net.citizensnpcs.npc.CitizensMobNPC;
|
||||||
import net.citizensnpcs.npc.CitizensNPC;
|
import net.citizensnpcs.npc.CitizensNPC;
|
||||||
import net.citizensnpcs.npc.ai.NPCHolder;
|
import net.citizensnpcs.npc.ai.NPCHolder;
|
||||||
import net.citizensnpcs.util.NMSReflection;
|
import net.citizensnpcs.util.NMS;
|
||||||
import net.citizensnpcs.util.Util;
|
import net.citizensnpcs.util.Util;
|
||||||
import net.minecraft.server.EntityZombie;
|
import net.minecraft.server.EntityZombie;
|
||||||
import net.minecraft.server.World;
|
import net.minecraft.server.World;
|
||||||
@ -35,10 +35,17 @@ public class CitizensZombieNPC extends CitizensMobNPC {
|
|||||||
super(world);
|
super(world);
|
||||||
this.npc = (CitizensNPC) npc;
|
this.npc = (CitizensNPC) npc;
|
||||||
if (npc != null) {
|
if (npc != null) {
|
||||||
NMSReflection.clearGoals(goalSelector, targetSelector);
|
NMS.clearGoals(goalSelector, targetSelector);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void bb() {
|
||||||
|
if (npc == null)
|
||||||
|
super.bb();
|
||||||
|
// check despawn method, we only want to despawn on chunk unload.
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void bc() {
|
public void bc() {
|
||||||
super.bc();
|
super.bc();
|
||||||
|
@ -3,7 +3,7 @@ package net.citizensnpcs.npc.network;
|
|||||||
import java.net.Socket;
|
import java.net.Socket;
|
||||||
import java.security.PrivateKey;
|
import java.security.PrivateKey;
|
||||||
|
|
||||||
import net.citizensnpcs.util.NMSReflection;
|
import net.citizensnpcs.util.NMS;
|
||||||
import net.minecraft.server.NetHandler;
|
import net.minecraft.server.NetHandler;
|
||||||
import net.minecraft.server.NetworkManager;
|
import net.minecraft.server.NetworkManager;
|
||||||
import net.minecraft.server.Packet;
|
import net.minecraft.server.Packet;
|
||||||
@ -13,7 +13,7 @@ public class EmptyNetworkManager extends NetworkManager {
|
|||||||
public EmptyNetworkManager(Socket socket, String string, NetHandler netHandler, PrivateKey key) {
|
public EmptyNetworkManager(Socket socket, String string, NetHandler netHandler, PrivateKey key) {
|
||||||
super(socket, string, netHandler, key);
|
super(socket, string, netHandler, key);
|
||||||
|
|
||||||
NMSReflection.stopNetworkThreads(this);
|
NMS.stopNetworkThreads(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -17,8 +17,8 @@ import org.bukkit.entity.EntityType;
|
|||||||
import com.google.common.collect.Maps;
|
import com.google.common.collect.Maps;
|
||||||
|
|
||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
public class NMSReflection {
|
public class NMS {
|
||||||
private NMSReflection() {
|
private NMS() {
|
||||||
// util class
|
// util class
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -34,11 +34,11 @@ public class NMSReflection {
|
|||||||
private static Field THREAD_STOPPER;
|
private static Field THREAD_STOPPER;
|
||||||
|
|
||||||
public static void clearGoals(PathfinderGoalSelector... goalSelectors) {
|
public static void clearGoals(PathfinderGoalSelector... goalSelectors) {
|
||||||
if (NMSReflection.GOAL_FIELD == null || goalSelectors == null)
|
if (NMS.GOAL_FIELD == null || goalSelectors == null)
|
||||||
return;
|
return;
|
||||||
for (PathfinderGoalSelector selector : goalSelectors) {
|
for (PathfinderGoalSelector selector : goalSelectors) {
|
||||||
try {
|
try {
|
||||||
List<?> list = (List<?>) NMSReflection.GOAL_FIELD.get(selector);
|
List<?> list = (List<?>) NMS.GOAL_FIELD.get(selector);
|
||||||
list.clear();
|
list.clear();
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
}
|
}
|
||||||
@ -98,6 +98,13 @@ public class NMSReflection {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static void updateAI(EntityLiving entity) {
|
||||||
|
entity.getNavigation().e();
|
||||||
|
entity.getControllerMove().c();
|
||||||
|
entity.getControllerLook().a();
|
||||||
|
entity.getControllerJump().b();
|
||||||
|
}
|
||||||
|
|
||||||
public static void updatePathfindingRange(CitizensNPC npc, float pathfindingRange) {
|
public static void updatePathfindingRange(CitizensNPC npc, float pathfindingRange) {
|
||||||
if (PATHFINDING_RANGE == null)
|
if (PATHFINDING_RANGE == null)
|
||||||
return;
|
return;
|
@ -80,7 +80,7 @@ public class Util {
|
|||||||
if (type != null)
|
if (type != null)
|
||||||
return type;
|
return type;
|
||||||
for (EntityType check : EntityType.values()) {
|
for (EntityType check : EntityType.values()) {
|
||||||
if (check.name().matches(toMatch) || check.name().replace('_', '-').equals(toMatch)) {
|
if (check.name().matches(toMatch) || check.name().replace('_', '-').equalsIgnoreCase(toMatch)) {
|
||||||
type = check;
|
type = check;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user