|
@@ -228,6 +228,7 @@ void ApplyClientNetPackVisitor::visitSetStackType(SetStackType & pack)
|
|
|
void ApplyClientNetPackVisitor::visitEraseStack(EraseStack & pack)
|
|
|
{
|
|
|
dispatchGarrisonChange(cl, pack.army, ObjectInstanceID());
|
|
|
+ cl.invalidatePaths(); //it is possible to remove last non-native unit for current terrain and lose movement penalty
|
|
|
}
|
|
|
|
|
|
void ApplyClientNetPackVisitor::visitSwapStacks(SwapStacks & pack)
|
|
@@ -243,6 +244,9 @@ void ApplyClientNetPackVisitor::visitInsertNewStack(InsertNewStack & pack)
|
|
|
void ApplyClientNetPackVisitor::visitRebalanceStacks(RebalanceStacks & pack)
|
|
|
{
|
|
|
dispatchGarrisonChange(cl, pack.srcArmy, pack.dstArmy);
|
|
|
+
|
|
|
+ if(pack.srcArmy != pack.dstArmy)
|
|
|
+ cl.invalidatePaths(); // adding/removing units may change terrain type penalty based on creature native terrains
|
|
|
}
|
|
|
|
|
|
void ApplyClientNetPackVisitor::visitBulkRebalanceStacks(BulkRebalanceStacks & pack)
|
|
@@ -253,6 +257,9 @@ void ApplyClientNetPackVisitor::visitBulkRebalanceStacks(BulkRebalanceStacks & p
|
|
|
? ObjectInstanceID()
|
|
|
: pack.moves[0].dstArmy;
|
|
|
dispatchGarrisonChange(cl, pack.moves[0].srcArmy, destArmy);
|
|
|
+
|
|
|
+ if(pack.moves[0].srcArmy != destArmy)
|
|
|
+ cl.invalidatePaths(); // adding/removing units may change terrain type penalty based on creature native terrains
|
|
|
}
|
|
|
}
|
|
|
|