Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

12260 refresh pre & post #12757

Closed
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,7 @@
import VASSAL.i18n.Resources;
import VASSAL.tools.BrowserSupport;
import VASSAL.tools.ErrorDialog;
import VASSAL.tools.NamedKeyStroke;
import VASSAL.tools.swing.FlowLabel;
import VASSAL.tools.swing.SwingUtils;
import net.miginfocom.swing.MigLayout;
Expand Down Expand Up @@ -340,6 +341,10 @@ public void execute(Set<String> options, Command command) throws IllegalBuildExc
}
}

// About to commence refreshing the game, allow a custom start
GameModule.getGameModule().fireKeyStroke(NamedKeyStroke.of("VassalGHKpreRefresh"));


/*
* 2. Build a list in visual order of all stacks, decks, mats and other pieces that need refreshing
*/
Expand Down Expand Up @@ -536,8 +541,11 @@ else if (!decksToDelete.isEmpty()) {
log(Resources.getString("GameRefresher.refreshable_decks", refreshable));
log(Resources.getString(options.contains("DeleteOldDecks") ? "GameRefresher.deletable_decks" : "GameRefresher.deletable_decks_2", deletable)); //NON-NLS
log(Resources.getString(options.contains("AddNewDecks") ? "GameRefresher.addable_decks" : "GameRefresher.addable_decks_2", addable)); //NON-NLS

}
}
// After all refreshing, allow a custom finish
GameModule.getGameModule().fireKeyStroke(NamedKeyStroke.of("VassalGHKpostRefresh"));
}


Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ Whenever a piece is created in a VASSAL game, the Id of the definition used to c

The Game Refresher works by matching the Id in each piece in the current game to the Id's of all piece definitions in the current module to find the new definition. If a match is found, then the piece is replaced with one created from the new defintion. Then each trait in the new Piece is checked to see if there is an EXACTLY matching trait in the old definition. If an EXACT match is found, then the 'state' of the old trait is copied over (e.g. what is the current layer showing, or current rotation facing).

Problems occur when the definition used to create the piece no longer exists in the module, or if traits are modified slightly so that they no longer EXACTLY match the old piece. There are various options in the Game Refresher dialog that can be used to help match and update these pieces and traits.
Problems occur when the definition used to create the piece no longer exists in the module, or if traits are modified slightly so that they no longer EXACTLY match the old piece. There are various options in the Game Refresher dialog that can be used to help match and update these pieces and traits. In addition to these options, <<#RefreshHotkeys,special hotkeys>> can be used to perform custom maintenance routines which you have designed.

[.text-center]
image:images/GameRefresher.png[]
Expand Down Expand Up @@ -61,7 +61,7 @@ Remove Decks from the game that no longer exist in the module. See the <<#DeckRe

*Add decks to game which have been added to the module since this game was created (empty deck will be added):*::

Add Decks to teh game that have been added to the module. See the <<#DeckRefresher,Deck Refresher>> section below for full details.
Add Decks to the game that have been added to the module. See the <<#DeckRefresher,Deck Refresher>> section below for full details.


|===
Expand All @@ -77,7 +77,16 @@ If you select the _Refresh decks_ option when running the Game Refresher, existi
===== Adding and Deleting Decks
When _Refresh decks_ is selected, two additional options also become available, to add and delete decks.

If you select the _Delete decks_ option, then any deck found in the current game that does not match (by name and board) a deck in the module definition will be deleted. Any current contents (e.g., cards) in that deck will be left in a stack at the deck's former location.
If you select the _Delete decks_ option, then any deck found in the current game that does not match (by name and board) a deck in the module definition will be deleted. Any current contents (e.g. cards) in that deck will be left in a stack at the deck's former location.

If you select the _Add decks_ option, then any _new_ deck found in the module definition that does not exist in the game being refreshed will be _added_. Note this will not add any _contents_ (e.g., cards) to the deck, it will only add the deck. If you need to add contents you will need to arrange to add them separately, e.g., from a piece palette, or dragged in from some other location.
If you select the _Add decks_ option, then any _new_ deck found in the module definition that does not exist in the game being refreshed will be _added_. Note this will not add any _contents_ (e.g. cards) to the deck, it will only add the deck. If you need to add contents you will need to arrange to add them separately, e.g. from a piece palette, or dragged in from some other location.

[#RefreshHotkeys]
==== Pre & Post-Refresh Hotkeys
If this option is checked, the Refresher will trigger special hotkeys. _VassalGHKpreRefresh_ is triggered before refreshing and _VassalGHKpostRefresh_ after refreshing. You may use this feature to perform maintenance that you wish to carry out on Predefined Setup or game files. Potential uses include converting counters or populating a new deck.

Design and test your maintenance actions carefully. You can use _Refresh Counters_ to do one-off tests. Also, remember that Startup GKCs are not executed during Refresh Predefined Setups.

After a Refeshing Predefined Setups, save your module as a different file name so you can do re-runs on the original if need be.

Once you are done, consider disabling or removing the maintenance components so that further refreshes don’t trigger them accidentally.