Cancel navigation on despawn: Navigation isn't carried over so CitizensNavigator would be left in an inconsistent state

This commit is contained in:
fullwall 2013-03-14 23:29:41 +08:00
parent 5f093276f1
commit aa022f8fae
2 changed files with 5 additions and 2 deletions

View File

@ -103,8 +103,11 @@ public class CitizensNavigator implements Navigator, Runnable {
public void run() { public void run() {
if (!isNavigating()) if (!isNavigating())
return; return;
if (!npc.isSpawned()) if (!npc.isSpawned()) {
if (isNavigating())
stopNavigating(CancelReason.NPC_DESPAWNED);
return; return;
}
if (updateStationaryStatus()) if (updateStationaryStatus())
return; return;
updatePathfindingRange(); updatePathfindingRange();

View File

@ -44,7 +44,7 @@ public class WanderWaypointProvider implements WaypointProvider {
@Override @Override
public void onSpawn(NPC npc) { public void onSpawn(NPC npc) {
if (currentGoal == null) { if (currentGoal == null) {
currentGoal = WanderGoal.createWithNPC(npc); currentGoal = WanderGoal.createWithNPCAndRange(npc, xrange, yrange);
CitizensAPI.registerEvents(currentGoal); CitizensAPI.registerEvents(currentGoal);
} }
npc.getDefaultGoalController().addGoal(currentGoal, 1); npc.getDefaultGoalController().addGoal(currentGoal, 1);