Skip to content

Commit ba0653d

Browse files
authored
Sort battles cleanup (#12814)
* sort_Battles #1 TripleAFrame.java - rename variable territoryDetails to territoryDetailsPanel - rename variable actionButtons to actionButtonsPanel - rename variable datacopy to gameDataCopy - fix typos e.g. savegame or gamedata Rename class ActionButtons to ActionButtonsPanel: - ForumPosterComponent.java - ActionPanel.java BattleCalculatorDialog.java - renamed Getter TripleAFrame.java.TerritoryPanel TripleAPlayer.java - fix typos savegame and gamedata - rename variable battlesite to battleTerritory Replace typos 'savegame' with 'save game' - ActionButtonsPanel.java - GameSequence.java - HeadlessGameServer.java - IEmailSender.java - NodeBbForumPoster.java - ServerLauncher.java - TripleAFrame.java - TripleAPlayer.java - UpdateChecks.java * sort_Battles #2 BattleTracker.java - rename variables (e.g. territory collections) with same name as member attribute - replace Map loop over keys with over entrySet - rework methods getPendingBattles to consistently use CollectionUtils.getMatches instead of stream() - rework methods getPendingBattle to consistently use stream() instead of loops - make method getPendingBattleSites(bombing) private and usages more clear with new methods getPendingBattleSitesWithBombing() and getPendingBattleSitesWithoutBombing() - replace lambdas with method - typo 's instead of s replace with new method BattleTracker.getPendingBattleSitesWithoutBombing() - BattleDelegate.java - MoveDelegateTest.java - MustFightBattleTest.java - RevisedTest.java - WW2V3Year41Test.java - WW2V3Year42Test.java * sort_Battles #3 Keep BattleListing for passing to other methods and let method/variable names indicate BattleListing ActionButtonsPanel.java - let method changeToBattle use BattleListing instead of battles map BattleTracker.java - rename method getPendingBattleSites to getBattleListingFromPendingBattles BattlePanel.java - rename attribute battles to battleListing - remove isBomb variable in method addBattleActions and subsequent methods as value can be determined by other parameter (BattleType) IBattleDelegate.java - rename method getBattles to getBattleListing TripleAFrame.java - let method getBattle use BattleListing instead of battles map Affected by renaming method (getBattles to getBattleListing; getPendingBattleSites to getBattleListingFromPendingBattles) - AbstractAi.java - AirThatCantLandUtilTest.java - BattleDelegate.java - ProSimulateTurnUtils.java - TripleAPlayer.java - WW2V3Year41Test.java * sort_Battles #4 Move BattleListing map building from BattleTracker into BattleListing BattleTracker - move logic of method getBattleListingFromPendingBattles() to constructor of BattleListing BattleListing.java - rename attribute battles to battlesMap - change constructor to include logic of method BattleTracker.getBattleListingFromPendingBattles() - extract new method getBattlesWith(predicate) Subsequent changes for Getter on BattleListing.battlesMap - AbstractAi.java - AirThatCantLandUtilTest.java - ProSimulateTurnUtils.java - WW2V3Year41Test.java * sort_Battles #5 fix RemoteActionCodeTest due to renaming IBattleDelegate.getBattles to getBattleListing - required-op-codes.csv
1 parent 206b245 commit ba0653d

File tree

26 files changed

+251
-221
lines changed

26 files changed

+251
-221
lines changed

game-app/game-core/src/main/java/games/strategy/engine/data/GameSequence.java

+3-3
Original file line numberDiff line numberDiff line change
@@ -21,9 +21,9 @@ public GameSequence(final GameData data) {
2121
}
2222

2323
/**
24-
* Only used when we are trying to export the data to a savegame, and we need to change the round
25-
* and step to something other than the current round and step (because we are creating a savegame
26-
* at a certain point in history, for example).
24+
* Only used when we are trying to export the data to a save game, and we need to change the round
25+
* and step to something other than the current round and step (because we are creating a save
26+
* game at a certain point in history, for example).
2727
*/
2828
public synchronized void setRoundAndStep(
2929
final int currentRound, final String stepDisplayName, final GamePlayer player) {

game-app/game-core/src/main/java/games/strategy/engine/framework/startup/launcher/ServerLauncher.java

+2-2
Original file line numberDiff line numberDiff line change
@@ -227,7 +227,7 @@ private void launchInternal() {
227227
} else {
228228
final String errorMessage =
229229
"Unrecognized error occurred. If this is a repeatable error, "
230-
+ "please make a copy of this savegame and report to:\n"
230+
+ "please make a copy of this save game and report to:\n"
231231
+ UrlConstants.GITHUB_ISSUES;
232232
log.error(errorMessage, e);
233233
stopGame();
@@ -310,7 +310,7 @@ private void stopGame() {
310310
}
311311

312312
private void saveAndEndGame(final INode node) {
313-
// a hack, if headless save to the autosave to avoid polluting our savegames folder with a
313+
// a hack, if headless save to the auto save to avoid polluting our save games folder with a
314314
// million saves
315315
final Path f = launchAction.getAutoSaveFile();
316316
try {

game-app/game-core/src/main/java/games/strategy/engine/posted/game/pbem/IEmailSender.java

+1-1
Original file line numberDiff line numberDiff line change
@@ -23,7 +23,7 @@ public interface IEmailSender {
2323
*
2424
* @param subject the subject of the email
2525
* @param htmlMessage the html email body
26-
* @param saveGame the savegame or null
26+
* @param saveGame the save game or null
2727
* @throws IOException if an error occurs
2828
*/
2929
void sendEmail(String subject, String htmlMessage, Path saveGame, String saveGameName)

game-app/game-core/src/main/java/games/strategy/engine/posted/game/pbf/NodeBbForumPoster.java

+1-1
Original file line numberDiff line numberDiff line change
@@ -162,7 +162,7 @@ private String uploadSaveGame(
162162
return parseSaveGameUrlFromJsonResponse(json);
163163
}
164164
throw new IllegalStateException(
165-
"Failed to upload savegame, server returned Error Code "
165+
"Failed to upload save game, server returned Error Code "
166166
+ status
167167
+ "\nMessage:\n"
168168
+ EntityUtils.toString(response.getEntity()));

game-app/game-core/src/main/java/games/strategy/triplea/ai/AbstractAi.java

+3-2
Original file line numberDiff line numberDiff line change
@@ -601,11 +601,12 @@ protected void battle(final IBattleDelegate battleDelegate) {
601601
// as in the case of a naval battle preceding an amphibious attack, keep trying to fight every
602602
// battle
603603
while (true) {
604-
final BattleListing listing = battleDelegate.getBattles();
604+
final BattleListing listing = battleDelegate.getBattleListing();
605605
if (listing.isEmpty()) {
606606
return;
607607
}
608-
for (final Entry<BattleType, Collection<Territory>> entry : listing.getBattles().entrySet()) {
608+
for (final Entry<BattleType, Collection<Territory>> entry :
609+
listing.getBattlesMap().entrySet()) {
609610
for (final Territory current : entry.getValue()) {
610611
final String error =
611612
battleDelegate.fightBattle(current, entry.getKey().isBombingRun(), entry.getKey());

game-app/game-core/src/main/java/games/strategy/triplea/ai/pro/simulate/ProSimulateTurnUtils.java

+1-1
Original file line numberDiff line numberDiff line change
@@ -50,7 +50,7 @@ public static void simulateBattles(
5050

5151
final BattleDelegate battleDelegate = data.getBattleDelegate();
5252
final Map<BattleType, Collection<Territory>> battleTerritories =
53-
battleDelegate.getBattles().getBattles();
53+
battleDelegate.getBattleListing().getBattlesMap();
5454
for (final Entry<BattleType, Collection<Territory>> entry : battleTerritories.entrySet()) {
5555
for (final Territory t : entry.getValue()) {
5656
final IBattle battle =

game-app/game-core/src/main/java/games/strategy/triplea/delegate/battle/BattleDelegate.java

+8-7
Original file line numberDiff line numberDiff line change
@@ -193,7 +193,7 @@ public void loadState(final Serializable state) {
193193

194194
@Override
195195
public boolean delegateCurrentlyRequiresUserInput() {
196-
final BattleListing battles = getBattles();
196+
final BattleListing battles = getBattleListing();
197197
if (battles.isEmpty()) {
198198
final IBattle battle = getCurrentBattle();
199199
return battle != null;
@@ -252,8 +252,8 @@ private static String getFightingWord(final IBattle battle) {
252252
}
253253

254254
@Override
255-
public BattleListing getBattles() {
256-
return battleTracker.getPendingBattleSites();
255+
public BattleListing getBattleListing() {
256+
return battleTracker.getBattleListingFromPendingBattles();
257257
}
258258

259259
/** Add bombardment units to battles. */
@@ -688,7 +688,7 @@ private void doScrambling() {
688688
if (!Properties.getScrambleRulesInEffect(data.getProperties())) {
689689
return;
690690
}
691-
final BattleListing pendingBattleSites = battleTracker.getPendingBattleSites();
691+
final BattleListing pendingBattleSites = battleTracker.getBattleListingFromPendingBattles();
692692
final Set<Territory> territoriesWithBattles =
693693
pendingBattleSites.getNormalBattlesIncludingAirBattles();
694694
if (Properties.getCanScrambleIntoAirBattles(data.getProperties())) {
@@ -1210,7 +1210,8 @@ private void doKamikazeSuicideAttacks() {
12101210
.and(Matches.unitCanEvade().negate());
12111211
final boolean onlyWhereThereAreBattlesOrAmphibious =
12121212
Properties.getKamikazeSuicideAttacksOnlyWhereBattlesAre(data.getProperties());
1213-
final Collection<Territory> pendingBattles = battleTracker.getPendingBattleSites(false);
1213+
final Collection<Territory> pendingBattles =
1214+
battleTracker.getPendingBattleSitesWithoutBombing();
12141215
// create a list of all kamikaze zones, listed by enemy
12151216
final Map<GamePlayer, Collection<Territory>> kamikazeZonesByEnemy = new HashMap<>();
12161217
for (final Territory t : data.getMap().getTerritories()) {
@@ -1478,7 +1479,7 @@ private static Collection<Territory> whereCanAirLand(
14781479
(Properties.getNeutralFlyoverAllowed(data.getProperties())
14791480
&& !Properties.getNeutralsImpassable(data.getProperties()));
14801481
final Set<Territory> canNotLand = new HashSet<>();
1481-
canNotLand.addAll(battleTracker.getPendingBattleSites(false));
1482+
canNotLand.addAll(battleTracker.getPendingBattleSitesWithoutBombing());
14821483
canNotLand.addAll(
14831484
CollectionUtils.getMatches(
14841485
data.getMap().getTerritories(), Matches.territoryHasEnemyUnits(alliedPlayer)));
@@ -1519,7 +1520,7 @@ private static Collection<Territory> whereCanAirLand(
15191520
possibleTerrs,
15201521
Matches.territoryHasUnitsThatMatch(Matches.unitIsAlliedCarrier(alliedPlayer))
15211522
.and(Matches.territoryIsWater())));
1522-
availableWater.removeAll(battleTracker.getPendingBattleSites(false));
1523+
availableWater.removeAll(battleTracker.getPendingBattleSitesWithoutBombing());
15231524
// simple calculation, either we can take all the air, or we can't, nothing in the middle
15241525
final int carrierCost = AirMovementValidator.carrierCost(strandedAir);
15251526
final Iterator<Territory> waterIter = availableWater.iterator();

game-app/game-core/src/main/java/games/strategy/triplea/delegate/battle/BattleTracker.java

+46-51
Original file line numberDiff line numberDiff line change
@@ -38,6 +38,7 @@
3838
import java.io.Serializable;
3939
import java.util.ArrayList;
4040
import java.util.Collection;
41+
import java.util.Collections;
4142
import java.util.HashMap;
4243
import java.util.HashSet;
4344
import java.util.List;
@@ -433,22 +434,23 @@ private void addEmptyBattle(
433434
.or(Matches.isTerritoryEnemyAndNotUnownedWaterOrImpassableOrRestricted(gamePlayer));
434435
final Predicate<Territory> conquerable =
435436
Matches.territoryIsEmptyOfCombatUnits(gamePlayer).and(passableLandAndNotRestricted);
436-
final Collection<Territory> conquered = new ArrayList<>();
437+
final Collection<Territory> conqueredTerritories = new ArrayList<>();
437438
if (canConquerMiddleSteps) {
438-
conquered.addAll(route.getMatches(conquerable));
439+
conqueredTerritories.addAll(route.getMatches(conquerable));
439440
// in case we begin in enemy territory, and blitz out of it, check the first territory
440441
if (!route.getStart().equals(route.getEnd()) && conquerable.test(route.getStart())) {
441-
conquered.add(route.getStart());
442+
conqueredTerritories.add(route.getStart());
442443
}
443444
}
444445
// we handle the end of the route later
445-
conquered.remove(route.getEnd());
446-
final Collection<Territory> blitzed =
447-
CollectionUtils.getMatches(conquered, Matches.territoryIsBlitzable(gamePlayer));
448-
this.blitzed.addAll(CollectionUtils.getMatches(blitzed, Matches.isTerritoryEnemy(gamePlayer)));
446+
conqueredTerritories.remove(route.getEnd());
447+
final Collection<Territory> blitzedTerritories =
448+
CollectionUtils.getMatches(conqueredTerritories, Matches.territoryIsBlitzable(gamePlayer));
449+
this.blitzed.addAll(
450+
CollectionUtils.getMatches(blitzedTerritories, Matches.isTerritoryEnemy(gamePlayer)));
449451
this.conquered.addAll(
450-
CollectionUtils.getMatches(conquered, Matches.isTerritoryEnemy(gamePlayer)));
451-
for (final Territory current : conquered) {
452+
CollectionUtils.getMatches(conqueredTerritories, Matches.isTerritoryEnemy(gamePlayer)));
453+
for (final Territory current : conqueredTerritories) {
452454
IBattle nonFight = getPendingBattle(current, BattleType.NORMAL);
453455
// TODO: if we ever want to scramble to a blitzed territory, then we need to fix this
454456
if (nonFight == null) {
@@ -885,8 +887,10 @@ public static void captureOrDestroyUnits(
885887
final Map<String, Tuple<String, IntegerMap<UnitType>>> map =
886888
u.getUnitAttachment().getWhenCapturedChangesInto();
887889
final GamePlayer currentOwner = u.getOwner();
888-
for (final String value : map.keySet()) {
889-
final String[] s = Iterables.toArray(Splitter.on(':').split(value), String.class);
890+
for (Map.Entry<String, Tuple<String, IntegerMap<UnitType>>> mapEntry :
891+
Collections.unmodifiableSet(map.entrySet())) {
892+
final String[] s =
893+
Iterables.toArray(Splitter.on(':').split(mapEntry.getKey()), String.class);
890894
if (!(s[0].equals("any")
891895
|| data.getPlayerList().getPlayerId(s[0]).equals(currentOwner))) {
892896
continue;
@@ -897,7 +901,7 @@ public static void captureOrDestroyUnits(
897901
}
898902
final CompositeChange changes = new CompositeChange();
899903
final Collection<Unit> toAdd = new ArrayList<>();
900-
final Tuple<String, IntegerMap<UnitType>> toCreate = map.get(value);
904+
final Tuple<String, IntegerMap<UnitType>> toCreate = mapEntry.getValue();
901905
final boolean translateAttributes = toCreate.getFirst().equalsIgnoreCase("true");
902906
for (final UnitType ut : toCreate.getSecond().keySet()) {
903907
toAdd.addAll(ut.create(toCreate.getSecond().getInt(ut), newOwner));
@@ -1036,17 +1040,15 @@ public Collection<IBattle> getPendingBattles(BattleType type) {
10361040
}
10371041

10381042
public Collection<IBattle> getPendingBattles(final Territory t) {
1039-
return pendingBattles.stream()
1040-
.filter(b -> b.getTerritory().equals(t))
1041-
.collect(Collectors.toSet());
1043+
return CollectionUtils.getMatches(pendingBattles, b -> b.getTerritory().equals(t));
10421044
}
10431045

10441046
public boolean hasPendingNonBombingBattle(final Territory t) {
1045-
return getPendingBattle(t) != null;
1047+
return getPendingNonBombingBattle(t) != null;
10461048
}
10471049

10481050
@Nullable
1049-
public IBattle getPendingBattle(final Territory t) {
1051+
public IBattle getPendingNonBombingBattle(final Territory t) {
10501052
return BattleType.nonBombingBattleTypes().stream()
10511053
.map(type -> getPendingBattle(t, type))
10521054
.filter(Objects::nonNull)
@@ -1056,50 +1058,43 @@ public IBattle getPendingBattle(final Territory t) {
10561058

10571059
@Nullable
10581060
public IBattle getPendingBattle(final Territory t, final BattleType type) {
1059-
for (final IBattle battle : pendingBattles) {
1060-
if (battle.getTerritory().equals(t) && type == battle.getBattleType()) {
1061-
return battle;
1062-
}
1063-
}
1064-
return null;
1061+
return pendingBattles.stream()
1062+
.filter(b -> b.getBattleType().equals(type) && b.getTerritory().equals(t))
1063+
.findFirst()
1064+
.orElse(null);
10651065
}
10661066

10671067
public IBattle getPendingBattle(final UUID uuid) {
10681068
if (uuid == null) {
10691069
return null;
10701070
}
1071-
10721071
return pendingBattles.stream().filter(b -> b.getBattleId().equals(uuid)).findAny().orElse(null);
10731072
}
10741073

1074+
/** Returns a collection of territories where no bombing battles are pending. */
1075+
public Collection<Territory> getPendingBattleSitesWithoutBombing() {
1076+
return getPendingBattleSites(false);
1077+
}
1078+
1079+
/** Returns a collection of territories where bombing battles are pending. */
1080+
public Collection<Territory> getPendingBattleSitesWithBombing() {
1081+
return getPendingBattleSites(true);
1082+
}
1083+
10751084
/**
10761085
* Returns a collection of territories where battles are pending.
10771086
*
1078-
* @param bombing whether only battles where there is bombing.
1087+
* @param bombing whether only battles where there is bombing or where there is no bombing.
10791088
*/
1080-
public Collection<Territory> getPendingBattleSites(final boolean bombing) {
1081-
final Collection<Territory> battles = new ArrayList<>();
1082-
for (final IBattle battle : pendingBattles) {
1083-
if (!battle.isEmpty() && battle.getBattleType().isBombingRun() == bombing) {
1084-
battles.add(battle.getTerritory());
1085-
}
1086-
}
1087-
return battles;
1089+
private Collection<Territory> getPendingBattleSites(final boolean bombing) {
1090+
return pendingBattles.stream()
1091+
.filter(b -> !b.isEmpty() && b.getBattleType().isBombingRun() == bombing)
1092+
.map(IBattle::getTerritory)
1093+
.collect(Collectors.toSet());
10881094
}
10891095

1090-
public BattleListing getPendingBattleSites() {
1091-
final Map<BattleType, Collection<Territory>> battles = new HashMap<>();
1092-
for (final IBattle battle : pendingBattles) {
1093-
if (!battle.isEmpty()) {
1094-
Collection<Territory> territories = battles.get(battle.getBattleType());
1095-
if (territories == null) {
1096-
territories = new HashSet<>();
1097-
}
1098-
territories.add(battle.getTerritory());
1099-
battles.put(battle.getBattleType(), territories);
1100-
}
1101-
}
1102-
return new BattleListing(battles);
1096+
public BattleListing getBattleListingFromPendingBattles() {
1097+
return new BattleListing(pendingBattles);
11031098
}
11041099

11051100
/**
@@ -1131,9 +1126,9 @@ public void addDependency(final IBattle blocked, final IBattle blocking) {
11311126
}
11321127

11331128
private void removeDependency(final IBattle blocked, final IBattle blocking) {
1134-
final Collection<IBattle> dependencies = this.dependencies.get(blocked);
1135-
dependencies.remove(blocking);
1136-
if (dependencies.isEmpty()) {
1129+
final Collection<IBattle> dependenciesOfBlocked = this.dependencies.get(blocked);
1130+
dependenciesOfBlocked.remove(blocking);
1131+
if (dependenciesOfBlocked.isEmpty()) {
11371132
this.dependencies.remove(blocked);
11381133
}
11391134
}
@@ -1204,7 +1199,7 @@ void sendBattleRecordsToGameData(final IDelegateBridge bridge) {
12041199
*/
12051200
void fightAirRaidsAndStrategicBombing(final IDelegateBridge delegateBridge) {
12061201
fightAirRaidsAndStrategicBombing(
1207-
delegateBridge, () -> getPendingBattleSites(true), this::getPendingBattle);
1202+
delegateBridge, this::getPendingBattleSitesWithBombing, this::getPendingBattle);
12081203
}
12091204

12101205
@VisibleForTesting
@@ -1226,7 +1221,7 @@ void fightAirRaidsAndStrategicBombing(
12261221
}
12271222
}
12281223

1229-
// now that we've done all the air battles, do all the SBR's as a second wave.
1224+
// now that we've done all the air battles, do all the SBRs as a second wave.
12301225
for (final Territory t : pendingBattleSiteSupplier.get()) {
12311226
final IBattle bombingRaid = pendingBattleFunction.apply(t, BattleType.BOMBING_RAID);
12321227
if (bombingRaid != null) {

0 commit comments

Comments
 (0)