From 0e26b92e04ecb335335d7e7d5cfd20d83395e5df Mon Sep 17 00:00:00 2001 From: Scoppio Date: Sun, 17 Nov 2024 08:41:56 -0300 Subject: [PATCH] feat: creates an interface for post game events, as necessary to implement the automated auto-resolve --- .../megamek/client/bot/ui/swing/BotGUI.java | 2 +- .../client/ui/swing/AbstractPhaseDisplay.java | 2 +- .../client/ui/swing/AccessibilityWindow.java | 2 +- .../boardview/BoardViewSpriteHandler.java | 2 +- .../swing/forceDisplay/ForceDisplayPanel.java | 2 +- .../megamek/common/event/GameListener.java | 8 ++++---- .../common/event/GameListenerAdapter.java | 8 ++++---- .../common/event/GameVictoryEvent.java | 8 +++++++- .../common/event/PostGameResolution.java | 19 +++++++++++++++++++ 9 files changed, 39 insertions(+), 14 deletions(-) create mode 100644 megamek/src/megamek/common/event/PostGameResolution.java diff --git a/megamek/src/megamek/client/bot/ui/swing/BotGUI.java b/megamek/src/megamek/client/bot/ui/swing/BotGUI.java index 89c273b547..84ab2208cd 100644 --- a/megamek/src/megamek/client/bot/ui/swing/BotGUI.java +++ b/megamek/src/megamek/client/bot/ui/swing/BotGUI.java @@ -134,7 +134,7 @@ public void gameClientFeedbackRequest(GameCFREvent evt) { } @Override - public void gameVictory(GameVictoryEvent e) { + public void gameVictory(PostGameResolution e) { } } diff --git a/megamek/src/megamek/client/ui/swing/AbstractPhaseDisplay.java b/megamek/src/megamek/client/ui/swing/AbstractPhaseDisplay.java index a0a7dfd179..4239e5a808 100644 --- a/megamek/src/megamek/client/ui/swing/AbstractPhaseDisplay.java +++ b/megamek/src/megamek/client/ui/swing/AbstractPhaseDisplay.java @@ -219,7 +219,7 @@ public void gameNewAction(GameNewActionEvent e) { } public void gameClientFeedbackRequest(GameCFREvent evt) { } @Override - public void gameVictory(GameVictoryEvent e) { } + public void gameVictory(PostGameResolution e) { } //endregion } diff --git a/megamek/src/megamek/client/ui/swing/AccessibilityWindow.java b/megamek/src/megamek/client/ui/swing/AccessibilityWindow.java index 666eb3a597..8040538ef4 100644 --- a/megamek/src/megamek/client/ui/swing/AccessibilityWindow.java +++ b/megamek/src/megamek/client/ui/swing/AccessibilityWindow.java @@ -266,7 +266,7 @@ public void gameClientFeedbackRequest(GameCFREvent e) { } @Override - public void gameVictory(GameVictoryEvent e) { + public void gameVictory(PostGameResolution e) { systemEvent("Game Victory! (unneeded.)"); } }; diff --git a/megamek/src/megamek/client/ui/swing/boardview/BoardViewSpriteHandler.java b/megamek/src/megamek/client/ui/swing/boardview/BoardViewSpriteHandler.java index 2f01263779..6418829e8b 100644 --- a/megamek/src/megamek/client/ui/swing/boardview/BoardViewSpriteHandler.java +++ b/megamek/src/megamek/client/ui/swing/boardview/BoardViewSpriteHandler.java @@ -121,6 +121,6 @@ public void gameNewAction(GameNewActionEvent e) { } public void gameClientFeedbackRequest(GameCFREvent e) { } @Override - public void gameVictory(GameVictoryEvent e) { } + public void gameVictory(PostGameResolution e) { } //endregion } diff --git a/megamek/src/megamek/client/ui/swing/forceDisplay/ForceDisplayPanel.java b/megamek/src/megamek/client/ui/swing/forceDisplay/ForceDisplayPanel.java index 023e5a3c21..f14ca359ea 100644 --- a/megamek/src/megamek/client/ui/swing/forceDisplay/ForceDisplayPanel.java +++ b/megamek/src/megamek/client/ui/swing/forceDisplay/ForceDisplayPanel.java @@ -331,7 +331,7 @@ public void gameClientFeedbackRequest(GameCFREvent evt) { } @Override - public void gameVictory(GameVictoryEvent e) { + public void gameVictory(PostGameResolution e) { // noaction default } diff --git a/megamek/src/megamek/common/event/GameListener.java b/megamek/src/megamek/common/event/GameListener.java index cea1067ad0..cc33f7ba76 100644 --- a/megamek/src/megamek/common/event/GameListener.java +++ b/megamek/src/megamek/common/event/GameListener.java @@ -23,7 +23,7 @@ * removed using the removeGameListener method. When Game is * changed the appropriate method will be invoked. *

- * + * * @see GameListenerAdapter * @see GameEvent */ @@ -61,10 +61,10 @@ public interface GameListener extends java.util.EventListener { void gameEntityChange(GameEntityChangeEvent e); void gameNewAction(GameNewActionEvent e); - + void gameClientFeedbackRequest(GameCFREvent e); - - void gameVictory(GameVictoryEvent e); + + void gameVictory(PostGameResolution e); default void gameScriptedEvent(GameScriptedEvent event) { } diff --git a/megamek/src/megamek/common/event/GameListenerAdapter.java b/megamek/src/megamek/common/event/GameListenerAdapter.java index 3e69b5d6ed..269362c0f0 100644 --- a/megamek/src/megamek/common/event/GameListenerAdapter.java +++ b/megamek/src/megamek/common/event/GameListenerAdapter.java @@ -21,7 +21,7 @@ * Classes that wish to deal with GamedEvents can extend this * class and override only the methods which they are interested in. *

- * + * * @see GameListener * @see GameEvent */ @@ -94,13 +94,13 @@ public void gameEntityChange(GameEntityChangeEvent e) { @Override public void gameNewAction(GameNewActionEvent e) { } - + @Override public void gameClientFeedbackRequest(GameCFREvent evt) { } @Override - public void gameVictory(GameVictoryEvent e) { - } + public void gameVictory(PostGameResolution e) { + } } diff --git a/megamek/src/megamek/common/event/GameVictoryEvent.java b/megamek/src/megamek/common/event/GameVictoryEvent.java index 6d0b98b11b..7afa4ec0ac 100644 --- a/megamek/src/megamek/common/event/GameVictoryEvent.java +++ b/megamek/src/megamek/common/event/GameVictoryEvent.java @@ -29,7 +29,7 @@ * @see Game#end(int, int) * @see GameListener */ -public class GameVictoryEvent extends GameEvent { +public class GameVictoryEvent extends GameEvent implements PostGameResolution { private static final long serialVersionUID = -8470655646019563063L; /** @@ -73,6 +73,7 @@ public String getEventName() { /** * @return an enumeration of all the entities in the game. */ + @Override public Enumeration getEntities() { return entities.elements(); } @@ -80,6 +81,7 @@ public Enumeration getEntities() { /** * @return the entity with the given id number, if any. */ + @Override public Entity getEntity(int id) { return entityIds.get(id); } @@ -88,6 +90,7 @@ public Entity getEntity(int id) { * @return an enumeration of salvageable entities. */ // TODO: Correctly implement "Captured" Entities + @Override public Enumeration getGraveyardEntities() { Vector graveyard = new Vector<>(); @@ -105,6 +108,7 @@ public Enumeration getGraveyardEntities() { /** * @return an enumeration of wrecked entities. */ + @Override public Enumeration getWreckedEntities() { Vector wrecks = new Vector<>(); for (Entity entity : vOutOfGame) { @@ -121,6 +125,7 @@ public Enumeration getWreckedEntities() { /** * Returns an enumeration of entities that have retreated */ + @Override public Enumeration getRetreatedEntities() { Vector sanctuary = new Vector<>(); @@ -137,6 +142,7 @@ public Enumeration getRetreatedEntities() { /** * Returns an enumeration of entities that were utterly destroyed */ + @Override public Enumeration getDevastatedEntities() { Vector smithereens = new Vector<>(); diff --git a/megamek/src/megamek/common/event/PostGameResolution.java b/megamek/src/megamek/common/event/PostGameResolution.java new file mode 100644 index 0000000000..217ebe89b0 --- /dev/null +++ b/megamek/src/megamek/common/event/PostGameResolution.java @@ -0,0 +1,19 @@ +package megamek.common.event; + +import megamek.common.Entity; + +import java.util.Enumeration; + +public interface PostGameResolution { + Enumeration getEntities(); + + Entity getEntity(int id); + + Enumeration getGraveyardEntities(); + + Enumeration getWreckedEntities(); + + Enumeration getRetreatedEntities(); + + Enumeration getDevastatedEntities(); +}