Compare commits

...

5231 Commits

Author SHA1 Message Date
Jetz72
01da2df6f0 Merge pull request #9080 from Jetz72/fixes20251104
Apply display/flavor names in more places
2025-11-04 09:53:20 -06:00
Fulgur14
ec84a3f137 TLA cards, 4th November (#9079) 2025-11-04 15:42:21 +01:00
Jetz
02e2e713ed Cleanup - use Card.getTranslatedName method 2025-11-04 09:27:12 -05:00
Jetz
a21666040c Apply Card.getDisplayName to user-facing text 2025-11-04 09:17:52 -05:00
Jetz
fe2bd016b6 Add card face display name for card name lists. 2025-11-04 08:41:42 -05:00
Fulgur14
0bb67ec8d0 TLA cards, 3rd November (#9072)
Firebender Ascension and support
2025-11-04 14:20:26 +01:00
Paul Hammerton
6d188c09ca Merge pull request #9077 from paulsnoops/edition-updates
Edition updates: PSPL, PURL, PW25, SLC, SLD, TLA, TLE
2025-11-04 09:29:50 +00:00
Paul Hammerton
f25d8c58d9 Edition updates: PSPL, PURL, PW25, SLC, SLD, TLA, TLE 2025-11-04 09:25:28 +00:00
Fulgur14
f9c5fc7317 Iroh's Demonstration (TLA) (#9076) 2025-11-04 10:20:02 +01:00
Fulgur14
02031e159d TLA/TLE cards 3rd November - Aftermath (#9075) 2025-11-04 10:03:56 +01:00
tool4ever
dd35f97035 Cleanup scripting API first pass (#9070) 2025-11-04 09:23:21 +01:00
tool4ever
ee045d854d Wiki cleanup: remove dead files (#9065) 2025-11-03 08:28:06 +01:00
Eradev
65e4fa7fd7 Minor card fixes (#9069)
* Update DDR

* Update BLB

* Update Realmbreaker, the Invasion Tree (Warning because SVar starts with X)

* Update LTR
2025-11-03 06:56:02 +01:00
tool4ever
be77cc1147 Add workflow_dispatch trigger to sync-wiki.yml 2025-11-02 18:01:03 +00:00
tool4ever
53683f2496 Change wiki sync branch from 'wiki' to 'master' 2025-11-02 17:55:14 +00:00
tool4ever
f0b937a5f0 Sync wiki from main repo (#8320) 2025-11-02 17:51:51 +00:00
Hans Mackowiak
def3fa5d23 build ValidTgtsDesc via Lang (#9063)
* build ValidTgtsDesc via Lang

* use buildValidDesc for AuraSpells

* Add ValidTgtsDesc to GUI message
2025-11-02 17:44:54 +01:00
Fulgur14
e33ddee5bf Agna Qel's (TLA leak) (#9062)
* Create mai_jaded_edge.txt

* Create iroh_tea_master.txt

* Update zedruu_the_greathearted.txt

* Update zedruus_lantern.txt

* Modify Agna Qel'a card attributes

Updated the land card description and abilities.
2025-11-02 17:59:16 +03:00
tool4ever
15fca4243d Fix reflected only checking activated mana abilities (#9058) 2025-11-02 10:50:16 +00:00
tool4ever
6bf288af38 Update trigger zones for Noctis card text 2025-11-01 20:39:58 +00:00
tool4ever
586e30af09 Update the_rise_of_sozin_fire_lord_sozin.txt
Closes #9059
2025-11-01 17:46:42 +00:00
Agetian
ab3c66fd0a Add puzzle PS_SPM3. (#9060)
* - Added puzzle PS_SPM3.

* - Minor mistype fix.
2025-11-01 20:26:38 +03:00
Janek Gröhl
ab4c91dd2d Implemented Commander variant of Adventure Mode (#8970)
* Added UI elements for commander mode in NewGame screen.
- still missing random pool of commander candidates sharing a color with each selected color identity.

* Added rudimentary commander choice with preview image.
For now, it is 5 suggestions per color identity with the requirement that the chosen color is part of the commander's identity.

* Commander card is now added to the player inventory and cannot be sold.
The save game adds a flag whether the game is in commander mode, which will be important for the future changes.

* Commander is now auto-added to the initial deck. Commander cannot be removed. Commander is properly saved and loaded.

* Duels now feature the command zone and all rules

* The chosen commander is now set to every deck if the game mode is commander.

* Only cards can be added to the deck that fulfill the color identity.

* heuristically add a pile of singleton cards to function as the starter for the commander's journey.

* Fix land color identity bug in commander pile

* Items are put on autosell if they do not match commander identity.

* Autosell is now properly set with the card flip timing rules. When visiting a shop, the deck conformaty message does not show anymore.

* Remove strict necessity for a fixed commander. This way, a player may choose to switch to a different legendary creature they find.

* 15 Streamlined commander choices without having to swap colors individually.

* Clean up to remove now redundant i18n label. More focus on creatures for starter commander decks.

* Refactor adventure commander deck generation into the DeckgenUtil class

* Refactorings as suggested by @Jetz72.

* Remove custom deck generator

* handle DeckFormat logic through AdventureDeckEditor.
Fix bugs, where partner commanders would be overwritten when using the stock DeckgenUtil.

* Remove random new line

* Code cleanup

* Fix unused import error

* Fix unused import error

* Revert "organise import" changes and random space linebreak changes.

* Removed another import package.* statement

* Implement fixed commander deck to start with. Removed UI edits and random commander choice.

* Add commander-specific cards and a two white overrun effects

* Revert to prior string formatting.

* Remove import *

* Formatting nitpicking to change as little original code as possible.

---------

Co-authored-by: Agetian <stavdev@mail.ru>
2025-11-01 19:56:55 +03:00
tool4ever
54b8094211 Some cleanup (#9056) 2025-11-01 14:44:47 +00:00
Fulgur14
1445fc2621 The Spirit Oasis (TLA) (#9054) 2025-10-31 20:52:32 +00:00
Fulgur14
d53d9a4ded TLA cards, 31st October (#9053) 2025-10-31 20:50:10 +00:00
Fulgur14
650bf09720 June, Bounty Hunter (TLA) (#9052) 2025-10-31 20:43:22 +00:00
Chris H
759c592b00 Fix trigger mana variable from SVar to DB (#9051) 2025-10-31 14:18:41 +00:00
Fulgur14
7d53fa88cf TLA cards, 30th October, Batch 2 (#9048) 2025-10-30 21:49:55 +00:00
Fulgur14
0de568ce71 TLA cards, 30th October (#9045) 2025-10-30 18:38:44 +00:00
Paul Hammerton
9f3120e2a9 Merge pull request #9046 from paulsnoops/edition-updates
Edition updates: TLA, TLE
2025-10-30 18:02:14 +00:00
Paul Hammerton
fc89ca7093 Edition updates: TLA, TLE 2025-10-30 18:01:05 +00:00
Eradev
4c44b6b337 Proper land selection when sacrificing 2025-10-30 13:50:59 +01:00
Fulgur14
3a1c3bf632 TLA cards, 28th October, Batch 3 (#9025) 2025-10-30 11:36:40 +01:00
Paul Hammerton
e5483f03c5 Add flavorName to editions (#9019) 2025-10-30 08:52:37 +01:00
Fulgur14
45e9bee6e5 Update gran_gran.txt (#9043) 2025-10-30 08:01:48 +01:00
Fulgur14
107aa63c07 TLA/TLE cards, 28th October, Batch 4 (#9031) 2025-10-29 21:58:27 +00:00
Fulgur14
106afcc200 TLA cards, 28th October, Batch 2 (#9024) 2025-10-29 21:58:06 +00:00
Fulgur14
2fc1c120f3 TLA cards, 28th October, Batch 1 (#9023) 2025-10-29 21:57:53 +00:00
Fulgur14
8a7f28858f TLA/TLE cards, 29th October (#9039) 2025-10-29 21:57:39 +00:00
Jetz72
149c14eea1 Fix CardRequest for unflavored name not preferring unflavored prints (#9040) 2025-10-29 21:55:11 +00:00
Paul Hammerton
f6c29f54b3 Merge pull request #9036 from paulsnoops/edition-updates-tla
Edition updates: SLD, TLA, TLE
2025-10-29 19:07:02 +00:00
Paul Hammerton
61f197b93c Edition updates: SLD, TLA, TLE 2025-10-29 19:06:01 +00:00
Eradev
124c595af5 Heist fix (#9032) 2025-10-29 10:53:41 +00:00
tool4EvEr
1cf6633b13 Fix corner case with Perplexing Chimera 2025-10-29 11:16:36 +01:00
Fulgur14
c8fd36682f Energybending (TLA) 2025-10-29 09:50:02 +00:00
Fulgur14
4673ec23bd Two TLA cards (#9020) 2025-10-28 16:22:55 +01:00
Paul Hammerton
b1ba531c64 Merge pull request #9018 from paulsnoops/edition-updates
Edition updates: LMAR, PF25, PMEI, PSPL, PW25, SLC, SLD, TLA, TLE
2025-10-28 10:26:24 +00:00
Paul Hammerton
2fa753d583 Edition updates: LMAR, PF25, PMEI, PSPL, PW25, SLC, SLD, TLA, TLE 2025-10-28 10:22:47 +00:00
Paul Hammerton
50c55a1893 Merge pull request #9017 from paulsnoops/formats-update
Archived formats update
2025-10-28 09:50:56 +00:00
Paul Hammerton
fdc65ffd85 Archived formats update 2025-10-28 09:45:15 +00:00
tool4ever
954031cdb2 Refactor AiProfile handling (#9012)
Co-authored-by: tool4EvEr <tool4EvEr@>
2025-10-28 07:26:18 +03:00
tool4ever
364845ab4e Fix Rock Hydra crash (#9011) 2025-10-27 19:25:41 +00:00
tool4ever
5fc1d4214b Restore check to treat empty room as dynamic state (#9009) 2025-10-27 17:03:15 +00:00
tool4ever
2ee356461c Update fire_lord_ozai.txt
Closes #9010
2025-10-27 16:38:09 +01:00
tool4ever
bfb0c9d41f Fix logic (#9008) 2025-10-27 10:11:46 +01:00
tool4ever
b272612c41 Clean up checks (#9006) 2025-10-26 22:02:08 +00:00
tool4ever
a6e8ac5ccf Subtlety fix (#9005) 2025-10-26 21:52:53 +00:00
Eradev
136940a16c Tokens cleanup (Sets T-Z) (#8159)
* Update TPR

* Update TMP

* Update 10E

* Update BRC

* Update BRO

* Update LTR

* Update ELD

* Update TSB

* Update TSP

* Update TOR

* Update PZ2

* Add r_1_1_soldier

* Update UNF

* Update UGL

* Update UNH

* Update 2ED

* Update UND

* Update UDS

* Update ULG

* Update USG

* Update VIS

* Update VMA

* Update 40K

* Update WAR

* Update WTH

* Update WWK

* Update PZEN

* Update ZEN

* Update ZNR

* Update ZNC

* Update WOE WOC

* Add mention needing to flip tokens

* Rename w_2_2_cat flying.txt to w_2_2_cat_flying.txt

fix name

* Fix squad token names

---------

Co-authored-by: Hans Mackowiak <hanmac@gmx.de>
2025-10-26 22:48:54 +01:00
Hans Mackowiak
76b9da7e22 Update PhaseHandler.java
Add missing break
2025-10-26 17:17:04 +01:00
Hans Mackowiak
f291e9ea59 Fix Multiple Replacement Effects not working correctly 2025-10-25 16:03:19 +02:00
Fulgur14
42a14cfad0 Sozin's Comet (TLA) (#8993) 2025-10-25 10:52:29 +02:00
Jetz72
ed3bc665e2 Update grolnoks_skin.txt
Fix a couple card names in the spellbook.

Closes #8989
2025-10-24 17:22:35 +02:00
Hans Mackowiak
0eb3062c64 CardCloneStates: EmptyRoom should be affected by CloneStates 2025-10-24 09:35:32 +02:00
Hans Mackowiak
4063ac55e6 AbilityUtils: refactor Party types (#8967) 2025-10-23 23:04:22 +02:00
Hans Mackowiak
4cb581152e Update fearsome_whelp.txt
Closes #8982
2025-10-23 11:27:43 +02:00
Cees Timmerman
43525ce657 Fix AI helps opponent create an army (#8901) (#8902) 2025-10-22 20:53:58 +03:00
Hans Mackowiak
8c2c32a3d8 CardRules: fix toUnmodifiableList for Android 2025-10-22 19:27:33 +02:00
Jetz72
7ea1c51990 Escape closed bracket character (#8978)
I *think* this might be what's breaking Android? Digging up docs for old versions is a pain.
2025-10-22 17:07:06 +02:00
Jetz72
b0ee850d0f Merge pull request #8976 from Jetz72/fixes20251022
Revert to numbered capturing groups in CardEdition regexes
2025-10-22 09:29:41 -04:00
Jetz
21a293a458 Revert non-capturing groups too 2025-10-22 09:21:48 -04:00
Jetz
e67365e0d6 Removed one last named group.
Change name group to require at least one character
2025-10-22 08:57:25 -04:00
Jetz
8f12828617 Revert to numbered capturing groups in CardEdition regexes 2025-10-22 08:31:59 -04:00
JoeMoCode
1cb873a1da Fixing issue 8925 - AI has trouble casting spells that create X-toughness creatures. (#8972) 2025-10-22 10:26:46 +03:00
Jetz72
f9b6652c2a Flavor Names (#8849)
* Make getAllFaces return nonnull list

* Optimize Predicates

* CardDB and script syntax changes

* Apply syntax changes

* In-game support for flavor names

* Add display names to PaperCards

* Support searching by flavor names

* Remove some WIP stuff

* Update PaperCard translation key.

* Update capitalization

* Auto-map to variants when edition entry uses a flavor name

* Consolidate display name logic.

* Added syntax for generating flavor named variants in edition files.

* Some examples of new syntax.

* Ignore flavored oracle text when searching rules text

* add hasFlavorName

* Add image key

* Get correct variant from card requests with flavor names.
2025-10-21 15:00:59 +02:00
tool4ever
1188b6889a Fix triggered Iterable missing support for LKI (#8968) 2025-10-21 08:58:53 +00:00
Paul Hammerton
ea590f8574 Merge pull request #8966 from Darthseid/patch-1
Updated to match MTG Arena changes.
2025-10-20 21:11:49 +01:00
Darthseid
6cc2dcf3f0 Updated to match MTG Arena changes. 2025-10-20 22:02:40 +02:00
Darthseid
42357d5d6f Updated to match MTG Arena changes. 2025-10-20 22:02:40 +02:00
Darthseid
21977e7dcd Updated to match MTG Arena changes.
https://www.reddit.com/r/MagicArena/comments/16b18t8/a_bunch_of_cards_were_unnerfed_for_rotation_to/
2025-10-20 22:02:40 +02:00
Darthseid
608a1c11ed Updated Official MTG Arena Change. 2025-10-20 22:02:40 +02:00
Darthseid
79d1f6f1da Updated MTG Arena Balance Change. 2025-10-20 22:02:40 +02:00
Darthseid
2fc6935563 Corrected Traumatic Prank's mana cost. (#8962)
It was previously 3R. You can see the actual cost and effects here: https://scryfall.com/card/ysnc/12/traumatic-prank
2025-10-20 18:20:57 +02:00
Hans Mackowiak
5efd7e6e7c ColorSet: add combine function (#8960) 2025-10-20 09:45:57 +02:00
tool4ever
a8d494d2d8 Update ComputerUtilCombat.java 2025-10-20 07:58:03 +02:00
tool4ever
7367e93140 Fix not being able to freely divide combat damage to attackers (#8961) 2025-10-19 20:50:57 +00:00
tool4ever
6f38479190 Fix AI not targeting triggered Random Charm (#8955) 2025-10-19 18:57:11 +00:00
Eradev
80a4a42575 Card typo and rewards fixes (#8953) 2025-10-19 08:17:21 +00:00
tool4ever
24ef895cb7 Fix Leonardo (#8949) 2025-10-19 08:15:36 +00:00
Fulgur14
472f94af66 Leonardo, Sewer Samurai (TMT) (#8948) 2025-10-18 19:13:59 +00:00
Hans Mackowiak
a99c899eec GameAction: cleanup Static giving Abilities to the Stack (#8587)
* Add test that fails on master engine (before KeywordCollection sanity fix)
2025-10-18 12:24:29 +00:00
Cees Timmerman
d94fe1e958 Fix Elturel Survivors not played (#8920) (#8921) 2025-10-18 07:29:39 +00:00
Hans Mackowiak
27a638a32b TMT: Add Sneak (#8915)
* TMT: Add Sneak

* Sneak on Creature
2025-10-18 09:27:38 +02:00
Hans Mackowiak
a0a3546691 GameObject: turn into an interface 2025-10-17 21:01:37 +02:00
Hans Mackowiak
bbf5319815 KeywordCollection: Use linkedHashSetValues to prevent duplicates (#8941) 2025-10-17 15:55:46 +00:00
tool4ever
5588268c74 Fix complex targeting restriction in mysterious_stranger (#8940) 2025-10-17 13:59:55 +02:00
tool4ever
b9008b7f12 Update heroes_in_a_half_shell.txt 2025-10-17 10:50:01 +02:00
Fulgur14
32fb982d0d Update the_lost_and_the_damned.txt (#8931) 2025-10-16 14:29:08 +00:00
Jetz72
efbba093e0 Merge pull request #8500 from Jetz72/setEventCommand
Refactor event generation, add `set event` command.
2025-10-16 10:24:20 -04:00
Jetz
4a616c8ac6 Move round calculation to after participant amount is set. 2025-10-16 09:09:08 -04:00
tool4ever
f64701d039 Raphael, Tag Team Tough and support (#8936) 2025-10-16 09:04:40 +00:00
tool4ever
77dae2418f Clean up Ruin Grinder (#8930) 2025-10-16 08:05:41 +00:00
Jetz
7e47a6ee2c Move EventStyle specification closer to similar parameters. 2025-10-15 09:53:36 -04:00
Jetz
1093984bec Merge branch 'master' into setEventCommand
# Conflicts:
#	forge-gui-mobile/src/forge/adventure/data/AdventureEventData.java
#	forge-gui-mobile/src/forge/adventure/stage/MapStage.java
#	forge-gui-mobile/src/forge/adventure/util/AdventureEventController.java
2025-10-15 09:19:44 -04:00
tool4ever
8ae1bcd2c5 Update mazes_end.txt
Closes #8933
2025-10-15 13:22:00 +02:00
tool4ever
f9150bea34 Fix Bitterbloom Bearer (#8932) 2025-10-15 11:30:41 +02:00
tool4ever
04186de397 Update bitterbloom_bearer.txt 2025-10-15 11:19:33 +02:00
Fulgur14
4827e10bd4 Create turtles_forever.txt (#8927) 2025-10-15 08:10:15 +02:00
tool4ever
da92a93d1d Fix The Lost and the Damned not triggering for tokens (#8928)
Co-authored-by: tool4EvEr <tool4EvEr@>
2025-10-15 08:12:50 +03:00
Hans Mackowiak
6b17b65084 Update shriek_treblemaker.txt
Closes #8929
2025-10-15 04:55:59 +02:00
tool4ever
fac5b6c253 Support Turtles Forever (#8926) 2025-10-14 17:16:21 +00:00
Hans Mackowiak
6617e2627c Conquest: make ColorButton instead of ColorFilter 2025-10-14 11:51:14 +02:00
Hans Mackowiak
17d361d62d ~ lf 2025-10-14 08:53:07 +00:00
tool4ever
05a81d00fd Update rally_maneuver.txt
Closes #8924
2025-10-14 06:58:59 +00:00
tool4ever
808ecde0c0 Update the_death_of_gwen_stacy.txt 2025-10-14 08:02:17 +02:00
Fulgur14
7fb7c62fbe 15 TMT/TMC cards (#8895) 2025-10-13 17:50:20 +00:00
tool4ever
6ddb3124ac Fix Pump / Draw AI half broken (#8918) 2025-10-13 17:49:05 +00:00
Hans Mackowiak
c454253d48 ManaCostShard: build imageKey
Remove "/" dynamic for `imageKey`
2025-10-12 22:23:12 +02:00
Hans Mackowiak
fdbdffd874 Update DeckRecognizer.java
Remove extra manaSymbolsMap
2025-10-12 22:22:41 +02:00
Renato Filipe Vidal Santos
010f917550 Update consuming_ferocity.txt 2025-10-12 15:58:27 +02:00
Renato Filipe Vidal Santos
43cefed048 Update lumbering_laundry.txt 2025-10-12 15:23:59 +02:00
Renato Filipe Vidal Santos
3d15f743c3 Update the_darkness_crystal.txt 2025-10-12 15:23:59 +02:00
Paul Hammerton
f05170c1a4 Merge pull request #8907 from Eradev/FixMissingTokenMED
Update MPS_RNA
2025-10-12 11:25:19 +01:00
Eradev
9147836f1a Update MPS_RNA 2025-10-11 18:49:48 -04:00
Paul Hammerton
098c98570d Merge pull request #8899 from paulsnoops/edition-updates
Edition updates: PMEI, PZA, SLD, TMC, TMT
2025-10-11 10:27:22 +01:00
Paul Hammerton
8bb15f6bbc Edition updates: PMEI, PZA, SLD, TMC, TMT 2025-10-11 10:25:52 +01:00
Eradev
63002aba97 Fix Ambitious Dragonborn (#8898)
* Update IKO

* Update Ambitious Dragonborn
2025-10-11 09:05:20 +03:00
Eradev
52adb2dc2b Ensure you get the valid card (#8878) 2025-10-11 09:05:08 +03:00
Renato Filipe Vidal Santos
8478d3ce47 Adventure cleanup: 2025-10-10 (#8896)
* Update skep_outer.tmx

* Update skep_outer.tmx

* Update skep_outer.tmx

* Update quests.json

* Update quests.json

* Update quests.json

* Update quests.json
2025-10-11 09:03:43 +03:00
Hans Mackowiak
02c865765b Update DeckRecognizer.java
remove call to getLocalisedMagicColorName
2025-10-10 11:26:40 +02:00
Hans Mackowiak
327d60ed84 Update doctor_octopus_master_planner.txt
Closes #8879
2025-10-09 17:39:26 +02:00
Hans Mackowiak
f8d883d91f ColorSet: turn Set into an Enum (#8757) 2025-10-09 15:03:45 +02:00
Eradev
1962a8d28b Fix typo 2025-10-08 21:10:14 -04:00
Eradev
f3ecd51253 Minor cleanup 2025-10-08 21:10:14 -04:00
Eradev
bceb3c4503 Check every edition of a card instead of just the first one 2025-10-08 21:10:14 -04:00
Eradev
87977e836d Update PLS 2025-10-08 21:10:14 -04:00
tool4ever
7b8f69a022 Update ComputerUtilCombat.java 2025-10-08 21:07:40 -04:00
Agetian
a0442e7c3e - Tweak the parameter names. 2025-10-08 21:07:40 -04:00
Agetian
845969bc34 Update forge-ai/src/main/java/forge/ai/ComputerUtilCombat.java
Co-authored-by: Chris H <zenchristo@gmail.com>
2025-10-08 21:07:40 -04:00
Agetian
4256d9ae1f - Add a TODO. 2025-10-08 21:07:40 -04:00
Agetian
3a956c4e20 - Take 4. Avoid creating an extra CardCollection unless needed. 2025-10-08 21:07:40 -04:00
Agetian
590abbe8e6 - Assign the result of the orderBlockers call. 2025-10-08 21:07:40 -04:00
Agetian
29fe1266d7 - Reuse AiBlockController.orderBlockers 2025-10-08 21:07:40 -04:00
Agetian
6152933766 - Only call the sort command in case legacy ordering is disabled, assume sorted elsewhere otherwise. 2025-10-08 21:07:40 -04:00
Agetian
af947c9af5 - Fix comment placement 2025-10-08 21:07:40 -04:00
Agetian
7deb7b1ecc - Fix AI not ordering combatants for damage in non-legacy mode - take two (inside distributeAIDamage) 2025-10-08 21:07:40 -04:00
Agetian
5a19c9ed7e Revert "- Fix AI not ordering combatants for damage in non-legacy mode."
This reverts commit ff784183dc.
2025-10-08 21:07:40 -04:00
Agetian
bbd9fb7c37 - Fix AI not ordering combatants for damage in non-legacy mode. 2025-10-08 21:07:40 -04:00
Eradev
4e17b4c9d2 Missing import 2025-10-08 21:06:33 -04:00
Eradev
caf8b0535f CardUtil File format 2025-10-08 21:06:33 -04:00
Eradev
0ee3dc4e67 Check for Snow lands and Wastes when generating random decks 2025-10-08 21:06:33 -04:00
kevlahnota
3847080221 Merge pull request #8875 from kevlahnota/master4
prevent NPE
2025-10-09 06:10:12 +08:00
Anthony Calosa
f7c965de02 prevent NPE 2025-10-09 06:06:59 +08:00
tool4ever
b844181c0b Benevolent Blessing: fix exception ignoring opponent auras (#8870) 2025-10-08 18:58:12 +00:00
Agetian
7f02c73090 Further amendment to AI MoveCounters (#8869) 2025-10-08 17:55:55 +00:00
Agetian
f0f1f5a1d4 Slight cleanup amendment to the MoveCounters AI (#8866)
* - Fix MoveCounters with beneficial counters.

* - Slight cleanup.
2025-10-08 14:23:11 +03:00
Agetian
5a59113d78 - Fix MoveCounters with beneficial counters. (#8865) 2025-10-08 14:08:24 +03:00
Eradev
6935f962d3 Update AKH (#8863) 2025-10-08 11:39:43 +02:00
Jetz72
34002a1ed7 Merge pull request #8858 from Jetz72/templateFixes
Add issue types to github templates
2025-10-07 14:59:33 -04:00
Jetz72
a22f28ef50 Update feature_request.md 2025-10-07 14:53:15 -04:00
Jetz72
f6d33ed483 Update bug_report.md
Add issue type to template.
2025-10-07 14:51:51 -04:00
Renato Filipe Vidal Santos
5fae32e048 Add files via upload (#8846)
Co-authored-by: Agetian <stavdev@mail.ru>
2025-10-07 18:58:21 +03:00
Eradev
ab1d423e28 Update the_soul_stone.txt (#8854) 2025-10-07 06:31:55 +02:00
Eradev
1b8c87e578 Fix event init 2025-10-07 06:30:10 +02:00
Hans Mackowiak
bbf7a25979 Refactor UnlockedDoors using PlayerProperty 2025-10-07 06:29:20 +02:00
kevlahnota
31c2686307 Merge pull request #8852 from kevlahnota/master4
prevent NPE
2025-10-07 09:48:10 +08:00
Anthony Calosa
04f454ae83 prevent NPE 2025-10-07 05:32:41 +08:00
tool4ever
5b2a56bd4d Update the_rise_of_sozin_fire_lord_sozin.txt 2025-10-06 17:52:18 +00:00
Eradev
5bbc86c1a1 Fix crash in Quest rewards screen 2025-10-06 07:41:52 -04:00
Eradev
a5765905d8 Fix Quest start with boosters and unsactionned pool 2025-10-06 07:41:52 -04:00
tool4ever
c4a3b5c545 Update avatar_aang_aang_master_of_elements.txt 2025-10-06 13:01:37 +02:00
tool4ever
81e1306cd7 Update garland_royal_kidnapper.txt 2025-10-05 18:31:42 +00:00
Hans Mackowiak
39f6377f33 remove leftover variable 2025-10-05 19:12:38 +02:00
Hans Mackowiak
0af4be42c4 DungeonsCompleted with handlePaid (#8842) 2025-10-05 18:31:12 +02:00
Agetian
da8b77acf7 Add AtOppEOT logic to a couple lands that the AI misuses (#8839)
* - AtOppEOT is automatic now (also tweak the FlipACoinAi template to make use of it)

* - AILogic$ Never is now generic.
2025-10-05 16:21:15 +00:00
Hans Mackowiak
4cef049a1d AbilityUtils: move SumPower to handlePaid (#8838)
* AbilityUtils: move SumPower to handlePaid

* Replace SumPower with CardPower

* Replace SumToughness with CardToughness
2025-10-05 11:27:21 +02:00
tool4ever
8cd386b654 Update ChangeZoneAi.java 2025-10-05 08:39:51 +00:00
tool4ever
c1e87334cd Some cleanup (#8833) 2025-10-04 20:31:47 +00:00
Jetz72
3ae3e1b218 Merge pull request #8828 from Eradev/FixDivZero
Fix Div by zero error for collection percentage.
2025-10-04 09:37:24 -04:00
Hans Mackowiak
7acfe6c240 Different names rework (#8823)
* turn CardChangedName into record

* Add CardLists.getDifferentNamesCount

* CostDiscard: rename to +WithDifferentNames

* CostSacrifice: use getDifferentNamesCount

* Refactor DifferentCardNames_
2025-10-04 15:36:17 +02:00
tool4ever
66a8e1f04f Fix Henzie + Gorex (#8829) 2025-10-04 11:30:21 +00:00
Eradev
091c61829b Fix Div by zero error 2025-10-04 03:56:40 -04:00
kevlahnota
a2b324c9ce prevent NPE VAvatar.java 2025-10-04 07:50:11 +08:00
Paul Hammerton
4ab8c1414c Merge pull request #8827 from paulsnoops/fix-sld
Edition updates: SLD
2025-10-03 21:29:03 +01:00
Paul Hammerton
46df4cdb0d Edition updates: SLD 2025-10-03 21:28:30 +01:00
tool4ever
183100fbdc Update soul_collector.txt 2025-10-03 20:16:57 +00:00
squee1968
50c7188e04 Update chocobo_camp.txt 2025-10-03 21:17:34 +02:00
Chris H
d46d7300b4 Reduce cost of Bird creature token spell 2025-10-02 23:40:28 -04:00
tool4ever
27a0a8f791 Update the_spot_living_portal.txt
Closes #8819
2025-10-02 19:48:54 +00:00
Paul Hammerton
5a63250735 Merge pull request #8817 from paulsnoops/edition-updates
Edition updates: ECL, FIC, FIN, SLD, SLP
2025-10-01 18:13:23 +01:00
Paul Hammerton
04fbe9fac3 Edition updates: ECL, FIC, FIN, SLD, SLP 2025-10-01 18:12:16 +01:00
tool4ever
31f8da5687 Some fixes (#8816) 2025-10-01 14:54:46 +00:00
Hans Mackowiak
c0fe93ee30 Update the_destined_thief.txt
fix DBDraw SVars
2025-10-01 11:39:31 +02:00
Simisays
a1042e0a1d Update jin_sakai_ghost_of_tsushima.txt (#8815) 2025-09-30 19:24:51 +00:00
Hans Mackowiak
cdbf10f1f7 Change type desc (#8809)
* add ChangeTypeDesc for basic land

* Search N is up to

* add some more ChangeTypeDesc

* add some more ChangeTypeDesc

* add some more ChangeTypeDesc

* Update panorama

* update landscape

* Update Clan Monuments

* Small Monument to Perfection change

* update capenna fetchers

* remove ChangeNum from basic Land searchers

* better desc for fetch lands

* remove uneeded ChangeTypeDesc
2025-09-30 20:43:42 +02:00
Simisays
bc6eed5c7d Update joel_resolute_survivor.txt (#8814) 2025-09-30 17:32:21 +00:00
Simisays
b90c14660c FIC 12 Panorama/Holiday box cards (#8803) 2025-09-30 14:22:24 +00:00
Renato Filipe Vidal Santos
eeac0272ab YEOE: 7 cards (#8476) 2025-09-30 06:42:50 +00:00
Renato Filipe Vidal Santos
dcdf2b6e7a YEOE: 4 cards, batch 3 (#8499) 2025-09-30 06:35:08 +00:00
Renato Filipe Vidal Santos
dab01c9b86 YEOE: 4 cards, batch 2 (#8451) 2025-09-30 05:48:49 +00:00
Fulgur14
74dc09b2e5 12 FIC Scene cards + Formidable Speaker (#8808) 2025-09-29 18:07:43 +00:00
Hans Mackowiak
8dc9a18c4f Card: addColor use internal Record (#8793) 2025-09-29 16:31:21 +02:00
Hans Mackowiak
a390284b8e Property cleanup (#8804)
* remove NotTriggeredCard

* remove nonManaAbility

* remove notattacking and notblocking

* remove notnamed
2025-09-28 21:55:25 +02:00
Hans Mackowiak
1d97a4ec7e Update eirdu_carrier_of_dawn_isilu_carrier_of_twilight.txt 2025-09-28 21:20:22 +02:00
Simisays
a21a61cb05 SLD 11 cards + support for new partner variants (#8797) 2025-09-28 19:07:54 +00:00
Simisays
cd84663bed [ECL] 10 cards (#8794) 2025-09-28 13:55:52 +00:00
Hans Mackowiak
4d2b634e4f cantBeEnchantedByMsg and cantAttach StaticAbility (#8772)
* cantBeEnchantedByMsg and cantAttach StaticAbility

* finish cantBeAttachedMsg
2025-09-28 15:35:19 +02:00
tool4ever
4eccfa8177 Restore fixes (#8800) 2025-09-28 07:09:47 +00:00
Paul Hammerton
90ea109a17 Merge pull request #8795 from paulsnoops/edition-updates
Edition updates: ECL, OLGC, OVNT, SLD
2025-09-27 10:42:39 +01:00
Paul Hammerton
a9c42fb340 Edition updates: ECL, OLGC, OVNT, SLD 2025-09-27 10:40:42 +01:00
kevlahnota
f1a095fb56 Merge pull request #8792 from kevlahnota/master4
add breadcrumb to GameAction moveTo
2025-09-27 08:16:02 +08:00
Anthony Calosa
4ed06fae87 add breadcrumb to GameAction moveTo 2025-09-27 08:08:53 +08:00
tool4ever
0d020070a2 Fix tapped cost parts blocking real payment (#8789) 2025-09-26 23:20:04 +00:00
Paul Hammerton
5d39efd9fc Merge pull request #8787 from paulsnoops/edition-updates
Edition updates: AA3, AA4, ECL, MAR, PMEI, SLD, TLE
2025-09-26 17:47:55 +01:00
Paul Hammerton
fd5555fdd6 Edition updates: AA3, AA4, ECL, MAR, PMEI, SLD, TLE 2025-09-26 17:46:48 +01:00
Hans Mackowiak
6dd10be044 Update wild_pack_squad.txt
Closes #8786
2025-09-26 17:00:33 +02:00
Agetian
1b419a13e8 - Fix isWebSligned in Card.
- Add puzzleds PS_SPM1 and PS_TLA1.
2025-09-26 16:07:20 +02:00
Chris H
c0f5615885 Manually fixing version touches 2025-09-26 09:08:49 -04:00
tool4ever
c10b5706f1 Some fixes (#8779) 2025-09-26 08:48:22 +02:00
kevlahnota
9599d01d2c Merge pull request #8780 from kevlahnota/master4
fix Vertical layout for VManaPool
2025-09-26 08:32:51 +08:00
Anthony Calosa
f11c2ad8a4 fix Vertical layout for VManaPool 2025-09-26 08:29:07 +08:00
kevlahnota
20479518da Merge pull request #8777 from kevlahnota/master4
fix removing item by name
2025-09-25 06:57:09 +08:00
Anthony Calosa
1ded8fe5da fix removing item by name 2025-09-25 06:51:02 +08:00
Hans Mackowiak
2d1fe88d32 FSkinProp: unify Enum to SkinProp places (#8764)
* FSkinProp: unify Enum to SkinProp places

* FSkinProp: add iconFromDeckSection
2025-09-24 19:52:58 +02:00
Paul Hammerton
7ca0c2b87b Merge pull request #8776 from paulsnoops/archived-formats-update
Format updates: AA3, AA4
2025-09-24 17:53:50 +01:00
Paul Hammerton
e4a83de6cf Format updates: AA3, AA4 2025-09-24 17:52:33 +01:00
Paul Hammerton
7321aac496 Merge pull request #8774 from paulsnoops/edition-updates
Edition updates: AA3, AA4, ECL, SLD
2025-09-24 09:24:00 +01:00
Paul Hammerton
28dcdf6ddf Update Secret Lair Drop Series.txt 2025-09-24 09:21:44 +01:00
Paul Hammerton
5999909d32 Create Arena Anthology 4.txt 2025-09-24 09:19:15 +01:00
Paul Hammerton
0036c27470 Create Arena Anthology 3.txt 2025-09-24 08:50:46 +01:00
Paul Hammerton
7325443da5 Create Lorwyn Eclipsed.txt 2025-09-24 08:29:33 +01:00
kevlahnota
c4c1388f8b Merge pull request #8773 from kevlahnota/master4
fix NoSuchMethodError on older Android
2025-09-24 13:57:46 +08:00
Anthony Calosa
f4e90e1d38 fix NoSuchMethodError on older Android
- closes #8771
- closes #8770
2025-09-24 13:47:12 +08:00
Renato Filipe Vidal Santos
ab3b00cb65 Cleanup 2025-09-23 2025-09-23 16:26:25 +00:00
kevlahnota
a6cbbeef84 Merge pull request #8767 from kevlahnota/master4
update Sentry, update oshi, update android-all, npe prevention
2025-09-23 19:17:46 +08:00
Anthony Calosa
40629a72a9 update Sentry, update oshi, update android-all, npe prevention 2025-09-23 19:09:15 +08:00
squee1968
f6bc6d6742 Fix Lady Octopus, Inspired Inventor (#8766)
* Fix Lady Octopus, Inspired Inventor
2025-09-23 10:00:33 +02:00
Hans Mackowiak
da52bc17e8 GameEventAttachment: flip oldTarget and newTarget param (#8761)
* GameEventAttachment: flip oldTarget and newTarget param

---------

Co-authored-by: tool4EvEr <tool4EvEr@>
2025-09-22 16:16:57 +02:00
Hans Mackowiak
50b7543933 ColorEnum: use ITranslatable interface 2025-09-22 16:14:21 +02:00
Chris H
a4378a20e5 Manually fixing version touches 2025-09-21 20:58:46 -04:00
GitHub Actions
a6395373f7 Restore POM files for preparation of next release 2025-09-21 20:58:46 -04:00
GitHub Actions
54f41a28cd [maven-release-plugin] prepare for next development iteration 2025-09-21 20:58:46 -04:00
GitHub Actions
a2c798ba86 [maven-release-plugin] prepare release forge-2.0.06 2025-09-21 20:58:46 -04:00
Chris H
8f7a77354a Update apt-get so latest libxml2-utils is available 2025-09-21 20:58:46 -04:00
kevlahnota
b50cdea5df Update drop_tower.txt 2025-09-22 06:37:26 +08:00
Renato Filipe Vidal Santos
a7568b0845 Cleanup 2025-09-21 2025-09-21 07:30:43 +00:00
kevlahnota
e158b5966e Merge pull request #8755 from kevlahnota/master4
use Supplier for FModel for thread safety
2025-09-21 09:01:18 +08:00
kevlahnota
bea5ffb0a8 Update FModel.java
unused var
2025-09-21 08:51:30 +08:00
Anthony Calosa
ac492fac35 use Supplier for FModel for thread safety 2025-09-21 08:47:28 +08:00
Renato Filipe Vidal Santos
35e6268a95 Add files via upload (#8754) 2025-09-20 19:58:28 +03:00
Hans Mackowiak
90bd0c73d0 Transform: all DFC can transform now 2025-09-20 18:11:39 +02:00
kevlahnota
ea293a46b1 Merge pull request #8750 from kevlahnota/master4
update FModel, add Icon Overlay for Horizontal tabs
2025-09-19 22:58:47 +08:00
Anthony Calosa
6ec6d64cb2 update FModel, add Icon Overlay for Horizontal tabs 2025-09-19 22:06:38 +08:00
Chris H
9bc6ab747d Update Venom, Eddie Brock's power and toughness 2025-09-19 09:22:54 -04:00
kevlahnota
a72df6ad16 updateRarityFilterOdds (#8746) 2025-09-19 07:19:50 +02:00
Renato Filipe Vidal Santos
1105b3fcbd Add files via upload 2025-09-19 07:14:55 +02:00
kevlahnota
08239def86 Merge pull request #8745 from kevlahnota/master4
fix gap and visibility on horizontal layout
2025-09-19 10:39:52 +08:00
Anthony Calosa
cb7fc3df4e fix gap and visibility on horizontal layout 2025-09-19 10:32:18 +08:00
tool4EvEr
9b8020bb30 Fix copied SA using old replacingObjects 2025-09-18 21:20:21 +02:00
Eradev
398917d010 Support named abilities (#8464)
* Support named abilities

* Check if spell was cast from a named ability
2025-09-18 20:15:07 +03:00
tool4ever
10a68c27d5 Update omarthis_ghostfire_initiate.txt 2025-09-18 16:36:25 +00:00
kevlahnota
ba4ee98c3b Merge pull request #8741 from kevlahnota/master4
remove duplicated code and minor format
2025-09-18 19:44:29 +08:00
Anthony Calosa
c2c3add52b update switch 2025-09-18 19:35:23 +08:00
Anthony Calosa
1c7bc1c0d3 remove duplicated code and minor format 2025-09-18 19:27:55 +08:00
tool4EvEr
14f146f8d0 Remove TargetsFromSingleZone 2025-09-18 08:02:15 +02:00
kevlahnota
0cab03b96c Update VManaPool.java 2025-09-18 06:37:45 +08:00
tool4ever
8f5f2059a2 Fix Self-Destruct (#8730) 2025-09-17 18:58:40 +00:00
Hans Mackowiak
34323107c9 AetherFilter: use Predicate for Caption (#8724)
* AetherFilter: use Predicate for Caption
2025-09-17 18:00:08 +02:00
kevlahnota
dbf9568866 Merge pull request #8726 from kevlahnota/master4
update setlookup files
2025-09-17 14:13:38 +08:00
Anthony Calosa
7933893dcb update setlookup files
- closes #8721
2025-09-17 14:08:54 +08:00
kevlahnota
415e2c12e1 Merge pull request #8725 from kevlahnota/master4
fix tab display area size on Horizontal layout
2025-09-17 12:28:25 +08:00
Anthony Calosa
930019db40 fix tab display area size on Horizontal layout 2025-09-17 12:24:35 +08:00
tool4ever
72139b523c Improve AI timeout detection (#8723) 2025-09-16 18:04:00 +00:00
Hans Mackowiak
6cf2f20cdc ColorSet: store EnumSet and toString as Final (#8720) 2025-09-16 16:32:16 +02:00
kevlahnota
cebddb7f4b Update damage_control_crew.txt 2025-09-16 15:38:33 +08:00
kevlahnota
4a6275d282 Merge pull request #8710 from Card-Forge/enhance-prize-visiblity
Only show event cost before you sign up for the event
2025-09-16 15:15:58 +08:00
kevlahnota
bdeaf8cef1 Merge pull request #8719 from kevlahnota/master4
update AltZoneLayout VCardDisplayArea for Landscape
2025-09-16 12:11:22 +08:00
Anthony Calosa
40f6a5b472 update 2025-09-16 12:03:18 +08:00
Anthony Calosa
f4bff30680 update AltZoneLayout VCardDisplayArea for Landscape
- Off (Default Layout)
- Vertical (Alt Layout with old Vertical Scroll Card Display Area)
- Horizontal (Alt Layout with Horizontal Scroll Card Display Area)
- fix mouse scroll to scroll horizontall while ShiftKey is pressed
2025-09-16 11:50:15 +08:00
marthinwurer
5f32c23dc5 moved stopwatch to a class field 2025-09-15 14:57:16 -04:00
marthinwurer
ae7159297b made simulation test extend ai test 2025-09-15 14:57:16 -04:00
marthinwurer
cedfa68c16 removed unused imports 2025-09-15 14:57:16 -04:00
marthinwurer
1f235c5e71 remove todos 2025-09-15 14:57:16 -04:00
marthinwurer
9f8bb8ae4d added integration test 2025-09-15 14:57:16 -04:00
marthinwurer
cd3a26e434 break out main loop step 2025-09-15 14:57:16 -04:00
marthinwurer
d2d6b7bc53 break out main game loop function 2025-09-15 14:57:16 -04:00
marthinwurer
052e72d8ea break out first turn setup 2025-09-15 14:57:16 -04:00
marthinwurer
b902d516a7 Added todos for known problems 2025-09-15 14:57:16 -04:00
tool4ever
79fd4a3f8d Fix crash after removing target when copying divided spell (#8714)
Co-authored-by: tool4EvEr <tool4EvEr@>
2025-09-15 14:27:21 +02:00
Hans Mackowiak
10d359e7d7 Update MagicColor.Color enum (#8715)
Adds ShortName and Symbol
2025-09-15 14:12:46 +02:00
kevlahnota
1cb9e78b21 Merge pull request #8712 from kevlahnota/master4
Prevent NPE
2025-09-15 10:30:31 +08:00
Anthony Calosa
d999c5e213 Prevent NPE 2025-09-15 09:48:45 +08:00
tool4ever
1f7862c970 Update superior_foes_of_spider_man.txt
Closes #8711
2025-09-14 19:26:44 +00:00
Chris H
cdc696c506 Only show event cost before you sign up for the event 2025-09-14 11:13:29 -04:00
Chris H
64897f1ab4 Simplify logic 2025-09-14 10:42:19 -04:00
Chris H
905cf52c5e Disable 4 player drafts for Quest and Adventure until the UIs can handle it 2025-09-14 10:42:19 -04:00
kevlahnota
3139d593a3 Merge pull request #8708 from kevlahnota/master4
throw RuntimeException message for BoosterGenerator makesheet
2025-09-14 08:49:04 +08:00
Anthony Calosa
8f71a5b06e throw RuntimeException message for BoosterGenerator makesheet 2025-09-14 08:44:10 +08:00
kevlahnota
e9742a2292 Merge pull request #8707 from kevlahnota/master4
use player or geneticAI deck for missing decks
2025-09-14 08:17:11 +08:00
Anthony Calosa
a6c893693d remove duplicated code 2025-09-14 08:14:28 +08:00
Anthony Calosa
327ee6853f use player or geneticAI deck for missing decks 2025-09-14 08:04:22 +08:00
kevlahnota
3e7f98db6a Merge pull request #8706 from kevlahnota/master4
Different effect card for Emrakul Castle difficulty
2025-09-13 21:19:19 +08:00
Anthony Calosa
e49021ffdd Different effect card for Emrakul Castle difficulty 2025-09-13 21:13:26 +08:00
Chris H
0c5ff17e94 Fix typo for SPM draft 2025-09-12 23:36:36 -04:00
kevlahnota
2925e94cec Merge pull request #8703 from kevlahnota/master4
fix crash Android 8-13 NoSuchMethodError, prevent crash for missing card
2025-09-13 09:14:09 +08:00
Anthony Calosa
02b7e408dc fix crash Android 8-13 NoSuchMethodError, prevent crash for missing card 2025-09-13 09:09:04 +08:00
Anthony Calosa
b61044abb5 prevent crash for missing card, fix crash Android 8-13 NoSuchMethodError 2025-09-13 08:57:29 +08:00
kevlahnota
f1114eeada Merge pull request #8700 from kevlahnota/master4
Android crash fix
2025-09-12 10:15:15 +08:00
Anthony Calosa
b131e4eb04 Android crash fix 2025-09-12 10:11:34 +08:00
kevlahnota
8ba2ae4a24 Merge pull request #8699 from kevlahnota/master4
remove duplicated code for keyword search
2025-09-12 09:55:22 +08:00
Anthony Calosa
ac93233e19 remove duplicated code for keyword search 2025-09-12 09:38:40 +08:00
kevlahnota
6b29e18a58 Merge pull request #8698 from kevlahnota/master4
update Keyword get method
2025-09-12 05:17:38 +08:00
Anthony Calosa
fd2d3c7bb9 update Keyword get method 2025-09-12 05:09:55 +08:00
Paul Hammerton
a1d67cf844 Merge pull request #8697 from paulsnoops/edition-updates
Edition updates: OMB
2025-09-11 17:44:02 +01:00
Paul Hammerton
2b64f82f98 Edition updates: OMB 2025-09-11 17:42:20 +01:00
Jetz72
43a1570601 Deck Importer support for Adventure, Quest, and Planar Conquest (#8681)
* Some cleanup.

* Expanded/fixed basic land set functions for quest and adventure.

* Get land sets from unlocked planes in conquest mode.

* Add importer for Adventure, Quest, and Conquest.

* Remove unused import

* Remove redundant override

* Deprecate hasBasicLands predicate.

* Delete getManaNameAndSymbol

---------

Co-authored-by: Jetz <Jetz722@gmail.com>
2025-09-11 19:22:17 +03:00
Agetian
db8e084332 - Add puzzle PS_EOE3. (#8696) 2025-09-11 19:21:51 +03:00
kevlahnota
c2fc877201 minor changes to Emrakul Boss Deck
replaced some cards that AI can't use properly
2025-09-11 19:45:39 +08:00
kevlahnota
50f34442f6 Merge pull request #8694 from kevlahnota/master4
fix Keyword Advanced Search
2025-09-11 19:04:51 +08:00
Anthony Calosa
1dbd358c19 fix to include main face 2025-09-11 19:01:59 +08:00
Anthony Calosa
bc3faa88c4 fix Keyword Advanced Search 2025-09-11 18:55:44 +08:00
kevlahnota
10618d4f31 Merge pull request #8693 from kevlahnota/master4
update Emrakul Deck, losing to boss fight breaks random equipment
2025-09-11 16:10:10 +08:00
Anthony Calosa
47e873b4e9 update Emrakul Deck, losing to boss fight breaks random equipment 2025-09-11 16:03:20 +08:00
Chris H
acc9ead5b2 Spm new set (#8687)
* Add draft info for Spider-man
2025-09-11 06:02:40 +02:00
Chris H
6125022c9e Migrate SPM (and some other early spoilers) 2025-09-10 19:08:22 -04:00
Hans Mackowiak
a0be5e25cb CardEdition: fix tokenCN with ☇ 2025-09-10 22:10:00 +02:00
Hans Mackowiak
f2e3cdc111 fix c_1_1_myr to c_1_1_a_myr 2025-09-10 22:02:38 +02:00
Hans Mackowiak
7384aada40 Update pictures_of_spider_man.txt 2025-09-10 06:34:11 +02:00
Eradev
1a8a4f63ae Update Recruit Instructor 2025-09-10 06:31:01 +02:00
Eradev
530d1efcd8 Fix tokens and some images ID (#8684)
* Fig hags ID

* Double sided tokens should now be supported

* Fix zombie ID
2025-09-10 06:30:15 +02:00
tool4ever
d8b1d76f42 Update silk_web_weaver.txt 2025-09-09 21:40:24 +00:00
kevlahnota
830b145e88 Merge pull request #8680 from kevlahnota/master4
update android hwinfo
2025-09-09 22:52:21 +08:00
Anthony Calosa
51ed06d60a update android hwinfo 2025-09-09 22:36:09 +08:00
Eradev
ac9b73935f Tokens cleanup (F-G sets) (#8049)
* Update FEM

* Update PIP

* Update FRF

* Update 5DN

* Update 5ED

* Update FDN

* Update 4ED

* Update F12

* Update V15

* Update V14

* Update DRB

* Update V11

* Update V16

* Update V12

* Update V10

* Update V17

* Update FUT

* Update F17

* Update GDY

* Update GNT

* Update GN2

* Update GTC

* Update GS1

* Update PGPX

* Update GPT

* Update GK1

* Update GRN

* Update GK1

* Added old numbers back for now.

* Rename Fallout set
2025-09-09 13:35:19 +02:00
Eradev
fe2f49fbcc Tokens cleanup (D-E sets) (#8046)
* Update DKA

* Update DST

* Update DIS

* Update WHO

* Update DMR

* Update DMU

* Update DOM

* Update 2X2

* Update 2XM

* Update DGM

* Update DTK

* Update DS0

* Update DDQ

* Update DDC

* Update DDO

* Update DDU

* Update DDT

* Update DDS

* Update TD2

* Update DDN

* Update DDP

* Update DPA

* Update AFR

* Update DSC

* Update P8ED

* Update 8ED

* Update EMN

* Update EMA

* Update EVE

* Update EXO

* Update E02

* Fixed emblem name

* Add u_2_1_a_myr back

* Add b_0_0_germ back

* Update NPH
2025-09-09 13:24:40 +02:00
Eradev
3d31494a1b Tokens cleanup (N-P sets) (#8056)
* Update NMS

* Update NPH

* Update 9ED

* Update OGW

* Update ODY

* Update ONS

* Update PHEL

* Update OTJ

* Update ONE

* Update PLC

* Update PC2

* Re-add planes

* Update HOP

* Update PLS

* Update PCA

* Update PWCS

* Update PCY

* Update PD3
2025-09-09 13:15:57 +02:00
Eradev
ff42e730a2 Tokens cleanup (R-S sets) (#8138)
* Update SOK

* Update SCG

* Update ALA

* Update SOM

* Update SHM

* Update SOI

* Update SCD

* Update SNC

* Update STX

* Update STH

* Update PSVC

* Update RNA

* Update RAV

* Update RTR

* Update REV

* Update ROE

* Update PRIX

* Update RIX

* Fix RNA
2025-09-09 13:00:12 +02:00
Paul Hammerton
a66fb8791c Merge pull request #8678 from paulsnoops/sld-update
Edition updates: OM1, SLD
2025-09-09 10:49:43 +01:00
Paul Hammerton
2ad5d20e83 Edition updates: OM1, SLD 2025-09-09 10:45:32 +01:00
Hans Mackowiak
4790394698 Update miles_morales_ultimate_spider_man.txt
Fix typo
2025-09-09 08:42:16 +02:00
Eradev
8b1c427809 Fix crash when equipping 2025-09-09 05:42:46 +02:00
tool4ever
c0b667c373 Some clean up (#8673) 2025-09-08 20:40:03 +00:00
kevlahnota
ca61627f5b Merge pull request #8671 from kevlahnota/master4
restore backup save for errors
2025-09-08 19:28:52 +08:00
Anthony Calosa
c3e2a5b5ea update 2025-09-08 19:23:58 +08:00
Anthony Calosa
0d26b499d3 restore backup save for errors 2025-09-08 19:17:51 +08:00
kevlahnota
bbbc5e0ee6 Merge pull request #8669 from kevlahnota/master4
return extra info for save errors
2025-09-08 15:46:43 +08:00
Anthony Calosa
714d9442f1 return extra info for save errors 2025-09-08 15:41:16 +08:00
tool4ever
d199765e6d Update coal_hill_school.txt 2025-09-08 08:47:27 +02:00
kevlahnota
e5156d8999 Merge pull request #8668 from kevlahnota/master4
revert save read
2025-09-08 14:34:46 +08:00
Anthony Calosa
c0d5397541 revert save read
- todo find a better way to inform player with save error
2025-09-08 14:34:10 +08:00
kevlahnota
444897d0f9 Update lizard_connorss_curse.txt 2025-09-08 14:20:43 +08:00
kevlahnota
f2cb7956d3 Merge pull request #8667 from kevlahnota/master4
announce savefile error
2025-09-08 12:10:10 +08:00
Anthony Calosa
e0c2a49c6b don't write data with errors 2025-09-08 12:06:23 +08:00
Anthony Calosa
d64e5ebc13 announce savefile error 2025-09-08 12:01:32 +08:00
xanxer6rB
9bea1bc717 Update the_reaver_cleaver.txt (#8661) 2025-09-07 12:43:19 +00:00
Hans Mackowiak
bdf9573467 CantTarget: fix AffectedZone not for Players 2025-09-07 11:25:35 +02:00
Hans Mackowiak
042eb4bf79 CantTarget: return the StaticAbility 2025-09-07 10:35:05 +02:00
Hans Mackowiak
4b0337a836 remove unneeded Protection flag 2025-09-07 09:44:22 +02:00
kevlahnota
9284775921 update ImageView group, piles
should fix concurrentmodification and npe prevention
2025-09-07 13:54:52 +08:00
tool4ever
1671a3298e Fix AI sometimes tapping mana sources for 0 (#8659) 2025-09-06 14:18:36 +00:00
kevlahnota
64e3193a80 Merge pull request #8660 from kevlahnota/master4
update VSubmenuSealed panel
2025-09-06 21:35:57 +08:00
Anthony Calosa
3e6cd92f14 update VSubmenuSealed panel
- closes #8658
2025-09-06 21:32:17 +08:00
Paul Hammerton
b7d4e0129e Merge pull request #8657 from paulsnoops/edition-updates
Edition updates: MAR, OMB, PSPM, SPM
2025-09-06 10:48:18 +01:00
Paul Hammerton
f76127dcea Edition updates: MAR, OMB, PSPM, SPM 2025-09-06 10:33:25 +01:00
Paul Hammerton
c7c0938936 Merge pull request #8656 from paulsnoops/spm-formats
SPM Format updates (+ MAR, OM1, OMB, SPE)
2025-09-06 10:20:18 +01:00
Paul Hammerton
9788a815a7 SPM Format updates (+ MAR, OM1, OMB, SPE) 2025-09-06 10:17:33 +01:00
Matija Huremović
cce25a37c4 Added the -c (clock) flag to determine the maximum time in seconds before the sim execution calls the match a draw. (#8202) 2025-09-06 09:04:59 +00:00
Hans Mackowiak
85812d819f Mayhem: add Reminder for Land with no Cost (#8654)
* Mayhem: add Reminder for Land with no Cost
2025-09-06 11:02:15 +02:00
Hans Mackowiak
a974352908 CountersPutAi: prevent AI from going overflow 2025-09-06 09:18:42 +02:00
kevlahnota
45e04cfef7 Update CONTRIBUTORS.txt
reference:
https://api.github.com/repos/Card-Forge/forge/contributors
[?per_page=100&&page=1] | [?per_page=100&&page=2]
2025-09-06 12:00:22 +08:00
kevlahnota
6a83cb89f7 Merge pull request #8653 from kevlahnota/master4
update mobile BugReporter savetofile
2025-09-06 10:57:34 +08:00
Anthony Calosa
494bd75572 update mobile BugReporter savetofile 2025-09-06 10:53:34 +08:00
Paul Hammerton
b065e468b0 Merge pull request #8652 from paulsnoops/fix-spm
Edition updates: SPM
2025-09-05 18:49:52 +01:00
Paul Hammerton
86aff59e40 Edition updates: SPM 2025-09-05 18:49:16 +01:00
Paul Hammerton
748c4e1dd7 Merge pull request #8651 from paulsnoops/edition-updates
Edition updates: MAR, OM1, PSPM, SLD, SPM
2025-09-05 18:34:51 +01:00
Fulgur14
dfb776f526 Final SPM batch (#8648) 2025-09-05 17:33:46 +00:00
Paul Hammerton
ca5d2bb109 Undo Add OM1 AltNames 2025-09-05 18:33:40 +01:00
Paul Hammerton
b42050a40f Add OM1 AltNames 2025-09-05 18:30:37 +01:00
Paul Hammerton
14220ae37f Edition updates: PSPM & SPM tokens 2025-09-05 18:26:56 +01:00
Paul Hammerton
46900c3f49 Edition updates: MAR, OM1, SLD, SPM 2025-09-05 18:19:16 +01:00
tool4ever
cb2bf996d0 Fix Profane Transfusion (#8650)
* Param for Mister Negative
2025-09-05 17:08:46 +00:00
tool4ever
edbf6692f2 Remove fake KW (#8649) 2025-09-05 16:04:07 +00:00
tool4ever
b5f16b83a0 Fix AI checking cost before less expensive logic (#8643) 2025-09-05 09:54:53 +02:00
Fulgur14
ee4902a5ae Spider-Girl and friends (SPM) (#8644) 2025-09-05 09:54:05 +02:00
Fulgur14
0835817d8a Morbius and friends (SPM) (#8640) 2025-09-05 09:48:21 +02:00
Hans Mackowiak
15d4e1ac20 Update spider_suit.txt 2025-09-05 09:23:07 +02:00
kevlahnota
ecdce50f12 Merge pull request #8645 from kevlahnota/master4
NPE prevention
2025-09-05 10:50:45 +08:00
Anthony Calosa
247fd7810e NPE prevention 2025-09-05 06:43:48 +08:00
tool4ever
055cd40fb1 Fix special actions going through frozen stack (#8642) 2025-09-04 19:16:46 +00:00
Renato Filipe Vidal Santos
f1d448509e YEOE: 6 cards 2025-09-04 15:50:36 +00:00
Paul Hammerton
f2581855a4 Merge pull request #8639 from paulsnoops/master
Edition updates: MAR, SPM
2025-09-04 16:03:09 +01:00
Paul Hammerton
1e4c7d4b00 Update Marvel's Spider-Man.txt 2025-09-04 16:02:16 +01:00
Paul Hammerton
2d80e44f70 Update Marvel's Spider-Man.txt 2025-09-04 16:01:06 +01:00
Paul Hammerton
a207bdbb51 Edition updates 2025-09-04 15:54:26 +01:00
Jetz72
c09ec2f410 Merge pull request #8619 from Jetz72/fixes20250902
Fix Arachnus Spinner not choosing a target for the Web
2025-09-04 08:20:21 -05:00
kevlahnota
c579df4c82 Merge pull request #8584 from SapphiCat/master
Fix crash copying adventure decks with full slots
2025-09-04 18:35:09 +08:00
Fulgur14
d39ab505df Sandman's Quicksand (SPM) 2025-09-04 11:38:12 +02:00
Fulgur14
7756dfa5be Jackal and friends (SPM) (#8634) 2025-09-04 11:13:36 +02:00
kevlahnota
c1b6f3126e Merge pull request #8633 from Eradev/FixCollectorNoRegex
Fix CollNo pattern after #7921
2025-09-04 15:47:54 +08:00
kevlahnota
11d45e0fa3 Merge pull request #8636 from kevlahnota/master4
Prevent building some card vars for view purposes only
2025-09-04 14:09:21 +08:00
Anthony Calosa
0504b41dbd Prevent building some card vars for view purposes only
buggy cards will still crash ingame when invoked
2025-09-04 14:04:56 +08:00
kevlahnota
b670cc3736 Update spider_verse.txt 2025-09-04 13:19:43 +08:00
kevlahnota
885300ba49 Merge pull request #8635 from kevlahnota/master4
prevent Concurrent Modificaton onRefresh ItemListView
2025-09-04 13:07:38 +08:00
Anthony Calosa
ff8fd51bf1 prevent NPE, update The Clone Saga trigger 2025-09-04 12:58:11 +08:00
Anthony Calosa
80475c6b62 prevent Concurrent Modificaton onRefresh ItemListView 2025-09-04 12:47:06 +08:00
kevlahnota
88ea36523b Merge pull request #8632 from Eradev/RemoveSetLookupForJ21
Delete SetLookup for J21
2025-09-04 10:17:31 +08:00
Eradev
3386d79cb1 Remove the Alchemy cards that were removed. 2025-09-03 22:07:36 -04:00
Eradev
f97429d1d4 Fix CollNo pattern after #7921 2025-09-03 21:53:49 -04:00
kevlahnota
3628d4e22a Merge pull request #8630 from kevlahnota/master4
remove unsupported cards on game matches
2025-09-04 09:38:26 +08:00
Eradev
fffc9a4282 Delete SetLookup for J21 2025-09-03 21:09:57 -04:00
Anthony Calosa
7cb32b0b25 update deck check 2025-09-04 07:33:21 +08:00
Anthony Calosa
cb13682737 remove unsupported cards on game matches
- closes #8616
2025-09-04 06:50:04 +08:00
Fulgur14
9656a9fb4c Lizard, Connors's Curse (SPM) (#8629) 2025-09-03 20:55:26 +00:00
tool4ever
2fd9d3ae14 CardDb: Remove hardcoded workaround in favor of reusing newer filter (#8628) 2025-09-03 20:49:33 +00:00
Fulgur14
1ea90f6655 Black Cat and gang (SPM) (#8626) 2025-09-03 17:53:50 +00:00
Fulgur14
37342910fa Swarm, Being of Bees and friends (SPM) (#8627) 2025-09-03 17:46:08 +00:00
autumnmyst
3a00727602 Add new duplicate cards directory to deal with duplicate test cards and implement correct Fast // Furious card in UNK (#8520)
* Added Steamflogger Boss to eternal cards in UST
2025-09-03 17:39:53 +00:00
Fulgur14
589d592997 Rhino's Rampage (SPM) (#8624) 2025-09-03 16:12:49 +02:00
Jetz
83101f7f41 Fix incorrect conformity in adventure events. 2025-09-03 09:11:09 -04:00
Fulgur14
c7d24f1c01 4 SPM cards (#8623) 2025-09-03 13:06:42 +02:00
Fulgur14
2a678aa7e9 Spider-UK et al. (SPM) (#8613) 2025-09-03 13:04:46 +02:00
tool4ever
6a758ffc0a Mayhem for Lands (#8615) 2025-09-03 13:03:52 +02:00
tool4ever
83421bac56 Optional fixes (#8622) 2025-09-03 13:00:15 +02:00
Fulgur14
5234365cc1 Heroes' Hangout (SPM) (#8621) 2025-09-03 09:39:06 +02:00
Fulgur14
76558a841c Create the_spot_living_portal.txt (#8617) 2025-09-03 09:37:47 +02:00
Chris H
1338735000 Spiderman is only pick 2 if pod size is 4 2025-09-02 23:12:32 -04:00
Chris H
44c33e2955 Apply pod size to Desktop UI draft view 2025-09-02 23:12:32 -04:00
Chris H
b8a5668db6 Add ability to draft with less than 8 players 2025-09-02 23:12:32 -04:00
Chris H
6a84a7a6f0 Update token entries in Fate Reforged.txt 2025-09-02 23:12:14 -04:00
Jetz
4811c9d726 end of file line break 2025-09-02 20:08:09 -04:00
Jetz
7cea6fce1e Fix Arachnus Spinner not choosing a target for the Web 2025-09-02 20:06:07 -04:00
tool4ever
46ba289329 Update sculpted_sunburst.txt
Closes #8618
2025-09-02 21:52:24 +00:00
Fulgur14
2c9e5ee814 Superior Spider-Man and other nonsense (SPM) (#8614) 2025-09-02 19:09:54 +00:00
Eradev
230eba687d Add unique suffix for reversible cards (#7921) 2025-09-02 18:05:19 +00:00
Fulgur14
5faf317aaf 3 SPM cards (2nd September) (#8612) 2025-09-02 16:59:23 +02:00
Fulgur14
388448c94f Cosmic Spider-Man (SPM) (#8610) 2025-09-02 16:24:11 +02:00
Fulgur14
230282b525 Parker Luck (SPM) (#8609) 2025-09-02 15:34:22 +02:00
Fulgur14
0f92bc18d4 Chameleon, Master of Disguise & Spinneret and Spiderling (#8608) 2025-09-02 13:16:27 +02:00
Paul Hammerton
dc4cee62dc Merge pull request #8607 from paulsnoops/edition-updates
Edition updates: MAR, SPM
2025-09-02 10:44:36 +01:00
Paul Hammerton
ea4c8fbc72 Edition updates: MAR, SPM 2025-09-02 10:42:42 +01:00
Fulgur14
068ea955d9 Impostor Syndrome (SPM) (#8600) 2025-09-02 09:19:18 +02:00
xanxer6rB
f898263bac Update the_soul_stone.txt
Added missing T: Add {B}
2025-09-02 06:34:47 +02:00
Hans Mackowiak
a3147f5e26 ~ fix spiders_man_heroic_horde TrigGainLife 2025-09-02 00:43:53 +02:00
tool4ever
a309eaee02 Update ultimate_green_goblin.txt 2025-09-01 19:25:29 +00:00
Fulgur14
94b058ec07 Agent Venom (SPM) (#8599) 2025-09-01 18:02:11 +00:00
Fulgur14
46bf3348be Flash Thompson and Peter Parker's Camera (SPM) (#8598) 2025-09-01 17:27:24 +00:00
Fulgur14
7c4c820e92 Ezekiel Sims and friends (SPM) (#8596) 2025-09-01 16:35:03 +00:00
Fulgur14
ed3ea99e1a Spiders-Man, Heroic Horde (SPM) (#8593) 2025-09-01 16:24:07 +02:00
tool4ever
ec21a0c789 The Soul Stone and support (#8579) 2025-09-01 13:45:01 +02:00
Fulgur14
bfe0a78765 Radioactive Spider (SPM) (#8592) 2025-09-01 13:40:06 +02:00
Fulgur14
0abc224e1b Steel Wrecking Ball (SPM) (#8588) 2025-08-31 18:06:16 +00:00
SapphiCat
fa3ce1c7f7 Merge branch 'Card-Forge:master' into master 2025-08-31 07:35:08 -07:00
tool4ever
48a5046d93 Fix Urza's Miter (#8586) 2025-08-31 10:39:59 +00:00
Fulgur14
9f9e68f34d Create pictures_of_spider_man.txt (#8583) 2025-08-31 07:29:35 +00:00
kit
d7c7aaa51e Fix crash copying adventure decks with full slots 2025-08-30 14:02:02 -07:00
tool4ever
ffe883e7d9 Behold the Sinister Six! and support (#8578) 2025-08-30 10:57:13 +00:00
Hans Mackowiak
b07a9944aa GameActionUtil: fix getFirstSpellAbility using castSA 2025-08-30 12:55:28 +02:00
Fulgur14
997d489a7e SPM cards from the debut (#8576) 2025-08-30 10:19:58 +00:00
Paul Hammerton
d181746679 Merge pull request #8581 from paulsnoops/master
Edition updates: MAR, PF25, SLD, SPM
2025-08-30 11:16:07 +01:00
Paul Hammerton
693d6cd9e3 Edition updates: MAR, PF25, SLD, SPM 2025-08-30 11:14:15 +01:00
kevlahnota
01d5bf3c21 Merge pull request #8521 from antoniomartinelli/fix/lastimportedcubeid
fix: wrong cube id saved as LAST_IMPORTED_CUBE_ID
2025-08-30 06:55:02 +08:00
kevlahnota
29a630386f Merge pull request #8410 from rappazzo/stop-tracking-changelog
fix: move CHANGES.txt generation to target directory
2025-08-30 06:31:10 +08:00
Hans Mackowiak
75c7938f1e CounterType: turn wrapper into an interface (#8572)
* CounterType: turn wrapper into an interface

* remove CounterType.get(CounterEnumType) helper
2025-08-29 20:44:08 +02:00
Fulgur14
110e885c67 Create with_great_power.txt (#8573) 2025-08-29 18:40:39 +00:00
Hans Mackowiak
548b448f0d Update Game.java
`getNonactivePlayers` not needed anymore
2025-08-29 20:38:55 +02:00
Hans Mackowiak
a2e80ac0f3 TriggerHandler: no need for APNAP (#8567)
* TriggerHandler: no need for APNAP

The order of the Trigger will be handled later in MagicStack

---------

Co-authored-by: tool4EvEr <tool4EvEr@>
2025-08-29 20:37:26 +02:00
Eradev
238d426202 Alchemy update 20250818 (#8492) 2025-08-29 17:55:18 +00:00
Hans Mackowiak
d6f585a80c Event: use Record 2025-08-29 18:05:05 +02:00
tool4ever
223aeb1bff Update displaced_dinosaurs.txt 2025-08-29 12:02:27 +02:00
Hans Mackowiak
4bf02ea61f MagicStack: remove getNonactivePlayers for SpellCastSinceBegOfYourLastTurn 2025-08-29 11:20:38 +02:00
tool4ever
ea186ae4af Update faunsbane_troll.txt 2025-08-28 19:26:09 +00:00
kevlahnota
3e4cd9e189 Update LoadDraftScreen.java
prevent IllegalStateException since the option pane show method needs to run in EDT
2025-08-28 20:13:01 +08:00
Eradev
e35c193f92 Fix content passed 2025-08-27 22:36:22 -04:00
Eradev
e5443fc394 Typo 2025-08-27 22:36:22 -04:00
Eradev
9998092c70 Create helper class to not duplicate the code 2025-08-27 22:36:22 -04:00
Eradev
9f81e0cd34 Move custom types into edition files 2025-08-27 22:36:22 -04:00
Eradev
5569f18053 Remove param 2025-08-27 22:36:22 -04:00
Eradev
40190b5442 Remove TreeSet 2025-08-27 22:36:22 -04:00
Eradev
a33905241d Revert "Ensure subtype not used"
This reverts commit 6797f0c1b0.
2025-08-27 22:36:22 -04:00
Eradev
3a40b560f6 Removed import 2025-08-27 22:36:22 -04:00
Eradev
d79fb96770 Ensure subtype not used 2025-08-27 22:36:22 -04:00
Eradev
f50fe2f89c Now read from a directory 2025-08-27 22:36:22 -04:00
Eradev
a36deab334 Allow custom types 2025-08-27 22:36:22 -04:00
kevlahnota
28feff99d7 Merge pull request #8565 from kevlahnota/master4
prevent NPE, ConcurrentModification on ImageView onRefresh
2025-08-28 10:04:57 +08:00
Anthony Calosa
bab8791012 prevent NPE, ConcurrentModification on ImageView onRefresh
use Record for ImageRecord
2025-08-28 06:28:34 +08:00
Fulgur14
db20b27c9d Update soul_seizer_ghastly_haunting.txt (#8431) 2025-08-27 15:20:24 +00:00
Renato Filipe Vidal Santos
087db3f757 YEOE: 5 cards (#8484) 2025-08-27 15:16:24 +00:00
kevlahnota
db194fab97 Merge pull request #8561 from kevlahnota/master4
Remove unsupported cards from AdventurePlayer inventory
2025-08-27 21:52:52 +08:00
Anthony Calosa
0585ece2c1 Remove unsupported cards from AdventurePlayer inventory
- closes #8545
2025-08-27 21:34:07 +08:00
Eradev
1611559909 Add new card filters (#8557)
* Add is:vanilla

* Add is:custom
2025-08-27 06:10:49 +00:00
Cees Timmerman
d6dee9575b More human-readable events (#8502) 2025-08-27 07:23:14 +02:00
Cees Timmerman
6dd9a731fa Fix event.oldEntiy typo 2025-08-27 07:23:14 +02:00
Leandro Doctors
cf5a8508d6 Remove empty test class
Dead, unmaintained code eventually leads to problems.
2025-08-27 06:56:12 +02:00
tool4ever
0fa7df090e Fix Muraganda Petroglyphs vs. Saga with no abilities (#8551)
---------

Co-authored-by: TRT <>
Co-authored-by: tool4EvEr <tool4EvEr@>
2025-08-27 06:51:15 +02:00
kevlahnota
86838d94f7 Merge pull request #8544 from Eradev/RemoveUnsupportedCard
Option to remove unsupported card from collection
2025-08-27 12:21:53 +08:00
kevlahnota
83c4db07ac Merge pull request #8559 from Eradev/RemoveAdvCardsRewards
Remove custom adventure cards from rewards.
2025-08-27 12:19:58 +08:00
Eradev
b544f2dd00 Remove custom adventure cards from rewards. 2025-08-26 20:54:26 -04:00
kevlahnota
079e6f04ac update canBeOathbreaker check (#8556) 2025-08-27 05:22:00 +08:00
Eradev
d04c541578 Fix edition mapping 2025-08-26 10:34:41 -04:00
Hans Mackowiak
7cc2cf530d AnimateBase: PerpetualManaCost 2025-08-26 15:57:50 +02:00
Hans Mackowiak
61a2c7cadb Update DamageAllAi.java (#8550)
Remove `getNonactivePlayers`
2025-08-26 15:51:39 +02:00
tool4ever
efbf2e1a9c Saga ETB counters aren't intrinsic (#8549) 2025-08-26 15:47:17 +02:00
Anthony Calosa
9b8441d45b update Console Textfield navigation 2025-08-26 21:04:06 +08:00
Hans Mackowiak
f8b7a0fb9a MagicStack: check for StackEntries in addAllTriggeredAbilities 2025-08-26 14:56:24 +02:00
shenshinoman
ab49e97797 Expanding my Innistrad further. new enemies. New maps. Second biome is partially populated. Everything is contained to innistrad plane, so should have no impact on the main game outside that plane. 2025-08-26 08:40:30 -04:00
shenshinoman
c27a9d136f Expanding my Innistrad further. new enemies. New maps. Second biome is partially populated. Everything is contained to innistrad plane, so should have no impact on the main game outside that plane. 2025-08-26 08:40:30 -04:00
Leandro Doctors
91241ee53c clean up: remove obsolete GitLab templates
The project moved to GitHub almost a year ago.

Having duplicated, unmaintained templates will generate problems in the
future. If needed, they can always be retrieved from the commit history.
2025-08-26 13:32:30 +02:00
Eradev
31e537f42b Remove changes to FContainer 2025-08-26 06:33:30 -04:00
Eradev
e550c307c2 Option to remove unsupported card from collection 2025-08-26 06:29:49 -04:00
Paul Hammerton
b4f01b7ebb Merge pull request #8542 from paulsnoops/treetop-recluse
Add treetop_recluse.txt
2025-08-26 09:10:59 +01:00
Eradev
7744474f39 Fix token numbers 2025-08-26 09:58:01 +02:00
Paul Hammerton
1365b82968 Add treetop_recluse.txt 2025-08-26 08:43:01 +01:00
Hans Mackowiak
5bb532bf9d Game: only reverse NonactivePlayers if more than one
Reversing the Turn Order should have no Effect there if only 2 players
2025-08-26 07:35:39 +02:00
tool4ever
258b8c18a9 Fix Thief of Blood simultaneous ETB (#8535)
Co-authored-by: TRT <>
2025-08-26 08:26:32 +03:00
Eradev
a66349d8a1 Missing token (#8538)
* Add g_1_1_forest_dryad_squirrel

* Update curiosity
2025-08-26 08:26:25 +03:00
kevlahnota
1933cf1863 Merge pull request #8537 from kevlahnota/master3
migrate Callback to Consumer Interface
2025-08-26 12:59:53 +08:00
kevlahnota
0d342c778f fix NG+ 2025-08-26 09:11:31 +08:00
kevlahnota
f452b94cb8 update missing migration 2025-08-26 07:16:43 +08:00
kevlahnota
9325794e2f Update FFileChooser.java 2025-08-26 07:03:24 +08:00
kevlahnota
192a64bbc3 Update Forge.java 2025-08-26 06:58:09 +08:00
kevlahnota
deb8369f11 Update FDeckChooser.java 2025-08-26 06:53:59 +08:00
Anthony Calosa
b24f536190 use Java Consumer 2025-08-26 06:34:59 +08:00
Leandro Doctors
28ec24069c CI: add support for JDK 21
Depends on https://github.com/Card-Forge/forge/pull/8533
2025-08-25 17:24:19 -04:00
Anthony Calosa
f27472d9bd migrate Callback to Interface
- closes #5717
2025-08-26 05:14:20 +08:00
Leandro Doctors
780cc8ddbf Fix build on JDK 21+
This bumps `izpack-maven-plugin`.

Tested with JDK 25.

Similar fix for another project:
https://github.com/lsc-project/lsc/pull/385

Original Error message:
`[ERROR] Failed to execute goal
org.codehaus.izpack:izpack-maven-plugin:5.2.3:izpack
(standard-installer) on project forge-installer: Execution
standard-installer
of goal org.codehaus.izpack:izpack-maven-plugin:5.2.3:izpack failed:
java.lang.ArrayIndexOutOfBoundsException: Index 70131 out of bounds for
length 22674 -> [Help 1]`
2025-08-25 13:50:57 -04:00
Jetz
4abc96c045 Fix rebase issue 2025-08-25 08:34:43 -04:00
Jetz
bee208f1d5 Add toNameLookup to print sheet, remove containsCardName. 2025-08-25 08:31:19 -04:00
Jetz
999e76e598 Refactor event generation, add set event command. 2025-08-25 08:30:56 -04:00
kevlahnota
23555b9564 migrate function to method reference 2025-08-25 19:54:42 +08:00
kevlahnota
431827be35 Update Keyword.java for Double Team
- closes #8519
2025-08-25 11:49:49 +08:00
kevlahnota
b0dba74c6c Merge pull request #8528 from kevlahnota/master3
update ConsoleCommandInterpreter
2025-08-25 06:56:58 +08:00
Anthony Calosa
ad0a690764 minor typo 2025-08-25 06:56:27 +08:00
Anthony Calosa
977f2c75b9 update comment 2025-08-25 06:53:28 +08:00
Anthony Calosa
8313414f78 update ConsoleCommandInterpreter 2025-08-25 06:49:59 +08:00
kevlahnota
89955bf201 Merge pull request #8527 from kevlahnota/master3
capture adventure SaveFileData exception to sentry
2025-08-25 05:38:14 +08:00
Anthony Calosa
99d191901a capture adventure SaveFileData exception to sentry 2025-08-25 05:33:45 +08:00
kevlahnota
1a306b3da3 Merge pull request #8525 from kevlahnota/master3
prevent saving error on inventory
2025-08-25 04:55:51 +08:00
Anthony Calosa
9ff03cbd41 prevent saving error on inventory 2025-08-25 04:50:58 +08:00
tool4ever
07a1dbc099 Fix scripts (#8524) 2025-08-24 22:10:56 +02:00
Hans Mackowiak
f24b3ea3b3 Update enchantment_alteration.txt
closes #8522
2025-08-24 22:02:36 +02:00
kevlahnota
770cc72fcd Merge pull request #8523 from kevlahnota/master3
update migration message
2025-08-25 03:36:27 +08:00
Anthony Calosa
8426a74900 update migration message 2025-08-25 03:34:43 +08:00
antoniomartinelli
8d98eda18d fix: wrong cube id saved as LAST_IMPORTED_CUBE_ID 2025-08-24 18:17:54 +02:00
Paul Hammerton
6e6509eaff Merge pull request #8518 from paulsnoops/edition-updates
Edition updates: PSPM
2025-08-24 11:13:05 +01:00
Paul Hammerton
c56ddee47d Edition updates: PSPM 2025-08-24 11:11:41 +01:00
Eradev
07985ac487 Allow custom cards as reward (#8512) 2025-08-23 21:55:28 -04:00
kevlahnota
6c93491d7f Don't select sideboard first when creating new deck 2025-08-24 05:13:36 +08:00
Eradev
c9b012c88a Fix Bloomburrow lands (#8489)
* Fix Bloomburrow lands

* Proper fix

* Revert "Proper fix"

This reverts commit f3a46e40d9.

* Use collector number
2025-08-23 14:14:57 -04:00
kevlahnota
9b53144976 Merge pull request #8509 from kevlahnota/master3
remove Normalizer from clipboard and PaperCard artist.
2025-08-24 00:53:22 +08:00
Anthony Calosa
31020296d8 unused import 2025-08-24 00:46:02 +08:00
Anthony Calosa
65fb3414d8 remove Normalizer from clipboard and PaperCard artist. 2025-08-24 00:42:40 +08:00
kevlahnota
98fee0d86b Merge pull request #8497 from kevlahnota/master3
update InventoryScene, add repair cracked item for gold
2025-08-23 23:17:08 +08:00
Anthony Calosa
becdadb279 NPE prevention for rewards 2025-08-23 23:08:11 +08:00
Hans Mackowiak
26da0ab0d4 Create rw_1_1_soldier.txt
Fix missing TokenScript
2025-08-23 16:46:16 +02:00
Anthony Calosa
e1f4d755e0 minor fix for refreshing overlay 2025-08-23 21:38:52 +08:00
Anthony Calosa
efe7d67d9f add unusable indicator 2025-08-23 21:34:57 +08:00
Anthony Calosa
3a5e11504a add migration message, fix cloning of itemData 2025-08-23 20:07:28 +08:00
Fulgur14
6657602b80 J. Jonah Jameson (SPM) (#8506) 2025-08-23 11:00:45 +02:00
Eradev
eeca33855d Fix minor card render problems (#8478)
* Missing space

* Unescape line breaks in card descriptions
2025-08-23 06:56:21 +03:00
Matthew Scott Krafczyk
cdc63f35bb Add python specific entries to .gitignore (#8390) 2025-08-23 06:55:28 +03:00
Jetz72
5a9ea8d260 Merge pull request #8344 from verifiedtm/deck-editor-sections
Add other deck sections for other formats
2025-08-22 07:56:55 -05:00
Fulgur14
5a363922bd Oracle updates - EOE (#8496) 2025-08-22 12:57:01 +02:00
Anthony Calosa
1ff16ca509 prevent NPE 2025-08-22 16:43:17 +08:00
TRT
c878401197 Script cleanup 2025-08-22 10:03:27 +02:00
Eradev
8f518b7b1f Fix IsDoctorCheck 2025-08-22 06:33:29 +02:00
Anthony Calosa
fb624458f0 update InventoryScene, add repair cracked item for gold 2025-08-22 12:32:12 +08:00
Paul Hammerton
ee3220f33b Merge pull request #8487 from paulsnoops/fix-yeoe
YEOE edition and format updates for check land cycle
2025-08-21 19:31:16 +01:00
Paul Hammerton
7bc591fa78 YEOE mana-fixing lands edtion and format update 2025-08-21 19:25:47 +01:00
kevlahnota
c02d942fc3 Merge pull request #8485 from kevlahnota/master3
request access if needed to use backup and restore
2025-08-21 22:00:02 +08:00
Anthony Calosa
3b9ded8270 request access if needed to use backup and restore 2025-08-21 21:49:45 +08:00
tool4ever
fdf0c13a7f Remove outdated Briar Shield code path (#8477) 2025-08-21 07:15:21 +01:00
Hans Mackowiak
80b1cac394 lf 2025-08-21 07:05:35 +02:00
Hans Mackowiak
8c80c32113 lf 2025-08-21 07:01:46 +02:00
Agetian
a74b033c26 Revert "Ambrosia Whiteheart AI slight improvement (#8473)" (#8483)
This reverts commit ba8a30ebdd.
2025-08-21 07:48:20 +03:00
kevlahnota
16fcbc0ebf Merge pull request #8481 from kevlahnota/master3
fix osFamily name for sentry, update android-all
2025-08-21 09:54:47 +08:00
Anthony Calosa
62ffada6fe update cpu name 2025-08-21 09:46:30 +08:00
Anthony Calosa
e5a0d335af fix osFamily name for sentry, update android-all 2025-08-21 08:00:29 +08:00
Agetian
ba8a30ebdd Ambrosia Whiteheart AI slight improvement (#8473)
* - Add achievement for EOE/EOC by Marek14.

* - Slight logic improvement for Ambrosia Whiteheart
2025-08-20 18:17:35 +03:00
Agetian
e25dbe5196 Add puzzles PS_EOE1 and PS_EOE2. (#8475)
* - Add achievement for EOE/EOC by Marek14.

* - Add puzzles PS_EOE1 and PS_EOE2.
2025-08-20 18:17:11 +03:00
Renato Filipe Vidal Santos
3533ad8b74 Update darigaaz_shivan_champion.txt (#8474) 2025-08-20 18:16:58 +03:00
kevlahnota
2d20ce07e3 Merge pull request #8470 from kevlahnota/master3
move hwinfo output on create method
2025-08-20 21:59:21 +08:00
Anthony Calosa
e5e0a9240d move hwinfo output on create method 2025-08-20 21:55:22 +08:00
kevlahnota
5e83fff859 Merge pull request #8469 from kevlahnota/master3
update device info
2025-08-20 20:58:00 +08:00
Anthony Calosa
2d0acc734e indention 2025-08-20 20:56:22 +08:00
Anthony Calosa
b6bc3a6e96 update device info
should fill up sentry basic device and os info for mobile builds
2025-08-20 20:41:46 +08:00
Eradev
7ec7a65f33 Partially revert 38b6283a by restoring deleted rebalanced card files 2025-08-20 12:55:47 +02:00
Eradev
2a97b67f72 Remove unused import 2025-08-20 12:55:47 +02:00
Eradev
06be01d81c Remove WIP 2025-08-20 12:55:47 +02:00
Eradev
386f6aaac6 Try to get non-Alchemy version 2025-08-20 12:55:47 +02:00
Eradev
82d11bfb45 Update coll.no. for Zendikar Rising 2025-08-20 12:55:47 +02:00
Eradev
f39d900fbf Huge Alchemy Cleanup 2025-08-20 12:55:47 +02:00
Eradev
335edec357 Add info 2025-08-20 12:53:44 +02:00
Eradev
e58f035b19 Update JUD 2025-08-20 12:53:44 +02:00
Eradev
f85d610393 Update J13 2025-08-20 12:53:44 +02:00
Eradev
fce0095af1 Update J12 2025-08-20 12:53:44 +02:00
Eradev
82bea111df Update G11 2025-08-20 12:53:44 +02:00
Eradev
0aded8f1f4 Add borders to H17 2025-08-20 12:53:44 +02:00
Eradev
84130f0586 Update XLN 2025-08-20 12:53:44 +02:00
Eradev
ed4d1059dd Update INV 2025-08-20 12:53:44 +02:00
Eradev
c73be86211 Update ISD 2025-08-20 12:53:44 +02:00
Eradev
6cb2e7a91a Update MID 2025-08-20 12:53:44 +02:00
Eradev
58713e65ed Update VOW 2025-08-20 12:53:44 +02:00
Eradev
676c26fae7 Update IKO 2025-08-20 12:53:44 +02:00
Eradev
f2e4e67021 Update ICE 2025-08-20 12:53:44 +02:00
Eradev
18ba476fc9 Fix H17 2025-08-20 12:53:44 +02:00
Eradev
d9ed82972f Add H17 2025-08-20 12:53:44 +02:00
Eradev
c9affaa1a1 Update HOU 2025-08-20 12:53:44 +02:00
Eradev
8ef89adaef Update HML 2025-08-20 12:53:44 +02:00
Eradev
f25db898ae Remove Code2 MD1 2025-08-20 12:52:52 +02:00
Eradev
cddc41b353 Update MOR 2025-08-20 12:52:52 +02:00
Eradev
d4e918660b Update MMA 2025-08-20 12:52:52 +02:00
Eradev
3f16a3e27f Update MM3 2025-08-20 12:52:52 +02:00
Eradev
53d27f1437 Update MM2 2025-08-20 12:52:52 +02:00
Eradev
408dd310d3 Update MH1 2025-08-20 12:52:52 +02:00
Eradev
0050446ff0 Update MH3 2025-08-20 12:52:52 +02:00
Eradev
efb47d949f Update MH2 2025-08-20 12:52:52 +02:00
Eradev
a67303866e Update MD1 2025-08-20 12:52:52 +02:00
Eradev
756e80595c Update MRD 2025-08-20 12:52:52 +02:00
Eradev
089a021d02 Update PMBS 2025-08-20 12:52:52 +02:00
Eradev
d89a94dcd2 Update MBS 2025-08-20 12:52:52 +02:00
Eradev
b298f66348 Update MIR 2025-08-20 12:52:52 +02:00
Eradev
fa277c7b7c Update MMQ 2025-08-20 12:52:52 +02:00
Eradev
76ec449d33 Update ME1 2025-08-20 12:52:52 +02:00
Eradev
d481ade524 Update ME4 2025-08-20 12:52:52 +02:00
Eradev
1b468efff1 Update ME3 2025-08-20 12:52:52 +02:00
Eradev
9be9a4795b Update ME2 2025-08-20 12:52:52 +02:00
Eradev
49bcf7ded4 Update A25 2025-08-20 12:52:52 +02:00
Eradev
28989b9c49 Update P04 2025-08-20 12:52:52 +02:00
Eradev
9e40b1f6cf Update MPR 2025-08-20 12:52:52 +02:00
Eradev
a9e95caa42 Update ORI 2025-08-20 12:52:52 +02:00
Eradev
eb39c97661 Update TD0 2025-08-20 12:52:52 +02:00
Eradev
52f19272d0 Update M15 2025-08-20 12:52:52 +02:00
Eradev
4cf37379c7 Update PM15 2025-08-20 12:52:52 +02:00
Eradev
746d0476c9 Update PM10 2025-08-20 12:52:52 +02:00
Eradev
cf93d61d0c Update M14 2025-08-20 12:52:52 +02:00
Eradev
5d9197446b Update PM14 2025-08-20 12:52:52 +02:00
Eradev
753d5560d6 Update M13 2025-08-20 12:52:52 +02:00
Eradev
1b68d30ff1 Update PM10 2025-08-20 12:52:52 +02:00
Eradev
278eed7af9 Update PPC1 2025-08-20 12:52:52 +02:00
Hans Mackowiak
6eb4e32225 Update Murders at Karlov Manor.txt 2025-08-20 12:48:52 +02:00
tool4ever
e160a7d517 Tighten scripts (#8467) 2025-08-20 12:34:56 +02:00
Eradev
476cdda0c2 Use KTK goblin as r_1_1_goblin_haste since it has unique art 2025-08-20 12:30:18 +02:00
Eradev
efdabb8bf6 Update PLG25 2025-08-20 12:30:18 +02:00
Eradev
ca648df852 Update LRW 2025-08-20 12:30:18 +02:00
Eradev
04afb61351 Update LEB 2025-08-20 12:30:18 +02:00
Eradev
869632361c Update LEA 2025-08-20 12:30:18 +02:00
Eradev
d994abb559 Update LGN 2025-08-20 12:30:18 +02:00
Eradev
d082c2c250 Update LEG 2025-08-20 12:30:18 +02:00
Eradev
586a474168 Update PZ1 2025-08-20 12:30:18 +02:00
Eradev
b7268dd6fd Update NEO 2025-08-20 12:30:18 +02:00
Eradev
c3e4ea228a Update KTK 2025-08-20 12:30:18 +02:00
Eradev
237946f569 Update KHM 2025-08-20 12:30:18 +02:00
Eradev
cae32e5b2a Update KLD 2025-08-20 12:30:18 +02:00
tool4ever
715ba9803f Fix running out of memory from too many waiting triggers (#8466) 2025-08-20 11:42:04 +02:00
Renato Filipe Vidal Santos
283198f0a4 Tidying trigger-granting Slivers (#8465) 2025-08-20 11:40:54 +02:00
Fulgur14
bab889c406 Firebending cards (TLA) (#8445) 2025-08-20 11:40:22 +02:00
tool4ever
92c6f5369d Fix missing trigger (#8462) 2025-08-20 10:30:55 +02:00
Renato Filipe Vidal Santos
6042948aed Update freyalise_skyshroud_partisan.txt 2025-08-20 06:39:07 +02:00
Fulgur14
136577fec0 Avatar Aang (TLA) (#8459) 2025-08-19 21:30:13 +02:00
tool4ever
180fda53df Update krumar_initiate.txt 2025-08-19 20:03:36 +02:00
Antonio Martinelli
ca6b175fb8 Import from CubeCobra for Draft and Sealed (#8375)
* Import from CubeCobra feature for Draft and Sealed

* adjust comment for cube Import

* CubeImporter refactoring and generalisation

* Allow hyphens in Cube ID validation

* remove unused imports

* make parseFromURL private

* add LAST_IMPORTED_CUBE_ID to ForgePreferences

---------

Co-authored-by: Antonio <mart@gmail.com>
2025-08-19 11:25:50 -04:00
Antonio Martinelli
dd25dc4b06 update rankings_cubecobra.txt (#8458) 2025-08-19 18:13:08 +03:00
Hans Mackowiak
9893fc3cf9 Player: extra Flag for Element Bend 2025-08-19 16:41:31 +02:00
Michael Rappazzo
67b6c2c03f fix: move CHANGES.txt generation to target directory
- Generate CHANGES.txt in forge-gui-desktop/target/ instead of source tree
- Update installer to copy from target directory for all build profiles
- Add CHANGES.txt to .gitignore since it's generated
- Remove hardcoded fromRef to use latest tag automatically
- Remove maven-release-plugin exclusion for untracked file
2025-08-19 06:49:42 -04:00
Agetian
bb073b8682 Tweak AI logic for Krumar Initiate (#8453)
* - Add achievement for EOE/EOC by Marek14.

* - Add AI logic for Krumar Initiate

* - Tweak AI logic for Krumar Initiate

* Update EndureAi.java

only when doing X

---------

Co-authored-by: Hans Mackowiak <hanmac@gmx.de>
2025-08-19 13:36:11 +03:00
Agetian
9bbfad5be3 AI logic for Krumar Initiate (#8450)
* - Add achievement for EOE/EOC by Marek14.

* - Add AI logic for Krumar Initiate
2025-08-19 13:11:41 +03:00
Paul Hammerton
2c7e7d5b63 Merge pull request #8448 from paulsnoops/edition-updates
Edition updates: AA1, AA2
2025-08-19 10:21:44 +01:00
Paul Hammerton
94e7258a03 Edition updates: AA1, AA2 2025-08-19 10:18:58 +01:00
Renato Filipe Vidal Santos
95eb90eac2 Update claws_out.txt 2025-08-19 07:08:24 +02:00
Eradev
0f0a4c54e7 Fix Hanweir Garrison CollNo 2025-08-19 07:07:27 +02:00
Eradev
399923bfa4 Remove dupe + fix SIR 2025-08-19 07:07:27 +02:00
Eradev
39f0ab9eae Fix closing bracket 2025-08-19 07:07:27 +02:00
Eradev
8b1cd54417 Search split types 2025-08-19 07:07:27 +02:00
Eradev
ff2192fa7a Fix Meld key 2025-08-19 07:07:27 +02:00
Eradev
08443a307c Fix Domri Rade's emblem 2025-08-19 06:35:36 +02:00
Eradev
bd90e1bccc Check for emblems in other instead of tokens 2025-08-19 06:35:36 +02:00
Hans Mackowiak
9cb0bd301e TLA: Firebending 2025-08-19 06:13:00 +02:00
kevlahnota
0923960215 Merge pull request #8442 from Jetz72/fixes20250818
Fix auto-sell cards reappearing in collection
2025-08-19 08:36:26 +08:00
Jetz
0f68dc1ab6 Make give item command case-insensitive 2025-08-18 19:06:52 -04:00
Jetz
09b88b8575 Fix auto-sell not being removed from adventure collection 2025-08-18 19:05:02 -04:00
kevlahnota
fae2f25b69 Merge pull request #8441 from kevlahnota/master3
update Itemmanager portrait layout, update Sentry scope
2025-08-19 06:29:03 +08:00
Anthony Calosa
d3e0696ecc update Itemmanager portrait layout, update Sentry scope 2025-08-19 06:19:44 +08:00
Paul Hammerton
6a7723eba9 Merge pull request #8440 from paulsnoops/fix-scripts
Fix Earth Rumble and Roku's Mastery
2025-08-18 23:05:34 +01:00
Paul Hammerton
10d6fd157e Fix Earth Rumble and Roku's Mastery 2025-08-18 23:01:10 +01:00
Paul Hammerton
048133df30 Merge pull request #8439 from paulsnoops/aa2-edition-fixes
AA2 edition spelling
2025-08-18 22:56:04 +01:00
Paul Hammerton
2fe7fec14f AA2 edition spelling 2025-08-18 22:53:36 +01:00
Paul Hammerton
73e7b27c09 Merge pull request #8438 from paulsnoops/yeoe-formats
Format updates: YEOE
2025-08-18 22:35:33 +01:00
Paul Hammerton
2fdbd5a85c Add YEOE to formats 2025-08-18 22:32:06 +01:00
Paul Hammerton
78e27e0073 Merge pull request #8437 from paulsnoops/edition-updates
Edition updates: AA1, AA2, SLD, TLA, TLE, YEOE
2025-08-18 22:25:38 +01:00
Paul Hammerton
bad585c8c9 Edition updates: AA1, AA2, SLD, TLA, TLE, YEOE 2025-08-18 22:23:11 +01:00
Eradev
11d10a8129 Fix Meld cards fetch (#7981)
* BOM

* ANB Update

* J25 Update

* SIR update

* Mend

* Find the right back for meld cards

* ANB Update

* J25 Update

* SIR update

* Mend

* Find the right back for meld cards

* Update PW25

* Update SPG

* Typo

* Update ACR

* Update CMM

* Add PFDN and Invasion alternate arts

* Update MKM

* Update NPH

* J25 -> J22 for non-existing cards

* Update WOC

* Update HBG

* Use printsheet

* Use helper functions
2025-08-18 14:31:33 +02:00
Agetian
0b89e9d137 - Add achievement for EOE/EOC by Marek14. (#8433) 2025-08-18 15:21:09 +03:00
kevlahnota
70df1ff0aa Merge pull request #8428 from Jetz72/fixes20250817
Handful of Deck Editor updates
2025-08-18 16:52:30 +08:00
Jetz
24d3169592 Enable variant replacement in Quest and Planar Conquest 2025-08-17 21:37:36 -04:00
Jetz
b8db0fea5e Disable custom cards conformity check in Adventure mode. 2025-08-17 21:11:51 -04:00
Jetz
514519b45b Merge branch 'master' into fixes20250817
# Conflicts:
#	forge-gui-mobile/src/forge/itemmanager/ItemManager.java
2025-08-17 21:01:42 -04:00
Jetz
70f6bcb63c Fix missing or crushed group and pile-by buttons in narrow layouts 2025-08-17 20:52:21 -04:00
Jetz
5a3e55f704 Fix crushed filter buttons in portrait mode 2025-08-17 20:51:20 -04:00
Jetz
4452e07443 Remove unused format filter visibility controls 2025-08-17 19:58:20 -04:00
Jetz
a125e6c0ea Support command line args width= and height= for easier testing of portrait layouts. 2025-08-17 19:57:21 -04:00
kevlahnota
fa4688e113 Merge pull request #8426 from kevlahnota/master3
fix Itemmanager portrait layout
2025-08-18 07:46:12 +08:00
Anthony Calosa
0236609558 fix Itemmanager portrait layout 2025-08-18 07:40:52 +08:00
kevlahnota
3f15fb1b98 Merge pull request #8424 from shenshinoman/Crystal_Expansions
Fixing bugs that were preventing proper world gen in Crystal Kingdoms…
2025-08-18 06:01:41 +08:00
kevlahnota
e22718c72a Merge pull request #8425 from kevlahnota/master3
fix RandomDeckGenerator AI Deck Selection by preference
2025-08-18 05:59:47 +08:00
Anthony Calosa
e94985576c refactor check 2025-08-18 05:56:54 +08:00
Anthony Calosa
71e132a9e0 fix RandomDeckGenerator AI Deck Selection by preference 2025-08-18 05:52:24 +08:00
Jetz
8d5d56bed8 Add dev cheat to add cards to inventory and draft packs 2025-08-17 17:18:17 -04:00
shenshinoman
386c9799c2 Fixing bugs that were preventing proper world gen in Crystal Kingdoms. Very basic fix, and a slight notice in the quests to inform the player that they have not been udpated yet. 2025-08-17 16:08:03 -04:00
Fulgur14
a1be657460 Airbending cards (#8422) 2025-08-17 19:36:15 +01:00
Fulgur14
d4994e8fa0 Fire Lord Ozai (TLE) (#8361)
* Support CombatMana
2025-08-17 17:03:26 +01:00
Renato Filipe Vidal Santos
fb054d9f64 Tidying DBCleanup (#8420) 2025-08-17 13:34:23 +01:00
kevlahnota
8790843b3b Merge pull request #8421 from kevlahnota/master3
revert fileprovider, add sentryscope
2025-08-17 20:32:51 +08:00
Anthony Calosa
38383dff02 revert fileprovider, add sentryscope 2025-08-17 20:20:33 +08:00
Hans Mackowiak
a0f9923c21 TLA: Airbend (#8419) 2025-08-17 13:24:11 +02:00
kevlahnota
812c0ac5b1 Merge pull request #8418 from kevlahnota/master3
update SettingsScene, Settings page indent
2025-08-17 11:12:43 +08:00
Anthony Calosa
2e09146f44 remove unused options 2025-08-17 11:02:48 +08:00
Anthony Calosa
25080411d5 update SettingsScene, Settings page indent
limit hasprintedpt to vehicles and spacecraft to fix modal card renders with non creature backside
- closes #8413
2025-08-17 10:52:17 +08:00
kevlahnota
55e20e96f9 Merge pull request #8414 from Jetz72/fixes20250816
Attempt to fix another NPE in deserializing decks
2025-08-17 06:14:31 +08:00
kevlahnota
981ab1c6ed prevent NPE 2025-08-17 06:13:51 +08:00
Hans Mackowiak
a1089f8073 Update the_cabbage_merchant.txt 2025-08-16 23:56:03 +02:00
tool4ever
fe747a3908 Update the_cabbage_merchant.txt 2025-08-16 21:50:39 +02:00
Paul Hammerton
a16c9480e7 Merge pull request #8412 from Eradev/FixEOE
Fix EOE def
2025-08-16 16:21:41 +01:00
Jetz72
b40e9fc817 Merge branch 'Card-Forge:master' into fixes20250816 2025-08-16 10:15:33 -05:00
Jetz
6eec0e8988 Fix another potential NPE deserializing old decks... 2025-08-16 11:13:42 -04:00
Hans Mackowiak
d6320caadf CardEdition: getPrintSheetsBySection use collectorNumber instead of index 2025-08-16 16:53:43 +02:00
Eradev
c4f125525a Fix EOE def 2025-08-16 10:38:43 -04:00
kevlahnota
56209261d0 Merge pull request #8411 from Jetz72/fixes20250816
Fix NPE deserializing old decks
2025-08-16 22:37:44 +08:00
Jetz
5df4d64345 Fix a potential NPE deserializing old decks.
Fix `Deck.cloneFieldsTo` to copy tags in the right direction.
2025-08-16 10:05:41 -04:00
kevlahnota
d6d6065104 Merge pull request #8402 from Jetz72/fixes20250815c
A few auto-sell section fixes
2025-08-16 14:32:04 +08:00
kevlahnota
333aea0641 Merge pull request #8405 from kevlahnota/master3
fix booster draft menu not showing on first try
2025-08-16 14:29:57 +08:00
Anthony Calosa
c7bb3d49a6 fix booster draft menu not showing on first try 2025-08-16 14:14:33 +08:00
Jetz
7c982498dd Avoid trying to generate a move option for cards that don't have a valid destination 2025-08-15 23:51:19 -04:00
Jetz
0e2c95afed Fix ClassCastException 2025-08-15 23:48:50 -04:00
Jetz
df6eb23341 Always show quantity of auto-sell section. 2025-08-15 23:48:31 -04:00
kevlahnota
1204de13c3 Merge pull request #8400 from Jetz72/fixes20250815b
Fix negative gold payouts from selling cards.
2025-08-16 09:55:23 +08:00
Jetz
9cb21de11d Fix negative gold payouts from selling cards. 2025-08-15 21:37:58 -04:00
kevlahnota
2f16b9e110 Merge pull request #8399 from Jetz72/fixes20250815
Fix some crashes from the new editor
2025-08-16 07:22:57 +08:00
Jetz
cf28139b02 Fix a second crash for the same reason... 2025-08-15 19:19:28 -04:00
Jetz
87e8e7d5e5 Fix crash entering a game without extra sections 2025-08-15 19:12:40 -04:00
Jetz
dcc3a681d9 Whoops committed the wrong file.
This reverts commit cc7f30da88.
2025-08-15 19:12:39 -04:00
Jetz
cc7f30da88 Fix crash entering a game without extra sections 2025-08-15 19:05:59 -04:00
Jetz
ed9eabed38 Fix Jumpstart deck preview 2025-08-15 18:31:45 -04:00
Paul Hammerton
99ac95bfca Merge pull request #8398 from paulsnoops/edition-updates
Edition updates: PMEI
2025-08-15 21:24:05 +01:00
Paul Hammerton
eb178fc9d1 Edition updates: PMEI 2025-08-15 21:15:07 +01:00
Paul Hammerton
7567e29cf1 Merge pull request #8397 from paulsnoops/edition-updates
Edition updates: TLA, TLE, YEOE
2025-08-15 19:18:48 +01:00
Paul Hammerton
b2a456140c YEOE 2025-08-15 19:11:49 +01:00
Paul Hammerton
9c3ff6b570 Edition updates: TLA, TLE 2025-08-15 18:40:44 +01:00
Hans Mackowiak
e4d238ba6c ~lf 2025-08-15 19:27:29 +02:00
Hans Mackowiak
42363204dd add PrintSheet & ItemPool helper 2025-08-15 19:27:09 +02:00
Jetz72
de89d557dd Mobile Deck Editor Reorganization and Feature Update (#7519)
Mobile Deck Editor Reorg
2025-08-15 11:48:25 -04:00
kevlahnota
c5a53b21e7 Merge pull request #8396 from kevlahnota/master3
fix flip cards redownloading same image with different name
2025-08-15 20:43:07 +08:00
Anthony Calosa
02f43b1ef0 update comment 2025-08-15 20:37:58 +08:00
Anthony Calosa
d7cb0b7ac1 fix flip cards redownloading same image with different name
also fix sync for sentry native ndk since this is declared as system scope
2025-08-15 20:34:26 +08:00
kevlahnota
2efeb573e6 Merge pull request #8395 from Eradev/DisplayFlipCards
Display flip cards correctly
2025-08-15 20:10:24 +08:00
kevlahnota
370ff638ab Merge pull request #8394 from dracontes/rv-fix_odin
Update summon_primal_odin.txt
2025-08-15 20:10:10 +08:00
kevlahnota
108564efe3 Merge pull request #8392 from Eradev/UpdatePLST
Update PLST
2025-08-15 20:09:34 +08:00
Eradev
43f96657e0 Rename vars 2025-08-15 06:57:06 -04:00
Eradev
cb004bfba2 Fix imports 2025-08-15 06:53:17 -04:00
Eradev
f276597a82 Flip in Reward screen 2025-08-15 06:49:18 -04:00
Renato Filipe Vidal Santos
4fd9855daa Update summon_primal_odin.txt 2025-08-15 11:27:31 +01:00
Eradev
ebdce74f92 Fix display in inventory 2025-08-15 06:20:20 -04:00
Eradev
98e9b8f28b Display flipped cards correctly 2025-08-15 05:54:31 -04:00
Hans Mackowiak
a31c0358a4 Update TriggerType.java
Add the other Bending trigger
2025-08-15 11:21:22 +02:00
Fulgur14
8640522fff TLA/TLE cards (14th August), Batch 4 (#8387) 2025-08-15 09:59:17 +02:00
Fulgur14
a5fa350e7e TLA/TLE cards (14th August), Batch 3 (#8385) 2025-08-15 09:57:34 +02:00
Fulgur14
c4a0cff1ca TLA/TLE cards (14th August), Batch 2 (#8383) 2025-08-15 09:56:22 +02:00
Fulgur14
30d02ebbb6 TLA/TLE cards (14th August), Batch 1 (#8382) 2025-08-15 09:48:11 +02:00
Hans Mackowiak
9a90359283 Update EarthbendEffect.java
Fix apostrophe
2025-08-15 09:44:55 +02:00
Fulgur14
edbcab544e TLA/TLE Earthbending cards (#8393) 2025-08-15 09:42:48 +02:00
Hans Mackowiak
f55bf4691d TLA: Earthbend (#8386) 2025-08-15 09:24:45 +02:00
Eradev
16e44309a6 Update PLST 2025-08-15 02:43:27 -04:00
tool4ever
c4d58e3dba Update wormfang_drake.txt 2025-08-15 08:33:17 +02:00
Ellios77
16155d3670 Punctuation fixes for card scripts (#8389) 2025-08-15 08:21:49 +02:00
kevlahnota
bd929bcc72 Merge pull request #8388 from kevlahnota/master3
add Preload Custom Drafts
2025-08-15 08:52:49 +08:00
Anthony Calosa
e2cc52fd02 add Preload Custom Drafts
Should fix longer startup time on mobile version instead of forcing to load custom drafts file at startup.
2025-08-15 08:45:21 +08:00
Paul Hammerton
be5c7cfd04 Merge pull request #8381 from paulsnoops/unf-update
Edition updates: UNF
2025-08-14 18:27:57 +01:00
Paul Hammerton
9d14949138 Edition updates: UNF 2025-08-14 18:25:28 +01:00
tool4ever
6fe5dbad3c Update InputAttack.java 2025-08-14 16:53:18 +00:00
Matthew Scott Krafczyk
f4f8ee9cb6 android-dev-build (#8352)
* improve resource finding procedure and add android-dev-build

Added the `android-dev-build` profile to trigger building a developer
apk.

Developer apk is at application id forge.app.dev, and has name
'Forge (dev)'. It is installable in parallel with the official release
app allowing developers to test the android build on their phones
without interfering with their existing installation.

Updated how android resources are found to accomodate changes in
application id at runtime. This method doesn't rely on the 'R' package.

* Use all arguments of getIdentifier

Use all arguments of getIdentifier instead of using a fully qualified
resource name
2025-08-14 19:06:54 +03:00
Antonio Martinelli
0767eb03e0 Add LSVCube and Name-Sticker Goblin (card) (#8348)
* Add LSVCube and draft

* Add "Name Sticker" Goblin card (MTGO Version)

---------

Co-authored-by: Antonio <mart@gmail.com>
Co-authored-by: Agetian <stavdev@mail.ru>
2025-08-14 19:06:46 +03:00
kevlahnota
feb6062f2f Update MakeCardEffect.java
- closes #8373
2025-08-14 22:44:23 +08:00
Eradev
113dc4d5e8 Don't try to attack itself. (#8376) 2025-08-14 16:11:00 +02:00
Hans Mackowiak
ca20d98a2c Update Tarkir Dragonstorm.txt 2025-08-14 14:15:00 +02:00
Hans Mackowiak
599a629068 Update Dungeons & Dragons Adventures in the Forgotten Realms.txt
Also add Dungeons to "other" section
2025-08-14 09:54:59 +02:00
Hans Mackowiak
4c05ad655d Update Dungeons & Dragons Adventures in the Forgotten Realms.txt
Fix Dungeon CN
2025-08-14 09:22:13 +02:00
Ellios77
203233f0d2 Fixed typo in script (#8372) 2025-08-14 09:18:31 +02:00
Hans Mackowiak
ac8f7357db Update corrupted_shapeshifter.txt 2025-08-14 06:29:33 +02:00
kevlahnota
4c396065f5 Merge pull request #8370 from kevlahnota/master3
update Sentry
2025-08-14 06:07:54 +08:00
Anthony Calosa
cc4dac38fe update Sentry 2025-08-14 05:59:47 +08:00
Eradev
394818f533 Filter by foil status (#8358) 2025-08-13 19:45:53 +03:00
Eradev
bfd4a68e23 Try to attack mustAttackEntities first. (#8355) 2025-08-13 19:45:42 +03:00
Paul Hammerton
9d54e82214 Merge pull request #8368 from paulsnoops/edition-updates
Edition updates: TLA, TLE
2025-08-13 17:41:30 +01:00
Paul Hammerton
18c2278066 Edition updates: TLA, TLE 2025-08-13 17:40:00 +01:00
tool4ever
b3d549a712 Update mirror_shield_hoplite.txt 2025-08-13 16:22:58 +00:00
tool4ever
0887e78e90 Update agrus_kos_eternal_soldier.txt 2025-08-13 16:22:26 +00:00
Hans Mackowiak
df3f86dd73 CardState: Fix Card copies itself though ReplacementEffect (#8356)
Co-authored-by: tool4EvEr <tool4EvEr@>
2025-08-13 17:51:14 +02:00
Hans Mackowiak
89af1d0cf1 Update Card.java 2025-08-13 17:07:32 +02:00
Eradev
10a68d63a1 Fix exact search (#8357) 2025-08-13 08:46:47 +00:00
Hans Mackowiak
8ccebbc13c Update The List.txt
Closes #8363
2025-08-13 10:37:22 +02:00
Fulgur14
4c663cd943 TLA/TLE cards that don't require bending (#8359) 2025-08-13 08:36:41 +00:00
Hans Mackowiak
ca16bf74f5 Update Card.hasNoAbilities
For Adventure and Omen
2025-08-13 10:09:01 +02:00
tool4ever
a1968ef9fd Update depthshaker_titan.txt 2025-08-13 07:58:25 +02:00
kevlahnota
de1a999611 Merge pull request #8353 from kevlahnota/master3
exclude unused xcf files in releases
2025-08-12 20:56:41 +08:00
Anthony Calosa
d0e8bc5de0 exclude unused xcf files in releases
- closes #8322
2025-08-12 20:49:49 +08:00
Eradev
38fb647cd7 Migration to PLST (#7972)
* Fallback to PLST

* Fix audit for Funny cards.

* Remove FMB1, update PLST

* Fallback to PLST

* Convert cards to PLST

* BOM

* Minor fix

* LF

* Remove conversion. Already handled.
2025-08-12 08:17:11 +03:00
kevlahnota
90bb83c5d4 Merge pull request #8351 from kevlahnota/master3
add backup/restore classic mode data
2025-08-11 22:00:07 +08:00
Anthony Calosa
467fff3651 add backup/restore classic mode data 2025-08-11 21:53:19 +08:00
Hans Mackowiak
3ab50a5fb5 Update samis_curiosity.txt
Add StackDesc for Lander Token
2025-08-11 09:35:03 +02:00
Tim Miller
e4d58a0a88 Add other deck sections for other formats 2025-08-10 17:03:30 -04:00
kevlahnota
10e592c741 Merge pull request #8343 from kevlahnota/master3
request external storage access
2025-08-10 20:04:33 +08:00
Anthony Calosa
b3241c85eb request external storage access
- closes #7405
2025-08-10 19:56:29 +08:00
Cees Timmerman
abd1702c96 Fix NullPointerException in forge.game.zone.Zone.toString (#8326) (#8327) 2025-08-10 08:03:56 +02:00
Hans Mackowiak
d91e86c608 Update GameEventManaPool.java (#8340)
Closes #8328, #8329
2025-08-09 16:13:49 +02:00
Hans Mackowiak
f0ebac019d Perpetual: use Record for different types (#8337)
* Perpetual: use Record for different types
2025-08-09 13:04:14 +02:00
tool4ever
c18995915a Fix scripts (#8339) 2025-08-09 10:50:27 +00:00
Paul Hammerton
55d2c23aa0 Merge pull request #8338 from paulsnoops/edition-updates
Edition updates: PSPM, PW25, SLD, SPM
2025-08-09 10:57:58 +01:00
Paul Hammerton
28c9f719c5 Edition updates: PSPM, PW25, SLD, SPM 2025-08-09 10:56:08 +01:00
Hans Mackowiak
bb5a276324 Update kessig.txt
Fix ActiveZones
2025-08-09 08:51:13 +02:00
tool4ever
e99df5b267 Update wellgabber_apothecary.txt
Closes #8334
2025-08-08 18:07:11 +00:00
kevlahnota
54e67b3d57 Merge pull request #8333 from kevlahnota/master3
update progressbar, update boosterdraft readfile
2025-08-08 22:01:42 +08:00
Anthony Calosa
b1d30ab9dd remove unused borderless list 2025-08-08 21:31:32 +08:00
Anthony Calosa
f2d65b2515 update check 2025-08-08 21:01:58 +08:00
Anthony Calosa
286fcd3fbe update progressbar, update boosterdraft readfile
also removed unneccesary settings since forge uses shaders for round corners for rendering borders
2025-08-08 20:46:12 +08:00
Hans Mackowiak
00332ff3fe Fix Phantom Train not updating PT (#8332)
* Fix Phantom Train not updating PT
2025-08-08 12:52:29 +02:00
tool4ever
000fa14c17 Fix voting crash (#8325) 2025-08-08 10:15:27 +02:00
tool4ever
c5b4be6c97 Update edgar_master_machinist.txt 2025-08-07 16:13:52 +00:00
kevlahnota
d9b2a8f4e0 Merge pull request #8321 from kevlahnota/master3
update sentry
2025-08-07 21:50:08 +08:00
Anthony Calosa
2898b00300 update sentry 2025-08-07 21:42:20 +08:00
Hans Mackowiak
a4671b62d4 CardStateName: combine Modal with Transformed (#8305)
* CardStateName: combine Modal with Transformed

* Make new TMDFC transformable

---------

Co-authored-by: tool4EvEr <tool4EvEr@>
2025-08-07 11:28:24 +02:00
kevlahnota
0c87ed7381 Merge pull request #8319 from kevlahnota/master3
fix VPrompt
2025-08-07 05:29:34 +08:00
Anthony Calosa
4104a0b2a8 fix VPrompt 2025-08-07 05:28:13 +08:00
tool4ever
4d62f436d5 ExiledWith check for keyworded (#8317) 2025-08-06 19:41:39 +00:00
kevlahnota
506f88bd6f Update friendly_neighborhood.txt
fix no API
2025-08-06 20:47:32 +08:00
Hans Mackowiak
a1ad355e25 Update CardEdition.java
Closes #8314 8314
2025-08-06 14:17:13 +02:00
kevlahnota
91d6571cff Merge pull request #8315 from kevlahnota/master3
Reversed prompt button toggle
2025-08-06 18:57:55 +08:00
Anthony Calosa
e43c5534b3 Reversed prompt button toggle
- closes #7366
2025-08-06 18:51:49 +08:00
Jetz
77e3453d35 Fix vote out card type 2025-08-05 21:50:39 -04:00
Jetz
2568df1b91 Reorder ReplaceMoved.canReplace to do some common easy checks first. 2025-08-05 21:50:39 -04:00
Jetz
dc830a8432 Include weird zones in forEachCardInGame 2025-08-05 21:50:39 -04:00
Chris H
a9cffbd313 Collect all of slots paper cards before adding it to the final result 2025-08-05 21:05:49 -04:00
tool4ever
65775f5c20 Update moonlit_meditation.txt
Closes #8310
2025-08-05 20:00:03 +00:00
Fulgur14
c6f9056e2c Gwen and Miles (Transformation to be added later) (#8306)
* Gwen and Miles (Transformation to be added later)

* Create miles_morales_ultimate_spider_man.txt

* Update miles_morales_ultimate_spider_man.txt

* Update miles_morales_ultimate_spider_man.txt
2025-08-05 19:06:01 +03:00
Hans Mackowiak
967807d441 Merge pull request #8307
Fixes Vote Protection
2025-08-05 11:17:15 +02:00
Hans Mackowiak
cc7b3505d7 Update ComputerUtilCard.java 2025-08-05 09:54:43 +02:00
Hans Mackowiak
3cd965a24f Update ComputerUtilCard.java 2025-08-05 09:49:11 +02:00
Hans Mackowiak
3502bf6de2 Update ComputerUtil.java
Fix
2025-08-05 09:45:31 +02:00
Hans Mackowiak
458e05635c Update CardFactoryUtil.java
Allow Iterable for getMostProminentColorsFromList
2025-08-05 09:42:47 +02:00
Hans Mackowiak
f4cd9e0f4f Update ComputerUtil.java
Fix Vote "Protection"
2025-08-05 09:40:12 +02:00
tool4EvEr
1f3871d5dc Thread.stop fallback 2025-08-04 22:15:23 +02:00
tool4ever
f4d304b2c1 Update abyssal_hunter.txt 2025-08-04 13:00:15 +00:00
tool4ever
24937fb32d Reduce potential for ConcurrentModificationException (#8302) 2025-08-04 14:30:10 +02:00
Hans Mackowiak
5d222577be Update AddTurnAi.java
Fix AddTurnAi
2025-08-04 14:15:46 +02:00
Hans Mackowiak
0e010cece2 Update ComputerUtil.java
Fix vote "StrengthOrNumbers"
2025-08-04 14:15:02 +02:00
Hans Mackowiak
21080d65f5 Create b_0_0_germ.txt
Closes #8301
2025-08-04 13:20:47 +02:00
Fulgur14
83475b9063 Carnage, Crimson Chaos (SPM) (#8299) 2025-08-04 07:40:39 +02:00
tool4ever
15a6494d9c Update space_time_anomaly.txt
Closes #8297
2025-08-03 16:26:40 +00:00
Hans Mackowiak
58ad1f3103 Keyword: Web-slinging 2025-08-03 16:24:52 +02:00
Hans Mackowiak
b2bff7762f Mayhem: add new Cast-from-Graveyard variant 2025-08-03 16:24:24 +02:00
kevlahnota
cd4a673862 Merge pull request #8295 from kevlahnota/master3
fix NPE and FChoiceList render display
2025-08-03 20:54:13 +08:00
Anthony Calosa
1f61c6bd00 fix NPE and FChoiceList render display 2025-08-03 20:51:02 +08:00
Cees Timmerman
cc2f46795f Fix infinite loop OOM crash (#8254) 2025-08-02 15:15:49 +02:00
Chris H
db5ea3ec9c Fix undo restore restoring to bottom of library 2025-08-02 15:03:27 +02:00
Adam Jones
21f2f6e2c3 Update forge.sh
Allow parameters to be passed in to the shell script
2025-08-02 15:03:11 +02:00
Hans Mackowiak
65b5f4fac3 VoteEffect: use SpellAbility Choices (#8286)
* VoteEffect: use SpellAbility Choices

* fixes

* fix VotePlayer

* subAbs only for Choices
2025-08-02 16:01:12 +03:00
tool4ever
2291cf9d0c Fix scripts (#8288) 2025-08-02 11:29:01 +00:00
Paul Hammerton
3f8b3fa2a7 Merge pull request #8287 from paulsnoops/edition-updates
Edition updates: PW25, SLD, SPM
2025-08-02 10:24:59 +01:00
Paul Hammerton
e6fa1268d9 Edition updates: PW25, SLD, SPM 2025-08-02 10:23:36 +01:00
Renato Filipe Vidal Santos
eda8205acd Fixing Ultima, Origin of Oblivion (#8278)
* Update ultima_origin_of_oblivion.txt

* Update ultima_origin_of_oblivion.txt

* Update ultima_origin_of_oblivion.txt

* Update ultima_origin_of_oblivion.txt

* Update ultima_origin_of_oblivion.txt
2025-08-02 08:20:50 +03:00
Renato Filipe Vidal Santos
019131447a Update icetill_explorer.txt 2025-08-02 06:59:59 +02:00
kevlahnota
41cd90bc2a Fix dual foil renders 2025-08-02 00:38:03 +08:00
kevlahnota
0fe1677ced Update Foil rotation check 2025-08-02 00:27:00 +08:00
tool4ever
b1a2a93f75 Update PumpAllAi.java 2025-08-01 12:43:56 +02:00
tool4ever
50a2c283f1 Update lightstall_inquisitor.txt 2025-08-01 08:34:25 +02:00
kevlahnota
83188daba4 Merge pull request #8275 from Card-Forge/kevlahnota-rotatefix
Extra check for rotation
2025-08-01 08:31:50 +08:00
kevlahnota
3312e409fd Extra check for rotation 2025-08-01 08:24:38 +08:00
tool4ever
5420a90f05 Update iron_spider_stark_upgrade.txt
Closes #8272
2025-07-31 20:16:28 +00:00
tool4ever
4d340d7bf3 Update wrathful_raptors.txt 2025-07-31 20:15:06 +00:00
tool4ever
5342175a97 Update wrathful_red_dragon.txt 2025-07-31 20:14:39 +00:00
tool4ever
e5a1c86b1f Align invalid Player property result with Card (for Lozhan) (#8264) 2025-07-31 18:56:55 +00:00
tool4ever
1aca32005b Fix Brave the Wilds (#8266)
Co-authored-by: tool4EvEr <tool4EvEr@>
2025-07-31 21:32:12 +03:00
tool4ever
6d7853428f Fix bad refactor (for real this time) (#8263)
Co-authored-by: tool4EvEr <tool4EvEr@>
2025-07-31 20:05:05 +02:00
kevlahnota
683d92399d FDeckEditor Foil Menu (#8260) 2025-07-31 21:58:05 +08:00
kevlahnota
9b9bf6cf53 update holofoil texture (#8259)
a bit modern but has more blended effect with most card images along with hue changes effect
2025-07-31 20:24:55 +08:00
kevlahnota
c9b826d9b4 Merge pull request #8237 from kevlahnota/master2
Refactor Foil Effect for Mobile
2025-07-31 05:48:36 +08:00
kevlahnota
81ff72f1f2 Merge pull request #8189 from kevlahnota/nyxDesktop
add nyx effect to desktop card renders
2025-07-31 05:45:46 +08:00
tool4ever
dfda04f7ba Fix bad refactor (#8252) 2025-07-30 20:43:20 +00:00
tool4ever
3bc0e0c386 More AI cleanup (#8251)
* Fix infinite loop
2025-07-30 19:59:20 +00:00
Hans Mackowiak
5829192446 Update valgavoths_onslaught.txt
fix SpellDescription
2025-07-30 21:50:57 +02:00
Chris H
cbae45be87 Update shaun_father_of_synths.txt (#8250) 2025-07-30 19:23:54 +00:00
Agetian
2b4ec73318 - Tweak marked damage on PS_FIN4. (#8249) 2025-07-30 18:21:59 +03:00
Agetian
7ff426e413 - Add puzzle PS_FIN4. (#8248) 2025-07-30 18:19:26 +03:00
shenshinoman
25e3ad8432 Resolving the land shop issue in Shandalar Old World. (#8231) 2025-07-30 17:52:25 +03:00
tool4ever
051edff18e Consolidate logic (#8247) 2025-07-30 09:50:59 +00:00
tool4ever
dde58be5a6 Clean up redundant "AI" from function names (#8243) 2025-07-30 07:44:17 +00:00
lemtom
1ad4fda3e6 16x16 avatars for every enemy (#8206)
* 16x16 avatars for every enemy

* 16x16 death knight

* 16x16 zombie poisoner

---------

Co-authored-by: Agetian <stavdev@mail.ru>
2025-07-30 07:50:51 +03:00
shenshinoman
b78ef7b010 Updating the "InsectShop" shop icon to a newly provided one from the community. Icon provided by coby_cat from the discord. (Also updated the GIMP XCF project file to match the current png. So as to ensure those using GIMP to edit these are up to date.) (#8227) 2025-07-30 07:50:41 +03:00
Renato Filipe Vidal Santos
d1776ce37a Add files via upload (#8205) 2025-07-30 07:50:32 +03:00
Anthony Calosa
100ae7b164 update dispose 2025-07-30 08:51:32 +08:00
tool4ever
415e247f6c Cleanup API handling Part 2 (#8241)
* Improve entrypoints

* Consolidate AtOppEOT
2025-07-29 19:12:52 +00:00
tool4ever
ca4a934e0f Cleanup API handling (#8238)
* Remove obsolete branch

* Merge ward logic

* Convert Fatal Push logic

* Streamline condition handling!

* Consolidate AIPlayForSub logic

* call preventRunAwayActivations earlier in Template

* Consolidate some logic

* Update LifeGainAi.java

* Update SurveilAi.java

---------

Co-authored-by: tool4EvEr <tool4EvEr@>
Co-authored-by: Hans Mackowiak <hanmac@gmx.de>
2025-07-29 16:11:03 +02:00
Anthony Calosa
3b4c417549 Refactor Foil Effect for Mobile
Should fix rendering for Full, Crop and Art renders
2025-07-29 19:42:01 +08:00
tool4ever
f5e96bc756 Streamline logic so canPlay always before canPay (#8234) 2025-07-29 07:35:18 +00:00
Chris H
7428b7420a Update dyadrine_synthesis_amalgam.txt (#8232) 2025-07-29 06:56:26 +02:00
kevlahnota
761d7848ef Merge pull request #8233 from kevlahnota/master2
fix SwingImageFetcher filename
2025-07-29 10:46:29 +08:00
Anthony Calosa
e9fc7899cd fix SwingImageFetcher filename 2025-07-29 10:44:57 +08:00
Chris H
df40fd5cb3 Convert checkApiLogic to AiAbilityDecision 2025-07-28 15:43:50 -04:00
Chris H
dce3b4b142 Thoguht i fixed this one already 2025-07-28 15:43:50 -04:00
Chris H
b20110edb4 Code review updatse 2025-07-28 15:43:50 -04:00
Chris H
4a05a66bc0 Update forge-ai/src/main/java/forge/ai/ability/VentureAi.java
Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
2025-07-28 15:43:50 -04:00
Chris H
39acc78fad Convert AiAbilityDecision to a record 2025-07-28 15:43:50 -04:00
Chris H
a0c58e2a1d Convert booleans to AiAbilityDecision objects to aid in decision making 2025-07-28 15:43:50 -04:00
Hans Mackowiak
c46ceca140 Update count_on_luck.txt
Remove wrong PT
2025-07-28 15:45:59 +02:00
tool4ever
4db0b6a67f Trigger fix (#8226) 2025-07-28 10:17:18 +02:00
tool4ever
38f6b699c6 Fix ward calculation when same card is targeted multiple times (#8222)
Co-authored-by: tool4EvEr <tool4EvEr@>
2025-07-28 07:36:36 +03:00
Paul Hammerton
9d80f4e78f Merge pull request #8221 from paulsnoops/edition-updates
Edition updates: TLA
2025-07-27 10:14:33 +01:00
Paul Hammerton
7dc95f8540 Edition updates: TLA 2025-07-27 10:13:32 +01:00
tool4ever
723ad5fe7c Update loyal_unicorn.txt 2025-07-27 08:17:56 +00:00
tool4ever
94aac494ea Update loyal_unicorn.txt 2025-07-27 08:17:25 +00:00
tool4ever
3e6b7af61f Update shaun_and_rebecca_agents.txt 2025-07-27 07:13:01 +00:00
Fulgur14
1574a88255 Create kravens_last_hunt.txt (#8220) 2025-07-27 07:11:39 +00:00
Renato Filipe Vidal Santos
2e2fea9182 SPM: 8 cards 2025-07-26 20:24:30 +00:00
kevlahnota
55549f1e70 Merge pull request #8218 from kevlahnota/master2
fix DualListBox Scrollbounds width and height
2025-07-26 21:56:21 +08:00
Anthony Calosa
71e97146ed fix DualListBox Scrollbounds width and height 2025-07-26 21:55:17 +08:00
tool4ever
35e4e580fa Cleanup duplicated field (#8217) 2025-07-26 12:09:09 +00:00
tool4ever
baab31d2e2 Rework Shared Fate (#8215) 2025-07-26 10:04:17 +00:00
Paul Hammerton
3f1295d9e4 Merge pull request #8216 from paulsnoops/edition-updates
Edition updates: SPM
2025-07-26 10:58:59 +01:00
Paul Hammerton
d759cc4e94 Merge pull request #8210 from Card-Forge/fix-cardrules-paths
Assign paths to CardRules so we can report where issues come from
2025-07-26 10:58:38 +01:00
Paul Hammerton
4c941df647 Friendly Neighborhood 2025-07-26 10:56:19 +01:00
Paul Hammerton
1f39ad4e91 Edition updates: SPM 2025-07-26 10:47:44 +01:00
Fulgur14
194e1d3356 Friendly Neighborhood (SPM) and its token (#8214) 2025-07-26 08:11:56 +00:00
Chris H
0aa8c933d8 Assign paths to CardRules so we can report where issues come from 2025-07-25 21:56:08 -04:00
Chris H
cf11802fbe Revert "Some handling for the 4 Arena cards that are no longer associated to …"
This reverts commit 7ccb925d76.
2025-07-25 21:25:22 -04:00
Chris H
2703cbc4c9 Restore revision versions 2025-07-25 19:54:42 -04:00
GitHub Actions
b87f3bd00b [maven-release-plugin] prepare for next development iteration 2025-07-25 19:54:42 -04:00
GitHub Actions
a1227167ea [maven-release-plugin] prepare release forge-2.0.05 2025-07-25 19:54:42 -04:00
Chris H
7ccb925d76 Some handling for the 4 Arena cards that are no longer associated to an edition file (#8207) 2025-07-25 19:10:12 -04:00
kevlahnota
beedd17cfe Update SFilterUtil.java
crash fix for Android
2025-07-26 07:07:55 +08:00
kevlahnota
332fa94dab Merge pull request #8065 from Eradev/BetterImageFetcherError
Better image fetcher error
2025-07-26 06:57:40 +08:00
kevlahnota
ae4b5be29f Merge pull request #8008 from Eradev/7859-DisplayTextTooltip
Allow the display of the placeholder in shops and reward windows.
2025-07-26 06:57:27 +08:00
Paul Hammerton
cc4a417c0a Merge pull request #8204 from paulsnoops/edition-updates
Edition updates: PF25, PH23, PLG24, PW25
2025-07-25 19:12:25 +01:00
Paul Hammerton
8a6e03e172 Edition updates: PF25, PH23, PLG24, PW25 2025-07-25 19:09:57 +01:00
Chris H
3ff0c740c4 Update orbital_plunge.txt (#8203) 2025-07-25 18:07:08 +00:00
Eradev
82f8a8f30b Merge remote-tracking branch 'origin/master' into BetterImageFetcherError 2025-07-25 12:37:44 -04:00
kevlahnota
2f7c315822 Merge pull request #8201 from kevlahnota/master2
try to fix dispose to clear more resource
2025-07-25 22:46:33 +08:00
Anthony Calosa
89b9c050a8 try to fix dispose to clear more resource 2025-07-25 22:41:31 +08:00
tool4ever
eb70e21f3d Update merieke_ri_berit.txt 2025-07-25 14:11:59 +00:00
Matthew Scott Krafczyk
ab2b06500b Better Games In Match Selection (#8098)
* Add GamesInMatch combo box selection to booster draft page

Also updated combo box default to be seeded with the stored preferences

* Working comboboxes for desktop version

* Working linked buttons on Mobile

* Add binder classes for preferences and other Model components

* Move to pref binders for mobile GUI
2025-07-25 14:07:19 +00:00
Hans Mackowiak
79845eff1d Update mystic_decree.txt
update Islandwalk to Landwalk:Island
2025-07-25 14:24:24 +02:00
Eradev
9d1b935643 Advanced filtering using the search box (#8077)
* Allow search by type and cmc

* Allow colon and added aliases to cmc

* Support negate

* Extract parser function into its own file

* Support for "!"

* Colors test

* Color search

* Oracle text

* Numeric p/t search

* Set search + fixes

* Typo

* Rarity check

* Loyalty

* Cleanup

* Case ignore for kw

* Support for "or"

* Rename method

* Support parentheses

* Add cases for l

* Cleanup

* Use PaperCardPredicates.printedInSet

* Fix in set to remove conjured cards

* Use func

* Remove redundant check
2025-07-25 11:06:40 +03:00
Fulgur14
ad0c81e984 Update alchemax_slayer_bots.txt (#8198)
* Update alchemax_slayer_bots.txt

* Update TypeLists.txt
2025-07-25 09:25:14 +02:00
Renato Filipe Vidal Santos
e86f4e80cb Spectacular Spider-Man: fixing typos 2025-07-25 05:06:08 +00:00
tool4ever
af4a6de809 Refactor Offering (#8199) 2025-07-25 05:02:57 +00:00
tool4ever
0d0fdd3c0b Update samis_curiosity.txt 2025-07-25 04:05:30 +00:00
Renato Filipe Vidal Santos
de4dcb19cf Quick cleanup: 2025-07-24 2025-07-25 03:54:46 +00:00
kevlahnota
cfcbbb5c21 Update README.md 2025-07-25 09:56:51 +08:00
kevlahnota
6d11361725 Merge pull request #8197 from kevlahnota/master2
refactor planechase BG fetcher
2025-07-25 09:18:02 +08:00
Anthony Calosa
924d9f57a6 minor cleanup 2025-07-25 09:10:32 +08:00
Anthony Calosa
8c5dfb61e7 refactor planechase fetcher 2025-07-25 08:44:21 +08:00
Renato Filipe Vidal Santos
895c5c1e65 SPM: 4 cards (#8194) 2025-07-24 19:14:47 +00:00
tool4ever
e64faa3cf2 Update patchwork_crawler.txt 2025-07-24 18:53:33 +00:00
Paul Hammerton
11815a4cf2 Merge pull request #8195 from paulsnoops/edition-updates
Edition updates: PURL, SPM
2025-07-24 18:51:37 +01:00
Paul Hammerton
d903e4d80d Edition updates: PURL, SPM 2025-07-24 18:47:54 +01:00
kevlahnota
6530515e98 Merge pull request #8193 from kevlahnota/master2
fix planechase bg download
2025-07-25 00:47:20 +08:00
kevlahnota
28711aa669 Merge pull request #8191 from Card-Forge/mkm-crash-fix
Update Murders at Karlov Manor.txt
2025-07-25 00:42:55 +08:00
Anthony Calosa
f3b2192dd2 fix planechase bg download 2025-07-25 00:36:42 +08:00
kevlahnota
d6451ae486 Update Murders at Karlov Manor.txt
fix crash sealed
2025-07-24 23:06:41 +08:00
tool4ever
a78c648e77 Fix Offering being an AltCost (#8190) 2025-07-24 14:33:51 +00:00
Fulgur14
b1afd28556 20 SPM/SPE cards plus Katara (July 24th, Batch 5) (#8184) 2025-07-24 12:45:53 +00:00
Fulgur14
82f5e17705 10 SPM/SPE cards (July 24th, Batch 4) (#8182) 2025-07-24 12:43:27 +00:00
Fulgur14
15e955576f 10 SPM/SPE cards (July 24th, Batch 1) (#8179) 2025-07-24 12:42:08 +00:00
Fulgur14
23b0fa09d9 10 SPM/SPE cards (July 24th, Batch 3) (#8181) 2025-07-24 12:36:18 +00:00
Fulgur14
34e31e7e29 11 SPM/SPE cards (July 24th, Batch 2) (#8180) 2025-07-24 12:34:54 +00:00
kevlahnota
3fcb9e7a3c add stars.png 2025-07-24 19:57:11 +08:00
Anthony Calosa
f69ff10b7c add nyx effect to desktop card renders 2025-07-24 19:31:26 +08:00
tool4ever
bd6ea12cc6 Update coercive_recruiter.txt 2025-07-24 10:10:47 +00:00
Fulgur14
10fa3f7f22 Removing RemoveIntrinsicAbilities$ (#8188) 2025-07-24 11:38:41 +02:00
kevlahnota
462b183548 Merge pull request #8187 from kevlahnota/master2
invert PT Box color
2025-07-24 16:13:21 +08:00
Paul Hammerton
4b5bf6fef4 Update Edge of Eternities.txt 2025-07-24 09:12:08 +01:00
Anthony Calosa
1f28e46e06 invert PT Box color 2025-07-24 15:58:03 +08:00
Paul Hammerton
990e515cb9 Merge pull request #8183 from paulsnoops/paulsnoops-patch-1
Edition updates: SLD, SPE, SPM
2025-07-24 08:26:37 +01:00
Paul Hammerton
6ee86f9762 Update Secret Lair Drop Series.txt 2025-07-24 08:25:02 +01:00
Paul Hammerton
41dfb3488c Create Marvel's Spider-Man.txt 2025-07-24 08:21:45 +01:00
Paul Hammerton
f61e1cd435 Edition updates: SPE, SPM 2025-07-24 08:17:29 +01:00
Fulgur14
1627503248 Origin of Spider-Man (SPM) (#8176) 2025-07-24 07:31:04 +02:00
kevlahnota
4c87c8a1ff update renderer for Spacecraft PT (#8178)
* update renderer for Spacecraft PT
2025-07-24 12:20:00 +08:00
kevlahnota
8036d4a553 Merge pull request #8175 from tool4ever/scpt
Basic renderer support for Spacecraft PT
2025-07-24 07:39:10 +08:00
kevlahnota
a9f18bbf48 Merge pull request #8177 from kevlahnota/newMaster
remove isNyx check
2025-07-24 07:35:40 +08:00
Anthony Calosa
64738f58d6 remove isNyx check 2025-07-24 07:33:42 +08:00
tool4ever
f426e9f236 Update plasma_bolt.txt 2025-07-23 21:29:25 +00:00
tool4EvEr
234237b43a Basic renderer support for Spacecraft PT 2025-07-23 19:11:47 +02:00
tool4ever
854d6640d1 Fix PlayEffect skipping some checks (e.g. split second on AI) (#8162) 2025-07-23 16:26:27 +00:00
Hans Mackowiak
c6514e0183 Update CopyPermanentEffect.java 2025-07-23 17:49:23 +02:00
Hans Mackowiak
9164e76f44 CopyPermanentEffect: fix DefinedName TokenKey 2025-07-23 17:49:23 +02:00
Hans Mackowiak
5cf155fb94 CardFactory: fix Squad TokenNames
Can be used for WH40K token

But FalloutToken need a fallback to Copy?
2025-07-23 17:49:06 +02:00
Renato Filipe Vidal Santos
11be569f35 Rename rukarumal_biologist.txt to rukarumel_biologist.txt (#8173) 2025-07-23 17:37:19 +02:00
kevlahnota
00412f6418 Merge pull request #8171 from kevlahnota/newMaster
QOL Groupby CardType Land
2025-07-23 22:13:43 +08:00
Anthony Calosa
c66e4a08e6 QOL Groupby CardType Land 2025-07-23 22:12:26 +08:00
kevlahnota
c22934f4af Merge pull request #8170 from kevlahnota/newMaster
fix Summon: Choco/Mog not importing
2025-07-23 21:27:46 +08:00
Anthony Calosa
2792c57405 fix Summon: Choco/Mog not importing 2025-07-23 21:26:19 +08:00
Eradev
e3637586d6 Revert "Add g_1_1_insect_flying token"
This reverts commit 0d2d01060d.
2025-07-23 06:53:50 +02:00
Hans Mackowiak
5787dfbca5 Update Edge of Eternities Commander.txt
Fix Insect Token
2025-07-23 06:31:31 +02:00
Fulgur14
9b80408bc6 Token wording update (July 2025 Comprehensive Rules) (#8160)
* Token wording update (July 2025 Comprehensive Rules)

* Update c_a_food_sac.txt

* Update c_a_treasure_sac.txt

* Update c_a_gold_sac.txt

* Update c_e_shard_draw.txt

* Update c_a_clue_draw.txt

* Update incubator_c_0_0_a_phyrexian.txt

* Update role_wicked.txt

* Update c_a_map_sac_explore.txt

* Update c_a_junk_sac_exileplay.txt

* Update c_a_blood_draw.txt

* Update elegy_acolyte.txt

* Update systems_override.txt

* Update survey_mechan.txt
2025-07-22 22:42:15 -04:00
Eradev
073f32c1c9 Update CM2 2025-07-22 21:42:36 -04:00
Eradev
6564e76aad Update CMR 2025-07-22 21:42:36 -04:00
Eradev
35563fe834 Update M21 2025-07-22 21:42:36 -04:00
Eradev
9b46581289 Update M20 2025-07-22 21:42:36 -04:00
Eradev
dbde27bc88 Update PM20 2025-07-22 21:42:36 -04:00
Eradev
b37c280bf8 Update M19 2025-07-22 21:42:36 -04:00
Eradev
643fc2106b Update CNS 2025-07-22 21:42:36 -04:00
Eradev
48496cfbbc Update CN2 2025-07-22 21:42:36 -04:00
Eradev
3022129fb5 Update CON 2025-07-22 21:42:36 -04:00
Eradev
5d0a7b5ef9 Update CM1 2025-07-22 21:42:36 -04:00
Eradev
fa1557c775 Update CMD 2025-07-22 21:42:36 -04:00
Eradev
cb47a9c4be Update CMM 2025-07-22 21:42:36 -04:00
Eradev
9e2ab76be3 Update CLB 2025-07-22 21:42:36 -04:00
Eradev
90c8f8e332 Germ token as Phyrexian Germ token has been printed 2025-07-22 21:42:36 -04:00
Eradev
63397dee07 Update CC2 2025-07-22 21:42:36 -04:00
Eradev
a602b1bdf2 Update CMA 2025-07-22 21:42:36 -04:00
Eradev
8653a26d38 Update CM2 2025-07-22 21:42:36 -04:00
Eradev
8ea5ac97a2 Upcate C19 2025-07-22 21:42:36 -04:00
Eradev
d72d36a8b9 Update C18 2025-07-22 21:42:36 -04:00
Eradev
664ce69993 Update C16 2025-07-22 21:42:36 -04:00
Eradev
93bca202bf Update C14 2025-07-22 21:42:36 -04:00
Eradev
72641e000b Update CSP 2025-07-22 21:42:36 -04:00
Eradev
36696f9b1b Update CST 2025-07-22 21:42:36 -04:00
Eradev
83bfe2a524 Update 6ED 2025-07-22 21:42:36 -04:00
Eradev
827a02563b Update CHR 2025-07-22 21:42:36 -04:00
Eradev
f06acf88f9 Update PCSP 2025-07-22 21:42:36 -04:00
Eradev
0f78751ce3 Update CHK 2025-07-22 21:42:36 -04:00
Eradev
c9fbd579b6 Update PCEL 2025-07-22 21:42:36 -04:00
Eradev
4e12f73444 Update BOK 2025-07-22 21:42:36 -04:00
Eradev
22f4a250e4 Update BBD 2025-07-22 21:42:36 -04:00
Eradev
ed6966b570 Update BFZ 2025-07-22 21:42:36 -04:00
Eradev
14c6794ee3 Update APC 2025-07-22 21:42:01 -04:00
Eradev
9494321965 Update E01 2025-07-22 21:42:01 -04:00
Eradev
34d009a458 Update ARN 2025-07-22 21:42:01 -04:00
Eradev
ac5128d133 Update ACR 2025-07-22 21:42:01 -04:00
Eradev
12c487f7b8 Update PAVR 2025-07-22 21:42:01 -04:00
Eradev
285417275d Update AVR 2025-07-22 21:42:01 -04:00
Eradev
f2db114cb6 Update APC 2025-07-22 21:42:01 -04:00
Eradev
87226d9bd9 Update ATH 2025-07-22 21:42:01 -04:00
Eradev
a644a4c7bc Update ATQ 2025-07-22 21:42:01 -04:00
Eradev
462bdf19b9 Update MPS_AKH 2025-07-22 21:42:01 -04:00
Eradev
3d9bb1f437 Update PAKH 2025-07-22 21:42:01 -04:00
Eradev
485d2dbaf8 Update ALL 2025-07-22 21:42:01 -04:00
Eradev
8f8abdbab9 Update YOTJ 2025-07-22 21:42:01 -04:00
Eradev
7ebe74e57c Update PARB 2025-07-22 21:42:01 -04:00
Eradev
b45153bee8 Update DFT 2025-07-22 21:42:01 -04:00
Eradev
55c4d4240f Update AER 2025-07-22 21:42:01 -04:00
Eradev
0d2d01060d Add g_1_1_insect_flying token 2025-07-22 21:41:36 -04:00
kevlahnota
f84237f25b Merge pull request #8163 from Drecon84/master
Re-adding item to New Game+ Adventure
2025-07-23 06:38:09 +08:00
kevlahnota
07cff6f9a9 Merge pull request #8164 from kevlahnota/newMaster
update SettingsScene landscape checkbox
2025-07-23 06:35:49 +08:00
Anthony Calosa
9f7852e76f update SettingsScene landscape checkbox 2025-07-23 06:29:58 +08:00
Drecon84
943d6edabd Re-adding item to New Game+ Adventure
When I put in the code to delete quest items on a new game+ I forgot to re-add the colorless rune in case you start without the main quest (you get it as part of the main quest). This fixes that.
2025-07-22 21:06:58 +02:00
Matthew Krafczyk
800b88911a Fix draft slot definitions 2025-07-22 14:07:03 -04:00
Matthew Krafczyk
dccbd9912d Small mistakes correction 2025-07-22 14:07:03 -04:00
Matthew Krafczyk
b5f696756e Fix EOS set name 2025-07-22 14:07:03 -04:00
Matthew Krafczyk
9ff528029a Fix draft ranking set codes 2025-07-22 14:07:03 -04:00
Matthew Krafczyk
44046b475b Add EOE to blocks 2025-07-22 14:07:03 -04:00
Matthew Krafczyk
65959f9089 Draft definitions for EOE 2025-07-22 14:07:03 -04:00
Paul Hammerton
94d87039e3 Merge pull request #8161 from paulsnoops/update-draft-ranking
Update draft rankings: DFT, FIN, PIO, TDM
2025-07-22 18:23:49 +01:00
Paul Hammerton
d3a13d4515 Update draft rankings 2025-07-22 18:14:19 +01:00
kevlahnota
b63bee045f Merge pull request #8157 from kevlahnota/newMaster
Prevents crashes when calculating soft buttons bar height
2025-07-22 19:21:24 +08:00
Anthony Calosa
977d46bca5 Prevents crashes when calculating soft buttons bar height 2025-07-22 19:17:57 +08:00
Hans Mackowiak
8293d4de63 Update Edge of Eternities.txt
Add Emblem
2025-07-22 10:41:06 +02:00
Renato Filipe Vidal Santos
94feb1b63b Add files via upload 2025-07-22 09:37:14 +02:00
Renato Filipe Vidal Santos
e37dac6cbe Update giott_king_of_the_dwarves.txt 2025-07-22 09:36:51 +02:00
tool4ever
c7b98bc578 Restore some fixes (#8154) 2025-07-22 06:18:36 +00:00
tool4ever
7d4369fdca Cast after warping only for owner (#8148)
* Cast after warping only for owner

* give effect to owner

---------

Co-authored-by: tool4EvEr <tool4EvEr@>
2025-07-22 08:23:57 +03:00
kevlahnota
28cb9f9d7d Merge pull request #8152 from kevlahnota/newMaster
fix CardRules setColorID reset
2025-07-22 11:21:02 +08:00
Anthony Calosa
94e3c71809 fix CardRules setColorID reset 2025-07-22 11:19:26 +08:00
Chris H
5dd6a5b45a Revert "Consolidate some PlayEffect logic (#8133)"
This reverts commit 514d40aefd.
2025-07-21 22:03:17 -04:00
kevlahnota
e486f846d8 Merge pull request #8150 from kevlahnota/newMaster
update some dialog translation, KeyBoardDialog
2025-07-22 09:27:00 +08:00
kevlahnota
e7793764a6 Merge pull request #8146 from Drecon84/master
Fix for red castle
2025-07-22 09:01:43 +08:00
Anthony Calosa
5aea2e5bbe update some dialog translation, KeyBoardDialog 2025-07-22 08:58:12 +08:00
Paul Hammerton
f52410f2f8 Merge pull request #8149 from paulsnoops/eoe-historic-bans
EOE Historic bans
2025-07-21 22:00:06 +01:00
Paul Hammerton
53e2f199cc EOE Historic bans 2025-07-21 21:55:48 +01:00
Drecon84
f86e9a56d1 Merge branch 'Card-Forge:master' into master 2025-07-21 20:26:34 +02:00
tool4ever
31ebe48bf3 Update diplomatic_relations.txt 2025-07-21 17:15:09 +02:00
Drecon84
ff963b2cb9 Fix for red castle
Hard mode didn't have the defeat dialogue because it spawned a different version of Lathliss without the defeat code.
2025-07-21 16:45:41 +02:00
kevlahnota
9a6ebce85a Increase MemoryStack
should prevent Out of stack space when exporting the large inventory of cards to clipboard, though not tested for the whole card database
2025-07-21 22:22:48 +08:00
kevlahnota
eb5e37e3de Merge pull request #8145 from kevlahnota/newMaster
fix Rewarded Deck dialogs
2025-07-21 18:42:22 +08:00
Anthony Calosa
92b96aea75 fix Rewarded Deck dialogs 2025-07-21 18:37:07 +08:00
kevlahnota
0f4c0488d5 Merge pull request #8144 from kevlahnota/newMaster
adjust playersprite spawn point on new game
2025-07-21 17:17:10 +08:00
Anthony Calosa
6879089149 adjust playersprite spawn point on new game 2025-07-21 17:10:05 +08:00
tool4ever
3e2eb86bd4 Update dockworker_drone.txt 2025-07-21 07:53:47 +02:00
tool4ever
84ff75c9cf Update frontline_war_rager.txt 2025-07-21 07:52:30 +02:00
tool4ever
9d3605ee96 RepeatEach refactoring (#8139)
* RepeatEach cleanup

* RepeatEach cleanup

---------

Co-authored-by: tool4EvEr <tool4EvEr@>
2025-07-21 07:22:40 +03:00
Chris H
83cd6b7291 Update wheel_of_sun_and_moon.txt 2025-07-21 06:18:20 +02:00
tool4ever
514d40aefd Consolidate some PlayEffect logic (#8133)
* Fix potential GUI lock if game ends during RepeatEffect

* Fix casting Feast of Blood from PlayEffect without creatures in play
2025-07-20 10:35:03 +00:00
Northmoc
31cca02d8d Flavor for Equip 2025-07-20 09:30:00 +02:00
Hans Mackowiak
5fbd2f9552 Devour: better keyword 2025-07-20 07:45:35 +02:00
Eradev
7ee0431a2f Fix Territorial Bruntar 2025-07-20 06:41:11 +02:00
Eradev
0786403fff Support code2 and alias in sheets (#8009)
* LF

* Support for Code2 and Aliases in sheets

* Support for Code2 and Aliases in sheets

* TryConvertingName

* Revert changes

* Update CardEdition.java

* Wrong check
2025-07-20 07:37:04 +03:00
Renato Filipe Vidal Santos
4f7dbfbc80 Add files via upload (#8004) 2025-07-20 07:36:45 +03:00
Eradev
6caf02fc77 Update Arena sets (#8000)
* Update ANB

* Add XANA

* Update ANA

* Add OANA

* Update G18
2025-07-20 07:36:17 +03:00
Chris Dietsch
9dedc9ecfa Update ISSUES.txt (#8129) 2025-07-20 07:35:23 +03:00
lemtom
b62434616a New 16x16 sprites and avatars for planeswalkers &c. (#8048)
* New sprites that fit established aesthetic

* Adjustments

* Remove downscale + fix wrong pixel on Sorin

---------

Co-authored-by: Agetian <stavdev@mail.ru>
2025-07-20 07:35:14 +03:00
Eradev
ad8f3ea06f Fix Lobelia 2025-07-19 22:09:08 -04:00
Renato Filipe Vidal Santos
dbed505282 Quick cleanup: 2025-07-19, pass 2 2025-07-19 20:18:24 +00:00
Renato Filipe Vidal Santos
1468746045 Quick cleanup: 2025-07-18, pass 3 (again) (#8124) 2025-07-19 14:44:09 +00:00
Paul Hammerton
6841b31849 Merge pull request #8125 from paulsnoops/eoe-sections
EOE Edition Sections
2025-07-19 15:19:37 +01:00
Paul Hammerton
a151dff3c5 EOE Edition Sections 2025-07-19 15:15:48 +01:00
Paul Hammerton
90f6e2b17f Migrate EOE card scripts 2025-07-19 14:28:57 +02:00
Renato Filipe Vidal Santos
7b1e96410f Add files via upload (#8119) 2025-07-19 11:29:28 +00:00
Paul Hammerton
7ecf619b94 Merge pull request #8122 from paulsnoops/decode-transmissions-name
Fix Decode Transmissions name
2025-07-19 12:10:23 +01:00
Paul Hammerton
b1d8b6fd5c Fix Decode Transmissions name 2025-07-19 12:08:15 +01:00
Paul Hammerton
a15a990730 Merge pull request #8121 from paulsnoops/eoe-formats
EOE Formats update
2025-07-19 12:01:51 +01:00
Paul Hammerton
7402aab2a8 EOE Formats update 2025-07-19 11:53:16 +01:00
Paul Hammerton
2a68427c82 Merge pull request #8120 from paulsnoops/edition-updates
Edition updates: EOC, EOE, EOS, SCH
2025-07-19 11:24:04 +01:00
Paul Hammerton
14dd9721e3 SCH 2025-07-19 11:20:46 +01:00
Paul Hammerton
6115eaf6da EOE 2025-07-19 11:11:42 +01:00
Paul Hammerton
b4922ce353 EOS 2025-07-19 11:06:39 +01:00
Paul Hammerton
0fb37bf2d4 DRAFT: Edition updates 2025-07-19 11:02:20 +01:00
Eradev
8ce5272e95 More console commands (#8096) 2025-07-19 08:33:43 +00:00
Fulgur14
08135545da Final EOE batch (part 4) (#8112) 2025-07-19 07:57:37 +00:00
Fulgur14
3cdbb8f1dd Final EOE batch (part 3) (#8106) 2025-07-19 07:57:24 +00:00
Fulgur14
4f662a5651 Final EOE batch (part 2) (#8105) 2025-07-19 07:56:02 +00:00
Fulgur14
0e0811a1ac Final EOE batch (part 1) (#8103) 2025-07-19 07:51:55 +00:00
Renato Filipe Vidal Santos
71882fe83c EOE: Memorial Vault (#8108) 2025-07-18 20:32:30 +00:00
Northmoc
fce67b847c moxite_refinery.txt and support (#7997) 2025-07-18 14:48:48 +02:00
Renato Filipe Vidal Santos
2ff0c6b92d Add files via upload (#8102) 2025-07-18 12:10:30 +02:00
Paul Hammerton
b27b8b7ba5 Merge pull request #8101 from paulsnoops/master
Edition updates: EOE, EOS, SLD
2025-07-18 10:16:14 +01:00
Paul Hammerton
f889abd57a Update Secret Lair Drop Series.txt 2025-07-18 10:11:28 +01:00
Paul Hammerton
1d2852fff6 Update Edge of Eternities Stellar Sights.txt 2025-07-18 10:03:29 +01:00
Paul Hammerton
48247f7d3b Edition updates 2025-07-18 09:58:56 +01:00
Eradev
d3e6932a23 Fix Dionus' power (#8100) 2025-07-18 10:40:10 +02:00
Renato Filipe Vidal Santos
e4d3e061d1 Quick cleanup: 2025-07-18 (#8099) 2025-07-18 09:32:27 +02:00
Eradev
e57708543a Back to quest list button fix (#8094) 2025-07-18 09:32:11 +02:00
Renato Filipe Vidal Santos
69e2f90c8d EOE: 2 cards (#8097) 2025-07-18 05:49:37 +00:00
shenshinoman
655d01114c Cleaning up Innistrad structure (#8058)
* Cleaning up the file structure to move all Innistrad maps under the Innistrad folder, as well as some minor logic change to Shandalar Old Border's config.json to make maintenance easier. (By setting the desired sets in allowedEditions, we no longer have to restrict every new edition as it comes in.)

Finally, added block info for Alchemy: Innistrad, so it should start being available in events as well.

* Cleaning up the file structure to move all Innistrad maps under the Innistrad folder, as well as some minor logic change to Shandalar Old Border's config.json to make maintenance easier. (By setting all the desired sets to be viewed in allowedEditions, it will only shows those, and we no longer have to restrict every new edition as it comes in.) Also fixed a bug making the "Ghost Town" not work in Shandalar Old Border

Finally, added block info for Alchemy: Innistrad, so it should start being available in events as well.

* Update Adventure - Guardian Gladiolus.dck

---------

Co-authored-by: Hans Mackowiak <hanmac@gmx.de>
2025-07-17 17:29:54 -04:00
Eradev
0d40508e69 Remove conjured cards from rewards 2025-07-17 17:12:11 -04:00
Fulgur14
b785a84dca Mm'menon, Uthros Exile and Pull Through the Weft (EOE) (#8093) 2025-07-17 19:16:32 +00:00
tool4ever
14af90cd27 Henzie day: fix copied spell gaining Blitz (#8092) 2025-07-17 18:57:07 +00:00
Fulgur14
0278918886 Blade of the Swarm (EOE) (#8090) 2025-07-17 17:20:27 +00:00
Fulgur14
b44738cda3 5 EOE cards (July 17th) (#8089) 2025-07-17 16:23:48 +00:00
Fulgur14
ddbe2d6051 3 EOE cards (July 17th) (#8087) 2025-07-17 16:22:30 +00:00
loud1990
a15ebe86db Cleaned up mechan_assembler and weftstalker_ardent triggerzones (#8088) 2025-07-17 16:32:05 +02:00
kevlahnota
16225d2894 Merge pull request #8086 from kevlahnota/newMaster
fix enter key and textfield keypress collision
2025-07-17 20:03:17 +08:00
Anthony Calosa
b4c87a198a fix enter key and textfield keypress collision 2025-07-17 20:02:06 +08:00
Eradev
38da204607 Try to use current set when creating a card from an effect (#8080)
* Fix CardDb fallback
2025-07-17 11:20:15 +00:00
kevlahnota
dbe410f8af Merge pull request #8084 from kevlahnota/newMaster
fix GamePad mapping
2025-07-17 19:18:49 +08:00
Anthony Calosa
b05eb4eed3 fix GamePad mapping 2025-07-17 19:17:36 +08:00
kevlahnota
02201c4527 Merge pull request #8083 from kevlahnota/newMaster
update keybinding for NewGameScene
2025-07-17 19:03:30 +08:00
Anthony Calosa
6536d39969 update keybinding for NewGameScene 2025-07-17 18:59:59 +08:00
Paul Hammerton
c9b41c2b81 Merge pull request #8082 from paulsnoops/paulsnoops-patch-1
Edition updates: EOE, EOS, SPG
2025-07-17 08:38:22 +01:00
Paul Hammerton
74e587a8a0 Update Special Guests.txt 2025-07-17 08:35:13 +01:00
Paul Hammerton
a751ad186e Update Edge of Eternities Stellar Sights.txt 2025-07-17 08:33:26 +01:00
Paul Hammerton
bae41478d9 Edition updates 2025-07-17 08:27:08 +01:00
Renato Filipe Vidal Santos
10dbafbe8c EOE: 4 cards (#8079) 2025-07-16 19:54:02 +00:00
Fulgur14
504946f72a Pinnacle Kill-Ship (EOE) (#8078) 2025-07-16 19:29:48 +00:00
Valensior
e45ae205ac Dauntless Scrapbot [EOE] (#8076) 2025-07-16 18:30:05 +00:00
Fulgur14
4a5969157d 6 EOE cards (July 16th) (#8075) 2025-07-16 17:55:38 +00:00
Fulgur14
bdda4d50f7 Create steelswarm_operator.txt (#8074) 2025-07-16 14:16:42 +00:00
tool4ever
f565943d8d Fix cost syntax (#8073) 2025-07-16 13:02:47 +00:00
Fulgur14
3158c0b1d9 Hymn of the Faller (EOE) (#8072) 2025-07-16 12:57:18 +00:00
Fulgur14
4346d83582 Update atmospheric_greenhouse.txt (#8071) 2025-07-16 06:58:57 +00:00
Fulgur14
7e016f4ca5 6 EOE cards (July 15th) (#8067) 2025-07-16 06:25:09 +00:00
Valensior
38242d0226 [EOE] Atmospheric Greenhouse & Cryogen Relic (#8064) 2025-07-16 07:58:11 +02:00
Eradev
b565095136 Stop spamming key is malformed. 2025-07-15 15:14:06 -04:00
Eradev
93b5fd5f3e Early stop if file exists. Display missing file location. 2025-07-15 15:07:37 -04:00
Eradev
8ca03c1f50 Set output as error 2025-07-15 15:06:36 -04:00
Hans Mackowiak
f5204b89fb lf 2025-07-15 19:53:49 +02:00
Fulgur14
b9dc63b3df Devastating Onslaught (EOE) (#8062) 2025-07-15 17:29:35 +00:00
Valensior
86910302dc Update famished_worldsire.txt (#8063) 2025-07-15 17:20:32 +00:00
Fulgur14
a0cca65075 3 EOE cards (July 15th) (#8060) 2025-07-15 16:56:40 +00:00
Fulgur14
0cc2c3b275 World Shaper EOC Commander Deck (#8011) 2025-07-15 17:22:43 +02:00
Eradev
2cb4856dc7 Daily EOE Update (2025-07-14) (#8006) 2025-07-15 17:22:16 +02:00
Fulgur14
88a53226a2 Create station_monitor.txt (#8057) 2025-07-15 16:49:09 +02:00
Fulgur14
1d42ab50c7 Desculpting Blast (EOE) (#8055) 2025-07-15 15:09:33 +02:00
Fulgur14
cf10851c78 Create meltstrider_eulogist.txt (#8054) 2025-07-15 14:56:05 +02:00
Fulgur14
c1727ffb3f Quantum Riddler (EOE) (#8047) 2025-07-15 13:58:55 +02:00
Fulgur14
43d79c024e Warp/Void EOE scripts, part 3 (#8041) 2025-07-15 12:14:50 +02:00
Fulgur14
3fcf200a86 Warp/Void card scripts, part 4 (#8045) 2025-07-15 11:40:25 +02:00
Fulgur14
8bc5588342 Warp/Void EOE scripts, part 2 (#8039) 2025-07-15 10:28:27 +02:00
Fulgur14
ab27b613e3 Warp/Void EOE scripts, Part 1 (#8038) 2025-07-15 10:25:33 +02:00
tool4ever
c6816dbe74 Close Encounter and support (#8040) 2025-07-15 09:25:32 +02:00
Eradev
41e43a8441 Change PHJ to JP1 (#8044) 2025-07-15 09:23:42 +02:00
Eradev
ff91114f39 Merge branch 'master' into 7859-DisplayTextTooltip 2025-07-14 22:00:22 -04:00
Eradev
b3951555a1 Remove tokens 2025-07-14 20:37:12 -04:00
Eradev
f3a68e940e Update tokens 2025-07-14 20:37:12 -04:00
Eradev
1d646753f2 J21 Update 2025-07-14 20:37:12 -04:00
tool4ever
b293700b13 Fix more MustBlockAi trigger misses (#8037) 2025-07-14 19:03:47 +00:00
Hans Mackowiak
ea2e0fa3e6 Keyword: Warp (#7914)
* Keyword: Warp

* Add Timeline Culler

* Player: remove revolt variable

* AbilityUtils: add Void Modifier

* Improve logic

* Fix import

---------

Co-authored-by: TRT <>
2025-07-14 21:03:36 +02:00
Eradev
bad55a173d Planar Conquest fixes (#8033)
* Only add commanders once. Fix REPRINT_SET_TYPES check.

* Cards.txt example

* Update Rhox Faithmender

---------

Co-authored-by: Agetian <stavdev@mail.ru>
2025-07-14 19:37:01 +03:00
tool4ever
69538f248d Fix MustBlockAi leaving stuff tapped (#8036) 2025-07-14 16:31:30 +00:00
Agetian
c2f4736f08 AI hint for Olivia's Wrath (#8035)
* - Add puzzles PS_TDM4-5, PS_FIN1-3.

* - Add AI hint for Olivia's Wrath.
2025-07-14 19:28:07 +03:00
Eradev
9aa142ba5a Update S00 (#8030)
Co-authored-by: Agetian <stavdev@mail.ru>
2025-07-14 18:57:48 +03:00
Eradev
f4aba94a18 Fix token generation in puzzles (#8031)
* Fix token generation

---------

Co-authored-by: Hans Mackowiak <hanmac@gmx.de>
2025-07-14 15:23:49 +02:00
kevlahnota
910c06b4d2 Merge pull request #8032 from kevlahnota/newMaster
add restart dialog on World selectbox
2025-07-14 20:44:44 +08:00
Anthony Calosa
490a9b1693 add restart dialog on World selectbox 2025-07-14 20:38:36 +08:00
tool4ever
f6a8705849 Update genestealer_patriarch.txt
Closes #8029
2025-07-14 13:24:42 +02:00
kevlahnota
df2f1105c1 Merge pull request #8023 from kevlahnota/newMaster
update libs for LibGDX 1.13.5
2025-07-14 05:36:38 +08:00
Renato Filipe Vidal Santos
acaf683166 EOE: 2 cards (#8028) 2025-07-13 18:43:19 +00:00
tool4ever
1c6b256268 Fix Spacecraft type collision (#8024) 2025-07-13 18:39:06 +00:00
Agetian
d59ec1527d - Add puzzles PS_TDM4-5, PS_FIN1-3. (#8027) 2025-07-13 20:22:14 +03:00
Anthony Calosa
4b6e46ab7d update libs for LibGDX 1.13.5
update gdx-controllers
2025-07-13 22:27:01 +08:00
Renato Filipe Vidal Santos
68b949bdbf EOE: 3 cards 2025-07-13 14:25:48 +00:00
Fulgur14
a49cc1db97 Update Adventure - Guardian Gladiolus.dck 2025-07-13 10:00:16 -04:00
Simisays
701cc31e1c Update config.json (#8019) 2025-07-13 12:37:22 +03:00
kevlahnota
8832920a4d Merge pull request #8020 from kevlahnota/newMaster
revert TextraTypist
2025-07-13 17:21:07 +08:00
Anthony Calosa
d044d0dc65 revert TextraTypist 2025-07-13 17:12:00 +08:00
Hans Mackowiak
e7427bb180 lf 2025-07-13 10:27:30 +02:00
Fulgur14
989acaa7d4 Lightstall Inquisitor (EOE) (#8018) 2025-07-13 08:19:17 +00:00
tool4ever
6351ea2593 Update lara_croft_tomb_raider.txt 2025-07-13 07:29:29 +00:00
tool4ever
1a586f07d1 Update fraying_sanity.txt 2025-07-13 07:26:42 +00:00
tool4ever
69ec802299 Update ravenous_trap.txt 2025-07-13 07:25:57 +00:00
Hans Mackowiak
817b72f67f lf 2025-07-13 09:10:45 +02:00
Fulgur14
cf1398606b 2 EOE cards (13th July) (#8017) 2025-07-13 07:01:56 +00:00
Fulgur14
31d733aacb Update scouring_swarm.txt (#8014) 2025-07-13 06:11:13 +00:00
kevlahnota
77544f855b Merge pull request #8016 from kevlahnota/newMaster
minor cleanup
2025-07-13 13:44:59 +08:00
Anthony Calosa
1be4880776 fix overlayLabel background 2025-07-13 13:39:53 +08:00
Anthony Calosa
ff39f82099 minor cleanup 2025-07-13 12:52:53 +08:00
shenshinoman
200e509cda Adding extra Planes to Adventure mode and providing an easy method to swap between them. (#7932)
* updating local project

* updating local project

* updating local project

* updating local project

* Update Config.java

updating the file with the better change made by Jetz

* Merge remote-tracking branch 'origin/master'

* Merge remote-tracking branch 'origin/master'

* Merge remote-tracking branch 'origin/master'

* Merge remote-tracking branch 'origin/master'
2025-07-12 21:21:25 -04:00
tool4ever
6a70c6705d Update orims_thunder.txt 2025-07-12 20:52:09 +00:00
kevlahnota
6749e5de7e fix crash (#8013)
* fix illegalargument TextButtonStyles
2025-07-12 23:48:35 +08:00
Eradev
9b83c7eeec Disable the art in the text version 2025-07-12 08:52:15 -04:00
kevlahnota
1c8f7eccbe Update RewardActor (#8012)
* add sell icon

* update RewardActor
2025-07-12 20:03:25 +08:00
kevlahnota
13c98c68e9 update TextraTypist (#8010)
* update TextraTypist

* use pixelmana atlas

* fix variable init
2025-07-12 18:43:03 +08:00
Hans Mackowiak
d492cff553 lf 2025-07-12 10:25:13 +02:00
Fulgur14
875bd54c21 Attempt at Eumidian Wastewaker 2025-07-12 08:13:03 +00:00
Eradev
9825bebb75 Merge branch 'master' into 7859-DisplayTextTooltip 2025-07-11 21:57:48 -04:00
Fulgur14
f2ab574a3b Weftwalking and Monoist Circuit-Feeder (EOE) (#8007) 2025-07-11 19:22:40 +00:00
Eradev
94babc2c53 Fix display 2025-07-11 13:34:13 -04:00
Jetz
4e42963033 Add fantasyBlock support for allowedJumpstart 2025-07-11 12:16:25 -04:00
Jetz
6fec40522e Use code instead of name for filtering drafts 2025-07-11 12:16:25 -04:00
Jetz
eea9890f9d Change allowedJumpstart to override default selection. 2025-07-11 12:16:25 -04:00
Jetz
89d1cffc12 Add allowedJumpstart support to config. 2025-07-11 12:16:25 -04:00
Jetz
40f168bf1e Add restrictedEvents support to config. 2025-07-11 12:16:25 -04:00
Jetz
891a098d2a Per-plane configs 2025-07-11 12:16:25 -04:00
Fulgur14
b6c0d86945 Sami's Curiosity (EOE) (#8005) 2025-07-11 15:29:53 +00:00
Eradev
2cb69c2d6e Allow display of text in tooltip in shops 2025-07-11 11:29:32 -04:00
Eradev
9a96760061 LF 2025-07-11 11:27:12 -04:00
Renato Filipe Vidal Santos
d4a484522e YTDM: 13 more cards (#7486) 2025-07-11 14:59:15 +00:00
Fulgur14
7a24b5cd0c 4 EOE cards (10th July) (#7990)
* Support The Dominion Bracelet
2025-07-11 13:45:04 +00:00
Fulgur14
c0e34799c8 5 EOE cards (11th July) (#8003) 2025-07-11 13:17:22 +00:00
Fulgur14
964d500414 9 EOC + 3 EOE cards (#7991) 2025-07-11 11:19:38 +00:00
Fulgur14
e2949b66fc Create kavaron_harrier.txt (#7999) 2025-07-11 08:34:35 +00:00
Paul Hammerton
06fcb531cd Merge pull request #7993 from Eradev/UpdateEOE20250710
Edge of Eternities Daily Update
2025-07-11 09:15:55 +01:00
Fulgur14
923b12caa0 Hemosymbic Mite (EOE) (#7998) 2025-07-11 08:02:50 +02:00
Chris H
69d75489e7 Fix Bands with other for humans 2025-07-10 22:47:36 -04:00
Eradev
9e985ff471 Edge of Eternities Daily Update 2025-07-10 14:19:52 -04:00
Hans Mackowiak
47390abf3b Update susur_secundi_void_altar.txt
fix Svar SusurDraw
2025-07-10 14:43:04 +02:00
tool4ever
59484f30b5 Fix Keepers (#7988)
* Fix Keepers

* Fix Keepers

---------

Co-authored-by: TRT <>
2025-07-10 15:14:26 +03:00
Eradev
e36701a9f3 Fix Klement, Knowledge Acolyte (#7987) 2025-07-10 12:52:53 +02:00
tool4ever
03b6567993 Fix Seek the Beast for Adventures (again) (#7986) 2025-07-10 11:31:33 +02:00
Eradev
56ef1a1df5 Encode token url (#7983)
* Update 40K

* Apply UTF-8 encoding to tokens too
2025-07-10 10:35:49 +02:00
Fulgur14
6d4af69c19 9 EOC cards (#7982) 2025-07-10 10:31:29 +02:00
Paul Hammerton
b8bd9d92a7 Merge pull request #7985 from Card-Forge/paulsnoops-patch-1
Edition updates: EOC, EOE, EOS, SPG
2025-07-10 09:29:06 +01:00
Paul Hammerton
6a4018f206 oops lands 2025-07-10 09:25:59 +01:00
Paul Hammerton
986b44af43 Update Edge of Eternities.txt 2025-07-10 09:22:46 +01:00
Paul Hammerton
64e6dbad13 ooops space 2025-07-10 09:17:54 +01:00
Paul Hammerton
2e559effcb Update Edge of Eternities Commander.txt 2025-07-10 09:17:15 +01:00
Paul Hammerton
d02f755fa7 Update Edge of Eternities Stellar Sights.txt 2025-07-10 09:14:53 +01:00
Paul Hammerton
17ffda684f Edition updates: EOC, EOE, EOS, SPG 2025-07-10 09:09:35 +01:00
Fulgur14
d6cd2f35ff 2 EOE cards (#7984) 2025-07-10 10:03:45 +02:00
tool4ever
81bba70548 Update monstrous_vortex.txt 2025-07-10 08:49:55 +02:00
Fulgur14
831a2d23e4 7 EOE cards (#7980) 2025-07-10 07:54:13 +02:00
Hans Mackowiak
a0f15cdcb1 lf 2025-07-09 21:04:57 +02:00
tool4ever
e882bd8264 The Eternity Elevator not allowed as Commander (#7978) 2025-07-09 11:45:47 +02:00
Eradev
7101d638c6 Update PRM, TD0, TD1, EOE, EOC (#7976) 2025-07-09 10:58:14 +02:00
Fulgur14
865e3dd783 Update octavia_living_thesis.txt 2025-07-09 10:12:24 +02:00
Fulgur14
b1c992db26 Adagia and Kavaron (EOE) (#7974) 2025-07-09 10:07:42 +02:00
Fulgur14
58f79ae6c0 18 EOE + 2 EOC cards (#7971) 2025-07-09 09:40:02 +02:00
Eradev
fd5af3c93e Fix Meld cards in FIN (#7973) 2025-07-09 05:39:48 +00:00
tool4ever
127d0fced6 Dyadrine, Synthesis Amalgam and support (#7970)
Co-authored-by: tool4EvEr <tool4EvEr@>
2025-07-09 07:28:04 +03:00
Eradev
6526d736bf Prefer random token from set (#7961)
* Prefer random token from set

* Aoivd the array cost

* Forgot import

* ImageUtil

* Fix some tokens
2025-07-09 07:21:09 +08:00
Eradev
cc4a43f0a2 Fix typo (#7955)
* Fix typo

* Support old save files
2025-07-09 07:20:16 +08:00
Fulgur14
286ade792f 12 EOE cards (#7967) 2025-07-08 18:45:18 +00:00
Fulgur14
e681775f47 Update frenzied_baloth.txt (#7969) 2025-07-08 18:38:28 +00:00
Fulgur14
67a9a2c34a 10 EOE cards (#7963) 2025-07-08 18:20:35 +00:00
Eradev
88c0cc00bc Missing emblems + Core sets update (#7966) 2025-07-08 17:51:41 +00:00
kevlahnota
f16f153448 Merge pull request #7968 from Card-Forge/kevlahnota-fix-Rug-of-Smothering
Fix Crash for Rug of Smothering
2025-07-08 22:03:50 +08:00
kevlahnota
1f93dcf5db Update uthros_scanship.txt
- closes #7965
2025-07-08 22:02:44 +08:00
kevlahnota
783fff300d Update AbilityUtils.java 2025-07-08 21:29:53 +08:00
kevlahnota
935e4a00d5 Fix Crash for Rug of Smothering
TriggeredActivator not defined on AbilityUtils calculateAmount, hence produces ClassCastException.
2025-07-08 21:03:39 +08:00
Eradev
6986b5a53d Replace unsupported cards + fix Theros (#7964) 2025-07-08 11:25:20 +02:00
Eradev
e6ed31e9d9 Change Elemental Resonance so it targets CMC>0 (#7962) 2025-07-08 09:26:19 +02:00
Eradev
288c845116 Remove deprecated between to us of (#7951) 2025-07-08 08:39:50 +03:00
Eradev
597222dbf5 Non-alchemy sets cleanup (#7954) 2025-07-08 08:39:17 +03:00
tool4ever
cea6eeabba Update gonti_lord_of_luxury.txt 2025-07-07 15:17:51 +00:00
Eradev
8475456c0b Add missing radiation token (#7948) 2025-07-07 08:51:41 +00:00
Fulgur14
651caccd71 Dawnsire, Sunstar Dreadnought (EOE) (#7958) 2025-07-07 06:18:15 +00:00
kevlahnota
8e9fb8570e Merge pull request #7957 from Eradev/FixEncodingAndroidCompatible
Encode collector number + fallback
2025-07-07 12:55:15 +08:00
Eradev
5a183a6042 Merge branch 'master' into FixEncodingAndroidCompatible 2025-07-07 00:14:02 -04:00
kevlahnota
67e6a7aa1a Merge pull request #7953 from kevlahnota/master2
fix W and S keys for TextField input
2025-07-07 12:09:28 +08:00
Anthony Calosa
b76c67f309 fix comment 2025-07-07 12:08:10 +08:00
Anthony Calosa
99c6b6d815 add comment 2025-07-07 12:06:35 +08:00
Eradev
cadc39699d Encode collector number + fallback 2025-07-07 00:05:37 -04:00
Chris H
8c06aab7b3 Revert "Encode UTF-8 symbols in collector number (#7923)"
This reverts commit fb69f245da.
2025-07-06 22:19:43 -04:00
Anthony Calosa
25c59cd5dd add KeyBinding ispressed condition 2025-07-07 09:37:03 +08:00
Anthony Calosa
9825239e43 fix W and S keys for TextField input 2025-07-07 06:00:04 +08:00
Eradev
fb69f245da Encode UTF-8 symbols in collector number (#7923)
* Fix black star in URL
2025-07-05 22:26:14 +02:00
Robin Woodby
7ef8dddc2a Remove unused import 2025-07-05 14:40:22 -04:00
Robin Woodby
2abcae84b1 Fix issue where card counts from additional printings were ignored 2025-07-05 14:40:22 -04:00
Robin Woodby
b4beb6c182 Remove unnecessary fully qualified names for java.util data structures 2025-07-05 14:40:22 -04:00
Robin Woodby
786d14663b Add copy collection to clipboard button to adventure mode deck editor
Includes translations
2025-07-05 14:40:22 -04:00
tool4ever
f8269e69c4 Fix Rest in Peace making merged cards disappear (#7946)
---------

Co-authored-by: tool4EvEr <tool4EvEr@>
2025-07-05 17:50:40 +02:00
tool4ever
29274d0acf StackInstance cleanup (#7947)
Co-authored-by: tool4EvEr <tool4EvEr@>
2025-07-05 18:15:55 +03:00
Hans Mackowiak
d6b925f171 move file 2025-07-05 17:01:18 +02:00
Hans Mackowiak
f1f18d1823 lf 2025-07-05 17:00:01 +02:00
tool4ever
03ff2147db True-Name Nemesis crashes on "$" Player name (#7944) 2025-07-05 08:54:14 +00:00
Fulgur14
c66a72806d 6 more leaked EOE cards (#7931) 2025-07-05 08:45:51 +00:00
Fulgur14
e89f2cbac0 Two cards from EOE uncommon leaks that I can actually read (#7895) 2025-07-05 08:34:04 +00:00
tool4ever
d831530c50 Tapestry Warden and support (#7943) 2025-07-05 08:31:38 +00:00
Fulgur14
9fe18c2af8 Evendo and Susur Secundi (#7942) 2025-07-05 08:25:45 +00:00
Fulgur14
fe4ff7ac0f 4 EOE leaks (#7941) 2025-07-05 07:26:04 +00:00
Cees Timmerman
a8ca3d8188 Fix 7937: Offspring token key malformed (#7938) 2025-07-05 07:00:06 +00:00
tool4ever
3b9867c537 Fix updateTarget (#7927)
* Fix meld exiling missing half
2025-07-05 06:58:26 +00:00
Fulgur14
01d22c26f4 Create terrasymbiosis.txt (#7936) 2025-07-04 17:03:28 +00:00
kevlahnota
e8f7fe5a95 Merge pull request #7933 from kevlahnota/master2
fix rounded borders for tokens since it gets the full bordered image …
2025-07-04 23:05:21 +08:00
Anthony Calosa
bd0b8fbc65 minor refactor 2025-07-04 22:45:50 +08:00
Anthony Calosa
05e20b4e92 Merge branch 'master' into master2 2025-07-04 22:39:20 +08:00
Anthony Calosa
716d58ad4b faster implementation 2025-07-04 22:28:51 +08:00
Anthony Calosa
ca12ad529a add comment 2025-07-04 21:58:20 +08:00
Anthony Calosa
6eea82706d better name 2025-07-04 21:52:56 +08:00
Anthony Calosa
d69d005ce0 update remaining checks 2025-07-04 21:27:25 +08:00
Anthony Calosa
b98b322dfe move check 2025-07-04 20:33:57 +08:00
Anthony Calosa
e73e72d150 update view check 2025-07-04 20:10:54 +08:00
Anthony Calosa
8cabc244f7 fix rounded borders for tokens since it gets the full bordered image on scryfall by default now 2025-07-04 19:32:50 +08:00
Fulgur14
4f04e5cc13 Infinite Guideline Station (EOE leak) (#7928) 2025-07-04 10:57:41 +02:00
Agetian
bcf9d2585d - Update LDA data for Standard and Modern (Final Fantasy). (#7926) 2025-07-03 21:42:02 +03:00
Fulgur14
e03b07f940 Create command_bridge.txt (#7924) 2025-07-03 16:45:45 +00:00
Eradev
a45c6aa37e Fix kavu deck (#7919)
* FIx Kavu Deck (C11 -> CMD)

* Whitespaces
2025-07-03 07:00:33 +00:00
Agetian
dd672945f2 - Update LDA data for Standard and Modern (Final Fantasy). (#7918) 2025-07-02 21:25:41 +03:00
Fulgur14
e634be4273 Embrace Oblivion (EOE) 2025-07-02 15:55:41 +00:00
Simisays
9acf5bee41 update (#7916) 2025-07-02 18:25:54 +03:00
tool4ever
1e3297ab64 Update spirit_sisters_call.txt
Closes #7912
2025-07-01 22:11:06 +00:00
Simisays
58df290c8e Adventure church map fix (#7911)
* update

* item name fix
2025-07-01 20:17:40 +03:00
tool4ever
e2075886b1 Update celes_rune_knight.txt 2025-07-01 07:42:42 +02:00
Chris H
ad53abc75a Update snapshot-both-pc-android.yml 2025-06-30 18:38:46 -04:00
Chris H
a599c318dd Update snapshot-both-pc-android.yml 2025-06-30 18:35:51 -04:00
Chris H
14e2a0c5e2 Update snapshot-both-pc-android.yml 2025-06-30 18:28:51 -04:00
Chris H
2ae3efc12e Fix The Brothers War landscape book 2025-06-30 16:48:09 -04:00
tool4ever
fb18134c12 Update merieke_ri_berit.txt
Fix missing trigger when destroyed
2025-06-30 21:13:47 +02:00
Paul Hammerton
2215a101a3 Merge pull request #7906 from paulsnoops/b-a-r-30-june-2025
Banned and Restricted Announcement for June 30, 2025
2025-06-30 18:19:22 +01:00
Paul Hammerton
4df2fe7ac5 Banned and Restricted Announcement for June 30, 2025 2025-06-30 18:08:25 +01:00
Chris H
c24369d1ec Update snapshot-both-pc-android.yml 2025-06-29 12:38:59 -07:00
kevlahnota
41eb86029a Update README.md
Add note to Android installation
2025-06-29 19:52:01 +08:00
Hans Mackowiak
357026ce66 ~ lf 2025-06-28 17:03:26 +02:00
Paul Hammerton
9b558cb069 Merge pull request #7901 from paulsnoops/edition-updates
Edition updates: EOE, EOS, PA1, SLD, TLA & Add Sonic, PA1 to formats
2025-06-28 09:15:11 +01:00
Paul Hammerton
303020ca75 Edition updates: EOE, EOS, PA1, SLD, TLA & Add Sonic, PA1 to formats 2025-06-28 09:10:28 +01:00
Fulgur14
b900abcc71 Sonic the Hedgehog and the rest of his Secret Lair (#7898) 2025-06-28 09:01:20 +02:00
tool4ever
c4ba6df6e9 Update rootwise_survivor.txt 2025-06-28 08:26:08 +02:00
tool4ever
cc4a507799 Update ghouls_night_out.txt
Closes #7900
2025-06-28 08:24:26 +02:00
tool4ever
d8de8ec696 Update professor_hojo.txt 2025-06-27 22:48:18 +02:00
tool4ever
e6563814e8 Amplify: fix only revealing hardcoded types (#7896) 2025-06-27 17:32:52 +02:00
Eradev
016d51669f Better DesecrationDemon sac check. (#7880)
* Better DesecrationDemon sac check.

* Fix var.

---------

Co-authored-by: Agetian <stavdev@mail.ru>
2025-06-27 06:58:49 +03:00
Jacob Arbib
f19828b2ec Add Duration handling to TextBoxExchangeEffect and added Exchange of Words (#7890) 2025-06-26 17:08:36 +00:00
Hans Mackowiak
36fc87c2a1 ~ lf 2025-06-26 07:03:38 +02:00
tool4ever
4322bddabf Fix NPE by defeating Invasion of Ikoria while controlling Henzie (#7893) 2025-06-25 19:59:27 +00:00
Fulgur14
c128a9d4ba Alpharael, Dreaming Acolyte (EOE) (#7891) 2025-06-25 17:53:25 +00:00
Chris H
2feeffc95c Update jenova_ancient_calamity.txt (#7892) 2025-06-25 17:42:20 +00:00
Hans Mackowiak
53de238a7e Update EnemySprite.java
Fix Android not having stream().toList()
2025-06-25 17:25:46 +02:00
Cees Timmerman
c207e74369 Fix Meld art download (#7858) (#7884)
* Fix Meld art download (#7858)

---------

Co-authored-by: tool4ever <therealtoolkit@hotmail.com>
Co-authored-by: Hans Mackowiak <hanmac@gmx.de>
Co-authored-by: Agetian <stavdev@mail.ru>
2025-06-25 10:18:43 +02:00
tool4ever
04ca02a77a Update fiery_gambit.txt
Fix collision
Closes #7886
2025-06-22 22:21:28 +02:00
Hans Mackowiak
6ff89c71b6 Add Spacecraft (#7885)
* Add Spacecraft

---------

Co-authored-by: tool4ever <therealtoolkit@hotmail.com>
2025-06-22 11:03:52 +02:00
Hans Mackowiak
d7c6a8e53e ~ lf 2025-06-22 10:09:00 +02:00
kevlahnota
150741a443 Merge pull request #7883 from Card-Forge/keybind-hud-android-fix
Fix Android Keybind for Adventure Mode Console toggle
2025-06-22 09:01:36 +08:00
kevlahnota
460f322c44 Update KeyBinding.java
remove duplicates, update back key binding
2025-06-21 22:49:58 +08:00
kevlahnota
ef5d35fe38 Update GameHUD.java
update console ZIndex
2025-06-21 22:46:25 +08:00
kevlahnota
16044556b5 Update Console.java
exit command for console
2025-06-21 22:43:40 +08:00
Paul Hammerton
81d5079468 Merge pull request #7882 from paulsnoops/editionupdates
Edition updates: EOE, PSPL
2025-06-21 11:04:48 +01:00
Paul Hammerton
edc4b22cbc Edition updates: EOE, PSPL 2025-06-21 11:01:04 +01:00
Cees Timmerman
c01dfd4740 Fix Meld art download (#7858) 2025-06-21 11:52:08 +02:00
Paul Hammerton
53a4a46d1f Merge pull request #7881 from paulsnoops/edition-updates
Edition updates: EOC, EOE, EOS, PF25, PJSC, PPRO, SLD, TLA
2025-06-21 10:03:39 +01:00
Paul Hammerton
d61e7e7102 PPRO 2025-06-21 09:59:24 +01:00
Paul Hammerton
17f4df9293 Edition updates: EOC, EOE, EOS, PF25, PJSC, SLD, TLA 2025-06-21 09:55:08 +01:00
Fulgur14
24071582bb 3 EOE cards + 2 EOC cards (#7875) 2025-06-21 07:24:52 +00:00
Eradev
5754466a0d Fix Triplicate Titans tokens ids 2025-06-21 08:27:56 +02:00
Fulgur14
a18eda92b7 Harmonious Grovestrider (EOE) (#7873) 2025-06-20 21:05:18 +00:00
Fulgur14
11d0a8f2fe Create tezzeret_cruel_captain.txt (#7870) 2025-06-20 21:05:10 +00:00
Cees Timmerman
2b8b386882 Fix ConcurrentModificationException (#7865) (#7867)
* Fix ConcurrentModificationException (#7865)

* Update CostPayment.java
2025-06-20 07:33:32 +02:00
Hans Mackowiak
45a5027451 Update kuja_genome_sorcerer_trance_kuja_fate_defied.txt
Closes #7869
2025-06-20 07:32:18 +02:00
Hans Mackowiak
2cb72f55f3 Update Modern Horizons 3.txt
Closes #7864
2025-06-19 10:12:05 +02:00
jpvorenk
fa27fbab46 fix null pointer on draft refresh (#7863) 2025-06-17 21:36:29 -04:00
EfourC
87821fe287 Adventure: Made tooltips instant and reduced size (#7787)
* Made adventure reward tooltips instant and adjusted their size on Desktop

* Moved RewardTooltipManager to be an internal class of RewardActor.
2025-06-16 20:40:08 -04:00
Seth Milliken
cee4bcd867 card: correct sundown pass mana order (#7855)
* card: correct sundown pass mana order
2025-06-15 10:28:23 +02:00
tool4ever
b9cc4c18a8 Update yuna_grand_summoner.txt 2025-06-14 21:56:29 +02:00
EfourC
4577e61940 Corrected height of buttons for disabled Auto and Quck save slots, and adjusted font color. 2025-06-14 13:59:24 -04:00
EfourC
9ac6147a98 Made the autoSell buttons for rewards semi-transparent unless selected and fixed transparency carrying over to other Actors in a batch. Also made small adjustment to card flipping speed to be a little more snappy and fit the sound effect better. 2025-06-14 13:54:14 -04:00
Chris H
74d4ea8a78 Replace each card in a slot individually instead of replacing the whole slot at once. (Fixes higher rates of replacements) (#7854) 2025-06-14 18:02:54 +03:00
Robin Woodby
e2f4c7f872 Autofocus the first dialog option on desktop with keyboard input
Previously, autofocus only worked with gamepads connected.
2025-06-14 10:33:41 -04:00
Robin Woodby
07db8e5a94 Allow ESC to dismiss console in addition to android back button 2025-06-14 10:33:41 -04:00
Robin Woodby
ed7fb03b9c Fix issue where eventTouchUp is firing before keyUp in GameHUD 2025-06-14 10:33:41 -04:00
Robin Woodby
f0ebc3e6a0 Remove redundant call to openMenu causing flickering 2025-06-14 10:33:41 -04:00
Robin Woodby
f2570b4cef Update adventure mode deck editor to support ESC key to go back. 2025-06-14 10:33:41 -04:00
Robin Woodby
97e1939021 Fix enter key not working to save/load in menus 2025-06-14 10:33:41 -04:00
Robin Woodby
bebb894f3e Fix setText call for done button on rewards page 2025-06-14 10:33:41 -04:00
Robin Woodby
288c533c91 Revert reward scene done button text to check mark except for shop
This way translation when loading from file works for "Done"
2025-06-14 10:33:41 -04:00
Robin Woodby
6891f9a5d5 Change back button to esc in shop and reward screens for consistency 2025-06-14 10:33:41 -04:00
Simisays
37a62eed6b Update crypt.tmx (#7853) 2025-06-14 16:40:25 +03:00
MD200210
3ee6b0e58d Details Labels and Zooming on Adventure World Map (#7840)
* Details Button on Adventure Map.
Zooming on Adventure Map

* no Wildcard Import
2025-06-13 07:12:28 +03:00
Robin Woodby
7e6f772345 Update forge-ai description to be more specific and less redundant 2025-06-11 21:05:20 -04:00
Robin Woodby
ef28173b65 Add missing module descriptions in contributing docs 2025-06-11 21:05:20 -04:00
Robin Woodby
a26614c6b6 Remove double spaces and fix typos 2025-06-11 21:05:20 -04:00
Chris H
ee00293e48 Update rydias_return.txt 2025-06-11 16:21:50 -04:00
MatthiasD
ce977387e6 Fix Update Symbols 2025-06-11 16:00:52 -04:00
MD200210
8cc45dbbd8 Fix Cid (#7842) 2025-06-11 17:47:29 +02:00
MatthiasD
851a4c104c Update and change FCA 2025-06-11 16:28:49 +02:00
45ddf3fded Fix: Update getCommander method to enable StorageImmediatelySerialized subfolders 2025-06-11 09:09:10 -04:00
tool4ever
cb538f4026 Update depth_defiler.txt (#7829) 2025-06-09 10:36:34 +02:00
EfourC
6bd6db3c16 Adventure: AccountingLabel animation update 2025-06-08 21:57:07 -04:00
Chris H
6af3940ffb Update queen_brahne.txt 2025-06-08 21:43:34 -04:00
Renato Filipe Vidal Santos
66c864c8d7 Cleanup: DBCleanup (#7822) 2025-06-08 21:32:18 +03:00
rwalters
15354dd8e8 Fix ff limited cards (#7819)
* Fixing the power and toughness of two cards relevant in limited

---------

Co-authored-by: Agetian <stavdev@mail.ru>
2025-06-08 08:37:56 +03:00
Renato Filipe Vidal Santos
215070fe3f Update blot_out.txt 2025-06-07 12:59:12 +02:00
Renato Filipe Vidal Santos
ed73883e80 Update overtaker.txt (#7815) 2025-06-07 12:59:25 +03:00
Renato Filipe Vidal Santos
df85ebc0aa Update ayula_queen_among_bears.txt (#7812)
* Update ayula_queen_among_bears.txt

* Update rampaging_yao_guai.txt

* Update ulvenwald_bear.txt

* Update rampaging_yao_guai.txt
2025-06-07 10:43:33 +03:00
Hans Mackowiak
885a6af943 Update shambling_cieth.txt
Closes #7810
2025-06-06 17:50:13 +02:00
Renato Filipe Vidal Santos
94820d4782 Update tranquil_frillback.txt 2025-06-06 17:05:11 +02:00
Renato Filipe Vidal Santos
7f044e5ac3 Update wicked_slumber.txt 2025-06-06 15:11:59 +02:00
Renato Filipe Vidal Santos
1284f23620 Update primeval_bounty.txt (#7807) 2025-06-06 12:34:37 +02:00
Agetian
bdcc8acdc4 Add Final Fantasy achievements by Marek14 (#7806)
* - Add FIN achievements by Marek14.

* - Minor tweak.
2025-06-06 10:21:44 +03:00
Chris H
73a9dfcf43 Automate patch version increment 2025-06-05 23:37:40 -04:00
GitHub Actions
7a277ce283 [maven-release-plugin] prepare for next development iteration 2025-06-05 23:37:40 -04:00
GitHub Actions
f8b3f9dd30 [maven-release-plugin] prepare release forge-2.0.04 2025-06-05 23:37:40 -04:00
Chris H
840f3ea96c Automate patch version increment 2025-06-05 22:45:57 -04:00
Chris H
51929434be Update flatten to work with full release 2025-06-05 22:45:57 -04:00
gsonnier333
3ec480afa4 fixed weapons_vendor.txt power/toughness 2025-06-05 21:21:27 -04:00
Chris H
3d19e9e444 Update summon_g_f_ifrit.txt 2025-06-05 21:21:14 -04:00
Renato Filipe Vidal Santos
6d987791f7 Fixing Animate Dead and similar effects) 2025-06-05 14:25:08 +02:00
Renato Filipe Vidal Santos
7b7da00c22 Incidental fixes: 2025-06-05 2025-06-05 08:54:38 +02:00
tool4ever
34791bd892 Update stangg.txt 2025-06-05 08:53:38 +02:00
Renato Filipe Vidal Santos
e6bcd1be72 Add files via upload 2025-06-04 20:33:46 -04:00
Paul Hammerton
4cac354983 Merge pull request #7794 from paulsnoops/fin-formats
Add Final Fantasy to formats
2025-06-04 18:11:13 +01:00
Paul Hammerton
042f7f77a9 Add Final Fantasy to formats 2025-06-04 18:06:21 +01:00
Hans Mackowiak
5fbb1dd0cd Update summon_leviathan.txt
Fix Draw
2025-06-04 08:55:00 +02:00
Hans Mackowiak
bb14dfc00e Update summon_leviathan.txt
Closes #7784
2025-06-04 07:20:24 +02:00
Renato Filipe Vidal Santos
f83cc4ccfa Update fin.rnk 2025-06-03 11:05:10 -04:00
tool4ever
d0d6835a5d Update zodiark_umbral_god.txt 2025-06-03 13:24:17 +00:00
tool4EvEr
104bc8fc55 SpellAbility: set CardState inside constructor 2025-06-03 13:26:25 +02:00
SprinkleMeTimbers
057dd867a8 Adventure: added support for dynamic deck count (#7669)
* Added: utility method for adding an integer selecting combo-box.

* Added: Adventure now supports dynamic amount of decks

* Tweaked: lowered max deck count to 20.

* Added: dynamic deck count can't ever be higher than the maximum in current version.
2025-06-03 13:17:30 +03:00
Chris H
9eed8f5095 Update some names in fin rankings (#7776) 2025-06-03 13:17:18 +03:00
Chris H
1f62be9773 Migrate FIN upcoming (#7777) 2025-06-03 10:13:01 +00:00
Hans Mackowiak
7a46f92059 Update CardState updateSpellAbilities only when not inPlay (#7780)
* Fix copy order
2025-06-03 10:12:35 +00:00
tool4EvEr
cfa79b9676 attachAuraOnIndirectETB: fix missing activator 2025-06-03 09:54:37 +02:00
tool4ever
c0a63fa15b Fix Dark Depths triggering vs. Blood Moon (#7768) 2025-06-03 08:07:10 +02:00
Renato Filipe Vidal Santos
c61537ae16 Add files via upload 2025-06-02 23:44:22 -04:00
Renato Filipe Vidal Santos
3871095b92 Add files via upload 2025-06-02 23:44:22 -04:00
Simisays
dee846da49 Update cave_bigzombie.tmx 2025-06-02 22:08:08 -04:00
Jason Vorenkamp
2477553d13 fix incorrect resource name 2025-06-02 21:46:37 -04:00
Renato Filipe Vidal Santos
c9df7d7f8e Cleaning upcoming: 2025-06-02 2025-06-02 16:02:17 +00:00
rwalters
53cb093f9e (Adventure) Fix draft scene transition (#7666)
* Fixing an issue in which touching the space the map occupies outside of the world map does not allow the player to move (very relevant on maps with content in the top left corner)

* Fixing a bug in which the transition screen's non-blocking of the start match button can be clicked multiple times, which results in a crash when the match ends
2025-06-02 10:24:50 -04:00
MD200210
28e86970dc Added Draft Info (#7764)
* FIN Draft Info

(cherry picked from commit ad0385617b26391efa2b866157eea674ea850e1e)

* Correction

* Correction

* Correction
2025-06-02 10:24:10 -04:00
Chris H
f847fc1669 Fix sketchbooks that are missing colons in the name 2025-06-02 07:22:26 -04:00
Hans Mackowiak
f3df55177a CardState: fix Android not having stream().toList(); Closes #7761 2025-06-02 07:10:26 +02:00
Chris H
be6f345127 Hotfix PaperCard edition issues 2025-06-01 22:50:58 -04:00
Seth Milliken
7fa89cbc2e fix: do not steal keyboard focus when "Visually Alert on Receipt of Priority" is enabled
When the "Visually Alert on Receipt of Priority" feature is enabled,
the `showTab()` call at the beginning of `forge.gui.framework.SDisplayUtil.remind()`
steals focus from the primary button whenever anything goes on the
stack.

This change, previously suggested by pfps as probably not necessary, is
indeed necessary after all to prevent that focus stealing by restoring
focus to the previous owner only if the owner was an `FButton`.

fixes https://github.com/Card-Forge/forge/issues/7660
2025-06-01 14:17:09 -04:00
Greg Sonnier
567e13c92b fixed locke_treasure_hunter.txt unblockable condition (#7752) 2025-06-01 08:30:27 +00:00
Hans Mackowiak
6f5a933de3 CardState: Refactor LandAbility/Aura/PermSpell (#7680)
* CardState: Refactor LandAbility/Aura/PermSpell

* Update CardState.java

Fix Room

* unify manaAbilities and nonManaAbilities and fix Room cards

* CardView: fix Left&Right Split not update abilities

* AbilityFactory: make Fuse Ability Secondary

* CardFactory: remove extra logic for LeftSplit and RightSplit

* AbilityFactory: set OriginalAbility for Fuse Parts

* SpellPermanent: fix Desc for CardState

* PermanentCreatureEffect: use getBasePowerString/getBaseToughnessString

* LandAbility: fix Modal Lands
2025-06-01 09:53:40 +02:00
kvn1338
e40567c9c8 Add TextBoxExchangeEffect Ability and 'Deadpool, Trading Card' (#7637)
* capure Textboxes to avoid LKI copy

* Fix copying keyworded traits twice

* Support keepTextChanges across all traits

Co-authored-by: kvn <kevni@secure.mailbox.org>
Co-authored-by: tool4EvEr <tool4EvEr@>
2025-06-01 07:19:50 +00:00
tool4ever
928ac875b5 Fix only turning fully unlocked rooms face down (#7742)
Co-authored-by: tool4EvEr <tool4EvEr@>
2025-05-31 13:28:52 +02:00
Paul Hammerton
f4831bc51b Merge pull request #7740 from paulsnoops/edition-updates
Edition updates: FCA, FIC, FIN, SLD
2025-05-31 11:19:28 +01:00
Paul Hammerton
d3e0e79325 Edition updates: FCA, FIC, FIN, SLD 2025-05-31 11:05:48 +01:00
Renato Filipe Vidal Santos
ac3015eff1 Add files via upload (#7730) 2025-05-31 07:52:06 +00:00
tool4ever
554e73e352 Fix Estinien Varlineau (#7738) 2025-05-31 06:42:04 +00:00
Hans Mackowiak
fe86bb1be3 line endings 2025-05-31 00:01:54 +02:00
Fulgur14
f98eca3925 The FINAL Fantasy cards (#7736) 2025-05-30 18:01:51 +00:00
Fulgur14
8506fd2bab 4 FIN cards (#7727) 2025-05-30 18:01:34 +00:00
Hans Mackowiak
c2ffa227e2 Saga: do State-Based and Turn-Based Action only with Chapters (#7737) 2025-05-30 17:16:15 +00:00
Hans Mackowiak
f33f780b25 line endings 2025-05-30 18:58:30 +02:00
Renato Filipe Vidal Santos
855e4dcabd FIN: Memories Returning (#7731) 2025-05-30 10:23:13 +02:00
Fulgur14
40c9a06b21 Couple fixes (#7732)
* Update breaching_hippocamp.txt

* Update skanos_dragon_vassal.txt
2025-05-30 08:52:06 +03:00
Chris H
7c4cf9425f Update INSTALLATION.txt 2025-05-29 10:11:13 -04:00
Fulgur14
d2a6329e03 Leaked Rydia and Exdeath (FIN) (#7725)
* Leaked Rydia and Exdeath (FIN)

* Update exdeath_void_warlock_neo_exdeath_dimensions_end.txt

* Update rydia_summoner_of_mist.txt
2025-05-29 13:33:12 +03:00
Renato Filipe Vidal Santos
6e2717e371 FIN: 11 cards (#7724) 2025-05-29 09:22:54 +00:00
Chris H
2152b7ca7d Fix line endings 2025-05-28 23:25:57 -04:00
Fulgur14
08387f12cb Summon: Brynhildr (FIN) (#7722) 2025-05-28 19:48:22 +00:00
tool4ever
01800d3c49 Update summon_valefor.txt 2025-05-28 19:03:00 +02:00
Fulgur14
2b3735662e 7 FIN cards (#7721) 2025-05-28 18:59:07 +02:00
Renato Filipe Vidal Santos
5ab2b44343 FIN: Golbez, Crystal Collector 2025-05-28 18:48:42 +02:00
Renato Filipe Vidal Santos
0bdb9d7d27 FIN: 7 cards (#7717)
* Add files via upload

* Update thiefs_knife.txt

* Update swallowed_by_leviathan.txt

* Update aether_spike.txt

* Update swallowed_by_leviathan.txt
2025-05-28 15:45:16 +02:00
Renato Filipe Vidal Santos
1f4cebf186 FIN: The Masamune (#7719) 2025-05-28 14:04:50 +02:00
rwalters
f651a7d73d (Adventure Mode) Fix quest references and step requirements (#7697)
* Fixing an issue in which touching the space the map occupies outside of the world map does not allow the player to move (very relevant on maps with content in the top left corner)

* Fixing several text based references that looked created in bulk with similar problems. Kiora and Teferi don't require going back to the town that issued the quest, and the others reference the wrong location when arriving there for where the reputation goes
2025-05-28 11:45:24 +03:00
Fulgur14
453bae6849 Summon: G.F. Cerberus and X-ATM092 (FIN) (#7715) 2025-05-28 09:47:38 +02:00
Fulgur14
292cca0727 10 FIN cards, batch #3 (#7713) 2025-05-28 05:43:27 +00:00
Fulgur14
24f568101f 10 FIN cards, batch #2 (#7712) 2025-05-28 05:41:34 +00:00
tool4ever
ad73651382 Prishe's Wanderings: support CantSearch case (#7711) 2025-05-28 05:40:38 +00:00
Chris H
476f3dfe9c Fix line endings 2025-05-27 16:07:02 -04:00
Fulgur14
5977129096 10 FIN cards (#7710) 2025-05-27 19:58:55 +00:00
Greg Sonnier
44e243d428 fixed hraesvelgr_of_the_first_brood.txt mana cost (#7708) 2025-05-27 18:21:55 +00:00
Fulgur14
491e275b8a Rufus and Seifer (#7707) 2025-05-27 16:54:42 +00:00
Renato Filipe Vidal Santos
7bf6ba0779 FIN: Minwu (#7706) 2025-05-27 16:30:54 +00:00
Fulgur14
ea33d589ae Diamond Weapon (FIN) (#7702) 2025-05-27 16:30:02 +00:00
Renato Filipe Vidal Santos
1314c98a5a Add files via upload (#7701) 2025-05-27 17:29:23 +03:00
Fulgur14
66c1c485f2 Magic Damper (FIN) (#7704) 2025-05-27 14:28:41 +00:00
Hans Mackowiak
fe1d37bed6 Update Ikoria Lair of Behemoths.txt
Closes #7700
2025-05-27 13:34:38 +02:00
Fulgur14
64d54dc7c7 Gysahl Greens (FIN) (#7699) 2025-05-27 08:24:08 +00:00
Renato Filipe Vidal Santos
050cebf944 FIN: 6 cards (#7696) 2025-05-27 08:22:13 +02:00
Renato Filipe Vidal Santos
42e5d9437b Adventure cleanup: 2025-05-26 (#7695)
* Add files via upload

* Update quests.json

* Update quests.json

* Update shops.json

* Update skep_outer.tmx
2025-05-27 07:20:08 +03:00
Fulgur14
67aaf9902e Cactuar and Light of Judgment (FIN) (#7692) 2025-05-26 20:15:52 +00:00
Fulgur14
3d0436aeca Restoration Magic (FIN) (#7690) 2025-05-26 22:32:28 +03:00
Simisays
827d60610d Update fort_white_4_farm.tmx (#7694) 2025-05-26 22:29:53 +03:00
Renato Filipe Vidal Santos
69a1d76778 FIN: 2 cards 2025-05-26 18:15:15 +00:00
tool4ever
7bd5dbbe28 Fix text change of keywords missing traits (#7689) 2025-05-26 15:41:16 +00:00
Fulgur14
39613a8413 3 FIN commons (#7688) 2025-05-26 14:42:26 +00:00
Renato Filipe Vidal Santos
225ff335e8 FIN: Midgar, City of Mako (#7685) 2025-05-26 14:10:03 +00:00
Paul Hammerton
23a3de5446 Merge pull request #7684 from paulsnoops/edition-updates
Edition updates: FCA, FIN
2025-05-26 11:32:01 +01:00
Paul Hammerton
75fd7bbfda Edition updates: FCA, FIN 2025-05-26 11:27:50 +01:00
tool4ever
ed6a14e180 Fix LKI missing changed text (#7683) 2025-05-26 08:35:57 +00:00
Fulgur14
42b6d2c17d Dion, Bahamut's Dominant (FIN) (#7682) 2025-05-26 08:23:59 +00:00
Hans Mackowiak
9a93f0a16c TokenDb: fix Endure Token Images causing crash on Token Viewer (#7679) 2025-05-25 19:27:13 +02:00
Renato Filipe Vidal Santos
1c0d3031d3 MB2: 2 cards (#7678) 2025-05-25 17:05:22 +00:00
Hans Mackowiak
724697391c Update Aetherdrift Commander.txt 2025-05-25 18:03:42 +02:00
Renato Filipe Vidal Santos
7820c3f519 Adventure cleanup: 2025-05-25 (#7674)
* Update quests.json

* Update shops.json

* Update bluewizard_hard_bounce.dck

* Update kavu_domain.dck

* Update sandghoul.dck

* Update aerie_0.tmx

* Update barbariancamp_kobold_mine.tmx

* Update evilgrove_5_swamp.tmx

* Update grolnok_f1.tmx

* Update grove_1_bears.tmx

* Update black_castle.tmx

* Update blue_castle.tmx

* Update green_castle.tmx

* Update red_castle.tmx

* Update white_castle.tmx

* Update graveyard.tmx

* Update steppe.tmx

* Update town.tmx

* Update bog.tmx

* Update graveyard.tmx

* Update town.tmx

* Update maze_2.tmx

* Update slime_hive.tmx

* Update wastetown..tmx

* Update skep_outer.tmx

* Update tibalt_f1.tmx

* Update tibalt_f2.tmx

* Update tibalt_f3.tmx

* Update main.tsx

* Update enemies.json

* Update skep_outer.tmx

* Update items.json

* Update quests.json

* Update shops.json

* Update town_names_black.txt

* Update aerie_0.tmx

* Update sorins_amulet.txt

* Update sorins_boss_effect.txt
2025-05-25 16:35:28 +03:00
Renato Filipe Vidal Santos
fe80b3850e Update carrionette.txt (#7650) 2025-05-25 16:35:17 +03:00
rwalters
16a2ae6741 (Adventure Mode): Fix abandoned town (#7665)
* Fixing an issue in which touching the space the map occupies outside of the world map does not allow the player to move (very relevant on maps with content in the top left corner)

* Adventure Mode: Fix Quest_APortalToNowhere, in which the file path got moved but the point of interest json was not updated

* Manually altering points_of_interest.json instead of using the adventure editor tool

* Actual change was removed during synchronization with remote head, re-applying actual fix
2025-05-25 08:47:23 -04:00
tool4ever
ce19c4fb9d Update capricious_sliver.txt
Closes #7672
2025-05-24 20:21:00 +00:00
tool4ever
4911a7f951 Update professor_hojo.txt 2025-05-24 17:40:36 +00:00
Renato Filipe Vidal Santos
c6f994d47a Quick cleanup: 2025-05-24 2025-05-24 16:20:19 +00:00
Hans Mackowiak
f0a9077791 lf 2025-05-24 16:38:52 +02:00
Fulgur14
b6941a9b38 Gogo, Master of Mimicry (FIN) (#7655) 2025-05-24 13:16:13 +00:00
Fulgur14
7023eb10d3 10 FIN cards (Vaan and his band) (#7661)
* 4 FIN cards (Vaan and his band)

* Add files via upload

* Add files via upload

* Add files via upload
2025-05-24 16:12:46 +03:00
tool4ever
007e132559 UnlessCost: fix checking wrong payer (#7663)
* UnlessCost: fix checking wrong payer

---------

Co-authored-by: tool4EvEr <tool4EvEr@>
2025-05-24 12:10:48 +02:00
tool4ever
9b9fdb2e5e Edgar, King of Figaro and support (#7645) 2025-05-24 07:27:48 +00:00
Renato Filipe Vidal Santos
f1f4310608 FIN: Black Waltz No. 3 2025-05-24 06:36:44 +00:00
Renato Filipe Vidal Santos
8634f96e4b FIN: 3 cards (#7646) 2025-05-23 15:20:26 +00:00
Fulgur14
6eed4c31a2 Raubahn, Bull of Ala Mhigo (FIN) (#7659) 2025-05-23 14:22:31 +00:00
Hans Mackowiak
c7b9934072 ImageFetcher: add downloadUrl for HiddenCard (#7651) 2025-05-23 13:51:00 +02:00
Paul Hammerton
cc50d72d63 Merge pull request #7654 from paulsnoops/edition-updates
Edition updates: FCA, FIN, SLD
2025-05-23 10:10:34 +01:00
Paul Hammerton
fbceab3252 fix-the-gold-saucer 2025-05-23 10:06:11 +01:00
Paul Hammerton
780491ae4b Edition updates: FCA, FIN, SLD 2025-05-23 09:56:26 +01:00
tool4ever
994471e9b6 Update verazol_the_split_current.txt 2025-05-23 10:50:35 +02:00
Chris H
e1bf639e90 Fix broken json in tmx file 2025-05-22 21:43:40 -04:00
Chris H
4386cead3e Fix end lines 2025-05-22 21:43:19 -04:00
Fulgur14
9b0d0f7924 8 FIN Cards (#7648) 2025-05-22 20:53:45 +00:00
Fulgur14
b9be1bc647 Omega, Heartless Evolution (FIN) (#7647) 2025-05-22 17:16:10 +02:00
tool4ever
513e4c6c8d Update hraesvelgr_of_the_first_brood.txt 2025-05-22 16:37:28 +02:00
tool4ever
0f5b67a504 Update lyse_hext.txt 2025-05-22 16:36:52 +02:00
Fulgur14
72f455067f Tellah, Great Sage (FIN) (#7644) 2025-05-22 16:36:13 +02:00
Hans Mackowiak
6dc508b631 ~fix Token ImageKeys without Set (#7643) 2025-05-22 09:29:33 +03:00
Hans Mackowiak
deecf128c3 Fix Henzie again with SvarFallback (#7604)
* Fix Henzie again with SvarFallback

* henzie rename Svar
2025-05-22 07:20:22 +02:00
Renato Filipe Vidal Santos
5f497669e5 Quick cleanup: 2025-05-21 (#7642) 2025-05-21 20:16:00 +00:00
Fulgur14
90952d95c9 Summon: G.F. Ifrit (FIN) (#7641) 2025-05-21 18:49:24 +00:00
Renato Filipe Vidal Santos
5a5ef52492 FIN: Clash of the Eikons 2025-05-21 18:27:22 +00:00
Fulgur14
3b4df7211c Jenova, Snow, and Ether (FIN) (#7638) 2025-05-21 18:25:28 +00:00
Renato Filipe Vidal Santos
45329a6df0 FIN: 5 more cards (#7627) 2025-05-21 18:25:11 +00:00
Fulgur14
22607adf57 Qiqirn Merchant and the 9 remaining Town duals. (#7639) 2025-05-21 18:06:34 +00:00
Agetian
bd9c72fee9 - Update Libgdx to 1.13.5. (#7636) 2025-05-21 18:12:33 +03:00
Renato Filipe Vidal Santos
35641265dd Update remorseless_punishment.txt (#7635) 2025-05-21 17:43:05 +03:00
Renato Filipe Vidal Santos
fe37a8358b Fixing Firion (#7633) 2025-05-21 14:23:56 +00:00
Fulgur14
bb7ae64ef8 Slash of Light (FIN) (#7632) 2025-05-21 09:46:28 +00:00
Fulgur14
4d9db78cc3 Aettir and Priwen (FIN) (#7631) 2025-05-21 06:18:15 +00:00
Agetian
ce46c684b5 - Fix AI logic for Sorin, Vengeful Broodlord. (#7630) 2025-05-21 09:03:54 +03:00
Fulgur14
29d4e716f5 The remaining 4 Crystals and some other FIN cards (#7628) 2025-05-21 05:02:21 +00:00
Chris H
c6bfdd5b78 Landscape Sketchbook expansion (#7618)
* Expand landscape sketchbooks

* Remove the sketchbooks for sale that are earned via quests
2025-05-21 06:57:58 +03:00
Hans Mackowiak
559daf9fce update ImageKey for Other 2025-05-20 22:58:22 -04:00
Hans Mackowiak
9caa024fa5 transformed token image 2025-05-20 22:58:22 -04:00
Hans Mackowiak
3605b4e34e uppercase token set and fallback token 2025-05-20 22:58:22 -04:00
Hans Mackowiak
56832ff987 ~ update set token image location 2025-05-20 22:58:22 -04:00
Hans Mackowiak
338bb09747 PaperToken: cleanup imageKey without collectorNumber 2025-05-20 22:58:22 -04:00
Hans Mackowiak
b57a5e9ad1 PaperToken: add CollectorNumber and update Downloader 2025-05-20 22:58:22 -04:00
Simisays
67f8f4760e Update skep_outer.tmx 2025-05-20 22:51:20 -04:00
Ryan Walters
485427c682 Fix poi references and an exception generated by failing to address non-swapped poi references, focusing on quest 18, A Focused Mind 2025-05-20 09:05:21 -04:00
Renato Filipe Vidal Santos
8852732e6b FIC: 4 cards (#7624) 2025-05-20 12:27:28 +00:00
Renato Filipe Vidal Santos
6264761117 Quick cleanup: 2025-05-20 (#7622) 2025-05-20 11:07:29 +00:00
Paul Hammerton
a3b1c98abf Merge pull request #7620 from paulsnoops/edition-updates
Edition updates: FCA, FIC, FIN, PF25, PPRO, PSS5, PW25, SCH, SLD
2025-05-20 11:10:31 +01:00
Paul Hammerton
c566a4bed8 oops 2025-05-20 10:59:42 +01:00
Paul Hammerton
a16e2a9c37 don't add FSPL because JP only and same art 2025-05-20 10:53:43 +01:00
Paul Hammerton
f80bb13ed7 Edition updates: FCA, FIC, FIN, FSPL, PF25, PPRO, PSS5, PW25, SCH, SLD 2025-05-20 10:48:58 +01:00
Fulgur14
1c350b1766 From Father to Son (FIN) (#7619) 2025-05-20 09:24:36 +00:00
Fulgur14
0b5ce9c8fc Add 4 cards [FIN]
* Add files via upload

* Update TypeLists.txt

* Create g_1_1_frog.txt

* Update quina_qu_gourmet.txt

I realized that I forgot to set the amount of tokens.
2025-05-20 09:52:01 +03:00
Fulgur14
74c7f4b164 Coral Sword (FIN) (#7614) 2025-05-20 09:47:02 +03:00
Fulgur14
6128f1d720 Queen Brahne and Lindblum (FIN) (#7615)
* Add files via upload

* Add files via upload
2025-05-20 09:46:48 +03:00
Fulgur14
9e2dcbb630 Haste Magic (FIN) (#7616) 2025-05-20 09:46:12 +03:00
Hans Mackowiak
ec9fc88734 ~ fix IterableUtil.and and Iterable.or usage (#7607) 2025-05-20 05:47:26 +02:00
Renato Filipe Vidal Santos
59c404f6c4 Cleanup: Blazing Crescendo (#7617) 2025-05-19 19:40:00 +00:00
Renato Filipe Vidal Santos
fd727a909b Update white_auracite.txt (#7613) 2025-05-19 16:59:50 +02:00
Chris H
ce6ad65e12 Add some combat tests for the AI to help improve poor combat areas (#7600)
* Add some basic testing for AI Combat decisions

* Add some basic testing for AI Combat decisions
2025-05-19 12:30:53 +03:00
tool4ever
6b65f8972c Update lupine_prototype.txt 2025-05-19 09:05:03 +02:00
Renato Filipe Vidal Santos
2e7fe8a81b FIN: Ice Flan 2025-05-19 07:35:42 +02:00
tool4ever
6f9db790a6 Fix updating room in exile (#7608)
* Fix wrong zone breaking X
2025-05-18 18:04:48 +00:00
Simisays
645aff52cb Fix Sanguine Soothsayer (#7606) 2025-05-18 11:38:51 +00:00
Hans Mackowiak
4d4afbdf03 lf 2025-05-18 13:01:33 +02:00
Renato Filipe Vidal Santos
a8c1f5c969 Quick cleanup: 2025-05-17 (#7597) 2025-05-18 09:33:29 +00:00
Fulgur14
0f4c94d6f8 PuPu UFO (#7603) 2025-05-18 09:33:06 +00:00
Renato Filipe Vidal Santos
53479c60b4 Fixing Living Lectern, Embereth Veteran (#7599)
* Update living_lectern.txt

* Update embereth_veteran.txt
2025-05-18 09:43:22 +02:00
Chris H
0c7b8c5b04 Collecting Landscape Sketchbooks adds that set to the basic land dialog (#7602)
* Collecting Landscape Sketchbooks adds that set to the basic land dialog

* Optimize the edition mapping
2025-05-18 07:33:11 +03:00
tool4ever
7860957d8f Update astrologians_planisphere.txt 2025-05-17 16:04:24 +00:00
Renato Filipe Vidal Santos
07bc31f4c1 FIN: 2 more cards (#7592) 2025-05-17 12:37:01 +02:00
Paul Hammerton
99390f5967 Merge pull request #7595 from paulsnoops/edition-updates
Edition updates: FCA, FIC, FIN, RFIN, SLD
2025-05-17 11:29:12 +01:00
Paul Hammerton
ee8ca02128 Edition updates: FCA, FIC, FIN, RFIN, SLD 2025-05-17 11:12:04 +01:00
Hans Mackowiak
1bc7efba65 Update Cards with WithMayLook (#7593) 2025-05-17 10:39:20 +02:00
Hans Mackowiak
efc2357905 lf 2025-05-17 09:16:55 +02:00
Fulgur14
d5d01011f4 Update fandaniel_telophoroi_ascian.txt (#7590) 2025-05-17 06:21:34 +00:00
Fulgur14
c1a19ea4ae Buster Sword (FIN) (#7589) 2025-05-17 06:11:40 +00:00
Fulgur14
ad3fb1137a The Falcon, Airship Restored (FIC) (#7586) 2025-05-17 06:10:53 +00:00
Renato Filipe Vidal Santos
c5c6b36f4f FIC: last 2 cards + FIN: 2 cards (#7576)
* Add files via upload

* Add files via upload

* Add files via upload
2025-05-17 07:41:23 +03:00
Fulgur14
f2f92212bc How to suplex a train (#7578)
There's something strange with Phantom Train's ability where its P/T display doesn't update properly after getting the counter -- maybe because the counter is gained before animating?
2025-05-17 07:41:11 +03:00
Fulgur14
3226be58be Serah, Sazh, and Anima (FIN) (#7585)
* Serah, Sazh, and Anima (FIN)

* Update serah_farron_crystallized_serah.txt
2025-05-17 07:41:03 +03:00
Renato Filipe Vidal Santos
46cfcff0ca Update dancers_chakrams.txt 2025-05-16 23:01:48 -04:00
Fulgur14
b161c9612b Triple Triad (FIN) (#7572) 2025-05-16 18:43:59 +00:00
Renato Filipe Vidal Santos
91dee5c379 FIN: another 2 cards 2025-05-16 18:43:47 +00:00
Fulgur14
349129f88f Quistis Trepe (FIN) (#7581) 2025-05-16 15:50:27 +00:00
Hans Mackowiak
57ea25bbbd Update white_auracite.txt
Closes #7579
2025-05-16 15:43:11 +02:00
Hans Mackowiak
d1725af64d Update urianger_augurelt.txt
Close #7575
2025-05-16 13:19:14 +02:00
Fulgur14
72626ef214 Choco, Seeker of Paradise and Paladin's Arms (FIN) (#7571) 2025-05-16 06:25:02 +00:00
Chris H
e00d5ee30b Fix line endings 2025-05-15 22:19:14 -04:00
tool4ever
d6c42c3c8c Update hildibrand_manderville.txt
Closes #7574
2025-05-15 21:06:53 +00:00
Greg Sonnier
950a1f2a44 fixed missing cleanup in graha_tia_scion_reborn.txt (#7573) 2025-05-15 20:35:17 +00:00
Renato Filipe Vidal Santos
c895b0eeab FIC: yet another 5 cards (#7570) 2025-05-15 18:50:48 +00:00
Fulgur14
82c8fb20e8 Jecht and 2 other FIN cards (#7562) 2025-05-15 18:18:20 +02:00
Fulgur14
cf54f3e04e Relm's Sketching (FIN) (#7569) 2025-05-15 17:27:05 +02:00
Fulgur14
f4958a4b49 9 FIC/FIN cards... plus a token (#7561) 2025-05-15 15:51:13 +02:00
Renato Filipe Vidal Santos
760f9412ff FIC: another 5 cards 2025-05-15 15:15:57 +02:00
Fulgur14
71f2d41eb0 Sin, Unending Cataclysm (FIC) (#7563) 2025-05-15 15:15:38 +02:00
Fulgur14
51d7933ef3 10 FIC cards, batch 3 (#7547) 2025-05-15 15:13:45 +02:00
Fulgur14
f5938b47e1 10 FIN/FIC cards, batch 8 2025-05-15 15:13:35 +02:00
tool4ever
807d078799 Support for Lifestream's Blessing (#7565) 2025-05-15 15:11:20 +02:00
Renato Filipe Vidal Santos
bedb97183b FIC: 7 more cards (#7557) 2025-05-15 15:11:04 +02:00
Fulgur14
08919e3375 Summon: Yojimbo and Capital City (#7568) 2025-05-15 14:34:19 +02:00
Fulgur14
a117d65f51 10 FIN/FIC cards, batch 9 (#7560) 2025-05-15 14:19:26 +02:00
Fulgur14
b61e3015f3 8 FIN/FIC cards (#7556) 2025-05-15 13:09:49 +02:00
Fulgur14
83a512a075 10 FIN/FIC cards, batch 5 (#7550) 2025-05-15 13:08:39 +02:00
Fulgur14
c1630a2e47 Rejoin the Fight (FIC) 2025-05-15 13:08:11 +02:00
Fulgur14
1d0b50356f Auron's Inspiration (FIN) (#7566) 2025-05-15 12:34:13 +02:00
Hans Mackowiak
43d82ce1ce lf 2025-05-15 07:08:09 +02:00
tool4EvEr
c4a8765d6c 2 fixes 2025-05-14 21:27:00 -04:00
Chris H
15d49bc1b1 - Sort inventory by item type 2025-05-14 20:36:46 -04:00
Chris H
d84712b65d Lock smith prices when you click the Smith button 2025-05-14 20:36:28 -04:00
Fulgur14
eac94f7249 10 FIN/FIC cards, batch 6 (#7553) 2025-05-14 17:18:28 +02:00
rpg2014
d134c3dfcd Cleaned up the High DPI monochrome image
Cleaned up some pixels from the high dpi monochrome android icon
2025-05-14 09:09:15 -04:00
rpg2014
0a03327299 Adding monochrome icon to the android app
Added monochrome icon pngs for each mipmap size and added them to the xml configs for the icons.  The monochrome icons were made by editing the respective icon in paint.net.
2025-05-14 09:09:15 -04:00
Fulgur14
0a673aeadc 10 FIC/FIN cards, batch 4 (#7548) 2025-05-14 10:54:45 +02:00
Paul Hammerton
40f7a9a22a Edition updates: FCA, FIC, FIN, SLD 2025-05-14 09:22:30 +01:00
Paul Hammerton
e2ccf8960a Merge pull request #1 from paulsnoops/edition-updates
Edition updates: FCA, FIC, FIN, SLD
2025-05-14 09:18:05 +01:00
Paul Hammerton
66acc6b920 oops lands 2025-05-14 09:15:41 +01:00
Paul Hammerton
83abcf7c44 Update Final Fantasy.txt 2025-05-14 09:13:00 +01:00
Paul Hammerton
ef9d807b6e Update Final Fantasy Commander.txt 2025-05-14 09:04:54 +01:00
Paul Hammerton
83f334888e Update Final Fantasy Through the Ages.txt 2025-05-14 08:58:38 +01:00
Paul Hammerton
8359cfda35 Edition updates: FIC, FIN, SLD 2025-05-14 08:53:21 +01:00
Fulgur14
93b2d7c795 19 FIN/FIC cards + tokens/counters (#7525) 2025-05-14 07:30:38 +00:00
rwalters
ea74cc8f7f Fix enemy name (#7551)
* Fixing an issue in which touching the space the map occupies outside of the world map does not allow the player to move (very relevant on maps with content in the top left corner)

* Fix a misspelling in the name of a Merfolk Warrior when being previewed before a battle
2025-05-14 06:46:00 +03:00
Fulgur14
4e16a5ea60 Update dancers_chakrams.txt (#7549) 2025-05-13 23:23:48 +02:00
Renato Filipe Vidal Santos
00325fb511 MB2: Value Town 2025-05-13 20:52:52 +02:00
Renato Filipe Vidal Santos
fe042fa6d9 FIC: 5 cards (#7541) 2025-05-13 20:24:15 +02:00
Fulgur14
6830f15859 10 FIC/FIN cards, batch 2 (#7543) 2025-05-13 20:23:43 +02:00
Renato Filipe Vidal Santos
fb3a8ce003 FIC: another 5 cards (#7545) 2025-05-13 20:21:53 +02:00
tool4ever
edc6edc44b Support for Lord Jyscal Guado (#7546) 2025-05-13 20:21:12 +02:00
tool4ever
40b3edd426 Update charismatic_conqueror.txt 2025-05-13 18:58:06 +02:00
Fulgur14
f50aea1576 10 FIC/FIN cards, batch 1 (#7542) 2025-05-13 17:53:35 +02:00
Renato Filipe Vidal Santos
4ab67b1d3b FIN: 10 more cards (#7528) 2025-05-13 17:39:48 +02:00
Chris H
a4e4525769 Remember card not spell for tibalts trickery (#7539) 2025-05-13 17:08:40 +02:00
Hans Mackowiak
1d664145e0 Update Dominaria United.txt
Note from Scyfall:

Dominaria United series of 26 tokens
Dominaria United comes with two sets of tokens: a series of 26 bearing either DMU or DMC set codes, and a separate series of 12 tokens with exclusively the DMC set code. We don't know why they did things this way. We've opted to file the entire series of 26 here regardless of set code to avoid archival conflicts.
2025-05-13 10:11:26 +02:00
Fulgur14
32355499aa Matoya, Archon Elder and Valkyrie Aerial Unit (#7535) 2025-05-13 07:18:31 +02:00
Fulgur14
a475855c4c Update cunning_azurescale_divining_dive.txt (#7540) 2025-05-13 06:52:27 +02:00
Fulgur14
598d3a4958 Update esper_origins_summon_esper_maduin.txt 2025-05-12 23:36:54 -04:00
Fulgur14
35a4053212 Update sevinnes_reclamation.txt 2025-05-12 23:36:54 -04:00
Fulgur14
9d770a9bca Esper Origins and Ishgard, the Holy See (FIN) 2025-05-12 23:36:54 -04:00
Paul Hammerton
de15ab3a71 Alchemy Rebalancing for May 13, 2025 2025-05-12 23:33:07 -04:00
rwalters
35bc80767f Fix exit to world map edge cases (Adventure) (#7522)
* Fixing an issue in which touching the space the map occupies outside of the world map does not allow the player to move (very relevant on maps with content in the top left corner)

* Attempt to band-aid two problems relating to showing a dialog to return to the main map, one in which some patrolling enemies ignore the menu restriction and another in which such enemies touching a player who is transitioning out of a dungeon causing a soft lock upon returning to the map
2025-05-12 23:28:00 -04:00
Simisays
ef28a92dff update 2025-05-12 23:15:13 -04:00
Chris H
99f3ccb8d6 Fix endlines 2025-05-12 18:03:04 -04:00
Simisays
16148ec992 10 cards (#7485) 2025-05-12 21:41:22 +03:00
rwalters
93f7987312 Fix on the hunt hole (Adventure) (#7516)
* Fixing an issue in which touching the space the map occupies outside of the world map does not allow the player to move (very relevant on maps with content in the top left corner)

* Fix an edge case where the On The Hunt quest can end up failing to ever spawn an enemy to hunt

---------

Co-authored-by: Agetian <stavdev@mail.ru>
2025-05-12 13:26:49 +03:00
Paul Hammerton
c7816daaf6 Remove Explorer from archived formats and net decks (#7524) 2025-05-12 13:14:17 +03:00
Simisays
bc458ecde4 FIN 10 cards (#7526) 2025-05-12 12:13:22 +02:00
Fulgur14
e4da62c254 3 FIN/FIC cards (#7529)
* 3 FIN cards

* Update starting_town.txt
2025-05-12 09:50:07 +02:00
Fulgur14
53588dfc24 Terra, Magical Adept (#7531)
* Terra, Magical Adept
2025-05-12 09:48:44 +02:00
Renato Filipe Vidal Santos
61c11b38a0 FIN: 4 Job select cards and support (#7520)
* Update CardFactoryUtil.java

* Update Card.java

* Update Keyword.java

* Update white_mages_staff.txt

* Update dragoons_lance.txt

* Update black_mages_rod.txt

* Update summoners_grimoire.txt

---------

Co-authored-by: tool4ever <therealtoolkit@hotmail.com>
2025-05-12 09:47:18 +02:00
tool4ever
fdcc33198b Update rhonas_the_indomitable.txt
Closes #7530
2025-05-12 08:13:13 +02:00
Hans Mackowiak
dd7a0e99e2 ~ lf 2025-05-12 07:00:53 +02:00
Hans Mackowiak
cb0e594a6e CardEdition: add collector number for other (#7504)
* CardEdition: add collector number for other

* EditionEntry record

* Add getOtherImageKey

* Update StaticData.java

* use getOtherImageKey in getFacedownImageKey

* Update CardEdition.java

Remove findOther in favor of getOtherSet

* Update CardEdition.java

return findOther, but with Aggregates.random

* ~ move more helper images to ImageKeys
2025-05-12 06:59:20 +02:00
tool4ever
059881a7b5 Some support for Desert Cenote (#7505)
---------

Co-authored-by: tool4EvEr <tool4EvEr@>
2025-05-11 18:19:37 +00:00
Jetz
ca59ac925c Fix weird behavior in image view with certain filters 2025-05-11 10:00:31 -04:00
Fulgur14
0b5f14cd9c 5 FIN cards (#7518) 2025-05-11 10:27:38 +00:00
Paul Hammerton
1d987c25e9 Merge pull request #7523 from paulsnoops/edition-updates
Edition updates: FCA, FIC, FIN, PF25, PLG25, SLD
2025-05-11 10:43:43 +01:00
Paul Hammerton
5cb68bc2f0 Edition updates: FCA, FIC, FIN, PF25, PLG25, SLD 2025-05-11 10:36:31 +01:00
Hans Mackowiak
1715efced7 FIN: Tiered (#7517)
* Tiered: first example

* use ModeCost for both Spree and Tiered
2025-05-11 09:38:23 +02:00
Chris H
aeb39b99bb If the AI cloned your deck, don't use your deck as a reward base if there aren't more than 5 choices. 2025-05-10 09:05:54 -04:00
Renato Filipe Vidal Santos
778066a622 FIN: Y'shtola Rhul (#7514) 2025-05-10 11:04:03 +00:00
Jetz
75a056abe6 Add a parameter for battle protection RE that can be used to override it for custom types. 2025-05-09 23:19:42 -04:00
Jetz72
3915f316e2 Unused Import 2025-05-09 23:19:42 -04:00
Jetz
b52646ee7e Delete some logic that doesn't currently work 2025-05-09 23:19:42 -04:00
Jetz
cb1d48a566 Support for non-siege battles 2025-05-09 23:19:42 -04:00
Ryan Walters
733d56246e Fixing an issue in which touching the space the map occupies outside of the world map does not allow the player to move (very relevant on maps with content in the top left corner) 2025-05-09 23:18:45 -04:00
distillate personality
7902ad71d7 Update forge-gui-mobile/src/forge/adventure/data/AdventureQuestStage.java
Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
2025-05-09 21:54:11 -04:00
birdbath
2666de0adb Fix for 'Fetch' objectives that allows the user to 'Use' an item in their inventory at the PoI to complete the objective instead. 2025-05-09 21:54:11 -04:00
Renato Filipe Vidal Santos
c2613a03b0 FIC: Yuna, G'raha and new token (#7512) 2025-05-09 08:26:30 +02:00
Chris H
b077cca3ac Fix line endings 2025-05-08 22:09:22 -04:00
Fulgur14
43fc281e65 Hildibrand Manderville (FIC) 2025-05-08 20:25:13 +00:00
Fulgur14
7b1f5d0a34 Zenos yae Galvus // Shinryu, Transcendent Rival (FIN) (#7503) 2025-05-08 20:05:13 +00:00
Paul Hammerton
330fe0a0a8 Merge pull request #7502 from paulsnoops/edition-updates
Edition updates: FIC, PURL, SLD
2025-05-07 18:08:15 +01:00
Paul Hammerton
30a4c24c35 Edition updates: FIC, PURL, SLD 2025-05-07 18:01:06 +01:00
Renato Filipe Vidal Santos
01a6a38285 YTDM: 4 cards (#7473) 2025-05-07 05:17:38 +00:00
Renato Filipe Vidal Santos
fe5aa37791 Update big_play.txt (#7500) 2025-05-07 06:43:39 +02:00
Simisays
42f1fba7c4 Adventure 3 small fixes (#7499)
* Update grolnok_f1.tmx

* update
2025-05-06 23:42:03 +03:00
autumnmyst
0c6f1ff58f UNF: Added the 4 eternal-format-legal dice modification/reroll cards (#7489) 2025-05-06 17:13:52 +00:00
Hans Mackowiak
8678b5ec5b Update Duskmourn House of Horror.txt
Moved to "other" section
2025-05-06 10:35:59 +02:00
Hans Mackowiak
71256972c4 Update Commander 2013.txt
remove token list
2025-05-05 22:32:37 +02:00
matthias8422
a76f23fc25 feature/Refactored-server-url-parsing-logic (#7496)
* HostPort now properly returns -1 when no port was specified

* refactored the URL parsing to now attempt a DNS lookup in cases where URI parsing fails
This now allows local computer names and localhost etc
2025-05-05 17:10:37 +00:00
Hans Mackowiak
3c7993d640 Update Secret Lair Drop Series.txt
Update token collector number and artist
2025-05-05 10:43:03 +02:00
Hans Mackowiak
71d984a5ff Update Archenemy.txt
reorder card list
2025-05-05 10:41:35 +02:00
Hans Mackowiak
be171c011a Volrath's Curse and Lost in Thought with Modes and IgnoreEffectCost (#7492)
* Refactor Damping Engine
2025-05-04 16:55:38 +00:00
tool4ever
becdd180f4 Some cleanup (#7493)
* Some cleanup

* Update StaticAbilityCantAttackBlock.java

* Some cleanup

---------

Co-authored-by: tool4EvEr <tool4EvEr@>
Co-authored-by: Hans Mackowiak <hanmac@gmx.de>
2025-05-04 18:11:00 +02:00
tool4ever
41efdb095a Update StaticAbilityCantAttackBlock.java 2025-05-04 12:25:24 +00:00
tool4ever
86453a6fa7 Update StaticAbilityCantAttackBlock.java 2025-05-04 12:24:22 +00:00
Hans Mackowiak
8448a6e20e Update cards with Static CantAttack or CantBlock (#7435)
* Update cards with Static CantAttack or CantBlock

---------

Co-authored-by: tool4ever <therealtoolkit@hotmail.com>
2025-05-04 13:14:58 +02:00
Hans Mackowiak
194662c9c7 StaticAbilityMode: add Enum and allow MultiMode (#7491) 2025-05-04 10:56:27 +02:00
Fulgur14
d3a33a0092 Update tifa_martial_artist.txt (#7488) 2025-05-03 21:12:06 +00:00
tool4ever
2bab13247c Some fixes (#7484) 2025-05-03 19:31:47 +02:00
Hans Mackowiak
da30b886c9 fix Card from Unknown Set calling getCardEdition 2025-05-03 16:47:39 +02:00
Hans Mackowiak
da38641ff8 Add CantBlock Mode (#7452) 2025-05-03 15:21:08 +02:00
Chris H
fcbc83c3ff Scryfall randomly changed the collector numbers 2025-05-02 16:03:25 -04:00
Hans Mackowiak
4ae93980b6 ~ remove last Unknown Artist 2025-05-02 09:42:04 -04:00
Hans Mackowiak
10b96138c3 ~ update other editions and remove wrong tokens 2025-05-02 09:42:04 -04:00
Hans Mackowiak
8706edbb01 CardEdition: have Token look for other Sets too 2025-05-02 09:42:04 -04:00
Renato Filipe Vidal Santos
4f5c074fe6 YTDM: 3 cards (#7448)
* Add files via upload

* Update loch_larent.txt
2025-04-30 19:55:06 +03:00
Hans Mackowiak
50ca71fc87 Update Return to Ravnica.txt 2025-04-30 13:24:44 +02:00
Hans Mackowiak
84134341e3 Update Bloomburrow Commander.txt
Update offspring token info
2025-04-30 09:58:39 +02:00
Hans Mackowiak
988518284c Update Bloomburrow.txt
Update offspring token info
2025-04-30 09:52:24 +02:00
Hans Mackowiak
1476621df1 CopyPermanentEffect: simplify getting PaperCard from DefinedName 2025-04-30 07:03:26 +02:00
Hans Mackowiak
cb8e13e933 Update Murders at Karlov Manor Commander.txt 2025-04-29 09:39:37 -04:00
Chris H
ea4d878a2d Update forge-gui/res/editions/Murders at Karlov Manor Commander.txt 2025-04-29 09:39:37 -04:00
Hans Mackowiak
eeafc6400c Update Commander Masters.txt 2025-04-29 09:39:37 -04:00
Hans Mackowiak
875b4557b0 Update Commander Anthology Volume II.txt 2025-04-29 09:39:37 -04:00
Hans Mackowiak
bec25c68f2 Update Commander Anthology.txt 2025-04-29 09:39:37 -04:00
Hans Mackowiak
f98aae35a5 Update Commander Legends Battle for Baldur's Gate.txt 2025-04-29 09:39:37 -04:00
Hans Mackowiak
b1acb9f0a3 Update Commander Legends.txt 2025-04-29 09:39:37 -04:00
Hans Mackowiak
89049db6a0 Update Modern Horizons 2.txt 2025-04-29 09:39:37 -04:00
Hans Mackowiak
77378855e3 Update Tarkir Dragonstorm Commander.txt 2025-04-29 09:39:37 -04:00
Paul Hammerton
709582086f Edition token section fixes 2025-04-29 09:39:37 -04:00
Paul Hammerton
7eda9e204e Merge pull request #7468 from paulsnoops/ytdm-formats
Format updates: YTDM
2025-04-29 11:29:43 +01:00
Paul Hammerton
cf94d96d95 Merge pull request #7467 from paulsnoops/edition-updates
Edition updates: FIC, SLD, UNK, YTDM
2025-04-29 11:29:31 +01:00
Paul Hammerton
a78d361b2e FIC 2025-04-29 11:23:53 +01:00
Paul Hammerton
d01619c09c UNK 2025-04-29 11:19:05 +01:00
Paul Hammerton
fd76098765 Format updates: YTDM 2025-04-29 11:13:51 +01:00
Paul Hammerton
9fb08f1695 Edition updates: SLD, YTDM 2025-04-29 11:09:12 +01:00
Hans Mackowiak
4eef86daf1 Card: add FacedownImageKey for better logic and set codes (#7459)
* Card: add FacedownImageKey for better logic and set codes
2025-04-29 07:32:51 +02:00
matthias8422
d74d2da755 Added a new Couldnt connect to server error message
Re wrote the URL parsing logic again, but due to increased complexity put it into a utility class
Fixed desktop version opening up a lobby even when it did not connect to a server
Wired up the new error message to mobile, and both error messages to Desktop
2025-04-28 17:56:08 -04:00
Simisays
f69fd12ebd Update quests.json
xira fix as well
2025-04-28 16:07:29 -04:00
Simisays
d41cdca1bd update 2025-04-28 16:07:29 -04:00
Chris H
acfc413465 Fix AI targeting illegally for each player destroy targeting (#7463) 2025-04-28 07:22:59 +03:00
Agetian
7a2ef6c9fd Update LDA data for Tarkir: Dragonstorm, add puzzle PS_TDM3 (Tarkir: Dragonstorm 03) (#7461)
* - Update LDA for Tarkir: Dragonstorm

* - Add puzzle PS_TDM3.
2025-04-28 07:16:06 +03:00
Chris H
b214b6f8bf Update font-list.txt 2025-04-26 23:46:01 -04:00
Chris H
4d75f7b225 Update fonts location 2025-04-26 23:46:01 -04:00
Chris H
b7db4b4cbc Fix if collector number is null 2025-04-26 22:40:43 -04:00
Chris H
efaca50d97 Fix accidentally removed other blocks 2025-04-26 22:40:43 -04:00
Chris H
0157113103 M-Z token fixes 2025-04-26 22:40:43 -04:00
Chris H
bf70d8e6f6 A-M token updates 2025-04-26 22:40:43 -04:00
Hans Mackowiak
30ac5ae381 Update Duskmourn House of Horror.txt
add artist
2025-04-26 22:40:43 -04:00
Chris H
dd94169c9a Download token images when token collector numbers are defined 2025-04-26 22:40:43 -04:00
Dave
4c24e7248d MTGO Cube 2025 04 (#7449)
* MTGO Vintage Cube 2025-04

* MTGO Vintage Cube 2025-04.draft

* MTGO Vintage Cube 2025-04.dck

* Update MTGO Vintage Cube 2025-04.dck

Use more standard versions of cards
2025-04-26 09:21:18 +03:00
Renato Filipe Vidal Santos
40eb8de90c Fixing Ravenous Harpy, Reaper of Flight Moonsilver (#7447) 2025-04-23 19:07:00 +00:00
Jetz
8f60973d95 Put back blank collector number suffix. 2025-04-23 12:48:03 -04:00
Jetz
bc9df8872f Added support for amount in give card command.
Added 'give print' command.
2025-04-23 12:48:03 -04:00
Renato Filipe Vidal Santos
1071089879 Cleanup: "During your turn" Oracle update, living metal (#7446) 2025-04-23 16:39:30 +02:00
Renato Filipe Vidal Santos
28ae7fa729 Cleanup: NumAtt$ & NumDef$, new cards 2025-04-23 11:01:27 +02:00
Hans Mackowiak
e9c5bc46ae CardEdition: add TokenInSet 2025-04-22 19:51:52 -04:00
Paul Hammerton
9308dac257 Merge pull request #7442 from paulsnoops/cmdr-bnr-22-apr-25
Commander Banned and Restricted Announcement for April 22, 2025
2025-04-22 20:34:36 +01:00
Paul Hammerton
f5fa87410b Commander Banned and Restricted Announcement for April 22, 2025 2025-04-22 20:29:07 +01:00
Renato Filipe Vidal Santos
c3167a9928 Cleanup: Optional wheel update 2025-04-22 10:41:29 +02:00
Pedro Durán
c533bee4b3 Update card translations (#7126) 2025-04-22 10:20:14 +02:00
matthias8422
01a3b2723f Fixed bug where android boolean settings were not properly displaying their checked state (#7440) 2025-04-21 17:53:53 +00:00
Hans Mackowiak
8640a2aaad ~ lf 2025-04-21 16:45:07 +02:00
Paul Hammerton
9f5e5f3068 Update Planeswalker Championship Promos.txt 2025-04-21 10:10:26 -04:00
Paul Hammerton
3db209f128 Update Media and Collaboration Promos.txt 2025-04-21 10:10:26 -04:00
Chris H
351a94281c Remove language code if we can't find it the first request 2025-04-21 10:10:26 -04:00
Chris H
f190e7e678 Add the ability to use hyphens in Collector numbers 2025-04-21 10:10:26 -04:00
Fulgur14
e01d3e0a6d Tifa, Martial Artist 2025-04-21 09:59:38 +00:00
Chris H
cb3fcb259f Revert "Add the ability to use hyphens in Collector numbers"
This reverts commit 0940e7433b.
2025-04-20 17:12:23 -04:00
Chris H
0940e7433b Add the ability to use hyphens in Collector numbers 2025-04-20 17:10:10 -04:00
tool4ever
8e48ff3dfa Update zenith_festival.txt 2025-04-20 17:57:07 +00:00
matthias8422
07b10f736b Feature/network improvement android (#7418)
* initial network improvements for mobile

* Fixed settings menu message referencing proper localization string
2025-04-20 17:34:24 +00:00
Drecon84
d0e4e5bd17 [Adventure] Quest order fix 2025-04-20 12:32:10 -04:00
Hans Mackowiak
fd082ffabb Fix implements IPref 2025-04-20 14:28:47 +02:00
Drecon84
520dcb88d6 [Adventure] Fixing fallback dialog in flower cave
This piece of code didn't work and produced a fallback dialog. Fixed the formatting to make it work as it was supposed to.
2025-04-19 22:44:37 -04:00
Jetz
a4138ebd4d Fix cards reverting to first art in set when game is restarted 2025-04-19 13:15:29 -04:00
tool4ever
1118f5b135 Fix UntilHostLeavesPlay corner case (#7430) 2025-04-19 14:35:07 +00:00
Renato Filipe Vidal Santos
e78f921e4d Update nantuko_slicer.txt (#7421) 2025-04-19 09:34:21 +00:00
tool4ever
a6ec235052 Fix Escalate (#7428) 2025-04-19 08:09:41 +00:00
Jetz72
613cc549f7 Update DraftEffect.java
Delete extra if statement
2025-04-18 19:21:37 -04:00
Jetz72
69c7083592 Update forge-game/src/main/java/forge/game/ability/effects/DraftEffect.java
Co-authored-by: Chris H <zenchristo@gmail.com>
2025-04-18 19:21:37 -04:00
Jetz
7f64e25691 Disable TokenCard flag on drafted cards by default. 2025-04-18 19:21:37 -04:00
Justin Babcock
2cb107380d Fix Knockout Maneuver wrong card type (#7425) 2025-04-18 20:13:36 +00:00
Drecon84
2a4eaea90a [Adventure] Fix for beating castles before getting there in main quest (#7391)
* First draft of the castle main quest bug workaround

Adds a possibility to start the game without the main quest and changes all castles to only let you into the gate if you either don't have a main quest active or are actively on the quest to defeat the castles.

* Rewrote main quest stuff

Wanted to decouple the main quest from the start of the game a little bit to allow the player to start without a main quest.

* Fully tested solution for main quest bug

Castles should now behave as expected.
Need to fix one minor bug still.

* Fixing the starting portal and wizard

This seems to have completely fixed the issues I have found with not starting with a main quest. Hopefully I have found all of the things that might break.
2025-04-18 12:54:09 -04:00
Paul Hammerton
8fdbaf3611 Merge pull request #7423 from paulsnoops/fix-sld
Edition updates: SLD
2025-04-18 09:19:06 +01:00
Paul Hammerton
55edec665f Edition updates: SLD 2025-04-18 09:15:41 +01:00
Paul Hammerton
f11c6a7038 Merge pull request #7422 from paulsnoops/edition-updates
Edition updates: PF25, SLD
2025-04-18 09:09:11 +01:00
Paul Hammerton
36150be7f3 Edition updates: PF25, SLD 2025-04-18 09:04:07 +01:00
Hans Mackowiak
b861994d2f add missing Enchant Keywords 2025-04-18 08:52:28 +02:00
matthias8422
0242189012 Fixed mobile server host UPnP dialog from accidently blocking ther GUI thread indefinatly (#7417) 2025-04-18 06:43:31 +00:00
tool4ever
69ddfdc18c Update envoy_of_the_ancestors.txt
Closes #7419
2025-04-18 06:39:56 +00:00
Hans Mackowiak
bef56d1caa add missing Enchant Keywords 2025-04-18 08:38:36 +02:00
tool4ever
c7f43e245d Fix missing LTB trigger (#7415) 2025-04-18 06:36:18 +00:00
Hans Mackowiak
939b7a22e0 Update fog_on_the_barrow_downs.txt 2025-04-18 06:12:52 +02:00
Jetz
a79a3503f5 Make PaperCardFlags serializable 2025-04-17 20:14:37 -04:00
NicolasCunha
9109207495 fix: concede shortcut not working due to event dispatch thread 2025-04-17 12:48:26 -04:00
Hans Mackowiak
dbac513027 Update tourachs_gate.txt 2025-04-17 16:50:31 +02:00
Hans Mackowiak
3152ac93f6 Update caribou_range.txt 2025-04-17 16:50:16 +02:00
Hans Mackowiak
fc56076f81 Update mystic_might.txt 2025-04-17 16:49:49 +02:00
Hans Mackowiak
ecc763faf6 Update hot_springs.txt 2025-04-17 16:48:50 +02:00
Hans Mackowiak
0130367873 Update bestial_bloodline.txt 2025-04-17 16:44:12 +02:00
Hans Mackowiak
c36b9b7610 Update ice_cage.txt 2025-04-17 16:18:30 +02:00
Renato Filipe Vidal Santos
774ab38335 Update nantuko_slicer.txt (#7413) 2025-04-17 15:34:10 +02:00
tool4ever
251ce2f83b Fix Torment of Hailfire in multiplayer (#7412)
Co-authored-by: TRT <>
2025-04-17 11:55:41 +03:00
Hans Mackowiak
2af47fe6df fix 'Land you control' auras 2025-04-17 06:43:04 +02:00
Hans Mackowiak
332c982695 Update crackling_emergence.txt
Fix Enchant
2025-04-17 05:58:03 +02:00
Hans Mackowiak
eb970665a6 Update harmonious_emergence.txt
Fix Enchant
2025-04-17 05:57:08 +02:00
Jetz72
4714319204 Store cards by collectorNumber instead of artIndex; PaperCard flag support (#7240)
* Refactor - Unknown set code to constant

* Refactor - Support for multiple initial selections for getChoices

* Covert noSell and marked color identities into serializable flags

* Fix cards in deck not being converted to newer noSell format

* unused imports

* Fix NPE

* Cleanup card filter

* Remove 14-year-old check that shouldn't be possible anymore

* CRLF -> LF

---------

Co-authored-by: Jetz <Jetz722@gmail.com>
2025-04-16 18:59:31 -04:00
tool4ever
c85214b9e3 Fix always targeting Graveyard with Aura (#7408) 2025-04-16 21:03:22 +00:00
tool4ever
d5854c9d1c Fix Artifact Possession (#7409) 2025-04-16 21:03:09 +00:00
Renato Filipe Vidal Santos
a3a2a5dd1b Update Reanimate, Kotis (#7403) 2025-04-16 11:22:23 +02:00
Chris H
8f155c9cca Verify we can still target before we add the target to our list (#7404) 2025-04-16 07:15:10 +02:00
matthias8422
366ed643a7 Feature/network improvements (#7365)
* Initial commit of network improvements
Seperated server properties into their own file, this will eventually help facilitate a headless server.
Fixed the localhost ip mapping to give the correct IP Address instead of failing and defaulting to "localhost"
Fixed UPnP as well as added some additional options and choices regarding UPnP
Added localization strings to all language files. (Translators will need to translate these, but the current English string is there for easy reference so they dont have to search the en-US file)

* Initial commit of network improvements
Seperated server properties into their own file, this will eventually help facilitate a headless server.
Fixed the localhost ip mapping to give the correct IP Address instead of failing and defaulting to "localhost"
Fixed UPnP as well as added some additional options and choices regarding UPnP
Added localization strings to all language files. (Translators will need to translate these, but the current English string is there for easy reference so they dont have to search the en-US file)

* Fixed properties file reference

* Refactored server address parsing logic to use the Java URI class for improved readability and robustness.
Extracted reusable code into separate functions to enhance modularity and maintainability.
General code cleanup to improve structure and readability.

* Fixed a potential issue if a protocol was already specified in the connection url.

* Removed logger implementation as changing loggers is out of scope for this PR
Reverted to JUPnP as its implementation is fixed in #7367
Made some of the new localization strings generic as they can be used elsewhere
Added a server.preferences.example file
removed the server port from the old location (forge.progile.properties.example)
Added a server port back into ForgeConstants as it doesnt make sense for the prefered hosting port of the user to override the default Forge connection port.

* resolve conflicts between this branch and master

* Implemented a parent class for all preference Enums so they can be passed into a function regardless of type using IPref, necessary since I separated server settings into its own FNetPref file
Added server preferences section to the preferences Desktop GUI
Added a port preference setting and a UPnP preference setting to the aforementioned server preferences section
Added a localizedComboBox and localizedComboBoxListener so that localized strings can be used in combobox dropdowns in the server preferences section.

TODO: (In scope)
The new server preferences section needs to be added to Android and IOS perhaps?

TODO: (out of scope)
GamePlayerUtil has a bunch on non localized english strings that should be converted to localized

* Fixed unused import

* Resolved merge conflicts
Added server settings to the reset to defaults function
2025-04-15 20:32:32 -04:00
tool4ever
e7becacd57 Fix StoreVoteNum (#7402)
Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
2025-04-15 18:47:24 +02:00
Hans Mackowiak
2cf9293ab3 AttachAI: remove getFirstAttachSpell (#7400)
* AttachAI: remove getFirstAttachSpell

* Update GameAction.java

---------

Co-authored-by: tool4ever <therealtoolkit@hotmail.com>
2025-04-15 11:55:38 +03:00
Hans Mackowiak
88300de6e5 Update aligned_heart.txt
remove keywords
2025-04-15 07:02:53 +02:00
tool4ever
a4cb0924f3 Fix World rule (#7397) 2025-04-14 14:59:51 +00:00
Hans Mackowiak
e0001f8348 Update TokenAi, remove getFirstAttachSpell (#7398)
Removes getFirstAttachSpell
2025-04-14 16:47:53 +02:00
tool4ever
e380590c4c Fix Old-Growth Troll (#7396)
* Fix Old-Growth Troll

* Update GameAction.java

Add AI SVars to EmptySA

* Fix logic

---------

Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
Co-authored-by: Hans Mackowiak <hanmac@gmx.de>
2025-04-14 15:24:09 +02:00
Hans Mackowiak
7410a2844f Update dance_of_the_dead.txt
Remove NewAttach
2025-04-14 14:45:54 +02:00
tool4ever
b4af62eda7 CantUntap Third Step (#7393) 2025-04-13 12:49:07 +00:00
tool4ever
9c14ba49a3 Fix Licids being able to reattach without ending the effect first (#7394) 2025-04-13 12:43:22 +00:00
Hans Mackowiak
25900ee10c Aura Spells have internal Attach Spell for multiple Enchant Keywords (#6996)
* Aura Spells have internal Attach Spell for multiple Enchant Keywords

* AttachAI: add logic for Reanimate Aura with AnimateAI
2025-04-13 13:36:31 +02:00
tool4ever
443ba2c1e0 Upgrade Jetty (#7390) 2025-04-12 21:47:04 +00:00
Hans Mackowiak
6ade60cd59 removed getDirectSVars (#7389) 2025-04-12 21:15:54 +02:00
tool4ever
436697e0b3 Update stadium_headliner.txt
Closes #7388
2025-04-12 14:29:52 +00:00
Hans Mackowiak
e7d8664386 Svar fallback changes (#7385)
* getSVarFallback use stream filter to find one with name
2025-04-12 10:44:19 +02:00
tool4ever
e2e3c658a0 Relocate android specific dependency (#7387) 2025-04-12 05:47:07 +00:00
tool4ever
2a4ea4cb5d Some fixes (#7386) 2025-04-11 20:40:35 +00:00
tool4ever
93215e6ce4 Fix Distended Mindbender (#7381) 2025-04-11 16:02:47 +02:00
tool4ever
f4a0de6392 JUPnP android fix (#7379) 2025-04-11 08:55:40 +02:00
Renato Filipe Vidal Santos
579033abb3 Update whirlwing_stormbrood_dynamic_soar.txt (#7377) 2025-04-10 19:32:01 +00:00
Renato Filipe Vidal Santos
8328866645 Cleanup: April 2025, pass 3 2025-04-10 16:44:28 +02:00
Hans Mackowiak
890ce2505c Unearth: add gain Haste as StaticLayer (#7369)
* Unearth: add gain Haste as StaticLayer
2025-04-10 16:40:37 +02:00
tool4ever
7e6697d100 Fix checking with LKI during combat (#7372) 2025-04-10 15:43:22 +02:00
Agetian
84d793b786 Add 4 Possibility Storm puzzles (#7371)
* - Add TDM/TDC achievements by Marek14.

* - Add 4 Possibility Storm puzzles.
2025-04-10 11:55:42 +03:00
tool4ever
386550da39 Fix JUPnP initialization (#7367)
Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
2025-04-10 08:55:47 +03:00
tool4ever
6d3d11398d Update rite_of_renewal.txt 2025-04-09 15:46:27 +00:00
Greg Sonnier
5db9c189ba Fixed Renew cost in alchemists_assistant.txt (#7363) 2025-04-08 20:59:04 +00:00
Hans Mackowiak
8d3e3cb253 AttachAi: make KeepTapped logic generic (#7361) 2025-04-08 20:54:09 +00:00
Agetian
2042aaa033 - Add TDM/TDC achievements by Marek14. (#7362) 2025-04-08 10:09:24 +03:00
tool4ever
6fc5d218c9 Update savior_of_the_sleeping.txt 2025-04-07 17:27:34 +00:00
Hans Mackowiak
6332f5cbfc Update champion_of_dusan.txt
Fix Renew Cost
2025-04-07 17:22:37 +02:00
Chris H
44340998fd Update host_of_the_hereafter.txt 2025-04-07 09:30:00 -04:00
Chris H
5274c976ef Restore flatten plugin 2025-04-06 12:13:08 -04:00
GitHub Actions
280d2fed6d [maven-release-plugin] prepare for next development iteration 2025-04-06 12:13:08 -04:00
GitHub Actions
9ecea646d2 [maven-release-plugin] prepare release forge-2.0.03 2025-04-06 12:13:08 -04:00
Chris H
c4e5101a42 Update maven-publish for releases without deploying to FTP 2025-04-06 12:13:08 -04:00
Chris H
48a555817d Temporarily remove flatten plugin for release 2025-04-06 12:13:08 -04:00
Renato Filipe Vidal Santos
2cc2ae421a Cleanup: April 2025, pass 2 (#7350)
* Add files via upload

* Add files via upload

* Add files via upload

* Add files via upload

* Update furious_forebear.txt
2025-04-06 17:05:44 +03:00
Paul Hammerton
9109b26484 TDM: Humbling Elder (#7355) 2025-04-06 07:45:55 +00:00
Hans Mackowiak
98e5eb9652 Adventure and Omen as ReplacementEffect in CardState (#7347) 2025-04-05 17:58:20 +00:00
tool4ever
4e93f95dff Update furious_forebear.txt 2025-04-05 17:48:51 +00:00
Renato Filipe Vidal Santos
44e1332fb4 Cleanup: April 2025, pass 1 2025-04-05 17:02:21 +00:00
Hans Mackowiak
e2972acad0 Put ForColor for Call of the Spirit Dragons (#7348)
* Support for Call the Spirit Dragons

* ~ better ChoiceTitle

* ~ add AI flags
2025-04-05 17:14:43 +02:00
Renato Filipe Vidal Santos
76086ffd35 Cleanup: Updating to Count$Valid, pass 4 2025-04-05 06:47:13 +00:00
tool4ever
3c3c47616b Update UnattachEffect.java
Closes #7345
2025-04-05 08:37:53 +02:00
tool4ever
de5a660a6a Update thought_lash.txt
Fix exiling own cards when stolen
2025-04-04 21:04:54 +00:00
Drecon84
d348a72ae4 Excluding more enemy types
These are also not suited for the tutorial. Excluding these as well.
2025-04-04 10:41:17 -04:00
Fulgur14
4055512698 Temur Roar deck 2025-04-04 10:37:56 -04:00
Renato Filipe Vidal Santos
b4b2346fb8 Cleanup: Updating to Count$Valid, pass 3 (#7342) 2025-04-04 11:20:44 +02:00
Paul Hammerton
caa5443874 Update tdm.rnk 2025-04-04 09:13:43 +01:00
Renato Filipe Vidal Santos
c7fb0bd3c3 Cleanup: Count$InYour[Zone], part 2 (#7325) 2025-04-04 09:58:01 +02:00
Renato Filipe Vidal Santos
1f5f62b21a Cleanup: Count$InYour[Zone], part 1 (#7324) 2025-04-04 09:57:21 +02:00
Chris H
04937b6447 Migrate upcoming card scripts 2025-04-03 23:36:00 -04:00
Chris H
94ea88b171 Migrate upcoming card scripts 2025-04-03 23:33:19 -04:00
Chris H
2188582e16 Add initial booster+set info for TDM 2025-04-03 23:19:46 -04:00
Drecon84
fbc73fa22b Small fix to clean up the code
Combining ifs that do not need to be split up.
2025-04-03 16:16:39 -04:00
Drecon84
31790c3dc9 Remove Quest items on NG+
This removes quest items from a NG+ run in adventure mode. It might not remove all when a file has multiple NG+'s already, but multiple resets will remove all of the items.
I decided to remove the quest item tag from the teleport runes, since they are not added by a quest but can be bought in the store instead. Keeping them seems a good move for NG+.
2025-04-03 16:16:39 -04:00
Hans Mackowiak
cdf3038ab6 Harmonize first try (#7321)
* Harmonize first try

* Use OptionalCost

* Keyworded don't need type

* TDM/TDC: 11 harmonize cards (#7323)

* Trickery extrinsic fix

* Split fix

* Annoying checks keep failing

* Fix logic

* Clean up

---------

Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
Co-authored-by: Renato Filipe Vidal Santos <45150760+dracontes@users.noreply.github.com>
Co-authored-by: TRT <>
2025-04-03 19:37:16 +02:00
tool4EvEr
ff1781b734 Fix creating token with Endure 0 2025-04-03 11:22:11 +02:00
Hans Mackowiak
49d7351eac ~ lf 2025-04-03 06:11:26 +02:00
Paul Hammerton
3b372eead7 Merge pull request #7330 from paulsnoops/edition-updates
Edition updates: FIN, SLD
2025-04-02 18:05:22 +01:00
Paul Hammerton
c815f7ed0c Edition updates: FIN, SLD 2025-04-02 17:59:44 +01:00
Fulgur14
04ac8d8de9 Gladiolus Amicitia (FIN) (#7329) 2025-04-02 15:42:57 +02:00
Renato Filipe Vidal Santos
6b961ed3e1 Update monstrous_rage.txt (#7326) 2025-04-02 08:34:22 +02:00
Renato Filipe Vidal Santos
17a2a23981 Cleanup: Count$TypeInYour[Zone].[Type] (#7312) 2025-04-01 11:01:45 +00:00
Renato Filipe Vidal Santos
74e83f2a94 Cleanup: Targeted effects that grant flashback (#7319) 2025-04-01 11:00:39 +00:00
tool4ever
8e25dd0e25 Clean up (#7322) 2025-04-01 08:46:15 +00:00
Drecon84
7f9260f54c WASD Adventure take 3
Now actually putting the keybinds back in. Forgot to unrevert previously.
2025-03-31 21:24:31 -04:00
Paul Hammerton
505d4b4f9a Merge pull request #7316 from HeitorBittenc/Alchemy-boosters-draft
Alchemy sets boosters added
2025-03-31 17:30:35 +01:00
Paul Hammerton
baca196066 Merge pull request #7317 from Fulgur14/Fulgur14-patch-452548
Mardu Surge deck
2025-03-31 17:30:27 +01:00
Paul Hammerton
b08cf3bf5b Merge pull request #7318 from paulsnoops/b-and-r-2025-03-31
Banned and Restricted Announcement for March 31, 2025
2025-03-31 17:29:49 +01:00
Paul Hammerton
b5ee3eb43c Banned and Restricted Announcement for March 31, 2025 2025-03-31 17:24:53 +01:00
Fulgur14
081e1a2960 Mardu Surge deck 2025-03-31 17:45:15 +02:00
Hans Mackowiak
d0310e257b Mobilize X: enable the keyword to pass the SVars to the static (#7310) 2025-03-31 09:32:38 +00:00
Renato Filipe Vidal Santos
a3733f1fa8 TDM: Avenger of the Fallen 2025-03-31 08:20:34 +00:00
HeitorBittenc
b4bd7947f9 Alchemy sets boosters added 2025-03-30 23:05:31 -03:00
Renato Filipe Vidal Santos
b56da433eb Update hunters_bow.txt 2025-03-30 16:20:07 +02:00
Hans Mackowiak
64b5906f08 lf 2025-03-30 13:09:12 +02:00
tool4EvEr
f7d94fabc9 Fix Damping Engine crashing 2025-03-30 11:27:39 +02:00
HeitorBittenc
87e0810603 Adventure Mode: Fix Waste town generic Equipment shop not appearing 2025-03-29 22:24:04 -04:00
Fulgur14
93f2fa8f43 Update Abzan Armor [TDC] [2025].dck 2025-03-29 20:47:00 -04:00
Fulgur14
c86bf402fd Update Jeskai Striker [TDC] [2025].dck 2025-03-29 20:47:00 -04:00
Drecon84
9926004cf1 Fix for main quest
This fixes the bug where the objective to free the wizard from the red castle doesn't complete.
2025-03-29 20:25:45 -04:00
Renato Filipe Vidal Santos
d0c24f49a9 Update captain_america_first_avenger.txt 2025-03-29 14:56:01 -04:00
Renato Filipe Vidal Santos
661f3b8e7a Update captain_america_first_avenger.txt 2025-03-29 14:56:01 -04:00
Chris H
14249150a0 Fix trailing comma in json 2025-03-29 14:55:08 -04:00
churrufli
93dccdeace Net Decks Archive Updates (#7283) 2025-03-29 19:23:58 +03:00
Renato Filipe Vidal Santos
706ef4ac6c TDM: 14 Omen-related cards (#7300) 2025-03-29 16:13:35 +00:00
Paul Hammerton
bd3994a217 Merge pull request #7302 from paulsnoops/edition-updates
Edition updates: PF24, PMEI, PSPL, PW25, SCH, SLP
2025-03-29 16:07:10 +00:00
HeitorBittenc
e722c4b63c Removed token image fetch attempt from old server (#7287) 2025-03-29 19:01:29 +03:00
Paul Hammerton
a062e0040d Edition updates: PF24, PMEI, PSPL, PW25, SCH, SLP 2025-03-29 15:57:12 +00:00
Hans Mackowiak
7fdd645026 Omen: first attempt (#7297)
* Omen: first attempt

* Support rendering

---------

Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
2025-03-29 16:54:20 +01:00
Paul Hammerton
3670891ec9 Merge pull request #7301 from paulsnoops/tdm-tdc-formats
Add TDM & TDC to formats
2025-03-29 14:55:58 +00:00
Paul Hammerton
6f3dd8deba Add TDM & TDC to formats 2025-03-29 14:49:32 +00:00
Chris H
63ac4a3ee4 Fix line endings 2025-03-29 09:58:37 -04:00
Hans Mackowiak
4616ee715e Update pom.xml
fix CDATA for Add-Opens
2025-03-29 09:07:54 -04:00
Paul Hammerton
5ef6bf1c15 Merge pull request #7299 from paulsnoops/fix-pp-name
Fix Poised Practitioner name
2025-03-29 12:31:28 +00:00
Paul Hammerton
862b4e19b6 Fix Poised Practitioner name 2025-03-29 12:25:05 +00:00
Paul Hammerton
378524dc39 Merge pull request #7298 from paulsnoops/edition-updates
Edition updates: TDC, TDM
2025-03-29 12:19:24 +00:00
Paul Hammerton
6d5f45a311 Edition updates: TDC, TDM 2025-03-29 12:16:13 +00:00
Fulgur14
0e00a52eb4 Update rainveil_rejuvenator.txt (#7294) 2025-03-29 08:14:43 +00:00
tool4ever
4b69d16c6d Update conduit_of_worlds.txt 2025-03-28 22:15:50 +00:00
Renato Filipe Vidal Santos
92e17a66f2 TDM: 6 cards (#7291) 2025-03-28 20:01:40 +00:00
Fulgur14
b601431591 TDM final spoiler batch - part 3 (#7292) 2025-03-28 18:49:19 +00:00
Fulgur14
76db40189e TDM final spoilers part 1 (#7289) 2025-03-28 18:46:00 +00:00
Renato Filipe Vidal Santos
8ddf8225c0 TDM: Mardu Siegebreaker 2025-03-28 18:43:56 +00:00
Fulgur14
359dd8d641 TDM final spoiler batch, Part 2 (#7290) 2025-03-28 18:41:12 +00:00
Fulgur14
878da9b06f Warden of the Grove (TDM) (#7281) 2025-03-27 19:24:57 +00:00
Fulgur14
d843004ad6 Hundred-Battle Veteran (TDM) (#7280)
The only problem I've found is that it's not shown in the "flashback" panel for some reason.
2025-03-27 18:57:53 +00:00
Hans Mackowiak
7f6024f81f Endure effect (#7254)
* add EndureEffect

* ~ fix style

* Add files via upload

* Update dusyut_earthcarver.txt

* add better Endure Message

* Update krumar_initiate.txt

* Fix message

* - Add basic EndureAi

* - Fix imports

* Update EndureAi.java

Apply static check for the token

* Update EndureAi.java

fix import

* Add files via upload

---------

Co-authored-by: Renato Filipe Vidal Santos <45150760+dracontes@users.noreply.github.com>
Co-authored-by: tool4ever <therealtoolkit@hotmail.com>
Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
Co-authored-by: Agetian <stavdev@mail.ru>
2025-03-27 19:21:18 +01:00
Paul Hammerton
5a37b49fcd Merge pull request #7279 from paulsnoops/edition-updates
Edition updates: SLD, TDM
2025-03-27 18:05:14 +00:00
Paul Hammerton
1c8cdac5be Edition updates: SLD, TDM 2025-03-27 18:00:21 +00:00
Fulgur14
20bd27d487 Lotuslight Dancers and Defibrillating Current (TDM) (#7277) 2025-03-27 15:23:34 +01:00
HeitorBittenc
fc761220d2 Removed 2 additional unnecessary requests for tokens images 2025-03-27 10:19:14 -04:00
HeitorBittenc
144681012c Removed print used for tests 2025-03-27 10:19:14 -04:00
HeitorBittenc
8fe3bd3c79 Removed unnecessary request for image fetching 2025-03-27 10:19:14 -04:00
tool4ever
da65308cf2 Some fixes (#7276)
* Fix unlocked Room token
2025-03-27 14:48:01 +01:00
Fulgur14
011457e949 2 TDM commons (#7271) 2025-03-27 15:29:02 +03:00
Renato Filipe Vidal Santos
c296025837 TDM: 10 cards (#7274) 2025-03-27 12:47:17 +01:00
Chris H
ac4c501629 Fix line endings 2025-03-26 19:05:22 -04:00
Heitor Bittencourt
fe062a9312 Refactor Entry to List + add comments 2025-03-26 16:05:22 -04:00
Hans Mackowiak
65d4505b67 Update FDeckViewer.java
Use Set instead of List
2025-03-26 16:05:22 -04:00
Heitor Bittencourt
073d7e537c indentation 2025-03-26 16:05:22 -04:00
Heitor Bittencourt
77dc367c95 Fix ConcurrentModificationException by iterating over a separate list 2025-03-26 16:05:22 -04:00
Heitor Bittencourt
7553d164f4 fix: copy to clipboard now collates copies of a card together. 2025-03-26 16:05:22 -04:00
Heitor Bittencourt
ee01e3d29f fix: copy to clipboard now collates copies of a card together. 2025-03-26 16:05:22 -04:00
Paul Hammerton
58f8c39197 Merge pull request #7267 from paulsnoops/edition-updates
Edition updates: TDC, TDM
2025-03-26 18:57:52 +00:00
Paul Hammerton
7304fa862a Edition updates: TDC, TDM 2025-03-26 18:53:10 +00:00
Fulgur14
1ef8b9ca47 Another 10 TDM cards, including Exhales (#7266) 2025-03-26 18:48:36 +00:00
tool4ever
5191d2f9c4 Safer canUntap check (#7265) 2025-03-26 17:27:18 +00:00
Fulgur14
ff74e36fe5 Kheru Goldkeeper (#7264) 2025-03-26 11:12:49 +00:00
Renato Filipe Vidal Santos
0121619e93 TDM/TDC: 10 cards (#7263) 2025-03-26 09:11:47 +00:00
Drecon84
aeb279a6f8 WASD Movement Take 2 (#7251)
* Enter now still brings up the menu, controller might need it to type. WASD typing still works.
2025-03-26 07:27:16 +00:00
Fulgur14
20815552b9 3 TDC + 1 TDM cards (#7262) 2025-03-25 18:53:59 +00:00
tool4ever
ac67a36ccf Replace first withContext call with more stable AI prediction (#7261) 2025-03-25 18:08:36 +00:00
Fulgur14
fcd8b8fd35 Thunder of Unity (TDM) (#7257) 2025-03-25 17:02:03 +00:00
Renato Filipe Vidal Santos
fbe4ad5c44 TDM: 2 cards 2025-03-25 17:10:23 +01:00
Renato Filipe Vidal Santos
ee17483fff AddPower & AddToughness: Removing redundancy 2025-03-25 15:45:32 +01:00
Renato Filipe Vidal Santos
a451f1a234 Cleanup: NumAtt$ & NumDef$, part 8 (#6885) 2025-03-25 15:01:24 +01:00
Renato Filipe Vidal Santos
52c4c01a7d Cleanup: NumAtt$ & NumDef$, part 7 (#6884) 2025-03-25 14:59:00 +01:00
Renato Filipe Vidal Santos
b1bb0d669f Cleanup: NumAtt$ & NumDef$, part 6 (#6883) 2025-03-25 14:58:47 +01:00
Renato Filipe Vidal Santos
eb1f9783aa Cleanup: NumAtt$ & NumDef$, part 5 (#6882) 2025-03-25 14:58:36 +01:00
Renato Filipe Vidal Santos
0724d224fa Cleanup: NumAtt$ & NumDef$, part 4 (#6881) 2025-03-25 14:58:25 +01:00
Renato Filipe Vidal Santos
e7775cdfa9 Cleanup: NumAtt$ & NumDef$, part 3 (#6880) 2025-03-25 14:58:13 +01:00
Renato Filipe Vidal Santos
f8836f0c40 Cleanup: NumAtt$ & NumDef$, part 2 (#6879) 2025-03-25 14:57:47 +01:00
Renato Filipe Vidal Santos
4c342cfc6a Cleanup: NumAtt$ & NumDef$, part 1 2025-03-25 14:57:35 +01:00
Fulgur14
df05ab34fb 4 TDM cards (#7235) 2025-03-25 14:56:23 +01:00
Paul Hammerton
5da0e75252 Merge pull request #7255 from paulsnoops/edition-updates
Edition updates: TDC, TDM
2025-03-25 10:07:21 +00:00
Paul Hammerton
92ec5d8f64 Edition updates: TDC, TDM 2025-03-25 09:55:59 +00:00
Renato Filipe Vidal Santos
6515fed9d2 TDM/TDC: 4 cards (#7252) 2025-03-25 07:10:37 +00:00
Chris H
5a7cd40614 Update README.md 2025-03-24 22:26:33 -04:00
Fulgur14
65b01e0822 10 TDM/TDC cards (#7249) 2025-03-24 21:19:13 +00:00
Renato Filipe Vidal Santos
643f893d43 TDM: 4 cards (#7248) 2025-03-24 20:42:02 +00:00
Paul Hammerton
e0c6b43214 Merge pull request #7247 from paulsnoops/edition-updates
Edition updates: TDC, TDM, SLD
2025-03-24 18:10:59 +00:00
Paul Hammerton
0f5d71f933 Edition updates: TDC, TDM, SLD 2025-03-24 17:54:03 +00:00
Paul Hammerton
e6a8b5ed74 Edition updates: TDC, TDM, SLD 2025-03-24 17:50:32 +00:00
LEGIONLAPTOP\dougc
24c11e47c4 Updating lang files with new strings 2025-03-24 12:39:50 -04:00
LEGIONLAPTOP\dougc
cb5f805767 Added CommanderGauntlet GameType, added CustomCommanderGauntlet to mobile 2025-03-24 12:39:50 -04:00
LEGIONLAPTOP\dougc
3788e01f38 Quick Commander and Build Commander Gauntlet both working on desktop 2025-03-24 12:39:50 -04:00
LEGIONLAPTOP\dougc
a9df4ea424 Renamed Commander Gauntlet to more accurate QUICK Commander Gauntlet 2025-03-24 12:39:50 -04:00
Chris H
25ba06d530 Revert "WASD movement for Adventure mode" (#7241)
* Revert "Improved WASD script"

This reverts commit fc901f1ebb.

* Revert "Fixed WASD movement"

This reverts commit c365f5a3d1.

* Revert "Update KeyBinding.java"

This reverts commit 49697c863c.

* Revert "Adventure Keybinds"

This reverts commit 4431c40de6.
2025-03-24 09:14:23 -04:00
tool4ever
9b81644f11 Fix Danny Pink triggering once for each type (#7245) 2025-03-24 13:09:57 +01:00
tool4ever
4b27536ed3 Update eshki_temurs_roar.txt
Closes #7238
2025-03-24 10:56:51 +01:00
Renato Filipe Vidal Santos
148da24456 TDM: 2 cards (#7244) 2025-03-24 09:19:51 +01:00
Renato Filipe Vidal Santos
d1be43fd83 TDM: Rot-Curse Rakshasa (#7242) 2025-03-24 07:06:02 +01:00
Chris H
f2df505237 Don't activate connive if Amount == 0 2025-03-23 13:14:58 -04:00
Chris H
bd37e26fab Make the AI more likely to sacrifice/chump block with Reef Worm + Spawn 2025-03-23 13:10:53 -04:00
Chris H
7954473476 FIx Line endings 2025-03-23 12:46:58 -04:00
Renato Filipe Vidal Santos
13287cefbd TDM: 5 Cards (#7234) 2025-03-23 13:48:29 +01:00
Fulgur14
9afbc91de1 1 TDC + 11 TDM cards (#7230) 2025-03-23 11:56:20 +01:00
Renato Filipe Vidal Santos
dfe5bd9ec9 TDM/TDC: 8 cards (#7223) 2025-03-23 10:11:28 +01:00
Renato Filipe Vidal Santos
e2411e34bd Update shiko_and_narset_unified.txt (#7236) 2025-03-23 10:07:41 +01:00
Chris H
f2998bdf9a FIx Line endings 2025-03-22 18:36:42 -04:00
Heitor Bittencourt
c52f886e89 Adventure: Disable Not For Sale Overlay Setting 2025-03-22 18:21:58 -04:00
Heitor Bittencourt
f972aa44ba Adventure: display shop name items on boosters removed 2025-03-22 18:21:09 -04:00
Heitor Bittencourt
ccafe0557f Adventure: Replaced Booster Shop Image 2025-03-22 18:21:09 -04:00
Paul Hammerton
f9f9b1a1f9 Merge pull request #7229 from paulsnoops/edition-updates
Edition updates: TDC, TDM
2025-03-22 10:21:34 +00:00
Fulgur14
e867aacbf5 9 TDC/TDM cards (#7225) 2025-03-22 11:12:21 +01:00
Paul Hammerton
a09e9e4fd6 Edition updates: TDC, TDM 2025-03-22 10:10:35 +00:00
Renato Filipe Vidal Santos
fc320e6524 Fixing Will of the Mardu (#7226) 2025-03-22 08:08:48 +01:00
Chris H
2b6a1c9f3d Refilter targetable list while looping the target selections 2025-03-21 19:11:01 -04:00
Chris H
3e9cd2c226 Fix some adventure issues 2025-03-21 19:11:01 -04:00
Paul Hammerton
3f722abba2 Merge pull request #7224 from paulsnoops/edition-updates
Edition updates: TDC, TDM
2025-03-21 18:01:50 +00:00
Paul Hammerton
06508f70a3 Edition updates: TDC, TDM 2025-03-21 17:42:54 +00:00
Fulgur14
8580108d1e 10 TDM cards (Sidisi and Sibsigs) (#7190) 2025-03-21 10:11:10 +01:00
Hans Mackowiak
300f34377c Update aligned_heart.txt
fix trigger
2025-03-21 09:35:41 +01:00
Renato Filipe Vidal Santos
c4828f510f TDC: 4 cards (#7221) 2025-03-21 09:06:50 +01:00
Fulgur14
04c400553a Another 10 TDM/TDC cards (#7220) 2025-03-21 08:36:50 +01:00
tool4ever
d2508333bc Fix NPE: Jacob Frye + Escape Detection (#7219)
Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
2025-03-21 08:31:09 +03:00
Drecon84
fc901f1ebb Improved WASD script
Now the script works with arrays, much cleaner. I have not been able to test the controller support, it should work but I don't have the means to test it.
2025-03-20 20:35:54 -04:00
Drecon84
c365f5a3d1 Fixed WASD movement
Adventure moves with WASD now
2025-03-20 20:35:54 -04:00
Drecon84
49697c863c Update KeyBinding.java 2025-03-20 20:35:54 -04:00
Drecon84
4431c40de6 Adventure Keybinds
Can now move in adventure mode with WASD keys
2025-03-20 20:35:54 -04:00
Renato Filipe Vidal Santos
a0f6efb959 TDM: 6 cards 2025-03-20 21:02:06 +00:00
tool4ever
44fea0ae75 Fix AI running into timeout keeping thread running (#7215) 2025-03-20 18:17:41 +00:00
Paul Hammerton
95c970e23f Merge pull request #7217 from paulsnoops/edition-updates
Edition updates: TDC, TDM
2025-03-20 17:43:54 +00:00
Paul Hammerton
8596151fa1 Edition updates: TDC, TDM 2025-03-20 17:32:44 +00:00
Paul Hammerton
2eac43734c Merge pull request #7216 from paulsnoops/master
LF
2025-03-20 17:29:09 +00:00
Paul Hammerton
dff91eb2aa LF 2025-03-20 17:25:12 +00:00
Renato Filipe Vidal Santos
aa122700a9 TDC: 4 cards (#7208) 2025-03-20 17:52:47 +01:00
Fulgur14
80f267df59 Dalkovan Packbeasts (TDM) (#7214) 2025-03-20 13:45:55 +01:00
tool4ever
235618c3bb Fix Valiant tracking incorrectly with controller change (#7200)
Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
2025-03-20 15:26:53 +03:00
Fulgur14
b7e55e785e Perennation (TDM) (#7213) 2025-03-20 13:24:25 +03:00
Fulgur14
050c986d08 A few more TDM/TDC cards (#7207) 2025-03-20 10:34:16 +01:00
Fulgur14
2b83541ebc 9 TDM + 1 TDC card (Eshki, Temur's Roar and friends) (#7198) 2025-03-20 08:37:17 +01:00
Fulgur14
d40894ef6a Tempest Hawk + 3 TDC cards (#7202) 2025-03-20 08:36:49 +01:00
Hans Mackowiak
b756bda988 to LF 2025-03-20 00:25:45 +01:00
Heitor Bittencourt
0e64a88005 fix: removed unused imports 2025-03-19 19:11:08 -04:00
Heitor Bittencourt
0d952a54bd feat/adventure: 4 new booster packs,spawn rate changed, removed colorless packs 2025-03-19 19:11:08 -04:00
Hans Mackowiak
d3ff7f3b61 Update parseAbilityCost (#7178)
cleanup and simplify
2025-03-19 22:48:57 +01:00
Renato Filipe Vidal Santos
0f9e7eca89 TDC: 2 cards 2025-03-19 19:18:24 +00:00
Paul Hammerton
207b786fcd oops 2025-03-19 14:01:26 -04:00
Paul Hammerton
0f6fa87da0 Alchemy Rebalancing for March 4, 2025 2025-03-19 14:01:26 -04:00
Paul Hammerton
995c1167dc Merge pull request #7201 from paulsnoops/edition-updates
Edition updates: SPG, TDC, TDM
2025-03-19 17:37:21 +00:00
Paul Hammerton
1ab1d9c002 Edition updates: SPG, TDC, TDM 2025-03-19 17:32:09 +00:00
Renato Filipe Vidal Santos
4b1a6a2f87 TDM: 2 cards (#7199) 2025-03-19 17:08:48 +00:00
Renato Filipe Vidal Santos
dacecd9006 TDM: 4 cards (#7197) 2025-03-19 16:16:19 +00:00
Fulgur14
dd5d75613e 10 TDM cards (All-Out Assault of them) (#7195) 2025-03-19 16:15:57 +00:00
Renato Filipe Vidal Santos
d59a316d8c TDM: 8 cards (#7189) 2025-03-19 16:44:06 +01:00
Fulgur14
9c4f855f71 10 TDM cards (#7196) 2025-03-19 16:41:01 +01:00
Fulgur14
90131b4a70 10 TDM cards (Taigam and pawns) (#7187) 2025-03-19 08:23:13 +01:00
Fulgur14
fb6725f2d7 Update zurgo_thunders_decree.txt (#7188) 2025-03-18 19:37:16 +00:00
tool4ever
475c57af55 Try fix AI not resetting context (#7186) 2025-03-18 19:06:49 +00:00
Renato Filipe Vidal Santos
6ae119a415 TDM: Zurgo, Thunder's Decree and mobilize support (#7185) 2025-03-18 18:51:43 +00:00
Renato Filipe Vidal Santos
8b5fe276e7 TDM: 3 cards (#7184) 2025-03-18 09:56:26 +01:00
Hans Mackowiak
5e4d5c262d ~ lf 2025-03-17 21:15:38 +01:00
Fulgur14
9b82f1ef1f Update united_battlefront.txt (#7183) 2025-03-17 19:56:22 +00:00
Paul Hammerton
321d2d7e33 Merge pull request #7182 from paulsnoops/edition-updates
Edition updates: FIN, SLD, TDM
2025-03-17 17:47:38 +00:00
Paul Hammerton
5b7cca95e1 Edition updates: FIN, SLD, TDM 2025-03-17 17:40:59 +00:00
Hans Mackowiak
2e0d53c6fe CantUntap Second Step (#7172)
* refactor more CantUntap Statics

* ~ no new hidden keywords

* ~ more CantBeActivated

* Update Card.java

* Refactor scripts

---------

Co-authored-by: tool4ever <therealtoolkit@hotmail.com>
Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
2025-03-17 17:48:39 +01:00
Fulgur14
9d4f6d2cbb United Battlefront (#7181) 2025-03-17 16:37:43 +00:00
tool4ever
9546b434e4 Update waltz_of_rage.txt 2025-03-17 17:01:40 +01:00
tool4ever
f230522657 Update contempt.txt (#7177) 2025-03-17 14:23:25 +01:00
tool4ever
a57a1f566a Refactor Telekinesis (#7174)
* Improve AI check
2025-03-17 12:06:03 +00:00
Renato Filipe Vidal Santos
8f8d6e6e30 FIN: Zell Dincht 2025-03-17 08:45:09 +00:00
tool4ever
3b8694483c Refactor Blinding Beam (#7171)
* Refactor Blinding Beam

* Refactor AI checking for Replacement while inactive

* Update stasis.txt

* Update sands_of_time.txt

---------

Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
Co-authored-by: Hans Mackowiak <hanmac@gmx.de>
2025-03-16 21:14:28 +01:00
Hans Mackowiak
4328a12967 Cant untap first step (#7162)
* CantHappen for UntapStep
2025-03-16 11:47:27 +01:00
tool4ever
fdc85b85c3 Cleanup "Cleanup" calls (#7169) 2025-03-16 10:04:10 +00:00
Chris H
bb2eed23b7 Fix Griselbrand overdrawing in one turn 2025-03-15 19:20:44 -04:00
Renato Filipe Vidal Santos
72e33146de YDFT: 14 cards (#7122) 2025-03-15 22:01:58 +00:00
HeitorBittenc
e371617938 fix: removed unused images, booster pack shops now respect the restricted cards and editions. (#7161) 2025-03-15 13:14:04 +00:00
tool4ever
b363db2bbd Fix North Star (#7163) 2025-03-15 13:03:51 +00:00
HeitorBittenc
37a5958750 Added 7 Card booster packs shops in Adventure Mode (#7141)
* Added 7 Card booster packs shops in Adventure Mode

* Update CHANGES.txt

* Fix: trailing space, extra comma and wrong color on shop fixed.

* Removed unused imports

---------

Co-authored-by: Heitor Bittencourt <heitorbite@outlook.com>
Co-authored-by: Agetian <stavdev@mail.ru>
2025-03-14 20:03:13 +03:00
Chris H
9091cfe3b0 Fix double mastesr 2022 basic lands 2025-03-14 11:36:57 -04:00
Chris H
e2614187ac Update brotherhood_vertibird.txt 2025-03-14 10:32:09 -04:00
Ayora29
5c69bf0470 Fix : Puzzle (Possibility Storm - Foundations #01). Opponent library is empty. (#7149) 2025-03-13 11:11:33 +01:00
tool4ever
383dc85166 Some cleanup (#7147) 2025-03-13 10:13:44 +01:00
Hans Mackowiak
7e47208888 Masako the humorless as Static 2025-03-13 08:37:47 +01:00
Hans Mackowiak
137d87c3df use StaticAbility for Topsy Turvy (#7143) 2025-03-12 09:24:53 +01:00
Paul Hammerton
fbff1fe10a Merge pull request #7144 from paulsnoops/edition-updates
Edition updates: CC2, FIC, PMEI, SLD, TDM
2025-03-11 08:31:42 +00:00
Paul Hammerton
3acd4490c5 Edition updates: CC2, FIC, PMEI, SLD, TDM 2025-03-11 08:28:25 +00:00
Hans Mackowiak
2952ed79f8 ~ lf 2025-03-11 07:07:08 +01:00
Fulgur14
cb23eda5a6 Stormplain Detainment [TDM] 2025-03-10 17:10:07 +00:00
Renato Filipe Vidal Santos
ced87c8aea FIC: Celes, Rune Knight 2025-03-10 15:49:40 +00:00
Jetz72
daf87e26ad Fix importing "Ice Tunnel"; Max Speed being flipped instead of transformed (#7138) 2025-03-10 14:31:35 +00:00
Chris H
0c30c4e32c Restrict conspiracy drafts in Adventure mode for now 2025-03-08 18:55:00 -05:00
Paul Hammerton
bf5f9f69ca Merge pull request #7133 from paulsnoops/edition-updates
Edition updates: PWCS
2025-03-08 20:50:08 +00:00
Paul Hammerton
b4828d3b4d Edition updates: PWCS 2025-03-08 20:35:44 +00:00
Renato Filipe Vidal Santos
617df8e07c Fixing Chimeric Mass and Svogthos (#7130) 2025-03-08 08:15:03 +00:00
Simisays
deaba89f46 jace update 2025-03-07 21:23:23 -05:00
Hans Mackowiak
d5b13d56cc Update jackdaw.txt
Closes #7127
2025-03-07 09:26:32 +01:00
Chris H
f893c7ddf8 Balance some item costs 2025-03-06 12:14:00 -05:00
Paul Hammerton
c6cf450ac4 Merge pull request #7121 from paulsnoops/edition-updates
Edition updates: TDM
2025-03-04 18:40:10 +00:00
Paul Hammerton
fa123023c7 Edition updates: TDM 2025-03-04 18:24:38 +00:00
Fulgur14
0b285fa045 Rally the Monastery (#7120) 2025-03-04 17:03:31 +00:00
Paul Hammerton
fe6c4243ee Merge pull request #7119 from paulsnoops/ydft-formats
Add YDFT to formats
2025-03-04 14:06:36 +00:00
Paul Hammerton
1a2c18d25e Add YDFT to formats 2025-03-04 14:03:04 +00:00
Renato Filipe Vidal Santos
12e6de4697 Highway Reaver fix (#7118) 2025-03-04 14:58:02 +01:00
Paul Hammerton
f2b72d4234 Merge pull request #7090 from dracontes/rb-ydft-3
YDFT: 12 cards
2025-03-04 11:22:35 +00:00
Renato Filipe Vidal Santos
25a84e9aee Update venom_deadly_devourer.txt (#7117) 2025-03-04 11:47:54 +01:00
Hans Mackowiak
488171b02b Dream counters rework (#7116)
* Dream Counters: moved to extra getCounterMax function

* Update Rasputin Dreamweaver State-Based-Action with a StaticAbility
2025-03-04 11:33:57 +01:00
Renato Filipe Vidal Santos
eb22a449f4 Update underworld_sentinel.txt 2025-03-04 09:25:14 +00:00
Renato Filipe Vidal Santos
c21c043f5f Add files via upload 2025-03-04 06:05:23 +00:00
Simisays
94808ea73e Update vampirecastle_4.tmx 2025-03-03 18:57:32 -05:00
Simisays
7fe486cba6 Update zedruu.tmx 2025-03-03 18:57:32 -05:00
Simisays
a3517e260c update 2025-03-03 18:57:32 -05:00
Paul Hammerton
377f1fad41 Update MagicFest 2025.txt 2025-03-03 13:30:44 -05:00
Chris H
17448f99c9 Update MagicFest 2025.txt 2025-03-03 13:30:44 -05:00
Hans Mackowiak
8c83886c2e Update legions_to_ashes.txt
fix missing OppCtrl
2025-03-03 16:10:56 +01:00
Renato Filipe Vidal Santos
9cef38af60 SPE: Sensational Spider-Man (#7112) 2025-03-03 15:54:00 +01:00
tool4ever
288ecc0d72 Support Sensational Spider-Man (#7110) 2025-03-03 15:52:35 +01:00
Renato Filipe Vidal Santos
bb514f6d08 Update fallaji_antiquarian.txt 2025-03-03 10:06:50 +00:00
Chris H
ecb21abb9a Delay rendering the next dialog by a short bit, to allow for the TouchUp keypress to clear 2025-03-02 21:04:07 -05:00
Chris H
9445093d68 Fix Wanderlust from breaking other quests 2025-03-02 21:04:07 -05:00
Renato Filipe Vidal Santos
8f3f83051b SPE: 5 cards (#7107) 2025-03-02 21:49:24 +00:00
Renato Filipe Vidal Santos
5750892edf Add files via upload 2025-03-02 17:47:48 +00:00
Renato Filipe Vidal Santos
db74b2b70b Update shops.json 2025-03-02 12:35:37 -05:00
Renato Filipe Vidal Santos
a5c036be05 Update quests.json 2025-03-02 12:35:37 -05:00
Renato Filipe Vidal Santos
b60ee73ce5 Add files via upload 2025-03-02 12:35:37 -05:00
Renato Filipe Vidal Santos
b743f1cbc5 Update golem.dck 2025-03-02 12:35:37 -05:00
Renato Filipe Vidal Santos
0f0bb56f7d Update goblins.dck 2025-03-02 12:35:37 -05:00
Renato Filipe Vidal Santos
8b593f8356 Update bluewizard_apprentice_2.dck 2025-03-02 12:35:37 -05:00
Renato Filipe Vidal Santos
79ac73fb15 Update banditarcher_damage.dck 2025-03-02 12:35:37 -05:00
Renato Filipe Vidal Santos
da0bb4c0ce Update lorthos.dck 2025-03-02 12:35:37 -05:00
Renato Filipe Vidal Santos
9d7617add9 Update emrakul.dck 2025-03-02 12:35:37 -05:00
Renato Filipe Vidal Santos
f38ed39c87 Update shops.json 2025-03-02 12:35:37 -05:00
Renato Filipe Vidal Santos
8ff5f45449 Update ChooseCardNameEffect.java 2025-03-02 17:19:14 +00:00
Hans Mackowiak
0447299e4f StaticAbility InfectDamage for Phyrexian Unlife 2025-03-02 11:42:37 +01:00
Paul Hammerton
b797317f1a Merge pull request #7106 from paulsnoops/edition-updates
Edition updates: PLG25, PSLDSC, SLD, SPE, YDFT
2025-03-01 22:27:41 +00:00
Paul Hammerton
388f334fd3 Edition updates: PLG25, PSLDSC, SLD, SPE, YDFT 2025-03-01 22:22:15 +00:00
Chris H
e47f623b0a Update argent_dais.txt (#7103) 2025-03-01 18:28:00 +00:00
Renato Filipe Vidal Santos
93e71bded8 Add files via upload 2025-03-01 16:09:56 +00:00
Renato Filipe Vidal Santos
8a93283398 Add files via upload 2025-03-01 11:43:07 +00:00
Renato Filipe Vidal Santos
aafd9b8f49 Update fear_of_change.txt 2025-03-01 08:52:38 +00:00
Renato Filipe Vidal Santos
32fec183d5 Add files via upload 2025-03-01 08:51:56 +00:00
Agetian
d1751262df Make canBlock check if the blocker is a creature. (#7098)
- TokenAi also checks if the spawned token is a creature before running checks.
2025-02-28 19:09:37 +00:00
tool4ever
d05523360d Fix missing SpellDescription (#7099) 2025-02-28 19:08:53 +00:00
Hans Mackowiak
a32f9a3c1c Update a-uurg_spawn_of_turg.txt 2025-02-28 14:38:32 +01:00
Hans Mackowiak
0468247c5a Update uurg_spawn_of_turg.txt 2025-02-28 14:38:07 +01:00
Hans Mackowiak
d02dd67016 Hidden and Double Agenda better as Keyword (#7093)
* Hidden and Double Agenda better as Keyword
2025-02-28 10:22:13 +01:00
tool4ever
27d5766abb Update aetherflux_conduit.txt 2025-02-28 09:13:02 +01:00
Renato Filipe Vidal Santos
be88c63414 Update decoy_gambit.txt (#7095) 2025-02-28 09:08:36 +01:00
Renato Filipe Vidal Santos
c0d965857a Add files via upload 2025-02-28 07:42:50 +00:00
Renato Filipe Vidal Santos
e1763c45af Update quicksilver_lapidary.txt 2025-02-28 04:28:43 +00:00
Renato Filipe Vidal Santos
177f7f64ac Update euru_acorn_scrounger.txt 2025-02-28 04:28:04 +00:00
Renato Filipe Vidal Santos
a2096aa753 Update sala_deck_boss.txt 2025-02-27 21:29:40 +00:00
Renato Filipe Vidal Santos
bc9fac1da6 Add files via upload 2025-02-27 21:23:18 +00:00
Renato Filipe Vidal Santos
e0dcf24c90 Update banquet_guests.txt 2025-02-27 19:36:39 +00:00
Paul Hammerton
db5eb095aa Merge pull request #7094 from Agetian/lda-update-dft
Update LDA deck generation information for Aetherdrift
2025-02-27 18:11:39 +00:00
marthinwurer
16b87f20ca Delegate to piles all the time 2025-02-27 11:07:44 -05:00
Agetian
00b82fe9f9 - Update LDA information (Aetherdrift) 2025-02-27 14:06:23 +03:00
Renato Filipe Vidal Santos
6af0ad100e Update marina_vendrell.txt 2025-02-27 06:17:25 +01:00
Renato Filipe Vidal Santos
f14fda5d1b Update ForgeScript.java 2025-02-27 02:13:01 +00:00
Renato Filipe Vidal Santos
1ef027e7e2 Add files via upload 2025-02-27 02:11:08 +00:00
Renato Filipe Vidal Santos
61aaba268f Update agent_of_masks.txt 2025-02-26 19:34:40 +00:00
Renato Filipe Vidal Santos
b041eee060 Update a-blood_artist.txt 2025-02-26 19:33:52 +00:00
Renato Filipe Vidal Santos
8ed65b95f2 Update blood_artist.txt 2025-02-26 19:32:41 +00:00
Renato Filipe Vidal Santos
3fe53f601c Add files via upload 2025-02-26 19:31:38 +00:00
Paul Hammerton
5ce0374426 Merge pull request #7089 from paulsnoops/edition-updates
Edition updates: YDFT
2025-02-26 19:29:38 +00:00
Paul Hammerton
e4aba70090 Edition updates: YDFT 2025-02-26 19:21:22 +00:00
Renato Filipe Vidal Santos
b17824c20a YDFT: Support Skyforge 2025-02-26 18:16:20 +01:00
Chris H
976dd18fa2 Update negan_the_cold_blooded.txt (#7085) 2025-02-26 18:15:58 +01:00
Renato Filipe Vidal Santos
56bfcec656 Incidental cleanup pass #4 (#7084) 2025-02-26 18:15:43 +01:00
Chris H
f935706d22 Disable upload workflows to ftp forge 2025-02-26 08:52:36 -05:00
Renato Filipe Vidal Santos
e2322ee7ef YDFT: 3 cards (#7077) 2025-02-26 09:53:15 +01:00
Chris H
d553a7cac4 Update stairs_to_infinity.txt (#7082) 2025-02-26 06:00:24 +01:00
tool4ever
f75b2ad9ee Update neriv_crackling_vanguard.txt 2025-02-25 19:42:22 +00:00
tool4ever
333b25eeaf Update yannik_scavenging_sentinel.txt 2025-02-25 19:09:32 +00:00
Hans Mackowiak
0db70261f9 Update TypeLists.txt
Add missing Glimmer
2025-02-25 19:29:53 +01:00
tool4ever
504db590db Fix All in Good Time (#7081)
* Fix for Ketramose
2025-02-25 18:25:35 +00:00
Agetian
650b667148 - Add an AI hint for Arid Archway. (#7080) 2025-02-25 17:17:21 +03:00
Paul Hammerton
4afdd0c264 Merge pull request #7079 from paulsnoops/edition-updates
Edition updates
2025-02-25 10:22:17 +00:00
Paul Hammerton
2816bdef85 Edition updates: SLD, TDC, YDFT 2025-02-25 10:18:25 +00:00
Paul Hammerton
855fe70281 Edition updates: SLD, TDC, YDFT 2025-02-25 10:17:04 +00:00
Fulgur14
e4071a4f4e Neriv and Elsha (TDC) (#7078) 2025-02-25 11:06:36 +01:00
Hans Mackowiak
18ee17f7c8 Update TypeLists.txt
Fix missing Balloon type
2025-02-25 09:26:47 +01:00
Chris H
f84f694351 Reroute card images to scryfall.
Don't try to redownload if it fails during a session
2025-02-24 22:50:14 -05:00
tool4ever
0a15a0352d Fix battles attacking/blocking (#7075)
* Add battle SBA

---------

Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.59>
Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
2025-02-24 16:03:58 +01:00
tool4ever
0e46d436de Update mimeoplasm_revered_one.txt 2025-02-24 08:00:48 +01:00
Hans Mackowiak
a16b4ffe75 CostBehold: add Special Reveal Cost (#7072)
* CostBehold: add Special Reveal Cost

----

Co-authored-by: tool4ever <therealtoolkit@hotmail.com>
2025-02-23 16:52:24 +01:00
tool4ever
608d4c5bda Don't update view of LKI instead of real Card (#7070)
Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
2025-02-23 15:18:40 +03:00
Paul Hammerton
dbb8d8c93a Merge pull request #7071 from paulsnoops/update-tdc
Edition updates: TDC
2025-02-23 10:36:42 +00:00
Paul Hammerton
e30f9a6cb1 Edition updates: TDC 2025-02-23 10:22:21 +00:00
Renato Filipe Vidal Santos
bd4f5a2aa4 TDC: Betor, Ancestor's Voice (#7069) 2025-02-23 09:43:54 +00:00
Renato Filipe Vidal Santos
2d352b110b Negation cleanup: IsUnsolved (#7068) 2025-02-22 22:04:05 +00:00
Renato Filipe Vidal Santos
2802c61abd Negation cleanup: notAttackedThisTurn (#7066) 2025-02-22 21:37:02 +00:00
Paul Hammerton
62c27f9142 Replace net deck links 2025-02-22 15:48:16 -05:00
Renato Filipe Vidal Santos
c358f4e71f Negation cleanup: IsNotCommander (#7064) 2025-02-22 20:38:15 +00:00
Chris H
a05ecbc810 Update teval_the_balanced_scale.txt (#7065) 2025-02-22 20:34:55 +00:00
tool4ever
6b299693ca Finish nonToken cleanup (#7063) 2025-02-22 19:26:48 +00:00
Renato Filipe Vidal Santos
bb3413c1e5 Negation cleanup: nonToken, part 3 (#6952) 2025-02-22 17:44:28 +00:00
Renato Filipe Vidal Santos
854267d521 Negation cleanup: nonToken, part 2 (#6951) 2025-02-22 17:42:28 +00:00
Renato Filipe Vidal Santos
c4e05a5d9b Negation cleanup: nonToken, part 1 (#6950) 2025-02-22 17:42:17 +00:00
Renato Filipe Vidal Santos
27b61a79c8 Negation cleanup: nonToken, part 4 (#6953) 2025-02-22 17:42:03 +00:00
Chris H
70183bcc85 Update snapshot-both-pc-android.yml 2025-02-22 11:19:33 -05:00
Hans Mackowiak
94da663287 ~ lf 2025-02-22 15:00:59 +01:00
Paul Hammerton
3c7c1cc4c7 Merge pull request #7060 from paulsnoops/edition-updates
Edition updates: SLD, TDC, TDM
2025-02-22 10:39:27 +00:00
Paul Hammerton
3b773da60d Edition updates: SLD, TDC, TDM 2025-02-22 10:34:19 +00:00
Renato Filipe Vidal Santos
afee15cf44 TDM: 5 cards (#7058) 2025-02-22 10:17:39 +00:00
Fulgur14
a424aa65df 2 TDM and 1 TDC card (#7056) 2025-02-22 09:03:40 +00:00
tool4EvEr
fa93a7dfdd Fix Well-Laid Plans 2025-02-21 10:46:14 -05:00
Renato Filipe Vidal Santos
446f60b331 Add files via upload 2025-02-21 15:22:33 +01:00
tool4ever
e136368ce3 Update narset_jeskai_waymaster.txt 2025-02-21 10:33:06 +01:00
Fulgur14
5f1b54860c Narset, Jeskai Waymaster (TDM) (#7052) 2025-02-21 11:59:24 +03:00
Chris H
23eb008d5f Trigger edition change if playing 10E draft on mobile 2025-02-20 20:13:21 -05:00
Chris H
40882c20d6 Send URL to github snapshots 2025-02-20 20:13:04 -05:00
tool4ever
9054e01273 Fix corner case with Jace, Wielder of Mysteries (#7050) 2025-02-20 19:03:24 +00:00
Chris H
c5fe9b2667 Snapshot direct to GitHub (#7049)
Upload snapshots directly to a prerelease on GH
2025-02-20 13:14:53 -05:00
tool4ever
0b382d3a9a Update boom_scholar.txt 2025-02-20 09:07:06 +01:00
Hans Mackowiak
45319ddf73 ~ lf 2025-02-20 06:54:18 +01:00
Paul Hammerton
76c725843d Merge pull request #7046 from paulsnoops/edition-updates
Edition updates: FCA, FIC, FIN, SLD
2025-02-19 17:59:37 +00:00
Paul Hammerton
ee09d6ca6a Edition updates: FCA, FIC, FIN, SLD 2025-02-19 17:56:27 +00:00
Fulgur14
02173ce357 8 FIN cards (#7040) 2025-02-19 16:42:24 +00:00
tool4ever
105bfdc489 Script fixes (#7045) 2025-02-19 16:19:57 +01:00
Hans Mackowiak
9b90d04376 Update boommobile.txt
fix Exhaust Cost
2025-02-19 15:22:43 +01:00
Hans Mackowiak
6233fc09af Update Aetherdrift.txt
fix Skysovereign, Consul Flagship
2025-02-19 14:09:15 +01:00
tool4ever
ec20b59ff3 Dependency tab (#7013) 2025-02-19 10:31:59 +01:00
Northmoc
049eb19be4 fix issue #7007 (Double Team) (#7038) 2025-02-19 10:08:12 +01:00
Renato Filipe Vidal Santos
e5e8fa4cdd FIN: 4 cards (#7042) 2025-02-19 10:07:09 +01:00
tool4ever
80c11b9f11 Speed again (#7035)
* Speed again

* Fix NPE

---------

Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
2025-02-18 19:52:43 +03:00
Renato Filipe Vidal Santos
af055f37dc Add files via upload (#7003) 2025-02-18 19:52:25 +03:00
Agetian
49c0db5280 Add puzzle PS_DFT1 - Possibility Storm - Aetherdrift 01 (#7037)
* - Add DFT/DRC achievements by Marek14.

* - Add puzzle PS_DFT1.
2025-02-18 19:52:03 +03:00
Agetian
8478835c4d - Add DFT/DRC achievements by Marek14. (#7036) 2025-02-18 19:39:29 +03:00
Paul Hammerton
804a9d9f20 Merge pull request #7034 from paulsnoops/edition-updates
Edition updates: FIC, FIN, SLD, SLP, SLX, TDM
2025-02-18 11:48:29 +00:00
Paul Hammerton
9060dd786f Edition updates: FIC, FIN, SLD, SLP, SLX, TDM 2025-02-18 11:38:30 +00:00
Renato Filipe Vidal Santos
802fee2e86 FIC: 4 cards (#7032) 2025-02-18 11:22:26 +00:00
Hans Mackowiak
8f6fc751dd Make AI start their engine in Main1 (#7033) 2025-02-18 10:06:37 +03:00
Simisays
770dbc31cd [ADVENTURE] Sorin dungeon cleanup (#7026)
* Update vampirecastle_4.tmx

* 2 more cleanups
2025-02-18 07:30:36 +03:00
Chris H
a49ab150f9 Fix imports 2025-02-17 20:19:41 -05:00
Chris H
4bc07e5311 Disable bulk images from the UI 2025-02-17 20:19:41 -05:00
tool4ever
8706ba7b68 Update sphere_of_annihilation.txt (#7030)
Closes #7029
2025-02-17 12:38:13 +01:00
Hans Mackowiak
99bc83ae84 Add GameEventDoorChanged for log 2025-02-17 10:04:55 +01:00
tool4ever
16e871be7b Fix Arvinox sometimes failing (#7023) 2025-02-16 14:16:42 +01:00
tool4ever
afc4024287 Effects don't need Exiled trigger (#7022) 2025-02-16 09:43:36 +00:00
tool4ever
0da1681c96 checkStaticAbilities: skip wrong zone earlier for less looping (#7018)
Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
2025-02-16 09:50:37 +03:00
tool4ever
da19214754 Radiant Lotus revisited (#7017)
Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
2025-02-16 08:00:41 +03:00
Chris H
44fca5ee5e Restore flatten library 2025-02-15 18:00:19 -05:00
GitHub Actions
2f33c24414 [maven-release-plugin] prepare for next development iteration 2025-02-15 18:00:19 -05:00
GitHub Actions
380f289887 [maven-release-plugin] prepare release forge-2.0.02 2025-02-15 18:00:19 -05:00
Chris H
a5ab069f5b Temporarily remove flatten library for release 2025-02-15 18:00:19 -05:00
Jetz
e880a83df2 Let SVars in functional variants overwrite original script 2025-02-15 12:34:00 -05:00
Jetz
80cc7218a3 URLs for token image keys for speed and max_speed 2025-02-15 12:34:00 -05:00
Renato Filipe Vidal Santos
4809fb858a Update gale_conduit_of_the_arcane.txt 2025-02-15 12:19:58 -05:00
Jetz
3af62888dc Remove wake lock on desktop 2025-02-15 07:50:06 +01:00
Jetz
79e1d0a0f0 Count destroyed attractions for "number of attractions you've visited this turn" 2025-02-15 07:50:06 +01:00
Jetz
c447dfc888 Support "Affinitycycling" and "Affinity for Affinity" 2025-02-15 07:50:06 +01:00
Jetz
8149966915 Fix Tyrranax Rex importing 2025-02-15 07:50:06 +01:00
Hans Mackowiak
472f9481e8 Update radiant_lotus.txt 2025-02-15 07:49:21 +01:00
Hans Mackowiak
2209ce3cee Update sanguine_soothsayer.txt
fix mana cost
2025-02-14 14:57:40 +01:00
Hans Mackowiak
258c89e65d Update CounterEffect.java (#7014) 2025-02-14 09:06:25 +01:00
tool4ever
11913085ef Misc cleanup (#7009) 2025-02-13 15:51:19 +01:00
Chris H
53fca12a57 Fix Radiant lotus 2025-02-12 21:14:01 -05:00
Chris H
8e8a795f19 Migrate upcoming 2025-02-12 20:34:55 -05:00
Renato Filipe Vidal Santos
a4b27321ac Oracle update: During your turn (#7005) 2025-02-12 10:55:57 +01:00
Renato Filipe Vidal Santos
ead83d932f Oracle update: Affinity (#7001) 2025-02-12 10:34:50 +01:00
tool4ever
900bd4327d Update pride_of_the_road.txt 2025-02-12 10:21:39 +01:00
Paul Hammerton
1a2bb054f4 Merge pull request #7000 from paulsnoops/fix-sld
Edition updates: SLD
2025-02-11 19:09:54 +00:00
Paul Hammerton
f908df46c8 Edition updates: SLD 2025-02-11 19:07:12 +00:00
Paul Hammerton
f8c97842c4 Merge pull request #6999 from paulsnoops/edition-updates
Edition updates: SLD
2025-02-11 17:08:59 +00:00
Paul Hammerton
c324b45025 Edition updates: SLD 2025-02-11 17:02:00 +00:00
tool4ever
5061ceda0e Clean up (#6995) 2025-02-10 21:43:04 +00:00
Chris H
d1e677eb4f Update rangers_refueler.txt 2025-02-10 17:37:26 +01:00
Jetz72
493a8f351b Add Speed Tracker to Command Zone (#6982)
* Add command zone effect displaying speed

* Remove enum counter type for speed.

* Make Start Your Engines an SBA.

* LifeLost -> LifeLostAll per speed rules.

* Use same game event for all speed changes.

* Fix keyword not appearing in detail text

* Cleanup extra createSpeedEffect.

* Add support for arbitrary overlay text. Remove fake counters.

* Text styling.

* Remove extra SBA check.

* Remove speed from PlayerView; localization support.

---------

Co-authored-by: Jetz <Jetz722@gmail.com>
2025-02-10 07:43:48 +03:00
Hans Mackowiak
04172eead0 suspected as Static Effect (#6991) 2025-02-09 13:02:59 +00:00
tool4ever
f0ed9288b3 Remove outdated logic (#6989) 2025-02-09 13:01:15 +00:00
Hans Mackowiak
03fe3d63ea Start your Engines as StaticAction (#6987)
* Start your Engines as StaticAction

* ~ fix trigger desc

* ~ moved keyword to better place
2025-02-09 10:52:17 +01:00
Hans Mackowiak
83438ef72b StaticAbilityContinous now have AffectedDefined for card list (#6986)
* StaticAbilityContinous now have AffectedDefined for card list
2025-02-09 10:49:19 +01:00
Paul Hammerton
cf18808a70 Merge pull request #6988 from paulsnoops/dft-rank
Update draft rankings: DFT, INR, PIO
2025-02-08 23:13:53 +00:00
Paul Hammerton
49dc2c1c42 Update draft rankings: DFT, INR, PIO 2025-02-08 23:10:29 +00:00
Northmoc
692400db2a finish up Max speed refactor (#6958)
Co-authored-by: Hans Mackowiak <hanmac@gmx.de>
2025-02-08 14:42:55 +01:00
Northmoc
751c31b226 refactor Max Speed round 1 (#6957) 2025-02-08 14:35:26 +01:00
tool4ever
7be252c509 Fix Elvish Refueler (#6984) 2025-02-08 08:04:30 +00:00
tool4ever
288eac743c Fix Blessing applying too late for triggers (#6983) 2025-02-07 18:17:00 +00:00
tool4ever
d0bd80f158 Update spire_mechcycle.txt 2025-02-07 09:28:38 +01:00
Paul Hammerton
7fe8154bcb Merge pull request #6979 from paulsnoops/edition-updates
Edition updates: PL25
2025-02-06 18:38:42 +00:00
Paul Hammerton
87cd5c90a3 Edition updates: PL25 2025-02-06 18:34:33 +00:00
tool4ever
12399fca48 Update elvish_refueler.txt 2025-02-06 17:42:04 +00:00
Chris H
aaf17553c1 Update syphon_fuel.txt (#6978) 2025-02-06 17:20:17 +01:00
tool4ever
9dedd24d3e Fix Manifest Dread vs. Grafdigger's Cage (#6977) 2025-02-06 17:19:40 +01:00
tool4ever
2443f1486d Fix Primal Wellspring trigger not working with Chun-Li (#6971)
Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
2025-02-06 09:40:29 +03:00
Simisays
cfd1822198 update 2025-02-05 19:05:00 -05:00
Paul Hammerton
7930c4949b Merge pull request #6975 from paulsnoops/fix-token
Edition updates: Fix token name in DFT
2025-02-05 17:50:39 +00:00
Paul Hammerton
ef6d0707ac Edition updates: Fix token name in DFT 2025-02-05 17:47:17 +00:00
Paul Hammerton
cfd792cb69 Merge pull request #6974 from paulsnoops/edition-updates
Edition updates: DFT, DRC, SLD, SPG
2025-02-05 17:14:52 +00:00
Paul Hammerton
f5352662cd Edition updates: DFT, DRC, SLD, SPG 2025-02-05 17:09:00 +00:00
Justin C
bf1192f80d instanceof Pattern variable changes (#6972) 2025-02-05 16:52:14 +03:00
tool4ever
dee2150cf9 Fix trigger targeting itself (#6973)
Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
2025-02-05 16:52:04 +03:00
Hans Mackowiak
c44b105d9f ~ lf 2025-02-04 07:03:51 +01:00
loud1990
b624fb3cf8 DFT Card Cleanup
Changed mana cost for Sundial, trigger for Necroregent
2025-02-03 20:48:11 -05:00
Chris H
45396c1bf4 Fix sellfactor duplication 2025-02-03 18:55:24 -05:00
tool4ever
f562ae6fdb More view cleanup (#6967) 2025-02-03 21:12:03 +00:00
Chris H
6615090bda Allow jumpstart/"nosell" cards to be sold for 0 credits 2025-02-02 12:55:09 -05:00
Chris H
eaf6f117a2 Don't try to load battle if entering village simultaneously 2025-02-02 12:54:38 -05:00
tool4ever
a8488502e7 Reduce some View updates (#6966) 2025-02-02 17:52:20 +00:00
Chris H
309e36827c Fix draftable cards 2025-02-01 22:24:36 -05:00
Chris H
fe7883ddd8 Add ManaCost for Wretched Doll 2025-02-01 22:08:14 -05:00
Chris H
06e5ff5174 DFT edition cards update 2025-02-01 22:08:14 -05:00
Chris H
2c31dd01dd Add booster info for Aetherdrift 2025-02-01 21:40:31 -05:00
Hans Mackowiak
d8a92c4879 ~ lf 2025-02-01 11:55:46 +01:00
Fulgur14
16baeadf0c Final DFT push (2 of 3) (#6948) 2025-02-01 09:34:31 +00:00
Hans Mackowiak
88ed81f75f ~ lf 2025-02-01 10:17:29 +01:00
Fulgur14
70d9df1db2 Final DFT push (3 of 3) (#6949) 2025-02-01 08:33:19 +00:00
Hans Mackowiak
aaa04570f2 Update howlers_heavy.txt 2025-02-01 07:10:20 +01:00
Fulgur14
9365d55964 Final DFT push (1 of 3) (#6947) 2025-01-31 23:04:52 +00:00
Renato Filipe Vidal Santos
0c61139f51 Add files via upload (#6945) 2025-01-31 17:36:16 +03:00
Hans Mackowiak
34bd623e45 Update kataki_wars_wage.txt
Closes #6943
2025-01-31 11:07:00 +01:00
Fulgur14
0e31bb8565 7 DFT cards (Waxen Shapethief and its models) (#6937) 2025-01-31 08:33:59 +01:00
Chris H
0b87094f96 Fix NPE with POEReference 2025-01-30 21:32:17 -05:00
Chris H
42e53c66f6 Update ravenous_amulet.txt 2025-01-30 16:58:11 -05:00
Renato Filipe Vidal Santos
25a7d80146 Fixing mistaken references to defending player in triggered abilities 2025-01-30 21:36:48 +00:00
Simisays
a6170745b1 Update config.json 2025-01-30 15:04:49 -05:00
Simisays
db32547a6e Update eldrazilarge.dck 2025-01-30 15:04:49 -05:00
Simisays
4df6d9998b Update config.json 2025-01-30 15:04:49 -05:00
Simisays
2f42f6ca28 Update config.json 2025-01-30 15:04:49 -05:00
Simisays
6617c10946 update 2025-01-30 15:04:49 -05:00
Northmoc
1d34e02957 grim_bauble.txt and some fixes (#6935) 2025-01-30 18:34:06 +00:00
Northmoc
132f8d3d4f another round of whitespace and other fixes (#6934) 2025-01-30 18:32:41 +00:00
Northmoc
d3961b1a53 outpace_oblivion.txt (#6936) 2025-01-30 18:31:40 +00:00
Fulgur14
2c04ef9e1f Howlsquad Heavy (DFT) (#6933) 2025-01-30 13:37:02 +01:00
Fulgur14
f599e3ead6 4 DFT cards (Oviya and her projects) (#6932) 2025-01-30 12:07:42 +01:00
Northmoc
e16da84a75 gonti_night_minister.txt + support (#6924) 2025-01-30 11:28:04 +03:00
Fulgur14
0a622f5282 19 DFT cards (Mimeoplasm and its imprints) (#6922)
* Add files via upload

* Update mimeoplasm_revered_one.txt

* Update radiant_lotus.txt

* Add files via upload

* Update radiant_lotus.txt

* Update ripclaw_wrangler.txt
2025-01-30 08:07:40 +03:00
Fulgur14
bb40138c52 8 DFT cards (Adrenaline Jockey and groupies) (#6925)
* 7 DFT cards (Adrenaline Jockey and groupies)

* Add files via upload
2025-01-30 08:07:31 +03:00
tool4ever
2a7bd8bbd2 Clean up logic (#6928) 2025-01-29 18:53:39 +00:00
Fulgur14
e6fc666012 Rover Blades and Gastal Thrillroller (#6927) 2025-01-29 18:21:24 +00:00
Fulgur14
a1297e593c Salvation Engine (#6926) 2025-01-29 17:38:50 +00:00
Renato Filipe Vidal Santos
2026c7eca0 Edit pile cleanup: Trigger effects formatted as activated abilities 2025-01-29 14:13:15 +00:00
Fulgur14
137076f224 9 DFT cards (3 Tyrants and their food) (#6912) 2025-01-29 11:08:51 +00:00
Fulgur14
5538650681 7 DFT cards (Gastal Blockbuster and friends) (#6909) 2025-01-29 11:08:39 +00:00
tool4ever
0e36e6b6d9 Fix room fully unlocked when turned up from manifest (#6921) 2025-01-29 08:46:57 +00:00
Fulgur14
f4c786763a Update bitter_chill.txt (#6920) 2025-01-29 07:42:41 +00:00
Northmoc
978f09e07b spikeshell_harrier.txt + support (#6915)
* spikeshell_harrier.txt + support

* combine effects

* remove unneeded
2025-01-28 21:24:40 +03:00
tool4ever
53e5f2b037 Update rocketeer_boostbuggy.txt 2025-01-28 11:35:27 +00:00
Paul Hammerton
73124adff9 Merge pull request #6914 from paulsnoops/edition-updates
Edition updates: DFT, DRC
2025-01-28 10:46:46 +00:00
Paul Hammerton
f7641c9b10 Edition updates: DFT, DRC 2025-01-28 10:41:12 +00:00
tool4ever
99fd4d9125 AnimateSubAbility rework (#6819)
* AnimateSubAbility rework

* Remove old fix code, it will no longer be needed

* Add zone ordering

* Add labels

* Clean up

* Fix test

* Tweak logic

* Fix Gilraen

* Refactor with counter

* Clean up

* Cleanup effect if card can't ETB

* Update semesters_end.txt

Format abilities

* Return as Aura trickery

* Apply effect before RE

* Update scripts

* Fix order after creating it earlier

* Fix test

---------

Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
Co-authored-by: Hans Mackowiak <hanmac@gmx.de>
2025-01-28 13:18:24 +03:00
tool4ever
1e1fa1a5e1 Dependency Graphs (#6869) 2025-01-28 09:16:31 +00:00
tool4ever
97553c5b76 Fix split card reset before LKI creation (#6911) 2025-01-28 08:48:34 +00:00
Hans Mackowiak
db4c891960 ~ lf 2025-01-27 21:37:15 +01:00
Fulgur14
c0505797f2 5 DFT cards (The Speed Demon and friends) (#6905) 2025-01-27 19:04:35 +00:00
Paul Hammerton
11d52c923c Merge pull request #6907 from paulsnoops/edition-updates
Edition updates: DFT, DRC
2025-01-27 18:26:04 +00:00
Paul Hammerton
f08c20abfd Edition updates: DFT, DRC 2025-01-27 18:22:44 +00:00
Paul Hammerton
b6fdfa752e Merge pull request #6906 from paulsnoops/master
LF
2025-01-27 18:17:08 +00:00
Paul Hammerton
b4a34cdd20 brawl 2025-01-27 18:13:25 +00:00
Fulgur14
f9fe3fb75c 8 DFT cards (Veteran Beastrider and friends) (#6904) 2025-01-27 17:24:31 +00:00
Northmoc
709f524604 risen_necroregent.txt, gas_guzzler.txt (#6903) 2025-01-27 17:15:07 +00:00
Northmoc
c59c91f4fa cards that need the new TapPower stuff (#6899) 2025-01-27 16:31:31 +01:00
Renato Filipe Vidal Santos
31890e19bd Puppeteer Clique (and similar effects) fix 2025-01-27 13:10:58 +01:00
Fulgur14
ad9059df43 Roadside Assistance, Reckless Velocitaur, and DRC decks (#6901) 2025-01-27 10:57:44 +01:00
Hans Mackowiak
77761dc00a StaticAbilityTapPowerValue: saddles Mounts and crews Vehicles (#6898) 2025-01-26 22:39:04 +01:00
Hans Mackowiak
1da25c1cc0 TriggerCrewedSaddled: unify (#6897) 2025-01-26 20:05:32 +01:00
Northmoc
70823e9353 Speed round 2 (#6896) 2025-01-26 15:55:19 +00:00
Renato Filipe Vidal Santos
de3ffe041a Update protean_war_engine.txt (#6895) 2025-01-26 14:30:41 +00:00
tool4ever
70ab4509fe Remove some Cost$ (#6894)
Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
2025-01-26 14:22:54 +03:00
Hans Mackowiak
7a221dcd3b ~ lf 2025-01-26 11:35:53 +01:00
Fulgur14
340ee5863a Update saheeli_radiant_creator.txt (#6893) 2025-01-26 10:01:37 +00:00
Fulgur14
9214dea4cb 7 DFT cards (Mu Yanling and friends 2025-01-26 09:49:12 +00:00
tool4ever
5701d11cae Update r_4_4_dinosaur_dragon_flying.txt 2025-01-26 08:56:16 +00:00
Northmoc
7b42dca49e Speed / Start your engines! (#6888) 2025-01-26 08:48:15 +00:00
Fulgur14
95c6b81b44 3 DFT cards (#6890) 2025-01-26 08:22:54 +00:00
tool4ever
0325a82aa2 Update demigod_of_revenge.txt 2025-01-26 08:20:11 +00:00
Northmoc
7c1ab8ec22 weird 2025-01-25 21:13:20 -05:00
Chris H
375f27de1e Preliminary booster slots for INR 2025-01-25 21:12:49 -05:00
Renato Filipe Vidal Santos
41eb303caf Cleanup: EffectZone$ All, part 3 (#6877) 2025-01-25 20:08:24 +00:00
Renato Filipe Vidal Santos
029e5da14b Cleanup: EffectZone$ All, part 2 (#6876) 2025-01-25 20:07:45 +00:00
Renato Filipe Vidal Santos
ef4055c1b5 Cleanup: EffectZone$ All, part 1 2025-01-25 20:07:27 +00:00
Renato Filipe Vidal Santos
d060b1af0e Cleanup: AffectedZone$ 2025-01-25 19:19:16 +00:00
Renato Filipe Vidal Santos
accc27c0e9 Cleanup: EffectZone$ Command, part 6 (#6845) 2025-01-25 18:41:46 +00:00
Renato Filipe Vidal Santos
376b0ef4ec Cleanup: EffectZone$ Command, part 5 (#6844) 2025-01-25 18:41:19 +00:00
Renato Filipe Vidal Santos
22f5f1e93d Cleanup: EffectZone$ Command, part 4 2025-01-25 18:40:12 +00:00
Renato Filipe Vidal Santos
2b828d7416 Cleanup: EffectZone$ Command, part 3 2025-01-25 18:39:24 +00:00
Renato Filipe Vidal Santos
83dd62f864 Cleanup: EffectZone$ Command, part 2 (#6841) 2025-01-25 18:36:29 +00:00
Renato Filipe Vidal Santos
597e7e80fa Cleanup: EffectZone$ Command, part 1 (#6840) 2025-01-25 18:33:34 +00:00
Hans Mackowiak
72be374158 StaticAbility: use getActiveZone functions (#6861)
* StaticAbility: use getActiveZone functions
2025-01-25 16:54:07 +01:00
Fulgur14
295abefb33 Lost Monarch of Ifnir (DRC) (#6868) 2025-01-25 14:40:56 +00:00
Fulgur14
5385678076 4 DFT + 7 DRC cards (#6850)
* Support Aetheric Amplifier
2025-01-25 13:56:39 +00:00
tool4EvEr
9bda7134d0 Fix wrong CDA param 2025-01-25 14:42:38 +01:00
Hans Mackowiak
f5221ca78c ReplaceToken: use Param from ReplacementEffect 2025-01-25 13:02:41 +01:00
Paul Hammerton
34e85d9356 Merge pull request #6871 from paulsnoops/format-updates
Add INR, DFT & DRC to formats
2025-01-25 11:55:02 +00:00
Paul Hammerton
47e62b8ef6 brawl 2025-01-25 11:49:52 +00:00
Paul Hammerton
2cdb17cb13 Add INR, DFT & DRC to formats 2025-01-25 11:48:30 +00:00
Paul Hammerton
a101b08f30 Merge pull request #6870 from paulsnoops/fix-pg
Fix pyrewood_gearhulk
2025-01-25 10:43:14 +00:00
Paul Hammerton
df368e2009 Fix pyrewood_gearhulk 2025-01-25 10:39:22 +00:00
Fulgur14
bcc2ad5037 Update territorial_aetherkite.txt (#6865) 2025-01-25 09:19:50 +00:00
Paul Hammerton
dfef8a44f8 Merge pull request #6867 from paulsnoops/master
~ LF
2025-01-25 09:09:35 +00:00
Paul Hammerton
dcccc57cec ~ LF 2025-01-25 09:04:19 +00:00
Fulgur14
c20dfe85e4 3 DFT + 5 DRC cards (#6860) 2025-01-25 08:20:41 +00:00
Hans Mackowiak
f59214737d ~ LF 2025-01-25 09:12:57 +01:00
Paul Hammerton
a92e786543 Merge pull request #6863 from paulsnoops/edition-updates
Edition updates: DFT, DRC, SLP
2025-01-24 23:13:34 +00:00
Paul Hammerton
9d0bad67dd Edition updates: DFT, DRC, SLP 2025-01-24 23:09:57 +00:00
Fulgur14
b6445dbad9 Add files via upload (#6862) 2025-01-24 22:36:45 +00:00
Hans Mackowiak
da4445bc92 Update and rename .github/full_throttle.txt to forge-gui/res/cardsfolder/upcoming/full_throttle.txt 2025-01-24 16:33:42 +01:00
Fulgur14
ab15743a74 7 DFT + 1 DRC card (#6853) 2025-01-24 16:20:11 +01:00
Fulgur14
36d72b98a5 Add files via upload (#6846) 2025-01-24 16:21:46 +03:00
Fulgur14
dd9bca2bd7 March of the World Ooze and Molt Tender (DFT) (#6848) 2025-01-23 20:25:57 +00:00
Paul Hammerton
e40d2aab89 Merge pull request #6849 from paulsnoops/edition-updates
Edition updates: DFT, PW25, SPG
2025-01-23 19:20:43 +00:00
Paul Hammerton
2b98349823 Edition updates: DFT, PW25, SPG 2025-01-23 19:15:59 +00:00
Fulgur14
3bb025801e Autarch Mammoth (DFT) (#6847) 2025-01-23 18:48:20 +00:00
Fulgur14
2f390114b5 3 DFT cards plus update of Sab-Sunen (#6839) 2025-01-23 08:10:12 +00:00
Hans Mackowiak
56606e0ac2 ~ LF 2025-01-23 07:36:22 +01:00
Fulgur14
d52590af7f Brightfield Mustang and Thopter Fabricator 2025-01-22 22:14:58 +00:00
Fulgur14
0a685a6c21 10 DFT cards (#6829) 2025-01-22 22:14:02 +00:00
Fulgur14
3126fffb4b Count on Luck (DFT) (#6837) 2025-01-22 21:33:49 +00:00
Fulgur14
f6297a9db6 Add files via upload (#6832) 2025-01-22 21:46:35 +03:00
Fulgur14
86cdaa9d20 Fearless Swashbuckler (DFT) (#6833) 2025-01-22 21:46:30 +03:00
Fulgur14
895d40f817 Full Throttle (DFT) (#6835)
* Full Throttle (DFT)

* Update full_throttle.txt

* Update full_throttle.txt
2025-01-22 21:46:13 +03:00
Paul Hammerton
7b4a8a7583 Merge pull request #6834 from paulsnoops/edition-updates
Edition updates: DFT, DRC, SPG
2025-01-22 17:59:16 +00:00
Paul Hammerton
148cf0b5c5 Edition updates: DFT, DRC, SPG 2025-01-22 17:48:12 +00:00
tool4ever
d314b2ef85 Clean + fix combo (#6830) 2025-01-22 16:52:43 +00:00
Renato Filipe Vidal Santos
47a57f50b3 January 2025 cleanup: pass 7 (#6831) 2025-01-22 16:12:50 +00:00
Justin C
82ebeefff7 Add ${androidPlatform} 2025-01-22 09:31:22 -05:00
Justin C
b721da78c8 Add ${androidBuildTools} to pom.xml
Update the Android Build Tools via variable
2025-01-22 09:31:22 -05:00
Hans Mackowiak
2a8e66fe60 Create .gitattributes (#6827)
Forces line ending for card scripts
2025-01-22 10:55:21 +01:00
Fulgur14
6d0bf19242 17 DST + 4 DSC cards (#6820) 2025-01-22 08:12:59 +00:00
Renato Filipe Vidal Santos
a815b70a8f January 2025 cleanup: pass 6, part C (#6826) 2025-01-22 08:12:41 +00:00
Renato Filipe Vidal Santos
99bb49e904 January 2025 cleanup: pass 6, part B (#6825) 2025-01-22 08:03:01 +00:00
Renato Filipe Vidal Santos
693988dd77 January 2025 cleanup: pass 6, part A (#6824) 2025-01-22 08:02:47 +00:00
Simisays
aec341655c Removal of convention cards in adventure (#6803)
* Update config.json

* Update config.json
2025-01-22 08:46:32 +03:00
Fulgur14
edb88f64ef 13 DFT cards (#6817) 2025-01-21 21:02:50 +00:00
Hans Mackowiak
5e708337c2 Exhaust: add new Flag and Static for bypass (#6818) 2025-01-21 21:59:03 +01:00
Hans Mackowiak
917b8dbd75 Timestamp rework (#117) 2025-01-21 17:11:37 +00:00
tool4ever
6c97eba8b1 Update keldon_firebombers.txt 2025-01-21 17:11:16 +00:00
Paul Hammerton
f5ef9b4866 Merge pull request #6813 from paulsnoops/edition-updates
Edition updates: DFT, DRC, PMEI, SLD
2025-01-21 13:08:32 +00:00
Paul Hammerton
a1718ec1ed Edition updates: DFT, DRC, PMEI, SLD 2025-01-21 13:02:50 +00:00
Chris H
a9f99ca5e6 Since people like flashing in blockers 2025-01-21 07:37:20 -05:00
Fulgur14
27a4512d42 Lifecraft Engine 2025-01-21 13:32:45 +01:00
Hans Mackowiak
e2e76e101e Reconfigure: use StaticLayer (#6806) 2025-01-21 09:31:34 +01:00
tool4ever
297c6d283c Fix ChangeZone logic (#6809) 2025-01-21 08:50:28 +01:00
Renato Filipe Vidal Santos
81c23d9586 January 2025 cleanup: pass 5 (#6805) 2025-01-20 22:55:18 +01:00
Renato Filipe Vidal Santos
44a1073362 January 2025 cleanup: pass 4 (#6801) 2025-01-20 17:20:56 +01:00
Agetian
dae4e2ef72 - Fix the AI never playing Hare Apparent. (#6802) 2025-01-20 15:07:57 +01:00
tool4ever
2ea377cbc6 Minor cleanup (#6800)
Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
2025-01-20 13:54:49 +01:00
Hans Mackowiak
3f605aa61a AmassEffect: use Effect in Command Zone for Type Change (#6797) 2025-01-20 13:05:08 +01:00
Hans Mackowiak
ab3fdbdca2 Card: add RenderForUI to disable Render for Effects (#6792) 2025-01-20 12:51:37 +01:00
Renato Filipe Vidal Santos
5a3e001bd9 Add files via upload (#6796) 2025-01-20 06:14:49 +01:00
tool4ever
a4d37824b4 Don't update reveal from library when paying with mana ability (#6791)
Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
2025-01-18 22:45:13 +01:00
tool4ever
cd5a1a3824 Fix Averna (#6790) 2025-01-18 16:12:59 +00:00
Renato Filipe Vidal Santos
14417ad40e January 2025 cleanup: pass 2, part C (#6788) 2025-01-18 16:09:44 +01:00
Renato Filipe Vidal Santos
9b43733a86 Add files via upload 2025-01-18 16:08:56 +01:00
Renato Filipe Vidal Santos
d23fc182af Add files via upload 2025-01-18 16:06:38 +01:00
Renato Filipe Vidal Santos
092caf71b2 DA1: The Battle of Dragon Brothers // Fate Reforged 2025-01-18 12:42:36 +00:00
tool4ever
453afa4275 Curse of Vengeance finally works (#6782) 2025-01-18 11:34:21 +00:00
Renato Filipe Vidal Santos
4698766585 January 2025 cleanup: pass 1 (#6784) 2025-01-18 11:06:48 +01:00
Hans Mackowiak
726d1f3330 ~ Remove Cost from Aura Spells, use ManaCost instead 2025-01-18 11:00:33 +01:00
tool4ever
42416bf732 CharmAi: fix duplicated choice (#6776) 2025-01-15 18:26:41 +00:00
GroundThing
bf2c184370 Fixing radiant smite's cost
Radiant Smite was coded as costing {W}, when it should cost {1}{W}
2025-01-15 17:51:11 +01:00
Hans Mackowiak
0153fca877 ~ CharacteristicDefining helper 2025-01-14 20:10:44 +01:00
tool4ever
ae6f937f35 Misc cleanup (#6767)
* Restore identical checkstyle until it can be cleaned up
2025-01-14 17:14:33 +00:00
tool4ever
7faeda3abc Update SpellAbilityEffect.java 2025-01-14 15:21:24 +01:00
Hans Mackowiak
7fe74f59f6 CardView: added extra check for Ward and Annihilator icons 2025-01-14 13:50:59 +01:00
Hans Mackowiak
f92c570bff Update CardRules.java (#6768)
small fix to unify Characteristic Defining Abilities
2025-01-14 11:49:08 +01:00
Hans Mackowiak
ec23136a45 ~ formatting 2025-01-14 07:29:07 +01:00
Hans Mackowiak
24e16abe89 ~ remove note about maven repo 2025-01-14 07:23:31 +01:00
Hans Mackowiak
c30716ec8a ~ remove 4thline 2025-01-14 07:18:05 +01:00
Hans Mackowiak
6e356d725a Update w_x_x_spirit_cleric_total_spirits.txt
Closes #6765
2025-01-14 07:14:51 +01:00
IceBen4444
54bedc1938 Update mr_foxglove.txt (#6766)
The card should remember replaced draws since it is a "this way" effect that cares about the number.
2025-01-13 21:47:12 +00:00
Chris H
1c0ca26c89 This list doesn't need to be instantiated like an array 2025-01-13 07:04:12 +01:00
Chris H
2ce91a04f1 This list doesn't need to be instantiated like an array 2025-01-13 06:53:28 +01:00
Hans Mackowiak
b8b2fd40d7 Averna: use ReplaceCascade Effect 2025-01-12 21:04:57 +01:00
Hans Mackowiak
3fb07c5ead Move Altar of the Pantheon to its own static (#6760) 2025-01-11 14:18:17 +00:00
Paul Hammerton
fb9770d8b9 Merge pull request #6759 from paulsnoops/edition-updates
Edition updates: INR
2025-01-10 17:49:29 +00:00
Paul Hammerton
cbc39b0e76 Edition updates: INR 2025-01-10 17:44:55 +00:00
Paul Hammerton
672bddfb60 Merge pull request #6757 from churrufli/netdecks080125
Net Decks Archive Updates
2025-01-09 18:09:12 +00:00
marthinwurer
4c7a55aaab Improved AI tapland playing (#6751) 2025-01-08 18:03:17 +00:00
Justin C
1981afca03 Replace Cling with jupnp (#6754)
* Update forthline cling dependency to the more supported jupnp, removes http source. FServerManager.java file formatted

* Update proguard.cfg

Fixes the build problem with Android

* Update FServerManager.java

fix code changes

* Update FServerManager.java

---------

Co-authored-by: Hans Mackowiak <hanmac@gmx.de>
2025-01-08 14:16:10 +03:00
Churrufli
0194fb6726 Net Decks Archive Updates (Standard, Modern, Legacy, Vintage, Pioneer, Pauper) 2025-01-08 10:53:22 +01:00
Churrufli
da5d5b1dc1 Net Decks Archive Updates (Standard, Modern, Legacy, Vintage, Pioneer, Pauper) 2025-01-08 10:49:08 +01:00
Hans Mackowiak
995b3f2cf5 Fix addOpen for Exe
Fix AddOpen for launch4j Exe until https://github.com/orphan-oss/launch4j-maven-plugin/issues/423 finds something better
2025-01-07 08:44:03 -05:00
Hans Mackowiak
acbb7036c3 Update GameAction.java (#6753)
Fix Vraska the Schemer trying to return Instant Spells as Artifact
2025-01-07 09:57:23 +00:00
tool4ever
5b76ccbbd2 Cleanup run (#6750) 2025-01-06 20:52:26 +00:00
Hans Mackowiak
6042884bb3 Update pom.xml 2025-01-06 07:28:34 -05:00
tool4ever
e4247a2402 Fix AI applying cost raise twice (#6747) 2025-01-05 12:32:27 +00:00
Hans Mackowiak
2fcf95c755 Extra cost gift rework (#6733)
* added PromisedGift as xCount

* SpellAbilityAi: move chooseOptionalCosts

* SpellAbilityAi: chooseOptionalCosts check for invalid targets

* Give API logic access to castSA

* ~ add BaseSpell for PromiseGift

* Unearth: remove unneeded Param

* PromiseGift: uses AITgts to stop AI from using Gift when not needed

---------

Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
2025-01-05 08:52:35 +01:00
Hans Mackowiak
1209f39cf1 Merge pull request #6743 from Card-Forge/runScriptFix
remove add-opens from mandatory.java.args, use MANIFEST.mf
2025-01-04 11:22:53 +01:00
Hans Mackowiak
9ee2cfbf18 remove add-opens from mandatory.java.args, use MANIFEST.mf 2025-01-04 10:39:38 +01:00
Jetz72
33e26c1ad2 Fix alt zone display having the zones on opposite sides of the screen. (#6742) 2025-01-03 18:47:56 +00:00
GroundThing
29245cd9d7 Add Missing Quest Reputation Rewards/Penalties
Some quests would notify the player of Reputation Rewards that were not actually awarded. Likewise some dialogue choices or upon declining some quests would notify the player of a loss of reputation that wasn't actually deducted. And in one case, the listed reputation change was different than the actual change. This change should ensure all displayed reputation rewards and penalties are applied. (Only applies to Shandalar)
2025-01-03 09:02:24 -05:00
Jetz
971befb1c9 Fix for hotseat mana selection 2025-01-02 22:20:08 -05:00
Justin C
6aa61684df GenerateGitChangelog goal skip. Update se.bjurr.gitchangelog to v2.2.0. (#6703)
* Updates se.bjurr.gitchangelog to v2.2.0. POM changes to skip "GenerateGitChangelog" in android test and debug builds.

* Remove jitpack.io repo

* Update pom.xml
2025-01-02 22:10:58 -05:00
Chris H
cd517fddbb Restore flatten for snapshots 2025-01-02 09:40:50 -05:00
GitHub Actions
7388468ceb [maven-release-plugin] prepare for next development iteration 2025-01-02 09:40:50 -05:00
GitHub Actions
31af1108d3 [maven-release-plugin] prepare release forge-2.0.01 2025-01-02 09:40:50 -05:00
Chris H
b4dd336ca7 Remove flatten temporarily for release 2025-01-02 09:40:50 -05:00
Jetz72
386ed8a082 Contraptions (#6717)
* Start of contraptions

* More contraption work

* More contraption stuff.
Steamflogger Boss implementation

* More Contraption things

* Use AI's preferred target for mandatory animate effects

* Possible fix for Boomflinger's empty target prompt

* Remove nullable low-definition mana pool icon.

* Contraption Predicates

* Desktop extra zone menu

* Remember cranked contraptions

* AnimateAi fallback to AITgts; Bee-Bee Gun

* Fix AI paying optional costs to assemble zero contraptions.

* Override predicted damage for DealDamage effects with random amounts

* Fix double prompt when reassembling other players' contraptions

* All remaining contraptions and support cards!

* Remove unused imports

* Some cleanup

* Implement non-assembled contraption rule.
Fix blank line prefix on card detail text.

---------

Co-authored-by: Jetz <Jetz722@gmail.com>
2025-01-02 09:41:53 +03:00
tool4ever
1c0cb07a2e Remove obsolete GameEvent (#6736) 2025-01-01 17:24:47 +00:00
Hans Mackowiak
dfce81f67c Update chaos_balor.txt
Closes #6524
2025-01-01 10:50:30 +01:00
Hans Mackowiak
2301a34673 Update pom.xml 2024-12-31 10:27:22 +01:00
dependabot[bot]
feb4195ec6 Bump ch.qos.logback:logback-core from 1.5.11 to 1.5.13
Bumps [ch.qos.logback:logback-core](https://github.com/qos-ch/logback) from 1.5.11 to 1.5.13.
- [Commits](https://github.com/qos-ch/logback/compare/v_1.5.11...v_1.5.13)

---
updated-dependencies:
- dependency-name: ch.qos.logback:logback-core
  dependency-type: direct:production
...

Signed-off-by: dependabot[bot] <support@github.com>
2024-12-31 10:27:22 +01:00
NimSpork
3bc5c1f11f Harold and Bob: Oracle fix (#6734) 2024-12-31 09:59:32 +01:00
tool4ever
5fe099eb03 Clean up scripts (#6732) 2024-12-30 08:04:36 +00:00
tool4ever
475020f742 Order hand option (#6729)
Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
2024-12-30 08:10:02 +03:00
tool4ever
f50f985e99 Some cleanup (#6728) 2024-12-29 09:27:07 +00:00
Simisays
ed2d5f6daf [[Adventure]] Jace quickfix (#6723)
* update

* Update jaces_signature_hoodie.txt

* Update jace_boss_effect.txt
2024-12-28 08:09:32 +03:00
tool4ever
672a9137d4 Clean up (#6722) 2024-12-26 12:59:18 +00:00
tool4ever
9b6203b883 Full Control unleashed (#6700)
* Fix APNAP order
2024-12-26 12:53:46 +00:00
NimSpork
c7d6446fb5 The Roaring Toeclaws fix
Fix to check Mana Value rather than power
2024-12-24 07:14:05 +01:00
Hans Mackowiak
020b205c46 SpellAbilityAi: move willPayUnlessCost to EffectSpecific Code (#6652)
* SpellAbilityAi: move willPayUnlessCost to EffectSpecific Code

* LifeLoseAi: add willPayUnlessCost

* ~ update LoseLife UnlessAI LifeLE cards

* DamageDealAi: add willPayUnlessCost

* ~ removed UnlessAI LifeLE from DealDamage cards

* TapAi with UnlessCost and UnlessSwitched

* ~ ChangeZoneAi with UnlessCost

* ~ remove UnlessAI Defined

* ~ remove UnlessAI OnlyDontControl

* ~ Join Forces cards

* ~ Icy Prison and remove OnlyOwn

* ~ remove UnlessAI Paralyze

* ~ Discard willPayUnlessCost

* ~ first logic for DrawAi + UnlessCost

* DestroyAllAi: willPayUnlessCost for Breaking Point

* move logic for Indulgent Tormentor

* Perplex: some more logic for UnlessCost Discard Hand

* TokenAi: add willPayUnlessCost for Development

* Chain of Vapor UnlessAI logic, need more love

* move WillAttack UnlessAI

* PlayerControllerAi: change how AI pays for UnlessCost

* Fix crash with Argothian Wurm

* fix PlayerControllerAi payManaCost

* Fix AI for Adarkar Unicorn

* remove null == getPayCosts checks

* Clean up

---------

Co-authored-by: tool4ever <therealtoolkit@hotmail.com>
2024-12-24 07:11:26 +01:00
tool4ever
4f2df85d8f Update trailtracker_scout.txt
Closes #6714
2024-12-23 08:00:21 +01:00
tool4ever
48a33e37c3 Some cleanup (#6712) 2024-12-22 10:27:29 +00:00
Hans Mackowiak
96b2b2cbe4 Upkeep cost remove (#6709) 2024-12-21 13:10:45 +01:00
Cyantime
cd83a16281 Corrects cost of Shrine Keeper (#6706) 2024-12-21 13:21:42 +03:00
Agetian
e25360384b - Fix the AI never playing Chain Lightning. (#6707) 2024-12-21 12:07:43 +03:00
tool4ever
b87be69b27 Cherry pick full control fix (#6702) 2024-12-18 09:22:33 +01:00
Paul Hammerton
c2015bf020 Merge pull request #6699 from paulsnoops/edition-updates
Edition updates: DFT, PLG24, PMEI, SLD
2024-12-17 10:34:26 +00:00
Paul Hammerton
a9c91f3225 filename 2024-12-17 10:31:25 +00:00
Paul Hammerton
2673b59db1 Edition updates: DFT, PLG24, PMEI, SLD 2024-12-17 10:29:45 +00:00
Paul Hammerton
0567300e77 Merge pull request #6698 from paulsnoops/bar-12-16
Banned and Restricted Announcement for December 16, 2024
2024-12-16 17:36:28 +00:00
Paul Hammerton
e47b012f2c Banned and Restricted Announcement for December 16, 2024 2024-12-16 17:30:41 +00:00
Jetz
348447c82d Re-Fix IndexOutOfBoundsException, sans janky method chain 2024-12-16 10:44:07 -05:00
Remko van Wagensveld
f8ddb06e1d fix: Add Set Codes to Commander Pre Cons
This commit adds the set cons to the Commander Pre Cons so that they are correctly
sorted when grouping for Set.
2024-12-16 15:26:20 +01:00
tool4ever
c7afe3ce7a Some cleanup (#6696) 2024-12-16 11:27:00 +00:00
Chris H
420f862e90 This function wasn't tested. And it seems like it was written not to be maintainable. Reverting. 2024-12-15 20:35:23 -05:00
kevlahnota
5651a92d12 Merge pull request #6691 from kevlahnota/master2
fix arrows
2024-12-16 05:52:14 +08:00
Anthony Calosa
ada8e9b8c0 fix arrows 2024-12-16 05:51:04 +08:00
kevlahnota
5bbcab3da9 Update razorfield_ripper.txt
- closes #6688
2024-12-15 21:17:12 +08:00
kevlahnota
1b493b0a2b Merge pull request #6047 from Jetz72/code-cleanup
Migrate Guava Predicates and Functions to Java implementations
2024-12-15 08:51:39 +08:00
kevlahnota
01e1a8f4dd Merge pull request #6687 from kevlahnota/master2
clear bookmarks
2024-12-15 01:05:13 +08:00
Anthony Calosa
63bf2b1a3d clear bookmarks
- closes #6685
2024-12-15 00:53:03 +08:00
Paul Hammerton
19023a97ed Merge pull request #6686 from paulsnoops/fix-pio-rnk
Fix split cards in PIO draft rank file
2024-12-14 11:33:03 +00:00
Paul Hammerton
b7d6186fd1 Fix split cards in PIO draft rank file 2024-12-14 11:29:18 +00:00
Chris H
5c7fb36907 Need to use special slot for the cards to load in the edition properly (#6684) 2024-12-14 09:31:29 +03:00
Paul Hammerton
b208dc4498 Update draft rankings: FDN, PIO 2024-12-13 14:52:29 -05:00
Chris H
7be429dc36 Pioneer masters booster slots 2024-12-13 09:11:36 -05:00
Paul Hammerton
d8ea4b5e06 Merge pull request #6680 from Card-Forge/dsk-booster-fixes
Mark DSK dual lands as Land rarity
2024-12-13 11:01:50 +00:00
Chris H
91a7ef124d Mark DSK dual lands as Land rarity 2024-12-12 22:29:37 -05:00
Justin C
9aeef28bc3 Fix for Bloodbraid Challenger P/T (#6679) 2024-12-12 08:09:10 +01:00
Chris H
e854566425 Mark gainlands as L rarity in Foundations file (#6678) 2024-12-11 11:26:48 +01:00
Justin C
e8067d872d Removed unused variable. Some documentation fixes. (#6675) 2024-12-10 20:24:20 +03:00
Agetian
770f51e891 - Fix draft rankings not showing in Adventure Mode on the first pick of the draft. (#6674) 2024-12-09 22:08:58 +03:00
Jetz
5a3409a8fa unused import 2024-12-09 08:54:23 -05:00
Jetz
931e734bc0 Merge remote-tracking branch 'origin/master' into code-cleanup
# Conflicts:
#	forge-ai/src/main/java/forge/ai/ComputerUtil.java
#	forge-ai/src/main/java/forge/ai/ComputerUtilCard.java
#	forge-gui/src/main/java/forge/player/HumanPlaySpellAbility.java
#	forge-gui/src/main/java/forge/player/PlayerControllerHuman.java
2024-12-09 08:52:36 -05:00
Anthony Calosa
40ee86167b fix typo 2024-12-08 08:47:37 +08:00
Anthony Calosa
7482856dad prevent NPE on AdventureDeckEditor onClose event 2024-12-08 08:45:57 +08:00
Anthony Calosa
4698c2d014 prevent NPE 2024-12-08 08:34:49 +08:00
Paul Hammerton
4172256ded Merge pull request #6673 from paulsnoops/edition-updates
Edition updates: DCI, INR, PMEI, PRES
2024-12-07 12:08:06 +00:00
Paul Hammerton
303a3ebf58 Edition updates: DCI, INR, PMEI, PRES 2024-12-07 12:03:03 +00:00
tool4ever
a9c5839217 Refactor SpellAbilityView canPlay (#6671) 2024-12-06 19:58:52 +00:00
Justin C
6c1f4c7ffe Fix for noted types for Volo's journal (#6665) 2024-12-06 15:13:22 +01:00
Agetian
95e5b7afca Improve AI for First Responder, improve evaluation for self-sac abilities e.g. Sakura-Tribe Elder. (#6668) 2024-12-06 12:45:51 +01:00
Hans Mackowiak
9370e6fa61 Update remove-stale-branches.yml
Bump version
2024-12-06 05:46:16 +01:00
kevlahnota
ea244ec39b Update CardFaceSymbols.java
fix CR -> ColorlessHybrid
2024-12-06 06:03:10 +08:00
Hans Mackowiak
933ff78b64 Update osseous_sticktwister.txt
fix AI for now until my PR is ready
2024-12-05 16:04:05 +01:00
Jetz
6c10351d93 Merge remote-tracking branch 'origin/master' into code-cleanup
# Conflicts:
#	forge-ai/src/main/java/forge/ai/ability/PlayAi.java
#	forge-core/src/main/java/forge/util/collect/FCollection.java
#	forge-game/src/main/java/forge/game/ability/effects/PlayEffect.java
2024-12-05 08:27:25 -05:00
Jetz
fa94754c91 Some Java 11 migrations 2024-12-05 08:05:17 -05:00
Anthony Calosa
13fbfe866e Merge remote-tracking branch 'origin/master' 2024-12-05 21:00:57 +08:00
Anthony Calosa
ebffb83932 prevent NPE on old skin/theme 2024-12-05 21:00:39 +08:00
tool4ever
45c9442330 Fix ConcurrentModificationException (#6664) 2024-12-05 13:15:46 +01:00
Anthony Calosa
b858b48fde remove Collections.synchronized 2024-12-05 16:39:10 +08:00
kevlahnota
d06673e401 Update FCollectionTest.java
prior to the threadsafeiterable restoration
2024-12-05 12:50:53 +08:00
kevlahnota
f637bd970b update check for ItemManagerConfig 2024-12-05 11:49:34 +08:00
kevlahnota
32ba304d11 Update AdventureDeckEditor.java
fix bulk sell menu appearing on other catalogpages
2024-12-05 11:32:45 +08:00
Paul Hammerton
6867a0eaba Merge pull request #6663 from paulsnoops/edition-updates
Edition updates: INR, PIO
2024-12-04 19:32:44 +00:00
Paul Hammerton
9c4333d608 Edition updates: INR, PIO 2024-12-04 19:28:51 +00:00
Agetian
32fc681726 - Add puzzle PS_FDN2. (#6662) 2024-12-04 21:18:18 +03:00
Anthony Calosa
8e16456b2e update comments 2024-12-04 22:12:22 +08:00
Anthony Calosa
36f0021cae revert threadsafeiterable 2024-12-04 22:04:29 +08:00
kevlahnota
a0cad5fa48 fix FCollection (#6657) 2024-12-04 14:45:05 +01:00
Jetz
db2764f1ce Fix Build Errors 2024-12-04 08:27:37 -05:00
Jetz
44cf7dbbea Merge remote-tracking branch 'origin/master' into code-cleanup
# Conflicts:
#	forge-ai/src/main/java/forge/ai/AiAttackController.java
#	forge-ai/src/main/java/forge/ai/AiCardMemory.java
#	forge-ai/src/main/java/forge/ai/AiController.java
#	forge-core/src/main/java/forge/card/ICardDatabase.java
#	forge-core/src/main/java/forge/item/generation/BoosterGenerator.java
#	forge-core/src/main/java/forge/util/FileSection.java
#	forge-core/src/main/java/forge/util/collect/FCollection.java
#	forge-game/src/main/java/forge/game/card/CardProperty.java
#	forge-game/src/main/java/forge/game/combat/Combat.java
#	forge-game/src/main/java/forge/game/spellability/SpellAbility.java
#	forge-game/src/main/java/forge/game/staticability/StaticAbilityContinuous.java
#	forge-gui-desktop/src/main/java/forge/screens/deckeditor/controllers/ACEditorBase.java
#	forge-gui-mobile/src/forge/itemmanager/ItemManager.java
#	forge-gui/src/main/java/forge/deck/DeckgenUtil.java
#	forge-gui/src/main/java/forge/gamemodes/limited/CardThemedDeckBuilder.java
2024-12-04 08:15:30 -05:00
Chris H
a337fd2aed Pay cost verbiage 2024-12-03 21:55:54 -05:00
Paul Hammerton
9fc971c2fb Merge pull request #6659 from paulsnoops/pio_formats
Add PIO to Explorer, Historic & Timeless formats
2024-12-03 09:38:39 +00:00
Paul Hammerton
22ed570cb9 Merge pull request #6658 from paulsnoops/edition-updates
Edition updates: PF25, PIO, PMEI
2024-12-03 09:34:34 +00:00
Paul Hammerton
14ef18ae96 Add PIO to Explorer, Historic & Timeless formats 2024-12-03 09:34:25 +00:00
Paul Hammerton
a94dc8d94f Edition updates: PF25, PIO, PMEI 2024-12-03 09:27:41 +00:00
tool4EvEr
e6deda205c Fully unlocked room traits should still be the same (for once per turn) 2024-12-03 06:30:16 +01:00
tool4ever
739a4ef0bd Fix RollDice (#6653) 2024-12-02 20:44:11 +00:00
tool4ever
560f660925 Update revitalizing_repast_old_growth_grove.txt 2024-12-02 12:51:51 +00:00
tool4ever
ecd2577770 Update embereth_veteran.txt 2024-12-02 12:50:50 +00:00
tool4ever
eb2a584f68 Update treetop_snarespinner.txt 2024-12-02 12:44:34 +00:00
tool4ever
b0fdd39371 Update touch_of_moonglove.txt 2024-12-02 12:43:51 +00:00
tool4ever
c88bdc2e1d Update protect_serve.txt 2024-12-02 12:42:14 +00:00
tool4ever
5008c519a1 Update pollen_shield_hare_hare_raising.txt 2024-12-02 12:28:19 +00:00
kevlahnota
b1c754499d Merge pull request #6651 from kevlahnota/master2
enable timeout on chooseSpellAbilityToPlayFromList
2024-12-02 10:13:17 +08:00
Anthony Calosa
d733b8933e enable timeout on chooseSpellAbilityToPlayFromList 2024-12-02 10:10:00 +08:00
kevlahnota
d1d14c196a Merge pull request #6650 from kevlahnota/master2
prevent crash on Android 11 and below
2024-12-02 09:55:46 +08:00
Anthony Calosa
e8a6d4ce92 prevent crash on Android 11 and below
Completablefuture -> completeOnTimeout
2024-12-02 09:44:29 +08:00
Hans Mackowiak
53541e8f5f Update remove-stale-branches.yml (#6645) 2024-12-01 08:54:58 +01:00
kevlahnota
23d0868e0a Merge pull request #6577 from Card-Forge/AI_ATTACK_TIMEOUT
AI Attack & getSpellAbilityToPlay Timeout
2024-12-01 13:12:24 +08:00
kevlahnota
c6c55a5a6a Merge branch 'master' into AI_ATTACK_TIMEOUT 2024-12-01 12:12:31 +08:00
tool4ever
4fb110939a Update commander_liara_portyr.txt 2024-11-30 19:31:26 +00:00
tool4ever
947d19078b Fix cheating class level 3 by copying level 2 activation (#6643) 2024-11-29 12:22:23 +01:00
tool4ever
4b1ca2449c Update mana_drain.txt 2024-11-29 12:21:08 +01:00
Agetian
143e3c8c75 - Add new genetic decks for Standard and Modern as of November 2024. (#6647) 2024-11-29 13:13:11 +03:00
Ayora29
115276fa56 Update draftable edition sections (#6631)
* Fix edition txt files

* Fix edition txt files

* Fix edition txt files

* Fix edition txt files

* Fix art index when parsing edition files sections
Add "scheme" section
Add fallback sheet in BoosterGenerator
Rewrite FileSection and Use LinkedHashMap for sections map

* Fix edition txt files

* Fix edition txt files

* Fix edition txt files

* Fix edition txt files

* Fix edition txt files

* Fix edition txt files

* Fix edition txt files

* Fix edition txt files

* Fix edition txt files

* Fix edition txt files

* Fix edition txt files

* Fix edition txt files

* Fix edition txt files

* Fix edition txt files

* Fix edition txt files

* Fix edition txt files

* Fix edition txt files

* Fix edition txt files

* Fix edition txt files

* Convert MKM to BoosterSlots

* Rename "RareMythic" section

* Remove conjured cards that do not have unique artwork.

* Restore basic land order

* Fixes

* parseSections : Fix Index out of bounds error for empty file

* FileSection.java : use for loop instead of do/while

---------

Co-authored-by: Agetian <stavdev@mail.ru>
2024-11-29 12:15:11 +03:00
Paul Hammerton
593af10942 Merge pull request #6644 from Agetian/lda-fdn
LDA update for current Standard & Modern formats
2024-11-28 23:23:03 +00:00
kevlahnota
486e8d37b5 Merge branch 'master' into AI_ATTACK_TIMEOUT 2024-11-29 06:03:51 +08:00
kevlahnota
5b183f5a06 update check for internet
- closes #6640
2024-11-29 05:55:28 +08:00
tool4ever
ea8fb23e9b Update lunar_insight.txt 2024-11-28 21:01:19 +00:00
Agetian
a8caee3b10 Merge branch 'master' into lda-fdn 2024-11-28 21:29:12 +03:00
Agetian
4c87dce4e9 - Update LDA deckgen info for the current Standard and Modern formats. 2024-11-28 21:28:44 +03:00
Agetian
9878544b5a - Kayla's Reconstruction AI hint. (#6642) 2024-11-28 20:56:55 +03:00
Agetian
da46cf785e - Kayla's Reconstruction AI hint. 2024-11-28 20:56:16 +03:00
Myyk Seok
535f175864 Alphabetically sort MTGO Cubes so they are easier to find (#6201)
* chore: move files to be alphabetically sorted

* feat: make the alphabetically stored cube contents match the new file names

* fix: cube name typo in MTGO Legacy Cube 2017-01

---------

Co-authored-by: Agetian <stavdev@mail.ru>
2024-11-28 18:04:37 +03:00
Hans Mackowiak
ad3044133c Class level ai (#6641)
* ClassLevelAi: add first logic

* Update ClassLevelUpAi.java

Check for ClassLevelGained Trigger

* Update ClassLevelUpAi.java

~ fix import
2024-11-28 17:59:18 +03:00
kevlahnota
3971d53746 Update TextRenderer.java
fix symbol out of bounds
2024-11-28 20:00:17 +08:00
Paul Hammerton
1bee1a498f Merge pull request #6639 from paulsnoops/edition-updates
Edition updates: PIO, PMEI, SLD
2024-11-28 09:57:39 +00:00
Paul Hammerton
877fb992c5 Edition updates: PIO, PMEI, SLD 2024-11-28 09:54:10 +00:00
Paul Hammerton
2d80cbc54c Merge pull request #6638 from paulsnoops/fix-da1
Fix DA1 edition and related cards
2024-11-27 13:32:00 +00:00
Paul Hammerton
3f7f777be1 Fix DA1 edition and related cards 2024-11-27 13:26:05 +00:00
Paul Hammerton
7d374eaf62 Merge pull request #6637 from churrufli/netdecks271124
Net Decks Archive Updates
2024-11-27 12:22:51 +00:00
Churrufli
d7a93ac59c Net Decks Archive Updates (Standard, Modern, Legacy, Vintage, Pioneer, Pauper) 2024-11-27 11:45:46 +01:00
Northmoc
5aaf65e394 magar_of_the_magic_strings.txt bug fix (#6618)
* take3

* tweak
2024-11-27 12:18:42 +03:00
Northmoc
f76c665e45 UNF: eelectrocute.txt + support (#6616)
* UNF: eelectrocute.txt + support

* tweak

* tweak2
2024-11-26 21:14:52 +03:00
Anthony Calosa
c317d1fb8a Merge remote-tracking branch 'origin/AI_ATTACK_TIMEOUT' into AI_ATTACK_TIMEOUT 2024-11-26 05:48:57 +08:00
Anthony Calosa
e1d7c4a429 use Guava memoize 2024-11-26 05:48:21 +08:00
Paul Hammerton
239ad3734c Merge pull request #6614 from Northmoc/ydsk4
YDSK: harrowing_swarm.txt + support
2024-11-25 21:28:54 +00:00
Paul Hammerton
2e8a373378 Merge pull request #6632 from paulsnoops/edition-updates
Edition updates: PIO
2024-11-25 20:06:34 +00:00
Paul Hammerton
35173eb55e Edition updates: PIO 2024-11-25 20:01:28 +00:00
Paul Hammerton
979635a317 Merge pull request #6630 from paulsnoops/edition-updates
Edition updates: HHO
2024-11-25 16:30:23 +00:00
Paul Hammerton
3e26f859dc Edition updates: HHO 2024-11-25 16:27:39 +00:00
Agetian
cf8c206a73 - Add puzzle PS_FDN1. (#6629) 2024-11-25 19:12:12 +03:00
Paul Hammerton
e3e2429acb Play booster updates: FDN, MH3 2024-11-25 10:37:24 -05:00
Agetian
c3fd663b49 - Only mark Resizable as false on non-fullscreen setups, helps avoid corner cases when fullscreen fails on Linux (e.g. on multiple monitor setups) (#6627) 2024-11-25 18:32:19 +03:00
Hans Mackowiak
451f12826f Update SeekEffect.java
Fix
2024-11-25 15:31:27 +01:00
Hans Mackowiak
4b63fd8dc1 Update SeekEffect.java
Fix StringBuilder.isEmpty to length() != 0
2024-11-25 15:27:43 +01:00
kevlahnota
8fa1ce175f Merge branch 'master' into AI_ATTACK_TIMEOUT 2024-11-25 20:46:07 +08:00
Anthony Calosa
08bab22a23 refactor lazy initialization 2024-11-25 20:45:05 +08:00
Hans Mackowiak
3c21054f8e Card: moved some getter/setter into a copyFrom 2024-11-25 12:35:08 +01:00
Hans Mackowiak
9170c64847 use CardState.getTypeWithChanges directly 2024-11-25 12:35:08 +01:00
Hans Mackowiak
87a16ea58c Card: copy getChangedCardTypes 2024-11-25 12:35:08 +01:00
Paul Hammerton
901c531964 Merge pull request #6626 from paulsnoops/edition-updates
Fix card name in DA1 edition
2024-11-25 09:56:37 +00:00
Paul Hammerton
b56e5e2029 Fix card name in DA1 edition 2024-11-25 09:53:50 +00:00
tool4ever
8c277983e5 Update reality_acid.txt 2024-11-25 08:34:23 +00:00
Hans Mackowiak
3e5a728646 Miracle: fix index 2024-11-24 19:43:37 +01:00
Chris H
78ad99ae6e Update snapshot automation (#6624)
* Update snapshots-pc.yml

* Update snapshots-android.yml

* Update snapshots-pc.yml
2024-11-24 11:01:51 -05:00
Agetian
85e3cef612 Revert "Update draftable edition sections (#6274)" (#6623)
This reverts commit 46f3f01450.
2024-11-24 16:48:01 +03:00
Ayora29
46f3f01450 Update draftable edition sections (#6274)
* Fix edition txt files

* Fix edition txt files

* Fix edition txt files

* Fix edition txt files

* Fix art index when parsing edition files sections
Add "scheme" section
Add fallback sheet in BoosterGenerator
Rewrite FileSection and Use LinkedHashMap for sections map

* Fix edition txt files

* Fix edition txt files

* Fix edition txt files

* Fix edition txt files

* Fix edition txt files

* Fix edition txt files

* Fix edition txt files

* Fix edition txt files

* Fix edition txt files

* Fix edition txt files

* Fix edition txt files

* Fix edition txt files

* Fix edition txt files

* Fix edition txt files

* Fix edition txt files

* Fix edition txt files

* Fix edition txt files

* Fix edition txt files

* Fix edition txt files

* Convert MKM to BoosterSlots

* Rename "RareMythic" section

* Remove conjured cards that do not have unique artwork.

* Restore basic land order
2024-11-24 16:39:21 +03:00
tool4ever
c20898ecec Fix Offspring not triggering for AI (#6622) 2024-11-24 11:43:57 +00:00
Hans Mackowiak
870add0da4 ~fix line style in cardsfolder 2024-11-24 11:21:12 +01:00
Paul Hammerton
a39f541b8f Merge pull request #6610 from Northmoc/ydsk3
YDSK: valiant_emberkin.txt + support
2024-11-24 09:53:39 +00:00
Paul Hammerton
44d9b42c2b Merge pull request #6607 from Northmoc/ydsk
YDSK: gilded_ambusher.txt
2024-11-24 09:53:27 +00:00
Paul Hammerton
1924f2126d Merge pull request #6609 from Northmoc/ydsk2
YDSK: improvising_aerialist.txt + support
2024-11-24 09:50:42 +00:00
Paul Hammerton
baf7d5afaa Merge pull request #6615 from Northmoc/ydsk5
YDSK: lurker_in_the_deep.txt + support
2024-11-24 09:50:28 +00:00
Alexander Kim
e035af3389 Update ashroot_animist.txt (#6621) 2024-11-24 09:49:45 +00:00
Hans Mackowiak
212f14063e Miracle&Madness: use ManaCost instead of CardManaCost (#6606)
* Miracle&Madness: use ManaCost instead of CardManaCost
2024-11-24 10:46:07 +01:00
Paul Hammerton
a611930041 Update draft rankings: BLB, DSK, FDN, LCI, MH3, OTJ 2024-11-23 20:56:49 -05:00
Northmoc
30e82c6b25 ChooseCardNameEffect.getStackDescription small fixes 2024-11-23 20:55:47 -05:00
Northmoc
05d812d5c0 harrowing_swarm.txt param fix 2024-11-23 18:16:48 -05:00
Northmoc
6b3159273e harrowing_swarm.txt fixes 2024-11-23 17:21:47 -05:00
Northmoc
14ad887a0a YDSK: harrowing_swarm.txt + support 2024-11-23 17:21:24 -05:00
Northmoc
bd55cc330e tidy up CardProperty.cardHasProperty for Top/BottomLibrary 2024-11-23 16:14:12 -05:00
Northmoc
ac721780f7 YDSK: improvising_aerialist.txt + support 2024-11-23 15:57:19 -05:00
Chris H
4d21db94f9 Update remove-stale-branches.yml 2024-11-23 19:55:22 +01:00
Northmoc
2905c742a8 YDSK: lurker_in_the_deep.txt + support 2024-11-23 13:29:29 -05:00
Anthony Calosa
8fa95a01ae update arrows 2024-11-23 19:32:03 +08:00
Anthony Calosa
b0411423f6 use Executor, update MatchScreen 2024-11-23 13:22:41 +08:00
Northmoc
14291e6a4f YDSK: valiant_emberkin.txt + support 2024-11-22 19:36:00 -05:00
Northmoc
8efa2234d5 YDSK: gilded_ambusher.txt 2024-11-22 17:01:04 -05:00
Anthony Calosa
0b9fb9f379 Merge remote-tracking branch 'origin/AI_ATTACK_TIMEOUT' into AI_ATTACK_TIMEOUT 2024-11-22 19:13:37 +08:00
Anthony Calosa
78e587b32b handle exception 2024-11-22 19:13:15 +08:00
kevlahnota
8486dbbd02 Merge branch 'master' into AI_ATTACK_TIMEOUT 2024-11-22 16:08:21 +08:00
Anthony Calosa
69fef79105 refactor timeout 2024-11-22 16:06:37 +08:00
kevlahnota
2a499d7390 Merge pull request #6605 from kevlahnota/master2
Fix crash on Splashscreen
2024-11-22 15:55:31 +08:00
Anthony Calosa
66045c0c0a .. 2024-11-22 15:45:44 +08:00
Anthony Calosa
7c3354cf70 Merge remote-tracking branch 'origin/AI_ATTACK_TIMEOUT' into AI_ATTACK_TIMEOUT 2024-11-22 12:46:26 +08:00
kevlahnota
f918ae5978 Merge branch 'master' into AI_ATTACK_TIMEOUT 2024-11-22 12:46:13 +08:00
Anthony Calosa
afb062e770 revert ManaPool
remove ManaPoolTest for concurrency
refactor timeout for chooseSpellAbilityToPlayFromList
2024-11-22 12:44:51 +08:00
kevlahnota
c773e39b52 Merge pull request #6602 from Card-Forge/kevlahnota-patch-2
prevent NPE
2024-11-22 11:57:14 +08:00
Chris H
03b87003ef Update remove-stale-branches.yml 2024-11-21 22:28:13 -05:00
Chris H
4436a83cc5 Update remove-stale-branches.yml 2024-11-21 22:28:13 -05:00
Chris H
2bf67e931e Update remove-stale-branches.yml 2024-11-21 22:16:18 -05:00
kevlahnota
f01d03e706 Merge branch 'master' into AI_ATTACK_TIMEOUT 2024-11-22 06:13:37 +08:00
kevlahnota
29ce2e01fd Update ImageView.java 2024-11-22 06:04:25 +08:00
kevlahnota
6f59c0d2ce prevent NPE 2024-11-22 05:58:49 +08:00
tool4ever
5fa9f5b50e Fix Kentaro (#6600) 2024-11-21 16:58:13 +00:00
Anthony Calosa
3d42da96d4 add persistentmana check 2024-11-21 16:10:20 +08:00
Anthony Calosa
259247c842 update ManaMultiMap clear
update ManaPoolTest
2024-11-21 14:37:32 +08:00
Anthony Calosa
dda5afe704 refactor ManaPool
move custom multimap implementation for floating mana since this only covers small section
2024-11-21 13:33:52 +08:00
kevlahnota
27740be1cd Merge branch 'master' into AI_ATTACK_TIMEOUT 2024-11-21 13:03:58 +08:00
Chris H
0bc4e5d7b9 Restore flatten and version for now 2024-11-20 20:48:21 -05:00
GitHub Actions
c95afd86d8 [maven-release-plugin] prepare for next development iteration 2024-11-20 20:48:21 -05:00
GitHub Actions
ac37ee1947 [maven-release-plugin] prepare release forge-2.0.00 2024-11-20 20:48:21 -05:00
Chris H
0553eb58ef Temporarily remove flatten to get a release out 2024-11-20 20:48:21 -05:00
Anthony Calosa
e23b3b90b4 Merge remote-tracking branch 'origin/AI_ATTACK_TIMEOUT' into AI_ATTACK_TIMEOUT 2024-11-20 22:02:43 +08:00
Anthony Calosa
81777761f5 add ManaPoolTest 2024-11-20 22:02:25 +08:00
kevlahnota
12ae996190 Merge branch 'master' into AI_ATTACK_TIMEOUT 2024-11-19 22:42:20 +08:00
Anthony Calosa
065f6b9273 Merge remote-tracking branch 'origin/AI_ATTACK_TIMEOUT' into AI_ATTACK_TIMEOUT 2024-11-19 22:33:07 +08:00
Anthony Calosa
0854fbb947 update FCollection
Replace copyonwritearray to a custom implementation for concurrent modification exception. A little bit slower but supports iterator operations.
Added FCollectionTest
2024-11-19 22:32:37 +08:00
Hans Mackowiak
d165aba624 Update tyvar_the_pummeler.txt
Closes #6594
2024-11-19 11:37:22 +01:00
kevlahnota
39fc1415aa Merge branch 'master' into AI_ATTACK_TIMEOUT 2024-11-19 05:49:27 +08:00
Chris H
0cfc7c2545 Update snapshot-both-pc-android.yml 2024-11-18 15:11:58 -05:00
kevlahnota
6d49bc7e53 Merge pull request #6593 from kevlahnota/master2
fix layout params
2024-11-18 16:28:22 +08:00
Anthony Calosa
fdfabfd5cf fix layout 2024-11-18 15:55:52 +08:00
kevlahnota
974e8b0760 update xstream, netty
fix dependabot vulnerability
2024-11-18 15:17:38 +08:00
kevlahnota
cbe48d0892 Update VPlayerPanel.java
should display error for null icons on VPlayerPanel Infotab. If pointer is still null then the icon seems to be disposed (probably on android) or just deliberately missing.
2024-11-18 15:09:10 +08:00
0nderzeeboot
8d230c774c Update cephalid_inkmage.txt (#6590)
Fixed wrong condition for threshold check.
2024-11-18 09:36:57 +03:00
kevlahnota
b9ac48e861 Merge pull request #6592 from kevlahnota/master2
set navigation bar color
2024-11-18 12:43:12 +08:00
Anthony Calosa
a1d1e2b335 set navigation bar color
add note to edge-to-edge enforcement on android 15
2024-11-18 12:41:58 +08:00
kevlahnota
a6f1b3ac02 Merge pull request #6591 from kevlahnota/master2
try to prevent Splashscreen crash on Linux
2024-11-18 11:28:55 +08:00
Anthony Calosa
f48cf951db .. 2024-11-18 11:23:00 +08:00
0nderzeeboot
9093c77e72 Update arahbo_the_first_fang.txt (#6589) 2024-11-17 23:44:00 +00:00
kevlahnota
f5e024bf63 Update ItemManager.java
it seems this is controlled via preference and would fail the logic for the view index
2024-11-18 06:11:42 +08:00
kevlahnota
b8a2903617 NPE prevention
- closes #6588
2024-11-18 05:11:48 +08:00
Chris H
24182e337a Update rune_sealed_wall.txt (#6587) 2024-11-17 21:02:06 +00:00
Hans Mackowiak
73940c584e ColorSet: use Stream to map ManaSymbol 2024-11-17 10:48:27 +01:00
kevlahnota
c9e733ecbd Update ImageView.java
isempty missing in streambuffer on android
2024-11-17 14:26:08 +08:00
kevlahnota
f6d4e322a8 Merge pull request #6583 from kevlahnota/master2
try to optout on Edge-to-Edge for android 15
2024-11-17 12:16:16 +08:00
Anthony Calosa
cca1468a85 try to optout on Edge-to-Edge for android 15 2024-11-17 12:12:58 +08:00
kevlahnota
c603bfb818 try to use immersive mode on android 13 and above 2024-11-17 11:07:44 +08:00
Anthony Calosa
619130b519 remove unused import 2024-11-17 08:07:07 +08:00
Anthony Calosa
5dc84a68c4 remove threadsafeIterable
The original purpose which is to create a copy of linkedlist to iterate to avoid concurrent modification, but we use copyonwritearray design and it is already thread safe and iteration while modification is handled internally.
2024-11-17 08:00:29 +08:00
kevlahnota
f6d2d420bb use anymatch 2024-11-17 07:14:33 +08:00
kevlahnota
6c847e00a2 refactor AiCardMemory 2024-11-17 06:49:50 +08:00
kevlahnota
f72ab6f22a use removeall
the fcollection will check if removing from set is successful, it will also remove the element from the list
2024-11-17 00:45:27 +08:00
kevlahnota
12613328fe Update PlayEffect.java 2024-11-17 00:37:22 +08:00
kevlahnota
54266e8914 Merge branch 'master' into AI_ATTACK_TIMEOUT 2024-11-16 20:27:05 +08:00
Anthony Calosa
f46e22cc54 minor cleanup 2024-11-16 20:13:17 +08:00
kevlahnota
cb645670d4 Merge branch 'master' into AI_ATTACK_TIMEOUT 2024-11-16 19:50:55 +08:00
Anthony Calosa
5597d0bf31 fix arrows drawing out of bounds 2024-11-16 19:50:09 +08:00
kevlahnota
0247acbd49 Merge branch 'master' into AI_ATTACK_TIMEOUT 2024-11-16 18:52:12 +08:00
Anthony Calosa
95e3304948 add coloridversion check 2024-11-16 18:24:22 +08:00
kevlahnota
5ebaeacb92 Merge pull request #6570 from Card-Forge/CrypticSpire
add support for Cryptic Spire
2024-11-16 17:18:43 +08:00
kevlahnota
b5f96ab8e2 Merge branch 'master' into CrypticSpire 2024-11-16 17:14:51 +08:00
kevlahnota
acfde12ca2 Merge branch 'master' into AI_ATTACK_TIMEOUT 2024-11-16 12:19:32 +08:00
kevlahnota
c11ca5d3fb Remove input check upload on android snapshot workflow
Don't know why this input is needed but it seems it's not taken into account even with default value to true when the cron job triggers, we have already test build workflow for android apk along with debug signing for checking if build and signing succeeded. Check discord reports on missing/cannot update reports.
2024-11-16 09:39:28 +08:00
Anthony Calosa
cf84ae5719 fix NoSuchElementException 2024-11-16 08:33:45 +08:00
kevlahnota
a53dc4ef85 Update snapshots-android.yml
add missing version.txt
2024-11-16 06:49:36 +08:00
Anthony Calosa
548f97ae36 dumb check for AI 2024-11-15 21:56:15 +08:00
Anthony Calosa
7c35968dfd try to fix ConcurrentModificationException on FCollection -> addAll
cause: tapped.addAll(tappedForMana) on AiCardMemory
2024-11-15 21:19:15 +08:00
Anthony Calosa
5c46048394 removed unused import 2024-11-15 20:44:02 +08:00
Anthony Calosa
f52b7abe61 create ConcurrentMultiMap, remove unused map 2024-11-15 20:24:20 +08:00
kevlahnota
d9c4c818b5 Merge branch 'master' into AI_ATTACK_TIMEOUT 2024-11-15 16:53:04 +08:00
kevlahnota
4b13e55d83 fix infinite notice for missing tokens 2024-11-15 16:26:05 +08:00
tool4ever
bd18600385 Fix DontPayTapCostWithManaSources (#6578)
* Fix DontPayTapCostWithManaSources

* Foundations Update Bulletin (engine)

---------

Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
2024-11-15 09:01:08 +03:00
kevlahnota
b9a56f04e3 revert multimap, needs better implementation for this 2024-11-15 13:40:27 +08:00
kevlahnota
a094149ce0 remove redundant check for can cast timing 2024-11-15 12:40:14 +08:00
kevlahnota
4936fd3950 remove comment, seems it works fine. need to test on android. 2024-11-15 12:38:00 +08:00
kevlahnota
fc85623343 better to use a linkedqueue 2024-11-15 11:51:26 +08:00
kevlahnota
8a1d25e4e9 fix failing test 2024-11-15 11:46:20 +08:00
kevlahnota
a988261377 check for stack only 2024-11-15 11:19:52 +08:00
kevlahnota
37eed29ad2 try this multimap for manapool 2024-11-15 11:08:17 +08:00
kevlahnota
dcd4fac927 update desktop logic 2024-11-15 09:51:04 +08:00
Anthony Calosa
66c08ab58b try to fix unsupportedoperation 2024-11-15 06:54:22 +08:00
Anthony Calosa
8dbb648638 add user setting for AI Timeout 2024-11-14 22:06:23 +08:00
Anthony Calosa
e2c37d11e7 AI Attack Timeout 2024-11-14 19:11:25 +08:00
tool4ever
ac96890f44 Some fixes (#6575) 2024-11-14 09:34:05 +00:00
kevlahnota
919832cc06 Update pom.xml
remove duplicate plugin
2024-11-14 16:11:14 +08:00
kevlahnota
e0d8b24412 Update ItemManagerConfig.java
use adventure default columns
2024-11-14 15:52:18 +08:00
kevlahnota
4ed7cb30d8 Update SColumnUtil.java
add adventure default columns
2024-11-14 15:51:11 +08:00
kevlahnota
88ca1d509f Update VAssignGenericAmount.java
support double tapping the mana symbols for max amount
2024-11-14 15:28:43 +08:00
Hans Mackowiak
8021520692 moved GameEventCardForetold and GameEventCardPlotted to GameLogFormatter 2024-11-14 07:09:21 +01:00
kevlahnota
9504705cd1 Merge pull request #6576 from Card-Forge/kevlahnota-patch-1
Update snapshots-android.yml
2024-11-14 13:07:08 +08:00
kevlahnota
bf24813aa7 update local-dir 2024-11-14 11:59:14 +08:00
kevlahnota
4248d1930e Update snapshots-android.yml 2024-11-14 11:54:34 +08:00
Anthony Calosa
58e4b7e2df Merge remote-tracking branch 'origin/CrypticSpire' into CrypticSpire 2024-11-14 10:31:11 +08:00
Anthony Calosa
b161502595 update setting colorID 2024-11-14 10:30:33 +08:00
kevlahnota
65c74b2009 Merge branch 'master' into CrypticSpire 2024-11-14 09:05:37 +08:00
Anthony Calosa
8d9dabf7d7 remove uncommited changes 2024-11-14 06:06:26 +08:00
Anthony Calosa
60cfd97162 remove unused imports 2024-11-14 06:02:38 +08:00
Anthony Calosa
71ecf91bb5 from list to set 2024-11-14 06:00:02 +08:00
Anthony Calosa
85913a3d6c load from deck 2024-11-13 23:42:08 +08:00
Jetz
c347ff5810 Merge remote-tracking branch 'origin/master' into code-cleanup
# Conflicts:
#	forge-core/src/main/java/forge/StaticData.java
2024-11-13 09:20:00 -05:00
Jetz
e879abca85 Merge remote-tracking branch 'origin/master' into code-cleanup 2024-11-13 09:17:45 -05:00
Jetz
d81c5a40cf Revert .toList() for Android compatibility 2024-11-13 09:17:33 -05:00
Anthony Calosa
88613c555a refactor some vars, and save to deck file
todo validate
2024-11-13 22:13:18 +08:00
Paul Hammerton
319a00d59e Alchemy Rebalancing for November 12, 2024 (#6568) 2024-11-13 14:20:32 +01:00
Anthony Calosa
4012469910 refactor var name 2024-11-13 19:12:34 +08:00
Hans Mackowiak
af545d69da Update nazar_the_velvet_fang.txt
Closes #6565
2024-11-13 09:45:07 +01:00
Hans Mackowiak
ea3806d7b6 Update lunar_insight.txt
Closes #6572
2024-11-13 09:43:56 +01:00
Anthony Calosa
f7dfdea361 update clone and copy effect 2024-11-13 14:13:16 +08:00
Anthony Calosa
f814292de7 update comment 2024-11-13 13:45:09 +08:00
Anthony Calosa
8fd521b949 update desktop editor 2024-11-13 13:43:47 +08:00
Agetian
93fd2dcf1c Attempt to fix Warlord's Elite AI payment (#6560)
* - Attempt to fix Warlord's Elite AI payment.

* - Add the workaround AI hint for now.
2024-11-13 07:48:27 +03:00
Anthony Calosa
31abd61a3f fix render for ImageView 2024-11-13 11:10:27 +08:00
Anthony Calosa
5afaff814a update deck editor for spire 2024-11-13 10:29:18 +08:00
kevlahnota
82555babd8 Update StaticData.java
remove concurrency for token audit
2024-11-12 22:48:15 +08:00
Anthony Calosa
65c5985281 add TODO 2024-11-12 22:14:11 +08:00
kevlahnota
38b098e5a4 Update AndroidRKeyboardHeightProvider.java 2024-11-12 21:28:53 +08:00
Anthony Calosa
eaab0bdd7d fix Cryptic Spire 2024-11-12 21:21:49 +08:00
Alexander Kim
fb0e147726 Update urdnan_dromoka_warrior.txt
Removed the "Flying" keyword from Urdnan, Dromoka Warrior; this keyword does not seem to appear on the card (source: https://scryfall.com/card/j25/34/urdnan-dromoka-warrior).
2024-11-12 09:26:21 +01:00
Paul Hammerton
334790846a Merge pull request #6567 from paulsnoops/bar_12_nov
Banned and Restricted Announcement for November 12, 2024
2024-11-11 19:19:12 +00:00
Paul Hammerton
2e4f2836f4 Banned and Restricted Announcement for November 12, 2024 2024-11-11 19:13:59 +00:00
kevlahnota
d7fd20ec5f add note 2024-11-11 23:49:26 +08:00
kevlahnota
1dc5c582f8 Merge pull request #6564 from kevlahnota/master2
Support older Android
2024-11-11 23:42:41 +08:00
Anthony Calosa
71480e63df Support older Android
- missing toList from stream
2024-11-11 23:36:54 +08:00
kevlahnota
cc346ca600 Merge pull request #6563 from kevlahnota/master2
update auditer
2024-11-11 21:41:03 +08:00
Anthony Calosa
2e9c685f26 Merge branch 'master' into master2 2024-11-11 20:17:04 +08:00
Anthony Calosa
cb2ddf39f8 update auditer 2024-11-11 17:00:04 +08:00
Agetian
365d9b995c - Added puzzle PS_DSK4. (#6561) 2024-11-10 20:40:05 +03:00
Chris H
9435ca6edc Create remove-stale-branches.yml 2024-11-10 08:53:06 -05:00
Chris H
bc3c847332 Remove cron from double snapshots 2024-11-09 19:06:42 -05:00
Paul Hammerton
1fd6da4813 Merge pull request #6552 from paulsnoops/edition-updates
Edition updates: PMEI, SLD
2024-11-09 10:23:04 +00:00
Paul Hammerton
7a4fc4ddd2 Edition updates: PMEI, SLD 2024-11-09 10:19:34 +00:00
kevlahnota
c25746b6c4 Merge pull request #6550 from kevlahnota/master2
update watermark
2024-11-09 10:36:05 +08:00
Anthony Calosa
b130f45fe1 update watermark
- show watermark on catalogpage only
2024-11-09 10:17:40 +08:00
Jetz
2b5fc37232 Remove unused imports 2024-11-08 20:02:02 -05:00
Jetz
c6ad1226b0 Guava migration - Swap in StreamUtil.stream 2024-11-08 19:49:03 -05:00
Jetz
6b7ac1ebef Guava migration - Use Arrays.stream() 2024-11-08 19:34:02 -05:00
Jetz
4bbc165460 Guava migration - Use .toList() 2024-11-08 19:33:45 -05:00
kevlahnota
05b18b34aa Merge pull request #6549 from kevlahnota/master2
fix SealedScreen
2024-11-09 08:24:52 +08:00
Jetz
7bb8ccd022 Remove unused imports 2024-11-08 19:23:28 -05:00
Jetz
c9ba926f45 Guava migration - Replace .negate() with Predicate.not(...) in compound predicates. 2024-11-08 19:21:25 -05:00
Anthony Calosa
ac15b32f32 fix SealedScreen
bind directly the back button to open the LoadSealedScreen on Sealed Editor
2024-11-09 08:21:19 +08:00
Jetz
903d636f52 Merge remote-tracking branch 'origin/code-cleanup' into code-cleanup 2024-11-08 18:41:17 -05:00
Jetz
d6c8e9a692 Merge remote-tracking branch 'origin/master' into code-cleanup
# Conflicts:
#	forge-ai/src/main/java/forge/ai/ability/ChooseCardAi.java
#	forge-ai/src/main/java/forge/ai/ability/ScryAi.java
#	forge-core/src/main/java/forge/card/DeckHints.java
#	forge-core/src/main/java/forge/util/TextUtil.java
#	forge-gui-mobile/src/forge/itemmanager/ItemManager.java
#	forge-gui/src/main/java/forge/download/AutoUpdater.java
#	forge-gui/src/main/java/forge/player/HumanCostDecision.java
2024-11-08 18:37:02 -05:00
kevlahnota
f47870a698 Update CCombat.java
- closes #6548
2024-11-09 06:34:47 +08:00
Agetian
98611a24b7 AI for Evolved Sleeper (#6547) 2024-11-08 15:10:14 +00:00
Agetian
ee43570ad9 - Add FDN planeswalker achievement by Marek. (#6546) 2024-11-08 08:07:13 +03:00
Simisays
73c3dd3def Jumpstart 2025 format + new dragon hero sprite + better avatars (#6544)
* update

* Update blocks.txt

* cleanup
2024-11-08 07:17:24 +03:00
kevlahnota
b400e612b4 Merge pull request #6545 from kevlahnota/master2
fix room choicelist render
2024-11-08 10:39:23 +08:00
Anthony Calosa
e9e14360f7 fix room choicelist render 2024-11-08 10:31:15 +08:00
Sagar
9d2c85f4ee Add back to top button to Wiki (#6427)
* Revamp Readme for more appealing

* revert back to top button only
2024-11-07 12:31:46 -05:00
kevlahnota
beb658ae99 Update electroduplicate.txt
- closes #6543
2024-11-07 14:57:43 +08:00
kevlahnota
216e3df533 Merge pull request #6542 from kevlahnota/master2
add confirm to autoSell, update ImageView
2024-11-07 14:23:59 +08:00
Anthony Calosa
4abcb0959a Merge branch 'master' into master2 2024-11-07 14:02:17 +08:00
Anthony Calosa
2ada458bf5 update filter description, add prompt option 2024-11-07 13:46:08 +08:00
Anthony Calosa
66e64995e3 add confirm dialog to autosell 2024-11-07 11:51:06 +08:00
Anthony Calosa
95ca1673b8 update ImageView
show NoSell overlay
2024-11-07 10:34:34 +08:00
kevlahnota
cd4b2a02e5 Merge pull request #6541 from kevlahnota/master2
fix sellAll
2024-11-06 23:24:58 +08:00
Anthony Calosa
7f7248f825 fix sellAll 2024-11-06 23:24:01 +08:00
Paul Hammerton
e7e5f4d9a7 Merge pull request #6540 from paulsnoops/master
Edition updates: FDN, J25, PLG24, PMEI
2024-11-06 13:41:45 +00:00
kevlahnota
9db592b10a Merge pull request #6539 from kevlahnota/master2
prevent townPriceModifier NPE
2024-11-06 21:35:00 +08:00
Anthony Calosa
a8bc8d42e1 format 2024-11-06 21:30:43 +08:00
Paul Hammerton
eed723bde2 Edition updates: FDN, J25, PLG24, PMEI 2024-11-06 13:30:37 +00:00
Anthony Calosa
6b31d101db prevent townPriceModifier NPE 2024-11-06 21:29:38 +08:00
kevlahnota
a140570752 Merge pull request #6538 from kevlahnota/master2
update adventure store/event preview filters
2024-11-06 20:15:50 +08:00
Anthony Calosa
e16468ad84 Merge branch 'master' into master2 2024-11-06 20:11:45 +08:00
Anthony Calosa
d85d00fbfb include ADVENTURE_SIDEBOARD config 2024-11-06 20:11:06 +08:00
Anthony Calosa
07d653d99b update adventure store/event preview filters 2024-11-06 19:47:33 +08:00
kevlahnota
307cf5a908 Merge pull request #6537 from kevlahnota/master2
update format filters for Adventure Deck Editor
2024-11-06 13:26:42 +08:00
Anthony Calosa
13eef9434f update filters 2024-11-06 13:14:22 +08:00
Anthony Calosa
0a3d2202c0 update item manager 2024-11-06 12:31:13 +08:00
Anthony Calosa
026913eebe Merge branch 'master' into master2
# Conflicts:
#	forge-gui-mobile/src/forge/adventure/scene/AdventureDeckEditor.java
2024-11-06 10:53:31 +08:00
kevlahnota
e59368422e update translation, remove duplicate single quote 2024-11-05 21:33:47 -05:00
Chris H
9f07bc9a98 Return false instead of throw if an illegal draft choice is made 2024-11-05 21:33:47 -05:00
Anthony Calosa
eb3b620858 update adventure editor default itemConfig 2024-11-06 06:10:22 +08:00
Anthony Calosa
a242f1fe04 update format filters for Adventure Deck Editor
use FormatFilter to filter Collections, AutoSell and NoSell cards
2024-11-05 22:56:47 +08:00
Paul Hammerton
fe52690f17 Merge pull request #6536 from paulsnoops/fix-fdn-edition
Fix FDN edition for boosters
2024-11-05 10:31:55 +00:00
Paul Hammerton
fa63d99d05 Fix FDN edition for boosters 2024-11-05 10:23:23 +00:00
Paul Hammerton
bb2b73d66f Merge pull request #6535 from paulsnoops/edition-updates
Edition updates: FDN
2024-11-05 09:39:41 +00:00
Paul Hammerton
d189a03550 Edition updates: FDN 2024-11-05 09:34:33 +00:00
Hans Mackowiak
a037532cb6 Merge pull request #6533 from Card-Forge/fdn-new-release
Fdn edition stuff
2024-11-05 09:51:58 +01:00
kevlahnota
e9ad6ef63e Merge pull request #6534 from kevlahnota/master2
reuse headerLabel as marker for loot
2024-11-05 15:49:05 +08:00
Anthony Calosa
46c502942b Merge branch 'master' into master2 2024-11-05 15:41:25 +08:00
Anthony Calosa
5d057837ff reuse headerLabel as marker for loot 2024-11-05 15:32:30 +08:00
Chris H
a71f57de3a Foundations new set things 2024-11-04 22:11:42 -05:00
Chris H
0e5303b84e Migrate upcoming 2024-11-04 21:39:55 -05:00
Paul Hammerton
bc6d78c376 Merge pull request #6511 from paulsnoops/combine-ue-into-da1
Combine Unknown Event editions into DA1
2024-11-04 19:01:16 +00:00
kevlahnota
fde2cd4538 Merge pull request #6529 from Card-Forge/kevlahnota-patch-1
Update QuestDataIO.java
2024-11-04 19:59:18 +08:00
tool4ever
41a3b24aef Fix Windfall (#6530) 2024-11-04 11:27:51 +01:00
kevlahnota
d8b86eb606 Update QuestDataIO.java
add EnumMap converter
2024-11-04 12:30:52 +08:00
tool4ever
fe259dafd2 Update fleeting_reflection.txt
Closes #6525
2024-11-03 15:46:11 +00:00
kevlahnota
fc1ba62078 Merge pull request #6523 from kevlahnota/master2
refactor HeroListData, update CoverScreen
2024-11-03 21:29:06 +08:00
Anthony Calosa
87d242028f refactor HeroListData, update CoverScreen
- remove redundant autosave
2024-11-03 21:24:20 +08:00
tool4ever
3e49ec6c88 Fix unattach logic (#6522) 2024-11-03 09:14:17 +00:00
Michael Lo
ecce3ab139 Add info about plotted cards into the game log (#6516) 2024-11-03 08:55:56 +00:00
Paul Hammerton
4fd6b3eff5 Merge pull request #6521 from paulsnoops/fdn-formats
Format updates for FDN & J25
2024-11-03 08:27:28 +00:00
Paul Hammerton
fb4dd87339 fdc_leg_vin 2024-11-03 08:23:58 +00:00
Paul Hammerton
c050d04881 j25_historic 2024-11-03 08:21:54 +00:00
Paul Hammerton
2a9960ca2b Add FDN & J25 to formats 2024-11-03 08:18:32 +00:00
kevlahnota
b179366bdd Merge pull request #6520 from kevlahnota/master2
update VCardDisplayArea, VZoneDisplay
2024-11-03 15:40:05 +08:00
Anthony Calosa
2d85fd845e update teleport animation 2024-11-03 15:27:30 +08:00
Anthony Calosa
5e326ef91a Merge branch 'master' into master2 2024-11-03 13:22:57 +08:00
Anthony Calosa
74f9d05b08 update NPE prevention 2024-11-03 12:14:43 +08:00
Anthony Calosa
4a1bbdc3ba update VZoneDisplay 2024-11-03 10:15:29 +08:00
Anthony Calosa
0ddf5b25d7 refactor VCardDisplayArea, prevent NPE 2024-11-03 10:07:14 +08:00
Chris H
2e7d4e3848 Return false instead of throw if an illegal draft choice is made 2024-11-02 21:57:37 -04:00
kevlahnota
09a1e6ecaf Merge pull request #6517 from kevlahnota/master2
add missing translation, minor speedup generating map
2024-11-03 06:27:51 +08:00
Anthony Calosa
68a5cb6c82 Merge branch 'master' into master2 2024-11-03 06:10:58 +08:00
Anthony Calosa
b01a155aa1 add missing 2024-11-03 06:04:45 +08:00
Fulgur14
9a7a8d7719 Update slinza_the_spiked_stampede.txt (#6515) 2024-11-02 22:01:56 +00:00
Anthony Calosa
c6aecafe6b add missing translation, minor speedup generating map 2024-11-03 05:58:28 +08:00
Agetian
343f09157d - Improve AI for Scry when X payment is necessary. (#6506) 2024-11-02 17:52:57 +03:00
Paul Hammerton
bdcf8ecb87 Merge pull request #6512 from paulsnoops/fix-strix-lookout
Fix Strix Lookout
2024-11-02 12:00:38 +00:00
Paul Hammerton
5ab34cf068 Combine Unknown Event editions into DA1 2024-11-02 11:59:45 +00:00
Paul Hammerton
ac935b92f6 Fix Strix Lookout 2024-11-02 11:55:27 +00:00
kevlahnota
6a12c12473 Merge pull request #6510 from kevlahnota/master2
fix newgame/newgame plus entering spawn point
2024-11-02 19:50:00 +08:00
Anthony Calosa
fa74a3b01c fix newgame/newgame plus entering spawn point 2024-11-02 19:45:01 +08:00
Paul Hammerton
58aacb07a8 Merge pull request #6509 from paulsnoops/edition-updates
Edition updates: FDN
2024-11-02 10:20:12 +00:00
Paul Hammerton
db940973c3 Edition updates: FDN 2024-11-02 10:15:46 +00:00
Fulgur14
9017c82f3e Final baker's dozen of FDN cards (#6507) 2024-11-02 08:31:41 +00:00
kevlahnota
6e961ac64e Merge pull request #6508 from kevlahnota/master2
fix infinite collision on Worldstage
2024-11-02 15:15:33 +08:00
Anthony Calosa
55d945857a fix format 2024-11-02 14:23:29 +08:00
Anthony Calosa
660a16a772 fix infinite collision on Worldstage
- closes #6485
2024-11-02 14:20:36 +08:00
Eli
396163a3de Added script text for Squad Rallier and Stab cards. (#6503)
* Added script text for Squad Rallier and Stab cards.

* Corrected script on Squad Rallier card; removed pump.
2024-11-02 07:22:17 +03:00
kevlahnota
097573d62d Merge pull request #6504 from kevlahnota/master2
move key indicators
2024-11-02 11:12:36 +08:00
Anthony Calosa
8d9f17fbac move key indicators 2024-11-02 11:08:30 +08:00
Fulgur14
a07db9168b Another dozen of FDN cards, nearing the end (#6502) 2024-11-01 21:16:47 +00:00
Paul Hammerton
aafa3a9b9f Merge pull request #6501 from paulsnoops/fix-hungry-ghoul
Fix Hungry Ghoul
2024-11-01 17:48:56 +00:00
Paul Hammerton
670c34a2c2 Fix Hungry Ghoul 2024-11-01 17:45:12 +00:00
Paul Hammerton
24b7373888 Merge pull request #6500 from paulsnoops/edition-updates
Edition updates: FDN, J25, PLTC
2024-11-01 17:34:03 +00:00
Paul Hammerton
6f344b729a Edition updates: FDN, J25, PLTC 2024-11-01 17:30:50 +00:00
Chris H
473a65f9ba Fix crash when a player dies with a card on the stack 2024-11-01 12:44:47 -04:00
Paul Hammerton
7a91e18e2d Merge pull request #6496 from Fulgur14/Fulgur14-patch-887518
Another fresh dozen of FDN cards
2024-11-01 10:49:56 +00:00
Paul Hammerton
b0f6484cbe Merge pull request #6497 from Fulgur14/Fulgur14-patch-946255
Four more FDN cards
2024-11-01 10:48:34 +00:00
Fulgur14
0a1cced6d7 Four more FDN cards 2024-11-01 10:47:59 +01:00
Fulgur14
826c631bd8 Another fresh dozen of FDN cards 2024-11-01 09:26:27 +01:00
tool4ever
28ff42c0a2 Update woodland_liege.txt 2024-11-01 06:42:19 +00:00
kevlahnota
0c676e8927 Merge pull request #6488 from kevlahnota/master2
increase allowance for update
2024-11-01 08:58:43 +08:00
Anthony Calosa
7f16956942 increase allowance for update 2024-11-01 08:57:49 +08:00
kevlahnota
0cb495d65a Merge pull request #6487 from kevlahnota/master2
prevent NPE
2024-11-01 08:36:21 +08:00
Anthony Calosa
e227fb8237 Merge branch 'master' into master2 2024-11-01 08:23:35 +08:00
Anthony Calosa
ce1d4b6a58 update date check, fix version String 2024-11-01 08:17:11 +08:00
Anthony Calosa
43912cbbb2 prevent NPE 2024-11-01 06:52:18 +08:00
BigCrunch22
dded9a56e6 Update Oracle text of some cards (#6479) 2024-10-31 20:23:53 +00:00
tool4ever
6ae0862b0d Goodbye mandatory suspend casting (#6483)
* Fix Divine Resilience
2024-10-31 20:20:08 +00:00
Paul Hammerton
e849999b51 Merge pull request #6486 from paulsnoops/soulstone-sanctuary-fix
Fix Soulstone Sanctuary name
2024-10-31 18:27:56 +00:00
Paul Hammerton
c7bd807714 Fix Soulstone Sanctuary name 2024-10-31 18:24:14 +00:00
Paul Hammerton
0f6cf76aa1 Merge pull request #6484 from paulsnoops/edition-updates
Edition updates: FDN, J25, SPG
2024-10-31 17:36:23 +00:00
Paul Hammerton
5b73ac957b Edition updates: FDN, J25, SPG 2024-10-31 17:32:10 +00:00
Fulgur14
55a6f2b88d Final 10 FDN/J25 cards (for now) (#6481) 2024-10-31 16:55:02 +00:00
Chris H
f2cc07b309 Update star_athlete.txt (#6482) 2024-10-31 17:34:50 +01:00
Fulgur14
2acf72e809 Eighth dozen (this time just FDN) (#6480) 2024-10-31 14:45:23 +01:00
kevlahnota
399fca6418 Merge pull request #6477 from kevlahnota/master2
update keyboardinput, android pom and assets downloader
2024-10-31 21:03:03 +08:00
Anthony Calosa
c55c07b8dd update android bg, min spec 2024-10-31 20:45:20 +08:00
Anthony Calosa
52d77c6862 fix NPE and update keyboard visibility 2024-10-31 17:28:30 +08:00
Anthony Calosa
550f738833 update location for build.txt and version.txt 2024-10-31 13:33:55 +08:00
Anthony Calosa
1f369732e5 fix updater message 2024-10-31 13:29:38 +08:00
Anthony Calosa
4664ff441b Merge branch 'master' into master2 2024-10-31 11:56:28 +08:00
Anthony Calosa
cea913e03c update tmxmaploader 2024-10-31 11:50:12 +08:00
Anthony Calosa
00a401de0e try to fix keyboardinput 2024-10-31 06:51:08 +08:00
Fulgur14
76b58e3ba7 Seventh dozen of FDN/J25 cards (#6475) 2024-10-30 20:19:25 +00:00
Fulgur14
4a70a27cf9 The fifth dozen of FDN/J25 cards (#6472) 2024-10-30 19:34:17 +00:00
Fulgur14
2c9ee76860 Sixth dozen of FDN/J25 cards, brought to you by letter S (#6474) 2024-10-30 18:41:06 +00:00
Paul Hammerton
935c720ab5 Merge pull request #6473 from paulsnoops/edition-updates
Edition updates: FDN, FDC, J25, SPG
2024-10-30 16:16:33 +00:00
Paul Hammerton
4979622425 Edition updates: FDN, FDC, J25, SPG 2024-10-30 16:13:16 +00:00
Fulgur14
a1235a89de Fourth dozen of FDN/J22 cards (#6470) 2024-10-30 12:57:52 +01:00
kevlahnota
f3a8a64207 Enable sync 2024-10-30 18:09:33 +08:00
kevlahnota
567ca35a29 Missed quote 2024-10-30 17:30:16 +08:00
Chris H
5f5e871840 Add a toggle to reenable declaring combatant ordering (#6467)
* Add a toggle to reenable declaring combatant ordering

* update translation

---------

Co-authored-by: kevlahnota <anthonycalosa@gmail.com>
2024-10-30 12:27:25 +03:00
kevlahnota
bd6d69c764 Update snapshot-both-pc-android.yml 2024-10-30 16:52:36 +08:00
kevlahnota
6f41d8ac0c Merge pull request #6471 from kevlahnota/master2
fix filename
2024-10-30 16:41:15 +08:00
Anthony Calosa
eefc20a1ac fix filename 2024-10-30 16:37:06 +08:00
kevlahnota
f8e9c15c79 Merge pull request #6469 from Card-Forge/kevlahnota-patch-1
Create snapshot-both-pc-android.yml
2024-10-30 14:18:13 +08:00
kevlahnota
5a333623fd Create snapshot-both-pc-android.yml 2024-10-30 12:51:04 +08:00
kevlahnota
ab3b238b29 Merge pull request #6468 from kevlahnota/master2
fix ClassCastException
2024-10-30 12:13:34 +08:00
Anthony Calosa
c1e7e4a3c1 revert class name (still can't override androidapplication), disable keyboardprovider 2024-10-30 12:01:13 +08:00
Anthony Calosa
e34b6b55ec Merge branch 'master' into master2 2024-10-30 11:22:35 +08:00
Anthony Calosa
c25467eda8 fix ClassCastException
forge.app.Main cannot be cast to com.badlogic.gdx.backends.android.AndroidApplication
2024-10-30 11:16:21 +08:00
tool4ever
e49f0baa12 Fix AbilityResolves timing (#6464) 2024-10-29 20:45:59 +00:00
Fulgur14
d54b48ec1d Third dozen of FDN/J25 cards (#6463) 2024-10-29 20:44:44 +00:00
tool4ever
3569dd37f1 Rename emergent woodwurm.txt to emergent_woodwurm.txt 2024-10-29 20:32:25 +00:00
tool4ever
86e4f5b500 Rename emrakul's messenger.txt to emrakuls_messenger.txt 2024-10-29 20:31:48 +00:00
tool4ever
80010d5fb5 Update anep_vizier_of_hazoret.txt 2024-10-29 20:25:54 +00:00
Fulgur14
2de9e7f92c Another 12 FDN/J25 cards (#6461) 2024-10-29 17:17:06 +00:00
kevlahnota
be983bcb20 Merge pull request #6462 from kevlahnota/master2
fix timestamp differences on build.txt
2024-10-30 01:02:44 +08:00
Anthony Calosa
a2419137e1 fix timestamp differences on build.txt 2024-10-30 00:57:56 +08:00
tool4ever
4a08a6a4e0 Fix some scripts (#6460) 2024-10-29 14:17:36 +00:00
Paul Hammerton
d4e6a67285 Merge pull request #6458 from Fulgur14/Fulgur14-patch-938101
12 FDN/J25 cards
2024-10-29 13:14:31 +00:00
kevlahnota
5c18bd0684 Merge pull request #6459 from kevlahnota/master2
restore libgdx keyboardheightprovider without androidx
2024-10-29 21:01:41 +08:00
Anthony Calosa
12407a62af Merge branch 'master' into master2 2024-10-29 20:55:07 +08:00
Anthony Calosa
57ccf5dd9e restore libgdx keyboardheightprovider without androidx
- https://github.com/libgdx/libgdx/pull/7485
2024-10-29 20:44:01 +08:00
Fulgur14
085bee2f61 Update cat_collector.txt 2024-10-29 13:25:46 +01:00
Fulgur14
63a09acb9f Update billowing_shriekmass.txt 2024-10-29 13:18:02 +01:00
Fulgur14
a21283fe8f Update claws_out.txt 2024-10-29 13:16:33 +01:00
Fulgur14
40d1423681 Update battlesong_berserker.txt 2024-10-29 13:16:00 +01:00
tool4ever
de4b35cc1d King of the Oathbreakers should trigger for Changeling (Discord post) (#6453)
* Fix NPE with Street Spasm
2024-10-29 12:02:32 +00:00
Paul Hammerton
5db52c38ec Merge pull request #6455 from Fulgur14/Fulgur14-patch-197369
Update gate_colossus.txt
2024-10-29 11:08:44 +00:00
Fulgur14
bbe2b3565e 12 FDN/J22 cards 2024-10-29 12:04:12 +01:00
kevlahnota
3972f68fe6 Merge pull request #6457 from kevlahnota/master2
fix android filtering
2024-10-29 18:58:26 +08:00
Anthony Calosa
ea472ba708 Merge branch 'master' into master2 2024-10-29 18:57:56 +08:00
Anthony Calosa
c74b282ed2 fix android filtering 2024-10-29 18:56:20 +08:00
Paul Hammerton
9de1847005 Merge pull request #6456 from paulsnoops/edition-updates
Edition updates: FDC, J25, PW24
2024-10-29 10:17:37 +00:00
Paul Hammerton
0c20c34452 Edition updates: FDC, J25, PW24 2024-10-29 10:02:08 +00:00
Fulgur14
ea1a5cbada Update gate_colossus.txt 2024-10-29 10:15:59 +01:00
kevlahnota
489611c3c4 Merge pull request #6454 from kevlahnota/master2
fix android updater, add fallback to android check
2024-10-29 16:52:26 +08:00
Anthony Calosa
a31e568557 Merge branch 'master' into master2 2024-10-29 16:45:54 +08:00
Anthony Calosa
1ef0656495 fix android updater, add fallback to android check
- copy build.txt to assets (gdx.files.internal looks only inside assets folder)
2024-10-29 16:44:29 +08:00
Fulgur14
4ad0126e22 Add files via upload (#6446) 2024-10-29 08:23:29 +00:00
kevlahnota
b70df0d422 Merge pull request #6452 from kevlahnota/master2
prevent NPE
2024-10-29 14:54:14 +08:00
Anthony Calosa
b3c867e326 prevent NPE 2024-10-29 14:41:25 +08:00
kevlahnota
2370bff495 Merge pull request #6451 from kevlahnota/master2
fix assetsdownloader release parsing
2024-10-28 22:55:29 +08:00
Anthony Calosa
9eebd7edd9 Merge branch 'master' into master2 2024-10-28 20:24:14 +08:00
Paul Hammerton
eea0123bed Merge pull request #6450 from Fulgur14/Fulgur14-patch-849353
Ashroot Animist (FDN)
2024-10-28 12:16:25 +00:00
Anthony Calosa
037344755a update constant 2024-10-28 20:13:34 +08:00
Anthony Calosa
51e0f37a14 update constant name 2024-10-28 20:10:33 +08:00
Anthony Calosa
f663fc52dc update release parsing 2024-10-28 20:04:47 +08:00
Anthony Calosa
9d569b4538 fix missing filename 2024-10-28 19:42:22 +08:00
Anthony Calosa
ad9b6e57bd move hardcoded url to ForgeConstants 2024-10-28 19:27:41 +08:00
Fulgur14
4a3e8b56bd Ashroot Animist (FDN) 2024-10-28 11:51:44 +01:00
Paul Hammerton
2fce568b51 Merge pull request #6448 from Fulgur14/master-1
Four J25 legends with their tokens
2024-10-28 10:32:50 +00:00
Fulgur14
0352e775dd Update cynette_jelly_drover.txt 2024-10-28 11:29:56 +01:00
Paul Hammerton
2f1f9a4294 Merge pull request #6449 from Fulgur14/Fulgur14-patch-906307
Elvish Regrower (FDN)
2024-10-28 10:26:15 +00:00
Fulgur14
0f947aa1fb Elvish Regrower (FDN) 2024-10-28 11:08:33 +01:00
Fulgur14
0758536352 Add files via upload 2024-10-28 06:52:52 +01:00
Fulgur14
6f01202042 Add files via upload 2024-10-28 06:51:10 +01:00
kevlahnota
c62f1c8631 Merge pull request #6447 from kevlahnota/master2
check snapshot update by timestamp
2024-10-28 12:44:14 +08:00
Anthony Calosa
0b5c3c54bd don't process logs if snapsBuildDate is empty 2024-10-28 12:38:06 +08:00
Anthony Calosa
750d41a2d3 filter commit messages 2024-10-28 12:34:48 +08:00
Anthony Calosa
0bac8ea04d format message 2024-10-28 12:19:50 +08:00
Anthony Calosa
20db37477f missing space 2024-10-28 12:12:17 +08:00
Anthony Calosa
b807c604e3 update mobile timestamp check 2024-10-28 12:07:22 +08:00
Anthony Calosa
e97b77cc8f missing return 2024-10-28 11:49:08 +08:00
Anthony Calosa
a6ae8ef051 Merge branch 'master' into master2 2024-10-28 11:45:56 +08:00
Anthony Calosa
420f6964ff update desktop timestamp check 2024-10-28 10:51:17 +08:00
Simisays
c3c5e0f114 FDN 10 cards (#6434) 2024-10-27 18:54:20 +00:00
Fulgur14
587399c422 15 FDN/J25 cards (#6436) 2024-10-27 17:17:05 +00:00
Anthony Calosa
6d77e0cff4 check snapshot update by timestamp 2024-10-27 23:49:14 +08:00
kevlahnota
885f030bed Merge pull request #6443 from Card-Forge/kevlahnota-patch-4
Update snapshots-pc.yml
2024-10-27 20:19:19 +08:00
Paul Hammerton
6409c5a791 Merge pull request #6444 from paulsnoops/edition-updates
Edition updates: FDC, -PE24, PEWK
2024-10-27 08:57:27 +00:00
Paul Hammerton
43aed05ad2 Edition updates: FDC, -PE24, PEWK 2024-10-27 08:53:42 +00:00
kevlahnota
0f60951219 Update snapshots-pc.yml 2024-10-27 16:32:25 +08:00
TwentyToedToad
9097e607a2 Add Verdant Dread (YDSK) (#6352)
* Add Verdant Dread (YDSK)

* Update verdant_dread.txt

* Update verdant_dread.txt

* Update verdant_dread.txt

---------

Co-authored-by: tool4ever <therealtoolkit@hotmail.com>
2024-10-27 08:55:01 +03:00
TwentyToedToad
f5f2bc340c Add Crude Abattoir // Unsavory Kitchen (YDSK) (#6348)
* Add Crude Abattoir // Unsavory Kitchen (YDSK)

* Update crude_abattoir_unsavory_kitchen.txt

* Update crude_abattoir_unsavory_kitchen.txt

* Update crude_abattoir_unsavory_kitchen.txt

---------

Co-authored-by: tool4ever <therealtoolkit@hotmail.com>
2024-10-27 08:37:19 +03:00
kevlahnota
18d8817b7e Merge pull request #6442 from kevlahnota/master2
include build.txt
2024-10-27 13:25:20 +08:00
Anthony Calosa
b711b00640 include build.txt 2024-10-27 13:24:32 +08:00
kevlahnota
16b0bd2809 Merge pull request #6440 from kevlahnota/master2
refactor mobile ImageCache, ImageView, FChoiceList
2024-10-27 13:17:10 +08:00
Anthony Calosa
89bc9c126f update snapshot notification message 2024-10-27 13:00:39 +08:00
Anthony Calosa
609777cf60 Merge branch 'master' into master2 2024-10-27 11:41:26 +08:00
Anthony Calosa
9bde207575 add settings for snapshot notification, removed obsolote java 8 check 2024-10-27 11:39:28 +08:00
Anthony Calosa
720ac7f8ca fix uncommited changes 2024-10-27 09:38:53 +08:00
Anthony Calosa
6fb600e6fb refactor mobile ImageCache, ImageView, FChoiceList
removed method to generate borderless card since we used shader as default method
Texture, TextureRegion and other LibGDX objects that are disposable should be nonstatic
show Morph image on FChoiceList
2024-10-27 08:52:58 +08:00
TwentyToedToad
2169263662 Add Mothlight Processionist (YDSK) (#6340) 2024-10-26 20:12:02 +00:00
Fulgur14
57c0246f82 Qala, Ajani's Pridemate 2024-10-26 20:11:45 +00:00
TwentyToedToad
ef500b7cec Add Effie, Fast Learner (YDSK) (#6361) 2024-10-26 20:02:38 +00:00
Paul Hammerton
004bd9a142 Merge pull request #6439 from paulsnoops/edition-updates
Edition updates: J25
2024-10-26 20:04:30 +01:00
Paul Hammerton
654c757ad2 Edition updates: J25 2024-10-26 20:01:06 +01:00
Simisays
a42bf18b9c update (#6433) 2024-10-26 18:14:15 +03:00
Paul Hammerton
0c5766caae Merge pull request #6435 from paulsnoops/edition-updates
Edition updates: DFT, FDN, INR, PE24, SPG
2024-10-26 13:46:14 +01:00
Paul Hammerton
fce6afb9db Edition updates: DFT, FDN, INR, PE24, SPG 2024-10-26 13:39:22 +01:00
kevlahnota
007941fda3 Merge pull request #6431 from kevlahnota/master2
prevent NPE
2024-10-26 06:34:32 +08:00
Anthony Calosa
5d1e780beb prevent crash audit 2024-10-26 06:31:36 +08:00
Anthony Calosa
4ae88ae6ba update static 2024-10-26 06:27:30 +08:00
Anthony Calosa
4f23a6026e update prevent NPE 2024-10-26 06:23:14 +08:00
Anthony Calosa
e6e6a6e0a4 prevent NPE 2024-10-26 06:05:03 +08:00
kevlahnota
6362796df5 Merge pull request #6428 from kevlahnota/master2
fix GameLauncher
2024-10-25 19:57:43 +08:00
Anthony Calosa
6f3debba7a Merge branch 'master' into master2 2024-10-25 19:56:35 +08:00
Anthony Calosa
ca6c105aff move check 2024-10-25 19:50:44 +08:00
Anthony Calosa
e71193b69b fix GameLauncher 2024-10-25 19:45:42 +08:00
kevlahnota
bd3bf824ed Merge pull request #6424 from kevlahnota/master2
fix manifest entries, update autoupdater
2024-10-25 18:29:34 +08:00
Anthony Calosa
e9aed24c8b update rssreader dependency 2024-10-25 18:18:07 +08:00
Anthony Calosa
6334c9f922 update AtomReader, add support releaseTag on android 2024-10-25 18:03:46 +08:00
Anthony Calosa
1f05a5a295 update AtomReader, add support releaseTag on android 2024-10-25 17:43:35 +08:00
Anthony Calosa
07bb0e6fe3 update check for release tag 2024-10-25 17:32:05 +08:00
Anthony Calosa
9897c85559 use release tag for downloading latest github releases... 2024-10-25 17:24:48 +08:00
Anthony Calosa
dcbd25d00e move shaders to Shaders class 2024-10-25 13:26:57 +08:00
Anthony Calosa
cd82a74eb0 Merge branch 'master' into master2 2024-10-25 12:31:41 +08:00
Anthony Calosa
2f05168b81 force non immersive mode 2024-10-25 11:54:27 +08:00
Anthony Calosa
7c5aa5fd90 revert Changes.txt 2024-10-25 11:44:03 +08:00
Anthony Calosa
8c085bbd33 add mobile updater, update gdx natives 2024-10-25 11:41:06 +08:00
wcoldren
2585ad1cf6 fix: add executable permissions for .command files during installation
- Update install.xml to set 775 permissions for .command files in Script pack
- Add .command files to target directory copy tasks in pom.xml
- Allow macOS users to run Forge apps without manual chmod

This change ensures .command files receive proper executable permissions
during installation, matching the behavior of .sh files on Unix/Linux.
2024-10-24 18:43:46 -04:00
Agetian
a6ccbe0f1d - Add GameState support for unlocked doors. (#6426)
- Add puzzle PS_DSK3.
2024-10-24 20:01:43 +03:00
Anthony Calosa
a0c865b4b3 add snapshot notification button 2024-10-24 20:44:22 +08:00
Anthony Calosa
fa974504b9 format release notes 2024-10-24 18:38:24 +08:00
Anthony Calosa
bf3111ba03 update TextUtil 2024-10-24 18:26:56 +08:00
Anthony Calosa
7a976291ba add desktop RSSReader, update autoupdater 2024-10-24 18:12:04 +08:00
Agetian
d92cacae7f Various improvements to AI-related logic (Canopy lands, Ugin's Labyrinth, Zuran Orb, Pyrite Spellbomb, Eladamri) (#6418)
* - Improve AI for Canopy lands.
- Improve AI for Ugin's Labyrinth.

* - Pyrite Spellbomb: also don't sac immediately.

* - Improve AI for Eladamri, Korvecdal

* - Improve AI decision for Zuran Orb.

* - Cleaner implementation for Eladamri AI
- More generic implementation for SacToDraw AI that doesn't need a logic parameter

* - Fix imports

* - Cleaner implementation for Eladamri AI

* - Suggested code tweak
2024-10-24 12:31:23 +03:00
Anthony Calosa
b26d0db07e fix manifest entries
BuildInfo reflects correct version
2024-10-24 09:18:32 +08:00
kevlahnota
e28d041ede Merge pull request #6419 from Card-Forge/revert-6234-ok_shortcut
Revert "gui-desktop : add keyboard shortcut to press OK/Yes button"
2024-10-24 07:35:01 +08:00
kevlahnota
c593c812bc Merge pull request #6423 from kevlahnota/master2
update splash closing
2024-10-24 07:34:00 +08:00
Anthony Calosa
07d2d0a023 update splash closing 2024-10-24 07:30:16 +08:00
Chris H
76ac1e2534 Revert "gui-desktop : add keyboard shortcut to press OK/Yes button" 2024-10-23 12:57:32 -04:00
kevlahnota
f06c8c3881 finally renamed 2024-10-23 09:35:40 +08:00
kevlahnota
0de880c68d update rename script 2024-10-23 07:42:34 +08:00
kevlahnota
f7cd6426d5 single mv workflow 2024-10-23 07:15:11 +08:00
kevlahnota
f1961c0394 Update snapshots-pc.yml again 2024-10-23 07:00:03 +08:00
kevlahnota
8000e80c13 Update snapshots-pc.yml 2024-10-23 05:55:50 +08:00
kevlahnota
8568498b69 Merge pull request #6412 from kevlahnota/master2
display locked room, fix nonrotated card panels
2024-10-23 05:49:21 +08:00
kevlahnota
051ec47ff6 Merge pull request #6234 from Ayora29/ok_shortcut
gui-desktop : add keyboard shortcut to press OK/Yes button
2024-10-23 05:48:04 +08:00
kevlahnota
99b0c96bfd Merge pull request #6392 from CollinJ/master
Fix the SpellSmith missing some cards.
2024-10-23 05:47:16 +08:00
tool4ever
4f3dc5891a Update attack_in_the_box.txt
Closes #6416
2024-10-22 21:16:31 +00:00
Chris H
2bab2f6c2b Merge branch 'master' into ok_shortcut 2024-10-22 15:40:18 -04:00
CollinJ
a02a0a25fc Merge branch 'master' into master 2024-10-22 10:12:12 -07:00
Paul Hammerton
dd33f9a28a Merge pull request #6414 from paulsnoops/22bar
Ban Leyline of Resonance in Arena Standard archive
2024-10-22 16:53:08 +01:00
Paul Hammerton
65f72b25ed Ban Leyline of Resonance in Arena Standard archive 2024-10-22 16:48:34 +01:00
Anthony Calosa
310f0ea352 incorporate emptyroom 2024-10-22 23:28:49 +08:00
Anthony Calosa
f7f9943436 update code as suggested 2024-10-22 23:05:47 +08:00
Anthony Calosa
b9a06e14a4 update better fix and replace rotate transform to spiral image (so it will not conflict with the existing rotate transform) 2024-10-22 22:36:05 +08:00
Anthony Calosa
f2cb01677e Merge branch 'master' into master2 2024-10-22 21:50:53 +08:00
Anthony Calosa
1b3e3f7f7c display locked room, fix nonrotated card panels 2024-10-22 21:38:23 +08:00
Agetian
84965594d0 Further improvement to PeekAndRevealAi (fix AI paying 0 for X) (#6410)
* - Add puzzle PS_DSK2.

* - Fix PeekAndRevealAi not paying the X mana cost.

* - Further improvement to PeekAndRevelAi.
2024-10-22 14:07:13 +03:00
Paul Hammerton
9014e282cb Merge pull request #6409 from paulsnoops/edition-updates
Edition updates: FDN, PW24
2024-10-22 11:16:47 +01:00
Paul Hammerton
890c5f0b0d Merge pull request #6407 from Ayora29/fix_token_names
Fix tokens things
2024-10-22 11:11:59 +01:00
Paul Hammerton
e05d0de220 Edition updates: FDN, PW24 2024-10-22 11:11:30 +01:00
tool4ever
031cd4176d Fix logic for Henzie (#6402) 2024-10-22 10:14:43 +02:00
fanch
18b22279df Fix tokens things 2024-10-22 09:59:33 +02:00
tool4ever
9dd712c18c Update experimental_lab_staff_room.txt 2024-10-22 07:51:45 +02:00
kevlahnota
32b209b47b Merge pull request #6405 from kevlahnota/master2
update manifest
2024-10-22 11:47:03 +08:00
Anthony Calosa
c5a01eb5d1 update manifest 2024-10-22 11:34:06 +08:00
kevlahnota
d231af2cad Merge pull request #6404 from kevlahnota/master2
Fix NPE, add manifest entries to jar
2024-10-22 10:59:28 +08:00
Anthony Calosa
bfca273ca6 Merge branch 'master' into master2 2024-10-22 10:58:54 +08:00
Anthony Calosa
5a84c9c4f4 prevent NPE 2024-10-22 10:36:57 +08:00
Anthony Calosa
2aa6d9a6e6 add manifest entries to forge desktop/mobile jar
allow launching the jar without launcher if possible
2024-10-22 10:18:07 +08:00
Chris H
1536868d61 Fix snaps (#6403)
* Update snapshots-pc.yml

* Update snapshots-pc.yml

* Update snapshots-pc.yml
2024-10-21 21:55:05 -04:00
Anthony Calosa
1ab6d82f69 Merge branch 'master' into master2
# Conflicts:
#	.github/workflows/snapshots-pc.yml
2024-10-22 06:49:11 +08:00
Anthony Calosa
5305050546 update snapshot-pc workflow 2024-10-22 06:25:05 +08:00
Anthony Calosa
13f0cda7f6 update snapshot-android workflow 2024-10-22 06:14:09 +08:00
kevlahnota
1a815b4ed7 Merge pull request #6401 from Card-Forge/kevlahnota-patch-3
Update AudioClip.java
2024-10-22 00:21:46 +08:00
kevlahnota
b4bffe93f1 Update AudioClip.java
Surround audio clip with try catch, seems accessing audio in lwjgl3 produce invalidid, could be thread problem.
2024-10-22 00:15:27 +08:00
Hans Mackowiak
7a34369c5e Merge branch 'master' into code-cleanup 2024-10-21 17:57:21 +02:00
Anthony Calosa
21a738e616 delete version.txt if res folder is incomplete to allow redownload 2024-10-21 11:16:55 -04:00
Anthony Calosa
993578d695 try to fix permission check 2024-10-21 11:16:55 -04:00
Anthony Calosa
0d06258edb add info on permission 2024-10-21 11:16:55 -04:00
Anthony Calosa
ec9209ceb6 update permission, include shell script to archive 2024-10-21 11:16:55 -04:00
Anthony Calosa
9a36808611 pretty print xml 2024-10-21 11:16:55 -04:00
Anthony Calosa
fbf26efc60 update installer, restore the tar.bz2 archive along with the installer and try to grant permission on the shell executables. 2024-10-21 11:16:55 -04:00
Anthony Calosa
4273420da5 delete version.txt if res folder is incomplete to allow redownload 2024-10-21 22:53:56 +08:00
Anthony Calosa
91cfd1ff3a try to fix permission check 2024-10-21 21:56:23 +08:00
Anthony Calosa
05ce94d36f add info on permission 2024-10-21 20:43:54 +08:00
Anthony Calosa
f3aa3c53ed update permission, include shell script to archive 2024-10-21 20:35:24 +08:00
Anthony Calosa
6e9febdfc7 pretty print xml 2024-10-21 19:41:07 +08:00
Anthony Calosa
995336a764 update installer, restore the tar.bz2 archive along with the installer and try to grant permission on the shell executables. 2024-10-21 19:35:23 +08:00
kevlahnota
2814207390 Merge pull request #6399 from Card-Forge/kevlahnota-patch-2
Update snapshots-pc.yml
2024-10-21 18:14:18 +08:00
kevlahnota
a47d4e6a6c Update snapshots-pc.yml 2024-10-21 18:13:49 +08:00
Agetian
41c64b282a Fix AI paying 0 for PeekAndRevealAi (#6396)
* - Add puzzle PS_DSK2.

* - Fix PeekAndRevealAi not paying the X mana cost.
2024-10-21 12:33:47 +03:00
Anthony Calosa
e9fa2a5fea remove adventure-mac command (-XstartOnFirstThread isn't needed anymore to start on Mac) 2024-10-21 15:26:30 +08:00
Anthony Calosa
ca5b0683d1 update version code, remove redundant CURRENT_VERSION 2024-10-21 15:01:39 +08:00
CollinJ
94c75f1e71 Merge branch 'master' into master 2024-10-20 22:05:24 -07:00
kevlahnota
ece5772217 Merge pull request #6394 from kevlahnota/master2
fix updater versionstring
2024-10-21 12:58:19 +08:00
Anthony Calosa
59f672225d update 2024-10-21 12:41:26 +08:00
Anthony Calosa
7203eaa07a Merge branch 'master' into master2 2024-10-21 12:19:02 +08:00
Anthony Calosa
f82236cc4f fix updater versionstring 2024-10-21 12:14:17 +08:00
Chris H
2495b02c73 Merge pull request #6393 from Card-Forge/tehdiplomat-patch-4
Update snapshots-pc.yml
2024-10-20 23:08:17 -04:00
Chris H
33c85a4f0f Update snapshots-pc.yml
izpack needs to allow jar files
2024-10-20 23:07:11 -04:00
Chris H
4e48daeadb Merge pull request #6103 from kevlahnota/master2
Update Android build (SDK 35), Java 17, LibGDX 1.13.0
2024-10-20 22:55:10 -04:00
Anthony Calosa
1979c23389 update pom 2024-10-21 09:15:57 +08:00
Anthony Calosa
612473c1fb fix adventure-editor pom 2024-10-21 09:13:45 +08:00
Collin
5de234aacb Fix the SpellSmith missing some cards.
The main issues is that getAllCards returns a card list that is unique
by name. That menas each card only has a single rarity. In this case,
cards like "Forbidden Orchard" and "Choke" de-deuplicate to a version of
the card with 'S' rarity. This means that when filtering by rarity, the
'S' rarity will be filtered out.
Another similar issue is that when a card exists in multiple sets with
different rarities, you might filter to a set in which the card is 'R',
but the de-duped version in allCards has rarity 'U', so using the cardDB
to check the rarity to filter on doesn't work.

When filtering by a specific set, the solution is to use the rarity of
the card in that set.
When not filtering by a set but filtering by rarity, we have to address
the root cause of the de-duping.

WHen de-duping, I changed the logic to ignore 'S' rarities. This fixes
the rarity filter when not filtering by an edition (although if there
are multiple rarities you still have to kind of guess).
This has the side-effect of making the card image used something more
legible. Before 'Choke' de-duped to the MPS_AHK set which has illegible
text. By ignoring 'S' rarities, it not de-dups to 8ED.

More work could probably be done to improve de-duping, but perfect
correctness would probably involve de-duping only after filtering, which
is likely too slow.
2024-10-20 12:29:11 -07:00
Anthony Calosa
e833b9f400 use flatten plugin 2024-10-21 00:03:42 +08:00
Anthony Calosa
9cf06a04da remove slf4j-simple 2024-10-20 22:23:01 +08:00
Anthony Calosa
7bebf8732c Merge branch 'master' into master2 2024-10-20 21:56:30 +08:00
Jetz
e52a7b1a53 Remove unused imports 2024-10-20 09:35:52 -04:00
Jetz
c5be6f1b17 Merge branch 'master' into code-cleanup
# Conflicts:
#	forge-game/src/main/java/forge/game/GameEntityCounterTable.java
#	forge-game/src/main/java/forge/game/ability/effects/PumpEffect.java
#	forge-game/src/main/java/forge/game/staticability/StaticAbilityContinuous.java
2024-10-20 09:33:41 -04:00
Jetz
64609b0867 Add some helper methods to StreamUtil;
Rewrite `generateParticipants`
2024-10-20 09:26:36 -04:00
Anthony Calosa
5a1f864db0 fix dependency conflict 2024-10-20 21:19:13 +08:00
Paul Hammerton
5a3f2ed607 Merge pull request #6386 from dracontes/rb-sld-2-marvel
SLD: Marvel x MTG Superdrop
2024-10-20 13:30:03 +01:00
Anthony Calosa
7b714423d8 remove '-P' 2024-10-20 20:19:30 +08:00
Anthony Calosa
39c8a6af3e fix compilation 2024-10-20 20:09:29 +08:00
Anthony Calosa
426e63598f Merge branch 'master' into master2 2024-10-20 18:38:41 +08:00
Anthony Calosa
1f596668f2 cleanup 2024-10-20 18:36:48 +08:00
Anthony Calosa
d1be724896 create forge-installer 2024-10-20 18:27:14 +08:00
tool4EvEr
0186759bf7 Support Black Panther 2024-10-20 12:21:00 +02:00
tool4ever
98c0959d8f Fix Embodiment of Agonies counting Asmoranomardicadaistinaculdacar (#6388) 2024-10-20 10:02:48 +00:00
tool4EvEr
cf7aa54769 Support Captain America 2024-10-20 10:45:16 +02:00
Anthony Calosa
86b58ef479 update dependency 2024-10-20 04:28:09 +08:00
Anthony Calosa
8a7866da87 update plugins 2024-10-20 04:00:07 +08:00
Renato Filipe Vidal Santos
43434e4999 Update TypeLists.txt 2024-10-19 14:29:27 +01:00
Anthony Calosa
5bc364393a Merge branch 'master' into master2 2024-10-19 20:04:26 +08:00
Renato Filipe Vidal Santos
26281603bb Add files via upload 2024-10-19 13:02:10 +01:00
Renato Filipe Vidal Santos
28a42b116b Update iron_man_titan_of_innovation.txt 2024-10-19 12:43:00 +01:00
Renato Filipe Vidal Santos
84eb2f28f5 Update wolverine_best_there_is.txt 2024-10-19 12:42:36 +01:00
Renato Filipe Vidal Santos
0a8c925a71 Update captain_america_first_avenger.txt 2024-10-19 12:41:51 +01:00
Renato Filipe Vidal Santos
9fb4e6e359 Update black_panther_wakandan_king.txt 2024-10-19 12:41:08 +01:00
Renato Filipe Vidal Santos
b0cc6fc49f Add files via upload 2024-10-19 12:01:29 +01:00
Paul Hammerton
42893234b3 Merge pull request #6385 from paulsnoops/marvel_formats
Add Marvel SLD to Vintage & Legacy Archived formats
2024-10-19 10:38:23 +01:00
Paul Hammerton
d9d89e9c0d Add Marvel SLD to Vintage & Legacy Archived formats 2024-10-19 10:30:37 +01:00
Paul Hammerton
1d6d356e02 Merge pull request #6384 from paulsnoops/edition_updates
Edition updates: PSPL, SLD
2024-10-19 10:26:29 +01:00
Paul Hammerton
af5e4eab69 Edition updates: PSPL, SLD 2024-10-19 10:20:17 +01:00
Anthony Calosa
a953818a76 Merge branch 'master' into master2 2024-10-19 15:59:18 +08:00
Agetian
339b04c60a - Add puzzle PS_DSK2. (#6382) 2024-10-19 08:33:38 +03:00
Anthony Calosa
ce7a182911 minor cleanup 2024-10-19 12:39:42 +08:00
Anthony Calosa
677bb7b12c fix tags 2024-10-19 12:13:43 +08:00
Anthony Calosa
8ad1f41fef fix name 2024-10-19 12:09:01 +08:00
Anthony Calosa
7f0ce0b4e7 refactor module to map-editor, add gdx particle editor 2024-10-19 12:07:36 +08:00
kevlahnota
8ce2f61390 remove custom manifest entries 2024-10-19 07:19:50 +08:00
Anthony Calosa
a09de0294f replacer token -> mandatory.java.args 2024-10-19 07:05:10 +08:00
Anthony Calosa
0cdcdeaa49 Merge branch 'master' into master2 2024-10-19 03:08:41 +08:00
Ayora29
1e707dcdbf Merge branch 'master' into ok_shortcut 2024-10-18 20:09:06 +02:00
Paul Hammerton
4ee2af4e1e Merge pull request #6377 from Ayora29/fix_token_names
WOC : Fix token name
2024-10-18 17:33:12 +01:00
tool4ever
b2ec9c3a49 Update longhorn_firebeast.txt 2024-10-18 16:29:09 +00:00
Anthony Calosa
3455045f2e update scripts 2024-10-18 23:16:00 +08:00
fanch
a1de6fa6cc Revert "ZNC : Add token b_1_1_faerie_rogue_flying (from card "Notorious Throng")"
This reverts commit 7f09129683.
2024-10-18 16:20:04 +02:00
fanch
7f09129683 ZNC : Add token b_1_1_faerie_rogue_flying (from card "Notorious Throng") 2024-10-18 16:18:54 +02:00
fanch
e7ec681470 WOC : Fix token name w_1_1_pegasus_flying -> w_2_2_pegasus_flying 2024-10-18 16:12:31 +02:00
Ayora29
b080a337be Merge branch 'master' into ok_shortcut 2024-10-18 16:05:52 +02:00
fanch
be6f353867 Merge branch 'master' into ok_shortcut
# Conflicts:
#	forge-gui-desktop/src/main/java/forge/toolbox/FOptionPane.java
2024-10-18 15:47:10 +02:00
Anthony Calosa
548450eb1a unused import 2024-10-18 20:00:55 +08:00
Anthony Calosa
c1779a55d5 update to LibGDX 1.13.0, add ForgeAndroidApplication (modified AndroidApplication) 2024-10-18 19:44:30 +08:00
Anthony Calosa
e6caed4ced cleanup 2024-10-18 11:38:57 +08:00
Anthony Calosa
5f98543f6d test remove old build tools on modded android maven plugin 2024-10-18 11:28:56 +08:00
Anthony Calosa
e0639ba33a Merge branch 'master' into master2 2024-10-18 05:23:38 +08:00
Anthony Calosa
2ec505b01a test older build tools 2024-10-18 05:13:21 +08:00
TwentyToedToad
e6a62e54fc Add Enduring Friendship (YDSK) (#6354) 2024-10-17 20:26:18 +00:00
JMAilan
2571aff4c8 Constructed as default mode (#6358)
Co-authored-by: Agetian <stavdev@mail.ru>
2024-10-17 17:58:01 +02:00
fanch
e862f4d8ca MH2 : Fix token name u_1_1_bird_flying -> w_1_1_bird_flying 2024-10-17 17:56:23 +02:00
TwentyToedToad
95eb400b19 Add Chittering Illuminator (YDSK) (#6370)
* Add Chittering Illuminator (YDSK)
2024-10-17 17:55:12 +02:00
fanch
faaec84a8b MH2 : Fix token name u_1_1_bird_flying -> w_1_1_bird_flying 2024-10-17 17:08:28 +02:00
fanch
0d63692ec6 Merge branch 'master' of https://github.com/Ayora29/forge 2024-10-17 17:06:59 +02:00
fanch
ed2a4bf3bf MH2 : Fix token name u_1_1_bird_flying -> w_1_1_bird_flying 2024-10-17 17:05:39 +02:00
Anthony Calosa
8403bda70e Merge branch 'master' into master2 2024-10-17 22:37:36 +08:00
Anthony Calosa
b1ba4b2c4f fix 2024-10-17 22:33:30 +08:00
Anthony Calosa
bde1ebc990 update 2024-10-17 22:20:46 +08:00
Anthony Calosa
54a1995572 test list 2024-10-17 21:48:20 +08:00
TwentyToedToad
9281f89974 Add Eager Flameguide (YDSK) (#6350) 2024-10-17 15:27:13 +02:00
TwentyToedToad
0048f25db2 Add Wingbright Thief (YDSK) (#6368) 2024-10-17 15:25:58 +02:00
TwentyToedToad
65775f87b4 Add Mischievous Lookout (YDSK) (#6366) 2024-10-17 15:25:14 +02:00
TwentyToedToad
54396e7f71 Add Unnatural Summons (YDSK) (#6367) 2024-10-17 15:16:45 +02:00
TwentyToedToad
ace00aa5f8 Add Golden Sidekick (YDSK) (#6362) 2024-10-17 15:11:29 +02:00
Anthony Calosa
dc357461d8 test tmate 2024-10-17 21:09:08 +08:00
TwentyToedToad
d2d38d5d26 Add Soul Shredder (YDSK) (#6338) 2024-10-17 15:03:31 +02:00
Anthony Calosa
e7814ec6d1 test min 2024-10-17 21:02:47 +08:00
TwentyToedToad
c44e41b4d3 Add Ethrimik, Imagined Fiend (YDSK) (#6339) 2024-10-17 15:02:41 +02:00
Anthony Calosa
a5d1165214 test again 2024-10-17 20:55:15 +08:00
Anthony Calosa
1db465d17c test build-tools 2024-10-17 20:53:15 +08:00
Anthony Calosa
331366687e test platform-tools 2024-10-17 20:50:55 +08:00
Jetz
67cedada04 Merge branch 'master' into code-cleanup
# Conflicts:
#	forge-gui-mobile/src/forge/adventure/data/AdventureEventData.java
2024-10-17 08:25:39 -04:00
Anthony Calosa
b1bc765627 test permission 2024-10-17 20:23:54 +08:00
Jetz
9be2c3df8b Merge branch 'master' into code-cleanup 2024-10-17 08:23:36 -04:00
Anthony Calosa
57b1c9e0c8 test android root 2024-10-17 20:18:57 +08:00
Anthony Calosa
5b26688303 test without path 2024-10-17 19:54:43 +08:00
Anthony Calosa
97f9ce6b43 add test-build profile 2024-10-17 19:43:17 +08:00
Anthony Calosa
24638ecfce Merge branch 'master' into master2 2024-10-17 15:56:46 +08:00
Anthony Calosa
e7aad18787 remove test build 2024-10-17 15:48:02 +08:00
Anthony Calosa
5c419df8b5 update name 2024-10-17 15:36:38 +08:00
Anthony Calosa
e1e69a4897 test android workflow 2024-10-17 15:34:29 +08:00
TwentyToedToad
ea045f6a15 Add Glimmer Hoarder (YDSK) (#6333) 2024-10-17 09:08:56 +02:00
TwentyToedToad
4aa7f0a4fe Add Razor Demon (#6334) 2024-10-17 09:07:15 +02:00
TwentyToedToad
aedd3bc521 Add Housemeld (YDSK) (#6341) 2024-10-17 09:01:46 +02:00
TwentyToedToad
7c3f8b57f0 Add Fear of Ridicule (YDSK) (#6343) 2024-10-17 08:56:28 +02:00
TwentyToedToad
9d8df142b4 Add Replicating Terror (YDSK) (#6344) 2024-10-17 08:55:06 +02:00
TwentyToedToad
c3aa31cb98 Add Welcome the Darkness (YDSK) (#6346) 2024-10-17 08:53:50 +02:00
TwentyToedToad
fbde7dca06 Add Anugished Recollection (YDSK) (#6347) 2024-10-17 08:52:45 +02:00
TwentyToedToad
dc6be93b25 Add Wary Zone Guard (YDSK) (#6353) 2024-10-17 08:48:07 +02:00
TwentyToedToad
b5246c42cf Add Mangled Soulrager (YDSK) (#6364) 2024-10-17 08:35:55 +02:00
TwentyToedToad
47a8b72b2e Add Polterheist (YDSK) (#6365) 2024-10-17 08:33:46 +02:00
Jetz72
54ecbeef6e Fix IndexOutOfBoundsException in generateParticipants (#6359)
Co-authored-by: Jetz <Jetz722@gmail.com>
2024-10-17 08:03:11 +03:00
Simisays
db0e188fab Sorin tweaks (#6373)
* update

* Update enemies.json
2024-10-17 08:01:58 +03:00
Anthony Calosa
e2a6dfabe8 update version digits 2024-10-17 12:35:11 +08:00
Anthony Calosa
89c699b94d update android pom 2024-10-17 11:34:37 +08:00
Anthony Calosa
0420ad4ef2 Merge branch 'master' into master2
# Conflicts:
#	README.md
#	forge-gui-android/pom.xml
#	forge-gui-android/src/main/AndroidManifest.xml
2024-10-17 10:48:20 +08:00
Hans Mackowiak
f5b30a6826 removed version from AndroidManifest 2024-10-16 21:12:02 -04:00
Hans Mackowiak
94f1835462 ~ fix version pattern for android.manifest merger 2024-10-16 21:12:02 -04:00
Hans Mackowiak
0c5f7962e2 ~ update android-maven-plugin 2024-10-16 21:12:02 -04:00
Hans Mackowiak
23be0c568d AndroidManifest 2024-10-16 21:12:02 -04:00
VishalKeerthan
0edd7d9d87 Update README.md 2024-10-16 21:09:13 -04:00
VishalKeerthan
c05760bab8 Update README.md 2024-10-16 21:09:13 -04:00
Anthony Calosa
143f2d883f update start button colors 2024-10-17 05:42:26 +08:00
Anthony Calosa
c07329db42 Merge branch 'master' into master2 2024-10-17 05:33:20 +08:00
TwentyToedToad
28744ff211 Add Fear of Change (#6327) 2024-10-16 17:12:10 +02:00
Paul Hammerton
ed7ba03b5a Merge pull request #6363 from paulsnoops/slp_edition
Edition updates: SLP
2024-10-16 15:52:36 +01:00
Paul Hammerton
ffda686533 Edition updates: SLP 2024-10-16 15:37:11 +01:00
Paul Hammerton
f727371a12 Merge pull request #6360 from Ayora29/fix_token_names
Fix token name in C21
2024-10-16 15:28:30 +01:00
Anthony Calosa
be8b77bf06 update button colors 2024-10-16 22:04:44 +08:00
fanch
cbefaf1984 Fix token name g_4_4_phyrexian_beast -> g_4_4_fungus_beast_trample 2024-10-16 15:15:09 +02:00
Anthony Calosa
d66a7ba604 Merge branch 'master' into master2 2024-10-16 20:45:48 +08:00
Hans Mackowiak
a1f425a803 Merge pull request #6337 from nwg5817/rewardRaritySort
Adventure: Reward Scene Sort by Rarity
2024-10-16 13:13:32 +02:00
Hans Mackowiak
a07cee4e76 Merge pull request #6335 from nwg5817/boosterQoL
Adventure: Minor Booster Pack QoL Changes
2024-10-16 13:12:36 +02:00
Anthony Calosa
94d5fc62bd replace ${alpha-version} -> ${revision} 2024-10-16 18:16:19 +08:00
Anthony Calosa
059d7aae1b Merge branch 'master' into master2 2024-10-16 18:16:03 +08:00
tool4ever
9d04766d13 Script fixes (#6356) 2024-10-16 11:35:40 +02:00
Paul Hammerton
4d04e49bd9 Merge pull request #6357 from churrufli/netdecks161024
Net Decks Archive Updates
2024-10-16 10:21:47 +01:00
Churrufli
92ee722db6 Net Decks Archive Updates (Standard, Modern, Legacy, Vintage, Pioneer, Pauper) 2024-10-16 11:12:14 +02:00
Anthony Calosa
fe83488c21 Merge branch 'master' into master2 2024-10-16 15:12:56 +08:00
Fulgur14
d65dedb92a Update demonic_covenant.txt (#6355) 2024-10-16 08:32:43 +02:00
Anthony Calosa
9c44efc629 Merge branch 'master' into master2 2024-10-16 09:05:08 +08:00
Chris H
5f53b8995e Update tunnel_surveyor.txt 2024-10-15 20:47:04 -04:00
JMAilan
38d8761fe3 Merge branch 'master' into rewardRaritySort 2024-10-15 11:46:19 -04:00
JMAilan
965dd136bb Merge branch 'master' into boosterQoL 2024-10-15 11:36:57 -04:00
Meta
0a08650393 Booster QoL
Remove open confirmation and disable leaving inventory scene when opening boosters.

Change Booster Pack Inventory Name

Old:
Booster Pack: WAR

New:
War of the Sparks Booster

Final

Tweak
2024-10-15 11:26:00 -04:00
tool4ever
83dd00e294 Update furious_spinesplitter.txt
Closes #6332
2024-10-15 12:41:39 +00:00
Anthony Calosa
ed58a68128 Merge branch 'master' into master2 2024-10-15 19:16:13 +08:00
Anthony Calosa
a565eff5fb update phase for upload since signv2 will run on verify phase and it should finish first before uploading 2024-10-15 19:14:45 +08:00
tool4ever
ce70a3949f Update head_games.txt 2024-10-15 10:51:57 +00:00
tool4ever
8f7b782d6b Update experimental_lab_staff_room.txt 2024-10-15 10:47:26 +00:00
Agetian
1466346d72 - Add DSK alt wincon achievement by Marek. (#6331) 2024-10-15 09:50:38 +03:00
Anthony Calosa
8fc3b45b12 quick fix for black texture 2024-10-15 10:55:56 +08:00
Jetz
2d6952f126 Swap out lingering use of Iterables.any 2024-10-14 22:51:16 -04:00
Jetz
6b93e628ac Merge branch 'master' into code-cleanup
# Conflicts:
#	forge-ai/src/main/java/forge/ai/ComputerUtil.java
#	forge-core/src/main/java/forge/card/DeckHints.java
#	forge-game/src/main/java/forge/game/ability/AbilityFactory.java
#	forge-game/src/main/java/forge/game/cost/CostUntapType.java
#	forge-gui/src/main/java/forge/player/HumanCostDecision.java
2024-10-14 22:36:07 -04:00
Anthony Calosa
83df147d0e Merge branch 'master' into master2
# Conflicts:
#	forge-adventure/pom.xml
#	forge-ai/pom.xml
#	forge-core/pom.xml
#	forge-game/pom.xml
#	forge-gui-android/AndroidManifest.xml
#	forge-gui-android/pom.xml
#	forge-gui-desktop/pom.xml
#	forge-gui-ios/pom.xml
#	forge-gui-mobile-dev/pom.xml
#	forge-gui-mobile/pom.xml
#	forge-gui-mobile/src/forge/Forge.java
#	forge-gui/pom.xml
#	forge-lda/pom.xml
#	pom.xml
2024-10-15 10:29:23 +08:00
Jetz
31547c6bbb Merge branch 'master' into code-cleanup
# Conflicts:
#	forge-game/src/main/java/forge/game/phase/PhaseHandler.java
2024-10-14 22:20:44 -04:00
Meta
5b62a1ffb5 Fixed non-cards for rarity sorting
import
2024-10-14 21:56:30 -04:00
Chris H
0475f4bafa Manually update files that need to be updated 2024-10-14 21:53:45 -04:00
GitHub Actions
d366bf8ffc [maven-release-plugin] prepare for next development iteration 2024-10-14 21:53:45 -04:00
GitHub Actions
fa538bd5c9 [maven-release-plugin] prepare release forge-1.6.65 2024-10-14 21:53:45 -04:00
Fulgur14
3db4db0d07 Add files via upload 2024-10-14 19:30:33 -04:00
Chris H
932bfb9e33 Migrate DSK upcoming 2024-10-14 14:22:35 -04:00
Chris H
da712a5e49 Add Winter Cynical Opportunist (#6325) 2024-10-14 18:04:30 +00:00
TwentyToedToad
0fb2db556b Add Experimental Lab // Staff Room (#6324) 2024-10-14 17:32:34 +00:00
TwentyToedToad
b820d6b622 Update my_will_is_irresistible.txt 2024-10-14 11:58:29 -04:00
TwentyToedToad
79337dbf1f Update my_will_is_irresistible.txt 2024-10-14 11:58:29 -04:00
TwentyToedToad
1a6d0a4354 Add My Will Is Irresistible 2024-10-14 11:58:29 -04:00
Paul Hammerton
68bb0ebd39 Fix Demonic Covenant (#6326) 2024-10-14 15:49:13 +00:00
Anthony Calosa
4af8061824 Merge branch 'master' into master2 2024-10-14 20:46:23 +08:00
Paul Hammerton
cc3b2a20ce Merge pull request #6323 from paulsnoops/ydsk_formats
Add YDSK to formats
2024-10-14 13:24:32 +01:00
Paul Hammerton
81faad08d4 Merge pull request #6322 from paulsnoops/edition_updates
Edition updates: SLD, YDSK
2024-10-14 13:22:05 +01:00
Paul Hammerton
c31b26a13d Add YDSK to formats 2024-10-14 13:21:03 +01:00
Paul Hammerton
efd883ef12 Edition updates: SLD, YDSK 2024-10-14 13:17:13 +01:00
tool4ever
b6f118f89b Fear of Sleep Paralysis and support (#6287) 2024-10-14 10:55:00 +00:00
tool4ever
8f33da5b9c AI aura targeting fix (#6320) 2024-10-14 10:23:18 +00:00
tool4ever
90adf4b0cb Update struggle_for_project_purity.txt 2024-10-14 06:38:01 +00:00
tool4ever
0df84b91f2 Support recursive check for tokens that create others (#6315) 2024-10-14 06:33:41 +00:00
tool4ever
2a5fa9d0a5 Fix CardZoneTable not using the LastStates before moving (#6291) 2024-10-14 08:05:24 +02:00
Anthony Calosa
12d2ec89f7 update android pom -> run signv2 on verify phase, fix versin string 2024-10-14 11:02:54 +08:00
Anthony Calosa
1e2d66f574 Merge branch 'master' into master2
# Conflicts:
#	README.md
2024-10-14 09:56:34 +08:00
Dnaynu
6859380e9e Docs: Typo fix
Corrected "[enviroment]" to "[environment]" in [README.md].

This pull request addresses a minor typo found in repository. The typo has been corrected to improve clarity and maintain the quality of the documentation.

This change is purely cosmetic and does not affect functionality.
2024-10-13 20:09:09 -04:00
Anthony Calosa
00e81d20dd Merge branch 'master' into master2 2024-10-14 06:06:40 +08:00
Chris H
8669859706 Accidentally pushed 2024-10-13 17:33:05 -04:00
Chris H
c948355f12 Add new set things 2024-10-13 17:20:02 -04:00
tool4ever
dc5cef1446 Update dreams_of_steel_and_oil.txt 2024-10-13 15:34:57 +00:00
tool4ever
bd659a1e44 Update defiled_crypt_cadaver_lab.txt 2024-10-13 15:32:42 +00:00
tool4EvEr
036e6ec1bf Ghostly Dancers and support 2024-10-13 11:03:02 -04:00
tool4ever
9568abc6f4 Update kraul_harpooner.txt 2024-10-13 11:50:01 +00:00
Renato Filipe Vidal Santos
31a1f05d51 Edit pile cleanup: Line reordering, second pass: part 10, folders 'w' to 'z' 2024-10-13 11:14:44 +00:00
Renato Filipe Vidal Santos
5bf12ab4eb Edit pile cleanup: Line reordering, second pass: part 9, folders 't' to 'v' (#6312) 2024-10-13 11:13:59 +00:00
Renato Filipe Vidal Santos
7fc3e18ff5 Edit pile cleanup: Line reordering, second pass: part 8, folder 's' 2024-10-13 11:11:20 +00:00
Renato Filipe Vidal Santos
9766d4b1e5 Edit pile cleanup: Line reordering, second pass: part 7, folders 'r', 'rebalanced' 2024-10-13 11:10:34 +00:00
Renato Filipe Vidal Santos
2a342b7e3b Edit pile cleanup: Line reordering, second pass: part 6, folders 'o' to 'q' (#6309) 2024-10-13 11:10:02 +00:00
Renato Filipe Vidal Santos
2a1b8b4c93 Edit pile cleanup: Line reordering, second pass: part 5, folders 'l' to 'n' 2024-10-13 11:09:26 +00:00
Renato Filipe Vidal Santos
f538eb1ec3 Edit pile cleanup: Line reordering, second pass: part 4, folders 'h' to 'k' 2024-10-13 11:07:58 +00:00
Renato Filipe Vidal Santos
ae28cd17c0 Edit pile cleanup: Line reordering, second pass: part 3, folders 'e' to 'g' 2024-10-13 11:07:28 +00:00
Renato Filipe Vidal Santos
add0e812a2 Edit pile cleanup: Line reordering, second pass: part 2, folders 'c' to 'd' 2024-10-13 11:06:57 +00:00
Renato Filipe Vidal Santos
0e9c95e542 Edit pile cleanup: Line reordering, second pass: part 1, folders 'a' to 'b' (#6304) 2024-10-13 11:06:16 +00:00
Chris H
6b03f6909f Add Central elevator (#6292) 2024-10-13 08:45:41 +00:00
Renato Filipe Vidal Santos
0bf92af38b Edit pile cleanup: Line reordering, first pass: part 10, folder 'tokenscripts', part 6 2024-10-13 08:34:39 +00:00
Renato Filipe Vidal Santos
042638612e Edit pile cleanup: Line reordering, first pass: part 9, folder 'tokenscripts', part 5 2024-10-13 08:34:22 +00:00
Renato Filipe Vidal Santos
b494ad8cd1 Edit pile cleanup: Line reordering, first pass: part 8, folder 'tokenscripts', part 4 2024-10-13 08:34:01 +00:00
Renato Filipe Vidal Santos
a2901eeeb8 Edit pile cleanup: Line reordering, first pass: part 7, folder 'tokenscripts', part 3 2024-10-13 08:33:32 +00:00
Renato Filipe Vidal Santos
e826c976c7 Edit pile cleanup: Line reordering, first pass: part 6, folder 'tokenscripts', part 2 2024-10-13 08:33:00 +00:00
Renato Filipe Vidal Santos
2ef75ac2a3 Edit pile cleanup: Line reordering, first pass: part 5, folder 'tokenscripts', part 1 2024-10-13 08:32:17 +00:00
Renato Filipe Vidal Santos
b9ac2aeaf8 Edit pile cleanup: Line reordering, first pass: part 4, folders 'w' to 'z' 2024-10-13 08:31:21 +00:00
Renato Filipe Vidal Santos
e86769ead6 Edit pile cleanup: Line reordering, first pass: part 3, folders 'o' to 'v', 'rebalanced', 'upcoming' (#6296) 2024-10-13 08:30:46 +00:00
Renato Filipe Vidal Santos
f91a2dbf58 Edit pile cleanup: Line reordering, first pass: part 2, folders 'e' to 'n' 2024-10-13 08:29:20 +00:00
Renato Filipe Vidal Santos
8d264b1ae9 Edit pile cleanup: Line reordering, first pass: part 1, folders 'a' to 'd' 2024-10-13 08:27:51 +00:00
Anthony Calosa
2b08b57179 Merge branch 'master' into master2 2024-10-13 12:35:31 +08:00
loud1990
44e8f3f20f Added Smoky Lounge//Misty Salon DSK (#6289) 2024-10-12 18:49:40 +00:00
loud1990
1b4a41d5da Updated Enter The Enigma DSK (#6288)
Changed to Sorcery
2024-10-12 17:45:51 +02:00
tool4ever
60216dc214 Fix NPE when creating room token (#6281) 2024-10-12 06:57:15 +00:00
tool4ever
4d8e55842f Update rendmaw_creaking_nest.txt 2024-10-12 06:49:40 +00:00
Fulgur14
ba4ad308cf Update mine_is_the_only_truth.txt (#6268) 2024-10-11 19:15:36 +00:00
Fulgur14
f92901d570 Polluted Cistern // Dim Oubliette (#6284) 2024-10-11 19:10:09 +00:00
Anthony Calosa
353600042f Merge branch 'master' into master2 2024-10-11 20:30:45 +08:00
tool4ever
b6cfbe3fae Update unholy_annex_ritual_chamber.txt 2024-10-11 08:03:06 +02:00
tool4ever
e5f60ca83d Update rendmaw_creaking_nest.txt 2024-10-11 08:01:48 +02:00
tool4ever
5189313d4d Update oblivious_bookworm.txt (#6272) 2024-10-10 20:23:29 +00:00
loud1990
73513cf2c1 Updated 3 DSK Cards (#6270) 2024-10-10 18:45:46 +00:00
Renato Filipe Vidal Santos
1068ff3f1a Edit pile cleanup: part 5, folder 'upcoming' part 2 2024-10-10 15:05:08 +02:00
Renato Filipe Vidal Santos
4fc77be4df Edit pile cleanup: part 4, folder 'upcoming' part 1 (#6221) 2024-10-10 15:04:18 +02:00
Renato Filipe Vidal Santos
747ed18e16 Edit pile cleanup: part 6, folder 'upcoming' part 3 (#6223) 2024-10-10 15:03:29 +02:00
Anthony Calosa
1da3e298e1 Merge branch 'master' into master2 2024-10-10 19:34:39 +08:00
Anthony Calosa
3e8b4cc3ca remove redundant plugin 2024-10-10 19:26:00 +08:00
Anthony Calosa
ad81b0e32d auto update snapshot-version, snapshot-versionCode via regex property 2024-10-10 17:10:05 +08:00
Agetian
fddab97eea - Added puzzle PS_DSK1. (#6269) 2024-10-10 10:28:38 +03:00
TwentyToedToad
cca7db5654 Add Rendmaw Creaking Nest and supporting changes (#6265)
* Add Rendmaw Creaking Nest, supporting property numTypes, and black 2/2 bird flying token

* Updated accoring to PR requests

* Update rendmaw_creaking_nest.txt

* Added landplayed trigger

---------

Co-authored-by: loperjchris <christopher.loper1990@gmail.com>
2024-10-10 10:16:39 +03:00
TwentyToedToad
96d065189b Add Demonic Covenant and supporting changes (#6257)
* Add Demonic Covenant and supporting changes

* Updated changes

* Update demonic_covenant.txt

* Addressing PR comments

---------

Co-authored-by: loperjchris <christopher.loper1990@gmail.com>
2024-10-10 10:13:19 +03:00
TwentyToedToad
b251328873 Added Your Plans Mean Nothing (#6262)
* Added Your Plans Mean Nothing

Tested with teammates to ensure that if a teammate is targeted they do not get to draw cards but they do discard their hand.

* Update your_plans_mean_nothing.txt
2024-10-10 10:13:11 +03:00
tool4ever
6f9cb7c74d Fix Summary Dismissal (#6263) 2024-10-10 08:34:41 +02:00
TwentyToedToad
1bd54d2ca0 Add Mine Is the Only Truth (#6259) 2024-10-09 20:27:33 +00:00
TwentyToedToad
5f022923b0 Add Running Is Useless (#6261) 2024-10-09 19:39:20 +00:00
Fulgur14
73c40b620b Room scripts (#6253) 2024-10-09 18:54:39 +00:00
Anthony Calosa
28a28bfd68 fix compilation 2024-10-09 22:54:57 +08:00
Anthony Calosa
f278aa5613 fix lines 2024-10-09 22:15:06 +08:00
Anthony Calosa
371b700a1e update JVMOptions info 2024-10-09 22:13:41 +08:00
Anthony Calosa
abdff9bb15 update to SDK 35 (Android 15), update versionString 2024-10-09 21:25:29 +08:00
Anthony Calosa
644fa46681 Merge branch 'master' into master2 2024-10-09 16:44:29 +08:00
TwentyToedToad
e1452ef997 Add I Am Never Alone (#6258)
* Add I Am Never Alone

* Update i_am_never_alone.txt

* Update i_am_never_alone.txt

---------

Co-authored-by: loperjchris <christopher.loper1990@gmail.com>
2024-10-09 10:30:45 +03:00
Anthony Calosa
39f5632df1 fix flatten plugin location 2024-10-09 14:18:43 +08:00
Anthony Calosa
708fed3350 update and unified version code property 2024-10-09 12:32:09 +08:00
Jetz72
48adeb357d Show chosen mana for mana abilities as symbols (#6256)
* Support for icons in dialogs.
Mana abilities show chosen mana via icons.
Thread safety for showOptionDialog

* Ensure EventDispatchThread for showInputDialog

---------

Co-authored-by: Jetz <Jetz722@gmail.com>
2024-10-08 22:17:18 +03:00
TwentyToedToad
cbdbe1d62b Added Fear My Authority (#6255) 2024-10-08 16:53:07 +00:00
TwentyToedToad
5e3833436e Added Disorienting Choice (#6244) 2024-10-08 16:12:03 +02:00
tool4ever
fe0abb25a6 Support Torture Pit (#6254) 2024-10-08 15:09:10 +02:00
kevlahnota
cfd90362e2 add translation 2024-10-08 09:07:15 -04:00
Chris H
dd60a84f40 Add Spell Smith Insurance (reject smithing for 10% cost) 2024-10-08 09:07:15 -04:00
Marco F
69d8bf52d3 Fixed spell description of snakeskin_veil (#6250) 2024-10-08 13:48:34 +02:00
Fulgur14
443a28e786 Update demon_of_fates_design.txt (#6251) 2024-10-08 13:48:00 +02:00
Fulgur14
31bd6d87ed Update Eerie cards (#6252) 2024-10-08 13:46:50 +02:00
Paul Hammerton
9a4d7fd399 Merge pull request #6249 from paulsnoops/add_ydsk
Edition updates: YDSK
2024-10-08 09:45:25 +01:00
Paul Hammerton
6060cfa5ee Edition updates: YDSK 2024-10-08 09:38:20 +01:00
Hans Mackowiak
065cf48d35 Merge pull request #6246 from Card-Forge/opened-rooms
Add Rampaging Soulrager
2024-10-08 10:35:40 +02:00
Hans Mackowiak
28e2627020 Merge pull request #6243 from Ivniinvi/patch-1
Aerie Typo Fix
2024-10-08 10:34:39 +02:00
Hans Mackowiak
4d93a40a56 Merge pull request #6247 from paulsnoops/fix_primo
Fix Primo the Indivisible token
2024-10-08 10:33:58 +02:00
Paul Hammerton
c8e4a8bde5 Merge pull request #6248 from paulsnoops/sld_update
Edition updates: SLD
2024-10-08 09:29:35 +01:00
Anthony Calosa
f6f51b916a Merge branch 'master' into master2 2024-10-08 16:27:50 +08:00
Anthony Calosa
af22edaff5 Merge remote-tracking branch 'origin/master' 2024-10-08 16:26:11 +08:00
Anthony Calosa
af3ceb3348 fix crash when card defined is missing or invalid
these card should be replaced or create a custom card for adventure mode
Power Struggle, Necropolis of Azar
2024-10-08 16:25:52 +08:00
Paul Hammerton
89f499baae Edition updates: SLD 2024-10-08 09:20:04 +01:00
Paul Hammerton
93d381a7ee Fix primo the Indivisible token 2024-10-08 09:14:39 +01:00
Paul Hammerton
e771ca43d8 Merge pull request #6242 from Simisays/ROOMBIS
DSK 10 Room cards
2024-10-08 08:52:03 +01:00
Anthony Calosa
7b310ae2ac Merge branch 'master' into master2 2024-10-08 13:08:38 +08:00
Chris H
ca9f6c2f8d Add Rampaging Soulrager 2024-10-07 22:23:00 -04:00
Chris H
57011c6cf5 Update glassworks_shattered_yard.txt 2024-10-07 22:14:24 -04:00
Anthony Calosa
8863c46caa Merge branch 'master' into master2 2024-10-08 09:30:02 +08:00
Matt Headley
fec420574f Update aerie_0.tmx 2024-10-07 19:51:37 -04:00
Anthony Calosa
dd50b54ffb reorder module, seems output is affected when builds are in parallel (-T 1C flag) 2024-10-08 06:50:43 +08:00
Anthony Calosa
877c8e71b7 update exec-id 2024-10-08 05:48:13 +08:00
Simisays
89c4f695c5 Update mirror_room_fractured_realm.txt 2024-10-07 19:59:53 +02:00
Simisays
33ae2ee952 cleanup 2024-10-07 19:31:25 +02:00
Simisays
d90577c77d update 2024-10-07 19:12:18 +02:00
Hans Mackowiak
5054223bb7 Create inquisitive_glimmer.txt (#6240) 2024-10-07 16:29:18 +00:00
Anthony Calosa
0594627833 fix pom entries 2024-10-07 17:00:40 +08:00
Anthony Calosa
fea65ddd4a update animated splash 2024-10-07 15:43:34 +08:00
Anthony Calosa
eada2c6d4f Merge branch 'master' into master2 2024-10-07 06:06:05 +08:00
Paul Hammerton
4b2640d412 Edition updates for rooms: DSC, DSK (#6239) 2024-10-06 19:46:31 +00:00
Hans Mackowiak
80b30d9a6a Room: First Spell Part (#6044)
* Room: First Spell 

----

Co-authored-by: tool4ever <therealtoolkit@hotmail.com>
Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.59>
Co-authored-by: TRT <>
Co-authored-by: Anthony Calosa <anthonycalosa@gmail.com>
2024-10-06 20:11:28 +02:00
Renato Filipe Vidal Santos
88006ebe85 Edit pile cleanup: part 2, folders 'h' to 'q' (#6219) 2024-10-06 17:14:01 +00:00
Renato Filipe Vidal Santos
7ca16f29eb Edit pile cleanup: part 1, folders 'a' to 'g' (#6218) 2024-10-06 16:20:08 +00:00
Anthony Calosa
4bb902dc31 splashscreen logo 2024-10-06 23:15:21 +08:00
Anthony Calosa
f4671133f3 add splashscreen for mobile-dev 2024-10-06 23:13:51 +08:00
Renato Filipe Vidal Santos
ae95ff2ea6 Edit pile cleanup: part 3, folders 'r' to 'u' & 'rebalanced' (#6220) 2024-10-06 14:08:23 +00:00
tool4ever
0829d02237 Display additional cost text during payment (#6233) 2024-10-06 14:08:11 +00:00
Renato Filipe Vidal Santos
5526621328 PCEL: 1996 World Champion (#6088)
* Add files via upload

* Update 1996_world_champion.txt

* Add files via upload

* Add files via upload
2024-10-06 13:25:15 +03:00
Anthony Calosa
5d959dc963 missing import 2024-10-06 16:03:08 +08:00
Anthony Calosa
4dfd344298 add JVM check 2024-10-06 15:29:51 +08:00
Anthony Calosa
4f819a9be3 update launch4j 2024-10-05 21:25:28 +08:00
Anthony Calosa
f40d3057b4 update info 2024-10-05 19:20:26 +08:00
Anthony Calosa
110575842e update enforce check 2024-10-05 17:41:13 +08:00
Anthony Calosa
a322dd45d8 update dependency 2024-10-05 13:13:58 +08:00
Anthony Calosa
f14de828ea mobile new summoning sickness icon 2024-10-05 12:20:16 +08:00
Anthony Calosa
5ce506c5ab update ImageView 2024-10-04 19:19:30 +08:00
Anthony Calosa
487f33e1e6 Merge branch 'master' into master2 2024-10-04 15:52:04 +08:00
kevlahnota
5affe7dd23 fix AI crash when minimum cards to discard exceeds than the valid cards
reported here: https://discord.com/channels/267367946135928833/1291545865814675578/1291545865814675578
2024-10-04 15:45:11 +08:00
Anthony Calosa
deff16b8f4 Merge branch 'master' into master2 2024-10-04 14:40:42 +08:00
kevlahnota
fea8855e0e prevent NPE 2024-10-04 11:33:36 +08:00
Anthony Calosa
650ee98c06 update standalone proguard 7.6.0
https://github.com/Guardsquare/proguard/releases/tag/v7.6
2024-10-03 20:44:14 +08:00
fanch
2debe4a42b Fix encoding 2024-10-03 08:58:52 +02:00
Anthony Calosa
1521f29ae3 Merge branch 'master' into master2 2024-10-03 10:24:22 +08:00
tool4ever
0971db66f4 Update screaming_nemesis.txt 2024-10-03 00:13:09 +00:00
Anthony Calosa
ee00fa3ec8 Merge branch 'master' into master2 2024-10-03 05:54:59 +08:00
fanch
12e31f4419 gui-desktop : Match : add a configurable keyboard shortcut to press OK/yes button from prompt and pop-up.
Allow to quickly pass phases and accept stack events.
Default to 'space bar'
2024-10-02 20:59:58 +02:00
Paul Hammerton
6a745c721b Merge pull request #6232 from Ayora29/artist
Update @Artist names in edition txt files
2024-10-02 19:25:59 +01:00
fanch
ab8a4be1ce Fix bad section move 2024-10-02 20:11:52 +02:00
Jetz72
84e6a61052 Fix ChangeZoneEffect ordering to library; Aetherspouts prompt (#5798)
* Fix ChangeZone ordering to library
Fix cards not showing up for Aetherspouts.
2024-10-02 15:39:51 +00:00
TwentyToedToad
436a3382b6 Sadistic Shell Game 2024-10-02 14:11:00 +00:00
fanch
95eea713ee Update @Artist names in edition txt files 2024-10-02 13:29:45 +02:00
Anthony Calosa
fdca506d20 Merge branch 'master' into master2 2024-10-02 18:48:53 +08:00
Anthony Calosa
1f5b90d998 Merge branch 'master' into master2 2024-10-02 16:51:04 +08:00
Paul Hammerton
3df291c1f5 Merge pull request #6231 from Ayora29/typos
Fix wrong rarity in edition txt files
2024-10-02 09:50:10 +01:00
tool4ever
9cbf0f8fc6 Update paranormal_analyst.txt 2024-10-02 07:48:27 +02:00
tool4ever
f336bd1284 Support second main (#6230) 2024-10-02 07:23:14 +02:00
fanch
abb6162e6f Revert CMB1 change in card names 2024-10-01 22:48:41 +02:00
Ayora29
d6aa7f3e35 Merge branch 'Card-Forge:master' into typos 2024-10-01 21:24:58 +02:00
fanch
589d50d553 More fixes to rarities 2024-10-01 21:14:40 +02:00
Renato Filipe Vidal Santos
301c000653 Update shichifukujin_dragon.txt (#6176) 2024-10-01 18:47:49 +00:00
Simisays
8d4ddec7da DSK 2 cards (#6210) 2024-10-01 18:38:50 +00:00
Ayora29
b502e0f8ac Restore Anthologies.txt L rarity for lands (#6229) 2024-10-01 18:38:15 +00:00
fanch
aa9f18f9fb Special rarities for masterpieces cards 2024-10-01 20:28:43 +02:00
fanch
345912fbae Fix wrong rarities 2024-10-01 20:23:49 +02:00
TwentyToedToad
c752f862ee Star Athlete (DSC) 2024-10-01 17:18:41 +00:00
Renato Filipe Vidal Santos
310cd28423 Edit pile cleanup: part 7, folders 'v' to 'z' & 'tokenscripts' (#6224) 2024-10-01 17:31:17 +02:00
fanch
e2a6e3b1b1 Add Scryfall code 2024-10-01 12:10:09 +02:00
fanch
d7ec1a225c Add Scryfall code 2024-10-01 11:59:35 +02:00
fanch
377d30dbf5 Restore Anthologies.txt L rarity for lands 2024-10-01 10:30:02 +02:00
Paul Hammerton
bd4843c6a3 Merge pull request #6228 from Ayora29/anthologies
Re-arange Anthologies edition txt file according to Scryfall
2024-10-01 09:14:29 +01:00
fanch
135f19e91a Re-arange Anthologies edition txt file according to Scryfall. Pictures still displayin correctly. 2024-10-01 09:31:50 +02:00
Agetian
4fcd6f577a LDA Update (better names for deck archetypes) (#6227)
* - Add new genetic decks (Standard, Modern) with metagame as of Bloomburrow

* - LDA Update
2024-10-01 09:44:32 +03:00
Anthony Calosa
36a1c0d5a3 Merge branch 'master' into master2 2024-10-01 06:12:26 +08:00
BigCrunch22
2691363738 Update Oracle text of some "main phase" related cards (#6216) 2024-09-30 18:09:56 +00:00
Anthony Calosa
55ec837b16 Merge branch 'master' into master2 2024-09-30 20:52:34 +08:00
Anthony Calosa
0cb589a905 update generated box display 2024-09-30 20:49:03 +08:00
Paul Hammerton
9e17cf433a Merge pull request #6214 from paulsnoops/edition_updates
Edition updates: SLD
2024-09-30 10:04:43 +01:00
Paul Hammerton
02ac064252 Edition updates: SLD 2024-09-30 09:55:23 +01:00
Anthony Calosa
61bf589f05 Merge branch 'master' into master2 2024-09-30 11:51:41 +08:00
tool4ever
a949a988a5 Fix GameStates starting with frozen stack if RE executes (#6213)
* Fix GameStates starting with frozen stack if RE executes

* Fix NPE when facedown
2024-09-29 20:18:35 +00:00
Jetz
c43015f05d Merge branch 'master' into code-cleanup
# Conflicts:
#	forge-game/src/main/java/forge/game/ForgeScript.java
2024-09-29 15:54:17 -04:00
Jetz
2e769ac279 Bug fix in RandomReservoir accumulator 2024-09-29 11:03:12 -04:00
Anthony Calosa
f9fc5b4213 fix some icon colors 2024-09-29 22:48:54 +08:00
Agetian
ea070a85aa - Add new genetic decks (Standard, Modern) with metagame as of Bloomburrow (#6212) 2024-09-29 17:29:34 +03:00
Anthony Calosa
683f9c2158 Merge branch 'master' into master2 2024-09-29 21:47:54 +08:00
Anthony Calosa
ea9aab7c4f mobile -> enable combat arrows on 2 player 2024-09-29 20:41:20 +08:00
Anthony Calosa
ddf009fed5 update skinlist 2024-09-29 15:34:52 +08:00
Anthony Calosa
7594888f8e SKIN Update 2024-09-29 15:25:11 +08:00
tool4ever
86dc3a4d5e Some cleanup (#6211)
Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.59>
2024-09-28 19:04:41 +03:00
Paul Hammerton
6169285cdb Merge pull request #6183 from Ayora29/master
Reorder card entries in 111 edition files.
2024-09-27 19:17:47 +01:00
Ayora29
ab7037f59c Merge branch 'Card-Forge:master' into master 2024-09-27 19:49:28 +02:00
tool4ever
cb4e0e5721 Some cleanup (#6209) 2024-09-27 18:59:27 +02:00
Hans Mackowiak
ac335a6b80 Merge pull request #6204 from Agetian/master
Add LDA information for Bloomburrow metagame (Standard, Modern)
2024-09-27 18:57:19 +02:00
tool4ever
c5aaf75838 Update enter_the_enigma.txt (#6206)
Closes #6202
2024-09-27 15:22:32 +02:00
Ayora29
b104249205 Add WithDifferentPowers$ to DigEffect + "Rip, Spawn Hunter" card (#6208) 2024-09-27 15:22:16 +02:00
Fulgur14
ec7314673e 10 DSK cards 2024-09-27 14:53:52 +02:00
Simisays
69985e4c2f Update myra_the_magnificent.txt (#6203) 2024-09-27 14:22:42 +02:00
Agetian
4622441ec8 - Add LDA information for Bloomburrow metagame (Standard, Modern). 2024-09-27 14:59:43 +03:00
Anthony Calosa
1f6f14cb3c remove unused property 2024-09-27 10:41:08 +08:00
Anthony Calosa
83e28d65f6 update android pom, proguard 2024-09-27 06:37:44 +08:00
tool4ever
ba4682e038 Update drop_tower.txt 2024-09-26 18:00:47 +00:00
Jetz
474be7bd67 Fix ConcurrentModificationException 2024-09-26 12:01:17 -04:00
Anthony Calosa
352967c8b8 update proguard, fix expected stack map table for method with non-linear control flow 2024-09-26 22:40:17 +08:00
Jetz
b35981218a Merge branch 'master' into code-cleanup
# Conflicts:
#	forge-game/src/main/java/forge/game/ability/effects/ManifestBaseEffect.java
2024-09-26 10:21:19 -04:00
Jetz
871947a540 Guava migration - Optimize imports 2024-09-26 09:59:26 -04:00
Jetz
6a04fcd500 Guava migration - Remove migration scaffold 2024-09-26 09:36:50 -04:00
Anthony Calosa
3a41f9d492 update more dependency, update CardMockTestCase 2024-09-26 19:36:59 +08:00
Anthony Calosa
f5949b9413 Merge branch 'master' into master2 2024-09-26 16:07:00 +08:00
Anthony Calosa
67cbd1444c update info 2024-09-26 16:02:50 +08:00
tool4ever
941a1129e5 Make Myriad optional for each player again (#6191)
* Make Myriad optional for each player again

* Fix scripts

* Fix NPE due to not removing empty shards

---------

Co-authored-by: TRT <>
Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.59>
2024-09-26 08:52:08 +03:00
Anthony Calosa
a7c69da4e6 fix tests 2024-09-26 13:17:02 +08:00
Anthony Calosa
c07e3b99a3 update argsfor Java 17 2024-09-26 12:28:55 +08:00
Anthony Calosa
56400d4444 JAVA17 Update 2024-09-26 11:52:42 +08:00
Fulgur14
2ac31bf45c Rename monstruous_emergence.txt to monstrous_emergence.txt (#6197) 2024-09-25 18:19:53 +00:00
Michael Lo
786d6834ef Fix valiant cards only triggering once per game rather than once per turn (#6196) 2024-09-25 14:58:28 +00:00
Jetz
0278f5817b Guava migration - Create IterableUtil to house iterable helper methods dependent on Java predicates 2024-09-25 09:26:41 -04:00
Jetz
f636910ebb Guava migration - Rename StreamUtils -> StreamUtil for consistency 2024-09-25 09:01:46 -04:00
Jetz
1395baa2ff Guava migration - Fix build error 2024-09-25 08:59:21 -04:00
Jetz
d01c4e056b Guava migration - Remove unused imports 2024-09-25 08:48:28 -04:00
Jetz
52112e671c Guava migration - Slight cleanup 2024-09-25 08:46:07 -04:00
Ayora29
68db59f080 New dsk card : Monstrous Emergence (#6194) 2024-09-25 11:01:18 +00:00
tool4ever
fb5d9a0b56 Update valgavoths_onslaught.txt (#6187) 2024-09-25 08:02:36 +00:00
Agetian
35cd7d0f4e - Add puzzle PS_BLB4, fix GameState support for class level. (#6195) 2024-09-25 08:02:22 +00:00
Anthony Calosa
3577f57419 Merge branch 'master' into master2 2024-09-25 06:27:21 +08:00
Jetz
a57bab1dac Guava migration - Remove single use Predicate implementations
Remove unused parameters of other predicates
2024-09-24 09:33:23 -04:00
kevlahnota
dd5aa11742 Update a_premonition_of_your_demise.txt 2024-09-24 20:38:59 +08:00
Anthony Calosa
7725d9e042 Merge branch 'master' into master2 2024-09-24 08:56:21 +08:00
Paul Hammerton
6334d22bf0 Merge pull request #6192 from paulsnoops/cmdr_bans_23_9
Commander Banned and Restricted September 23, 2024
2024-09-23 17:54:06 +01:00
Paul Hammerton
3df6319efa Commander Banned and Restricted September 23, 2024 2024-09-23 17:46:46 +01:00
Ayora29
1cd976344a Merge branch 'Card-Forge:master' into master 2024-09-23 09:49:00 +02:00
Anthony Calosa
c6d334ad69 update 2024-09-23 11:10:48 +08:00
Anthony Calosa
bd8ff97dc2 Merge branch 'master' into master2 2024-09-23 09:48:00 +08:00
Jetz
1af22ff4b6 Guava migration - Remove CollectionSuppliers 2024-09-22 16:54:49 -04:00
Jetz
cb4c64ce2c Guava migration - Added PaperCard predicates for commonly forwarded CardRules predicates 2024-09-22 16:48:08 -04:00
Jetz
d173c22688 Fixed some predicate logic issues. 2024-09-22 16:12:04 -04:00
Jetz
cbcfa8f884 Guava migration - Replace select usages of Aggregates methods 2024-09-22 15:56:48 -04:00
Jetz
e739dad1ba Guava migration - Slim down quest reward logic 2024-09-22 14:48:20 -04:00
Jetz
05d58c2fce Guava migration - Add StreamUtils.random collectors 2024-09-22 14:47:57 -04:00
loud1990
2b41b1cbe8 Fixed 2 DSK cards (#6186)
Fixed Trial of Agony which wasn't dealing the damage, and Disturbing Mirth which was only allowing you to sacrifice another enchantment (not a creature).
2024-09-22 20:56:17 +03:00
tool4ever
aebde7a1d0 Fix NPE with Starforged Sword (#6188)
* Fix NPE

* Fix The Lord of Pain

---------

Co-authored-by: TRT <>
2024-09-22 20:54:02 +03:00
Jetz
c2f72bb3c2 Guava migration - Stream support for FCollectionView 2024-09-22 11:05:19 -04:00
Anthony Calosa
34c6258d26 update maven 2024-09-22 08:53:13 +08:00
fanch
3825904d42 collector number stating with F\d are considered numeric only 2024-09-21 21:44:40 +02:00
fanch
59a8050a5f Reorder card entries in 111 edition files.
No card add, no card remove. Only reorder, numerically then alphabetically.
2024-09-21 15:31:31 +02:00
Anthony Calosa
ca2110c2c2 Merge branch 'master' into master2 2024-09-21 09:16:36 +08:00
tool4ever
11a7f7b271 Script cleanup (#6180)
Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.59>
2024-09-20 19:29:27 +03:00
Renato Filipe Vidal Santos
a67ab2818b Fixes gleaned from notes: pass #3 (#6179) 2024-09-20 14:59:41 +00:00
Anthony Calosa
c1f9c766b2 Merge branch 'master' into master2 2024-09-20 20:19:12 +08:00
tool4ever
7a192a6873 Fix Valiant triggers failing if another player targets first (#6178) 2024-09-20 11:53:07 +02:00
Anthony Calosa
25435c847b update sign tool 2024-09-20 06:55:14 +08:00
Anthony Calosa
f53bc65f96 Merge branch 'master' into master2 2024-09-19 22:06:29 +08:00
Jetz
c91334029a Guava migration - Refactor edition type checks 2024-09-19 09:20:02 -04:00
Hans Mackowiak
869db7febb Impending NonCreature as StaticAbility (#6177) 2024-09-19 10:36:13 +03:00
tool4ever
86294108eb Update grist_voracious_larva_grist_the_plague_swarm.txt 2024-09-19 09:27:56 +02:00
Renato Filipe Vidal Santos
ac807c4766 Fixes gleaned from notes: pass #2, Cataclysm-like and other "choose to keep" effects. (#6165)
* Add files via upload

* Update slaughter_the_strong.txt

* Update incriminate.txt

* Update a-incriminate.txt

* Update phyrexian_dreadnought.txt

* Update killing_wave.txt

* Update global_ruin.txt

* Update barrins_spite.txt

* Update szats_will.txt

* Update soul_shatter.txt

* Update slaughter_the_strong.txt

* Update shadowgrange_archfiend.txt

* Update professor_onyx.txt

* Update phyrexian_dreadnought.txt

* Update myrkuls_edict.txt

* Update gixs_command.txt

* Update flare_of_malice.txt

* Update demonic_hordes.txt

* Update crackling_doom.txt

* Update revival_experiment.txt

* Update perilous_predicament.txt

* Update regnas_sanction.txt

* Update catch_release.txt

* Update regnas_sanction.txt

* Update regnas_sanction.txt

---------

Co-authored-by: tool4ever <therealtoolkit@hotmail.com>
2024-09-19 06:56:29 +03:00
Anthony Calosa
fd4ba1397a Merge branch 'master' into master2 2024-09-18 21:41:52 +08:00
kevlahnota
e09c09b924 Merge pull request #6173 from tool4ever/fix18
Fix RE choice for different sources
2024-09-18 19:18:44 +08:00
tool4EvEr
ee3c8173e1 Fix RE choice for different sources 2024-09-18 09:37:11 +02:00
tool4ever
daf1a891c0 Update zndrsplts_judgment.txt 2024-09-18 07:11:28 +00:00
tool4ever
b396e780cf Fix scripts (#6169) 2024-09-18 10:08:58 +03:00
Fulgur14
7b94f07fa8 DSK cards from misplaced PR (#6157) 2024-09-18 07:25:08 +02:00
Glorax
dd0bd28d2c Erratic Apparition fix (#6170) 2024-09-18 07:24:43 +02:00
Fulgur14
95dd06e55f Ancient Cellarspawn - incomplete, might need support (#6123)
* Ancient Cellarspawn - incomplete, might need support

* Support Ancient Cellarspawn

---------

Co-authored-by: TRT <>
2024-09-18 08:18:06 +03:00
Anthony Calosa
0dde987367 update jaxb-api -> fix illegal access warning 2024-09-18 10:56:36 +08:00
Anthony Calosa
fd7da13f15 Merge branch 'master' into master2 2024-09-18 06:01:03 +08:00
Glorax
922a0c21be Overgrown Zealot fix (#6167) 2024-09-17 20:48:07 +00:00
Glorax
05bf665f52 Spineseeker Centipede fix (#6166) 2024-09-17 20:21:05 +00:00
Anthony Calosa
5099d0f24f set landscape sensor from android 11 onwards 2024-09-17 20:16:29 +08:00
Anthony Calosa
bbc3d5639c update maven, dependency plugins 2024-09-17 20:05:37 +08:00
Anthony Calosa
de9823ab71 Merge branch 'master' into master2 2024-09-17 16:12:19 +08:00
Paul Hammerton
90d550facc Merge pull request #6163 from paulsnoops/dsk_formats
Format updates for DSK & DSC
2024-09-17 08:56:04 +01:00
Paul Hammerton
120d435424 Format updates for DSK & DSC 2024-09-17 08:51:21 +01:00
Paul Hammerton
e204ea751d Merge pull request #6162 from paulsnoops/edition_updates
Edition updates: SCH, SLD
2024-09-17 08:35:55 +01:00
Paul Hammerton
5d389ad62c Edition updates: SCH, SLD 2024-09-17 08:32:45 +01:00
Anthony Calosa
0c248d76eb Merge branch 'master' into master2 2024-09-17 15:13:11 +08:00
kevlahnota
663bde22ac Add ReplacementEffectView, StaticAbility View for Netplay Dialog 2024-09-17 14:58:43 +08:00
tool4ever
0a4cff5adc Update suspended_sentence.txt 2024-09-17 07:38:06 +02:00
Fulgur14
7c7c1fda01 Fulgur14 patch 191321 (#6158) 2024-09-16 20:13:43 +00:00
tool4ever
4c7c7edbf1 Update only_i_know_what_awaits.txt 2024-09-16 15:34:27 +00:00
Jetz
7ab333a60a Guava migration - ItemPool collector 2024-09-16 09:10:21 -04:00
Anthony Calosa
21540668c3 Merge branch 'master' into master2 2024-09-16 19:42:48 +08:00
kevlahnota
79b1c3c9fd Update PlayerControllerHuman.java
show more info on choice list on non network game
2024-09-16 19:38:30 +08:00
Hans Mackowiak
7b9e2a6735 ManifestDread as separate Effect (#6151) 2024-09-16 12:36:31 +02:00
Anthony Calosa
c04055fff0 Merge branch 'master' into master2 2024-09-16 16:19:52 +08:00
Fulgur14
6e3c17a2a8 18 mostly leaked DSK/DSC cards (plus one token) (#6131) 2024-09-16 10:17:22 +02:00
kevlahnota
512b3208ae Merge pull request #6156 from Card-Forge/kevlahnota-patch-1
fix netplay crash
2024-09-16 16:09:33 +08:00
kevlahnota
c4d943750c fix netplay crash
-closes issue #6145
2024-09-16 16:04:19 +08:00
Fulgur14
a63f87e5be Update all_shall_smolder_in_my_wake.txt (#6155) 2024-09-16 09:58:15 +02:00
Anthony Calosa
9fc93847b3 Merge branch 'master' into master2 2024-09-16 13:52:07 +08:00
kevlahnota
cb325996c9 prevent NPE 2024-09-16 13:34:48 +08:00
tool4ever
419ca27328 Update commander_liara_portyr.txt (#6152) 2024-09-16 06:53:15 +03:00
Anthony Calosa
116720a10f update compiler release 2024-09-16 08:43:03 +08:00
Jetz
ae251372c1 Guava migration - Cleanup 2024-09-15 18:18:27 -04:00
Jetz
8189f134eb Merge branch 'master' into code-cleanup
# Conflicts:
#	forge-ai/src/main/java/forge/ai/AiAttackController.java
#	forge-ai/src/main/java/forge/ai/ComputerUtilCard.java
#	forge-core/src/main/java/forge/item/IPaperCard.java
#	forge-game/src/main/java/forge/game/ForgeScript.java
#	forge-game/src/main/java/forge/game/ability/effects/ManifestBaseEffect.java
#	forge-game/src/main/java/forge/game/card/CardState.java
#	forge-game/src/main/java/forge/game/staticability/StaticAbilityContinuous.java
#	forge-game/src/main/java/forge/game/trigger/Trigger.java
2024-09-15 18:11:24 -04:00
Jetz
1644e7427e Guava migration - Replace select usages of Iterables.transform 2024-09-15 17:33:18 -04:00
Jetz
76aa19622e Guava migration - Replace select usages of Iterables.filter 2024-09-15 17:16:24 -04:00
Chris H
b85b6cac6e Update victor_valgavoths_seneschal.txt 2024-09-15 16:37:35 -04:00
tool4ever
cbfcbfa8c5 Fix Mutate + Unexpectedly Absent (#6150) 2024-09-15 17:05:14 +00:00
Fulgur14
0ab14fdb37 2 DSC cards + 6 schemes (#6136) 2024-09-15 14:21:51 +00:00
tool4ever
91e952da63 Fix optional shuffle into Library cases (#6147) 2024-09-15 14:21:39 +00:00
Anthony Calosa
ef6716c5f6 update exec-plugin 2024-09-15 21:19:16 +08:00
Anthony Calosa
99c235eb62 Merge branch 'master' into master2 2024-09-15 18:33:40 +08:00
Paul Hammerton
653bf46404 Merge pull request #6148 from paulsnoops/edition_updates
Edition updates: DSC
2024-09-15 11:31:24 +01:00
Paul Hammerton
148a13c9cf Edition updates: DSC 2024-09-15 11:28:19 +01:00
Fulgur14
a60f3f84e0 2 DSK cards, some DSC cards, 5 Schemes (#6122) 2024-09-15 09:18:24 +00:00
tool4ever
f1ff92801f Fix Undying not triggering when dying from SBA (#6146) 2024-09-15 08:15:54 +00:00
Anthony Calosa
dd11d04452 Merge branch 'master' into master2 2024-09-15 16:09:52 +08:00
Fulgur14
445508d3ab 5 DSC Schemes (#6134)
* Update amped_raptor.txt

* Add files via upload

* Update i_call_for_slaughter.txt

* Update reality_is_mine_to_control.txt

* Update you_exist_only_to_amuse.txt

* Update your_nightmares_are_delicious.txt

* Update your_nightmares_are_delicious.txt

---------

Co-authored-by: tool4ever <therealtoolkit@hotmail.com>
2024-09-15 07:24:43 +03:00
Anthony Calosa
372c3cf25e Merge branch 'master' into master2 2024-09-15 11:48:45 +08:00
Glorax
813588b897 Update coordinated_clobbering.txt (#6144) 2024-09-14 20:48:39 +00:00
tool4ever
21c34b552d Fix Frankenstein's Monster (#6143) 2024-09-14 19:47:40 +02:00
Anthony Calosa
b6a0540b9b Merge branch 'master' into master2 2024-09-14 22:21:14 +08:00
tool4ever
d303bb122c Update your_own_face_mocks_you.txt 2024-09-14 10:17:37 +00:00
Paul Hammerton
12f937e4ca Merge pull request #6142 from paulsnoops/edition_updates
Edition updates: DSC, DSK
2024-09-14 10:52:50 +01:00
Paul Hammerton
df868df7cd Edition updates: DSC, DSK 2024-09-14 10:49:45 +01:00
Renato Filipe Vidal Santos
2db3e4d7ba Update ogre_battlecaster.txt (#6140) 2024-09-14 09:40:23 +00:00
Paul Hammerton
78a134b2df Fix Break Down the Door, Wickerfolk Thresher (#6141) 2024-09-14 07:51:24 +00:00
Anthony Calosa
74eebf4081 move signer to tools 2024-09-14 08:43:13 +08:00
Anthony Calosa
edc3af50af Merge branch 'master' into master2 2024-09-14 08:08:00 +08:00
Anthony Calosa
ca9f2dad48 update manifest, add uber-apk-signer 2024-09-14 07:58:48 +08:00
Anthony Calosa
1918770d3f update to sdk 33, update v2 signer-modded 2024-09-14 07:55:01 +08:00
Renato Filipe Vidal Santos
52ae896280 Update season_of_gathering.txt (#6139) 2024-09-13 19:37:07 +00:00
Fulgur14
2ac557c46e 23 DSK cards (+one Scheme) (#6112) 2024-09-13 19:36:58 +00:00
Fulgur14
d8c45e7d62 Seized from Slumber (DSK) (#6137)
This should be the last new card, all unimplemented cards are now in the project.
2024-09-13 20:01:44 +03:00
Paul Hammerton
5143f3ade0 Merge pull request #6138 from paulsnoops/edition_updates
Edition updates: DSC, DSK
2024-09-13 17:30:48 +01:00
Paul Hammerton
33e733559e fix_test 2024-09-13 17:27:43 +01:00
Paul Hammerton
a2d653a0fc Edition updates: DSC, DSK 2024-09-13 17:22:12 +01:00
Anthony Calosa
368ef9d903 Merge branch 'master' into master2 2024-09-13 21:20:01 +08:00
Fulgur14
e76eb919d9 Violent Urge (DSK) (#6132) 2024-09-13 08:16:38 +03:00
Anthony Calosa
b9a36bd039 Merge branch 'master' into master2 2024-09-13 09:31:25 +08:00
Paul Hammerton
486a93e4b1 Merge pull request #6133 from paulsnoops/edition_updates
Edition updates: DSK
2024-09-12 17:41:49 +01:00
Paul Hammerton
f87c24b9f5 Edition updates: DSK 2024-09-12 17:26:30 +01:00
Anthony Calosa
f442189868 update SplashScreen 2024-09-12 20:06:58 +08:00
Fulgur14
7cf11e21ae Add files via upload (#6125) 2024-09-12 08:38:52 +03:00
Fulgur14
0a58e8a354 Fear of Exposure and Killer's Mask (DSK) (#6128) 2024-09-12 08:38:47 +03:00
Anthony Calosa
83b653a0bb Merge branch 'master' into master2 2024-09-12 07:12:34 +08:00
Paul Hammerton
82d3c549f2 Merge pull request #6130 from paulsnoops/edition_updates
Edition updates: DSC, DSK
2024-09-11 17:55:51 +01:00
Paul Hammerton
f14d2ca26f Edition updates: DSC, DSK 2024-09-11 17:48:41 +01:00
Hans Mackowiak
9efa29cbf0 Teferi without PlayerKeyword 2024-09-11 12:51:54 +02:00
Anthony Calosa
b683f2d64e Merge branch 'master' into master2 2024-09-11 18:42:17 +08:00
Fulgur14
d76b798526 4 DSK + 7 DSC cards (#6099)
* Support The Tale of Tamiyo

* Support Kianne, Corrupted Memory
2024-09-11 12:24:44 +02:00
tool4ever
bd1f48d530 Fix MDFC NPE (#6121)
Co-authored-by: TRT <>
2024-09-11 10:11:42 +03:00
Anthony Calosa
d6b9ad525d Merge branch 'master' into master2 2024-09-10 23:47:33 +08:00
Anthony Calosa
78f3d3d74d update more dependency 2024-09-10 23:39:51 +08:00
Fulgur14
138c866b12 Add files via upload (#6118) 2024-09-10 17:11:22 +03:00
Fulgur14
8aa398f7eb 8 DSK cards (Marvin, Murderous Mimic and audience) (#6117)
* 8 DSK cards (Marvin, Murderous Mimic and audience)

* Update optimistic_scavenger.txt

* Update rootwise_survivor.txt

* Update rootwise_survivor.txt
2024-09-10 17:11:11 +03:00
Paul Hammerton
246a49e642 Merge pull request #6120 from paulsnoops/edition_updates
Edition updates: DSK
2024-09-10 14:33:35 +01:00
Paul Hammerton
56c4ffa39b Edition updates: DSK 2024-09-10 14:30:38 +01:00
Anthony Calosa
d7c106ba7e Merge branch 'master' into master2 2024-09-10 19:52:07 +08:00
Hans Mackowiak
e1c794c640 Player: use LifeReduced CantHappen for Archon of Coronation (#6116)
* Player: use LifeReduced CantHappen for Archon of Coronation
2024-09-10 12:56:31 +02:00
Fulgur14
ebe9fbebe4 Valgavoth's Onslaught (#6119) 2024-09-10 12:42:06 +02:00
Anthony Calosa
e623e02c53 update network check 2024-09-10 17:56:24 +08:00
Anthony Calosa
bfca199175 Merge branch 'master' into master2 2024-09-10 16:37:59 +08:00
tool4ever
69158e01ba Support for Valgavoth's Onslaught (#6114) 2024-09-10 09:58:46 +02:00
Anthony Calosa
822676dcfd Merge branch 'master' into master2 2024-09-10 10:32:34 +08:00
Chris H
4170ba7b32 Update bashful_beastie.txt (#6113) 2024-09-09 21:23:53 +02:00
Paul Hammerton
e061766cfc Merge pull request #6111 from paulsnoops/edition_updates
Edition updates: DSC, DSK
2024-09-09 17:40:46 +01:00
Paul Hammerton
b5fa9b81f6 Edition updates: DSC, DSK 2024-09-09 17:35:25 +01:00
Anthony Calosa
b790455866 Merge branch 'master' into master2 2024-09-09 21:05:12 +08:00
Anthony Calosa
c40edf88e9 revert to sdk 29 (Android 10) until the v2 signing works on android 11 above 2024-09-09 21:04:35 +08:00
Fulgur14
4fe3e51e62 Arabella, Abandoned Doll (DSK) (#6110) 2024-09-09 12:38:39 +02:00
Hans Mackowiak
5ff515b03b Drop Java 8 Test (#6109) 2024-09-09 10:38:44 +02:00
Anthony Calosa
7ea3e6b7b4 Merge branch 'master' into master2 2024-09-09 14:39:30 +08:00
Anthony Calosa
21b6e156ad update 2024-09-09 14:22:54 +08:00
Anthony Calosa
af89e52213 update target sdk and build tools to 33 2024-09-09 14:18:37 +08:00
Hans Mackowiak
75bbbfe6c8 Update PlayerPredicates.java
CANT_WIN not used anymore, use player.cantWin()
2024-09-09 06:59:15 +02:00
Jetz
cf68a75c03 Guava migration - Inline Iterables.all (Collection overload) 2024-09-08 15:29:41 -04:00
Jetz
7e3bb81428 Guava migration - Inline Iterables.any (Collection overload) 2024-09-08 15:27:36 -04:00
Jetz
b4015af203 Guava migration - Inline Iterables.any and Iterables.all (FCollectionView overloads) 2024-09-08 14:56:05 -04:00
Jetz
47164153f4 Guava migration - Add helper methods for FCollectionView anyMatch and allMatch 2024-09-08 14:21:43 -04:00
tool4ever
d6bc1788d9 Fix Enhanced Surveillance (#6104) 2024-09-08 14:59:58 +00:00
Anthony Calosa
a8f6842e21 update some dependency 2024-09-08 21:30:29 +08:00
Anthony Calosa
3e5b239062 Merge branch 'master' into master2 2024-09-08 20:58:32 +08:00
Anthony Calosa
09b5ee8ac5 update android builds to SDK 29, use Java 11 2024-09-08 20:44:23 +08:00
Fulgur14
5f3e531d2e 4 DSK cards + some Schemes (#6101) 2024-09-08 12:34:24 +00:00
Paul Hammerton
036365e984 Merge pull request #6102 from paulsnoops/edition_updates
Edition updates: DSC, DSK
2024-09-08 10:42:23 +01:00
Paul Hammerton
6813e80e1e Edition updates: DSC, DSK 2024-09-08 10:37:44 +01:00
Paul Hammerton
050e3d1eb6 Fix Erratic Apparition 2024-09-07 15:43:26 -04:00
Fulgur14
0408b3149e Under the Skin (DSK) (#6098) 2024-09-07 14:58:06 +00:00
Fulgur14
cce6ccfd01 13 DSK cards (Diversion Specialist and friends) (#6084) 2024-09-07 14:20:48 +00:00
Hans Mackowiak
4862071db7 Keyword: link StaticAbility into it (#6079)
* Keyword: link StaticAbility into it

* fix getKeywordMagnitude to check for StaticAbility
2024-09-07 17:19:57 +03:00
Fulgur14
e7b05b2c9b 7 DSK cards (Boilerbilges Ripper and victims) (#6092)
* 7 DSK cards (Boilerbilges Ripper and victims)

* Update glimmerburst.txt
2024-09-07 17:19:29 +03:00
Hans Mackowiak
f792a5b79e Impending: use Effect for Last Time counter removed (#6096) 2024-09-07 17:19:17 +03:00
Fulgur14
73adb8b2d9 Eerie DSK cards (#6063)
* Eerie DSK cards

* Add files via upload

* Update zimone_mystery_unraveler.txt

* Add files via upload

* Update stalked_researcher.txt

* Update victor_valgavoths_seneschal.txt
2024-09-07 17:19:00 +03:00
tool4ever
7a1fa8b1a4 Update cloudsteel_kirin.txt 2024-09-07 13:48:18 +00:00
Fulgur14
b6aeb14e57 Growing Dread -- might need support (#6083)
* Bonus Hallow fix / old revert
2024-09-07 09:27:04 +00:00
Paul Hammerton
5aa0832e7b Merge pull request #6095 from paulsnoops/edition_updates
Edition updates: DSK
2024-09-07 10:13:31 +01:00
Paul Hammerton
7d2f1ba193 Edition updates: DSK 2024-09-07 10:10:30 +01:00
Hans Mackowiak
d2e3175961 Add Room Helper functions (#6093) 2024-09-07 10:55:10 +02:00
kevlahnota
07cc3ef58f Update it-IT.properties
try to fix UnknownFormatConversionException
Conversion = 'm'
2024-09-07 15:58:34 +08:00
tool4ever
825296eaf2 Dread fix (#6094) 2024-09-07 07:26:10 +00:00
Fulgur14
af519dc62d Lionheart Glimmer (DSK) (#6087) 2024-09-07 07:11:54 +00:00
kevlahnota
86b142099d Merge pull request #6090 from Card-Forge/kevlahnota-patch-1
Update nahiri_heir_of_the_ancients.txt
2024-09-07 09:21:30 +08:00
kevlahnota
8b5ad4ebe7 Update nahiri_heir_of_the_ancients.txt 2024-09-07 09:20:58 +08:00
kevlahnota
5b3e7eff63 Merge pull request #6089 from kevlahnota/master2
check awaitNextInputTimer
2024-09-07 08:33:43 +08:00
Jetz
dfac93a668 Guava migration - Inline Iterables.find (Collection overload) 2024-09-06 20:33:37 -04:00
Jetz
36cff7e401 Guava migration - Inline Iterables.removeIf (Collection overload) 2024-09-06 20:32:22 -04:00
Anthony Calosa
f61fa59566 check awaitNextInputTimer 2024-09-07 08:30:24 +08:00
Jetz
8489866461 Guava migration - Inline Iterables.contains (Collection overload) 2024-09-06 20:23:14 -04:00
Jetz
79a640ca8a Guava migration - Cleanup imports 2024-09-06 20:20:06 -04:00
Jetz
d9c54aa9a1 Guava migration - Inline Iterables.addAll (Collection overload) 2024-09-06 20:18:49 -04:00
Jetz
c1de0dee6a Guava migration - Inline Iterables.removeAll (Collection overload) 2024-09-06 19:58:24 -04:00
Jetz
efe55efa43 Guava migration - Inline Iterables.isEmpty (Collection overload) 2024-09-06 19:57:22 -04:00
Jetz
4c8a94b18a Guava migration - Inline Predicates.compose 2024-09-06 19:50:14 -04:00
Jetz
6e3726ee79 Guava migration - Remove unused imports 2024-09-06 19:23:54 -04:00
Jetz
734bcec8bf Guava migration - Helper method for composing CardRules into PaperCards 2024-09-06 19:17:28 -04:00
Jetz
85f80bb5f1 Guava migration - Explode Predicate "Presets" subclasses 2024-09-06 18:10:24 -04:00
tool4ever
07154c1265 Update tin_street_gossip.txt 2024-09-06 17:48:45 +00:00
Fulgur14
73f2a1a041 Overgrown Zealot (DSK) 2024-09-06 17:46:56 +00:00
tool4ever
d2af4c2bcb Fix intrinsic ETB replacement not working if card enters from sideboard (#6082) 2024-09-06 16:40:11 +00:00
tool4ever
45c70b08fd Support for Overgrown Zealot (#6085) 2024-09-06 16:40:01 +00:00
tool4ever
1049f9c885 Update kirtars_wrath.txt 2024-09-06 14:31:48 +00:00
Jetz
0bf04c2fc8 Guava migration - Add common helper predicates 2024-09-06 09:24:32 -04:00
kevlahnota
46c1e5db72 Merge pull request #6081 from kevlahnota/master2
Update Adventure BG files
2024-09-06 20:12:05 +08:00
tool4ever
c7841c6e56 Update threats_around_every_corner.txt 2024-09-06 12:10:16 +00:00
Anthony Calosa
1781eb2ba3 Update Adventure BG files 2024-09-06 20:05:27 +08:00
Fulgur14
d20a75d171 3 DSK cards (Omnivorous Flytrap and friends) (#6080) 2024-09-06 08:26:41 +02:00
Fulgur14
ba4defbb53 Irreverent Gremlin (#6078)
* Add files via upload

* Update irreverent_gremlin.txt
2024-09-06 08:52:16 +03:00
Fulgur14
faadf62e2a 8 DSK cards (#6076) 2024-09-05 17:03:32 +00:00
Paul Hammerton
dbf6fc0134 Merge pull request #6077 from paulsnoops/edition_updates
Edition updates: DSK
2024-09-05 18:01:49 +01:00
Paul Hammerton
b1e6920e3f Edition updates: DSK 2024-09-05 17:57:27 +01:00
Fulgur14
0231e68d85 6 DSK cards (#6067) 2024-09-05 16:38:02 +00:00
Fulgur14
e8b98039ca Orphans of the Wheat (#6073) 2024-09-05 15:13:00 +00:00
Fulgur14
14262404b8 5 DSK cards (#6065)
* 5 DSK cards

* Update shrewd_storyteller.txt

* Update fear_of_burning_alive.txt
2024-09-05 18:06:17 +03:00
Fulgur14
b8a70ef9df More DSK cards (#6059)
* Update veteran_survivor.txt

* Update carrionette.txt

* Add files via upload

* Update titania_voice_of_gaea_titania_gaea_incarnate.txt

* Add files via upload

* Update carrionette.txt

* Update titania_voice_of_gaea_titania_gaea_incarnate.txt

* Update haunted_screen.txt

* Update haunted_screen.txt

* Update overlord_of_the_boilerbilges.txt

* Update savior_of_the_small.txt

* Update untimely_malfunction.txt

* Update savior_of_the_small.txt

* Update savior_of_the_small.txt

* Update insidious_fungus.txt
2024-09-05 18:06:03 +03:00
Fulgur14
dd2f9cad54 Unstoppable Slasher and Dashing Bloodsucker (#6069)
* Unstoppable Slasher and Dashing Bloodsucker

* Add files via upload
2024-09-05 18:04:54 +03:00
Fulgur14
1b7405dffa 19 DSK cards (#6054)
* 19 DSK cards

Ghost Vacuum has a weird bug: if AI uses the second ability, I get a window where I can order how the cards should enter the battlefield.

* Add files via upload

* Update grievous_wound.txt

* Update meathook_massacre_ii.txt

* Update say_its_name.txt

* Update say_its_name.txt

* Update drag_to_the_roots.txt

* Update patchwork_beastie.txt

---------

Co-authored-by: tool4ever <therealtoolkit@hotmail.com>
2024-09-05 18:04:44 +03:00
tool4ever
9acbcb710e Fix self-replacement scripts (#6041)
* Fix self-replacement scripts

* Fix scripts to use current value on resolve

* Clean up

* Try to get right controller when ordering

* Fix corner case

* Fix script

* Revert for now

---------

Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
2024-09-05 18:03:38 +03:00
Kay Schwenk
a396312deb Fixed typos in Heartflame Slash and Tyr's Blessing (#6074) 2024-09-05 15:00:35 +00:00
tool4ever
30af288318 Fix transformed backside cast failing when some AltCost apply (#6070) 2024-09-05 13:34:17 +00:00
tool4ever
1f8317dae9 Fix SVar fallback for Splice (#6072) 2024-09-05 13:33:01 +00:00
Hans Mackowiak
32510dd118 Update dog_umbra.txt
Closes #6061
2024-09-05 14:37:44 +02:00
Chris H
9a5f0b9ff1 Fix MH3 generation 2024-09-05 07:13:13 -04:00
tool4ever
53719aeab7 Zimone, All-Questioning and support (#6040) 2024-09-05 12:41:21 +02:00
tool4ever
dbaf9451c5 Fix Pawprint in Compleated (#6060) 2024-09-04 17:54:28 +00:00
Hans Mackowiak
a9755129f2 TriggerFullyUnlock: Trigger used for Eerie (#6052) 2024-09-04 20:32:46 +03:00
Paul Hammerton
1ced41dded Merge pull request #6062 from paulsnoops/edition_updates
Edition updates: DSK, SPG
2024-09-04 18:19:50 +01:00
Paul Hammerton
8a3ce730c6 Edition updates: DSK, SPG 2024-09-04 18:13:17 +01:00
tool4ever
1ee37020dd Hauntwoods Shrieker and support (#6058) 2024-09-04 16:13:39 +00:00
Fulgur14
959bfe8d31 Added cards with manifest dread (#6057)
* Added cards with manifest dread

* Add files via upload

* Update disturbing_mirth.txt

* Update zimone_mystery_unraveler.txt

* Update turn_inside_out.txt
2024-09-04 15:01:58 +02:00
Fulgur14
4a0a4c110a 3 new DSK cards (#6034) 2024-09-04 10:30:27 +00:00
Fulgur14
cf4879c040 Balustrade Wurm (DSK) (#6056) 2024-09-04 13:03:23 +03:00
Fulgur14
5d1d6cab14 Niko, Light of Hope -- needs a bit more (#6053)
* Niko, Light of Hope -- needs a bit more

* Fix script

* Add support

---------

Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
2024-09-04 13:03:08 +03:00
Fulgur14
14e2fa9ff5 7 DSK cards from Card Gallery (#6048)
* 7 DSK cards from Card Gallery

* Update acrobatic_cheerleader.txt

* Update fanatic_of_the_harrowing.txt

* Update acrobatic_cheerleader.txt

---------

Co-authored-by: tool4ever <therealtoolkit@hotmail.com>
2024-09-04 13:02:50 +03:00
tool4EvEr
9e30bd943c Manifest Dread 2024-09-04 11:28:18 +02:00
Fulgur14
d33f6296a7 Intervening if triggers with tapped/untapped state (#6037) 2024-09-04 07:12:26 +00:00
Hans Mackowiak
53d9936fb9 CardTraitBase: PresentDefined for Trigger and ReplacementEffects 2024-09-04 07:39:08 +02:00
tool4ever
67edc8d371 DSK: Undead Sprinter (#6050) 2024-09-04 07:24:05 +02:00
Simisays
676174043e DSC 4 cards + moving upcoming to folders (#6027)
* Support Aminatou, Veil Piercer

---------

Co-authored-by: TRT <>
2024-09-04 07:10:42 +02:00
Renato Filipe Vidal Santos
736ccdd893 Add files via upload (#6049) 2024-09-04 08:01:10 +03:00
Jetz
2d233f8ad5 Guava migration - Inline Predicates.or 2024-09-04 00:23:58 -04:00
Jetz
b37f8725ba Guava migration - Inline Predicates.and 2024-09-03 20:22:45 -04:00
Jetz
78bc9fd04e Guava migration - Inline Predicates.not 2024-09-03 09:41:07 -04:00
Jetz
22e7465212 Guava migration - Swap in Predicate.isEqual 2024-09-03 09:12:41 -04:00
Jetz
6b96bca83f Guava migration - Inline Predicates.equalTo 2024-09-03 08:54:18 -04:00
Paul Hammerton
a512990cf5 Merge pull request #6046 from paulsnoops/dsk_fixes
Some DSK card script fixes
2024-09-03 13:17:48 +01:00
Paul Hammerton
7bcb127e9d file_name 2024-09-03 13:10:42 +01:00
Paul Hammerton
e8ce564605 Some DSK card script fixes 2024-09-03 13:08:38 +01:00
Paul Hammerton
8d714fce30 Merge pull request #6026 from Fulgur14/Fulgur14-patch-53
18 Duskmourn cards + 2 Schemes
2024-09-03 12:54:43 +01:00
Paul Hammerton
aa47c8099f Merge pull request #6018 from Lykrast/master
27 cards from 2024 Unknown Events (1 is in mystery booster 2)
2024-09-03 12:53:49 +01:00
Paul Hammerton
bc8f8bb4ff Merge pull request #6038 from Fulgur14/Fulgur14-patch-57
Common dual cycle for DSK
2024-09-03 12:53:20 +01:00
kevlahnota
13c50ffe60 Merge pull request #6043 from kevlahnota/master2
update adventure UI BG
2024-09-03 19:31:47 +08:00
Anthony Calosa
bfaaed2738 increase badge fb resolution 2024-09-03 19:23:26 +08:00
Anthony Calosa
9296aece25 update bg, ui outline 2024-09-03 18:18:02 +08:00
Paul Hammerton
c27af329b1 Merge pull request #6045 from paulsnoops/edition_updates
Edition updates: DSC, DSK, SLD
2024-09-03 10:54:19 +01:00
Paul Hammerton
b56d9b7894 Edition updates: DSC, DSK, SLD 2024-09-03 10:40:23 +01:00
Fulgur14
0f36b53a1e Update kaito_bane_of_nightmares.txt 2024-09-03 08:12:37 +02:00
Anthony Calosa
5b4f093032 pixelized other UI icons, indexed BG color 2024-09-03 13:02:58 +08:00
Anthony Calosa
76b433ec93 downscale tavernevent 2024-09-03 11:54:03 +08:00
Anthony Calosa
b5c46f388a update defeat badge
- u[scale and proper pixelized
2024-09-03 11:34:36 +08:00
kevlahnota
a634ffeb89 Merge pull request #6042 from kevlahnota/master2
fix autosell refresh, update SaveLoadScene
2024-09-03 10:14:00 +08:00
Anthony Calosa
df04f1b1b1 add defeat badge, prevent console toggle when controls are frozen 2024-09-03 10:10:16 +08:00
Anthony Calosa
b785f5042e update location info 2024-09-03 08:56:58 +08:00
Anthony Calosa
13968ffb08 update preview info 2024-09-03 08:30:36 +08:00
Anthony Calosa
b80ac34189 fix autosell refresh, update SaveLoadScene 2024-09-03 08:18:40 +08:00
Jetz
4eb8fddfef Guava migration - Inline Predicates.in 2024-09-02 20:06:49 -04:00
Jetz
ef011d3f51 Guava migration - Inline Predicates.instanceOf 2024-09-02 20:03:13 -04:00
Jetz
77ba9f1728 Guava migration - Inline Predicates.alwaysTrue 2024-09-02 20:00:38 -04:00
Jetz
16c0fa1095 Guava migration - Fix lingering build errors 2024-09-02 19:51:21 -04:00
Jetz
055dff71ce Guava migration - Inline Predicate varargs methods 2024-09-02 19:36:39 -04:00
Jetz
a070feefb2 Guava migration - Remove forwarding overloads 2024-09-02 18:19:04 -04:00
Jetz
67f22c647d Guava migration - Migrate Lists.transform 2024-09-02 18:16:25 -04:00
Jetz
6a87768647 Guava migration - Migrate Suppliers 2024-09-02 18:03:26 -04:00
Jetz
ecf25a8c00 Guava migration - Migrate Optionals 2024-09-02 17:52:18 -04:00
Jetz
8702e299cd Guava migration - Migrate Functions 2024-09-02 17:40:41 -04:00
Jetz
9765279166 Guava migration - Migrate Predicates 2024-09-02 17:08:25 -04:00
Jetz
4d6292802f Guava migration - Migrate static libraries 2024-09-02 14:52:42 -04:00
Agetian
1a1833c588 - Add puzzle PS_BLB3, add support for class level to GameState. (#6039) 2024-09-02 19:59:07 +03:00
Jetz
fb16a46389 Guava migration - Remove Functions dependency 2024-09-02 12:29:50 -04:00
Lykrast
9e28e06d70 Fix ate o clock spell description 2024-09-02 18:23:01 +02:00
Fulgur14
bc056c7f92 Add files via upload 2024-09-02 18:09:47 +02:00
Fulgur14
2fd7f66e25 Update nowhere_to_run.txt 2024-09-02 18:06:36 +02:00
Jetz
bb520b1a60 Guava migration - Create migration scaffold 2024-09-02 12:04:24 -04:00
Jetz
b46c1deeb4 Guava migration - Preliminary 2024-09-02 12:03:59 -04:00
Fulgur14
319e743df1 Common dual cycle for DSK 2024-09-02 18:02:37 +02:00
Fulgur14
205a13ce2a Update nowhere_to_run.txt 2024-09-02 17:56:25 +02:00
Fulgur14
29db7f6ccb Update kaito_bane_of_nightmares.txt 2024-09-02 17:48:51 +02:00
Fulgur14
7322ffbdad Update veteran_survivor.txt 2024-09-02 15:51:16 +02:00
kevlahnota
19d8c7bac6 Merge pull request #6036 from kevlahnota/master2
update adventure defeat penalty
2024-09-02 21:41:47 +08:00
Anthony Calosa
f59ebf64e9 update adventure defeat penalty
- random armor crack (unusable)
- add difficulty indicator in load game preview (red - insane, gold - hard, green - normal, cyan - easy)
2024-09-02 21:38:19 +08:00
Fulgur14
8a409c91b0 Update champions_of_archery_join_the_group.txt (#6035) 2024-09-02 14:18:54 +02:00
Fulgur14
c5da294e05 Update veteran_survivor.txt 2024-09-02 13:21:27 +02:00
tool4ever
229b1562be Some cleaning brought with smaller fixes (#6029)
* Fix Teferi's Imp
2024-09-02 10:47:50 +02:00
Hans Mackowiak
40bc5aa021 GameLoss: use CantHappen for cantLose (#6024)
* GameLoss: use CantHappen for cantLose
2024-09-02 10:35:45 +02:00
Renato Filipe Vidal Santos
bf9a9beac6 Update mishra_claimed_by_gix_mishra_lost_to_phyrexia.txt (#6030) 2024-09-02 07:34:47 +02:00
Fulgur14
e530c3a34c Update veteran_survivor.txt 2024-09-01 19:50:36 +02:00
Fulgur14
695e1344d6 Update overlord_of_the_mistmoors.txt 2024-09-01 19:50:19 +02:00
Fulgur14
6ec11f0a77 Update kaito_bane_of_nightmares.txt 2024-09-01 19:49:59 +02:00
kevlahnota
4db49a094a Merge pull request #6028 from kevlahnota/master2
fix freeze
2024-09-01 20:37:51 +08:00
Anthony Calosa
9aecf60ac7 fix freeze 2024-09-01 20:37:19 +08:00
Chris H
754cfcd79a Fix booster replacement for Bloomburrow 2024-09-01 08:00:53 -04:00
Fulgur14
8d23de631f Add files via upload 2024-09-01 12:20:30 +02:00
Fulgur14
29cbb11e24 18 Duskmourn cards + 2 Schemes 2024-09-01 12:19:45 +02:00
Paul Hammerton
bcbfe14a70 Merge pull request #6023 from paulsnoops/edition_updates
Edition updates: DSC, DSK, SPG
2024-09-01 08:40:28 +01:00
Paul Hammerton
ae2ab498f1 Edition updates: DSC, DSK, SPG 2024-09-01 08:37:00 +01:00
kevlahnota
f8c89995db Merge pull request #6022 from kevlahnota/master2
Disable autosell/nosell labels
2024-09-01 12:08:09 +08:00
Anthony Calosa
00ab0bf50b Disable labels
-todo distinction
2024-09-01 12:06:37 +08:00
kevlahnota
845f7f60f0 Merge pull request #6020 from kevlahnota/master2
update AdventureDeckEditor
2024-09-01 07:20:04 +08:00
Anthony Calosa
cdbc3cfab7 update AdventureDeckEditor
- show Shop prices, show Auto Sell / No Sell card label
2024-09-01 07:12:53 +08:00
Paul Hammerton
256fc780d8 Merge pull request #6019 from paulsnoops/edition_updates
Edition updates: DSK, PRES
2024-08-31 09:53:00 +01:00
Paul Hammerton
d2fb65c108 Edition updates: DSK, PRES 2024-08-31 09:48:20 +01:00
Simisays
6d43aa9152 YBLB 24 cards (#5955)
* update

* Update awestruck_cygnet.txt

* 10 more

* cleanup + last 4

* cleanup

* Update archival_whorl.txt

* cleanup

* Update buxton_decorated_host.txt

* cleanup 2

* cleanup
2024-08-31 07:47:05 +03:00
Lykrast
0db4ac579c Amsterdam cards 2024-08-31 03:10:41 +02:00
tool4ever
080d347199 Fix Conspiracy removing types without choice for new one (#6017)
* Skip incomplete overwrite

* Fix NPE for Unhaunting
2024-08-30 17:13:49 +00:00
Paul Hammerton
cadf278871 Merge pull request #6013 from paulsnoops/mh3_m3c_updates
MH3 & M3C remove unnecessary tokens
2024-08-30 08:52:09 +01:00
kevlahnota
6d42917005 Merge pull request #6016 from kevlahnota/master2
fix noSell cardreward
2024-08-30 09:51:08 +08:00
Anthony Calosa
5978b3ef16 fix noSell cardreward 2024-08-30 09:47:16 +08:00
kevlahnota
20f5bbed98 Merge pull request #6012 from kevlahnota/master2
add autosell toggle for rewards
2024-08-30 06:21:46 +08:00
Anthony Calosa
e184fb20b9 update touchcancelled 2024-08-30 06:15:09 +08:00
Paul Hammerton
9b7659ab84 MH3 & M3C remove unnecessary tokens 2024-08-29 18:34:04 +01:00
Renato Filipe Vidal Santos
d24e296322 PH19: Champions of Archery (#6006) 2024-08-29 16:28:43 +00:00
tool4ever
7421871a36 Merge pull request #5933 from Jetz72/youreInCommand
You're In Command + Support
2024-08-29 18:28:29 +02:00
Anthony Calosa
b1e6e6fd3d update button 2024-08-29 23:09:27 +08:00
Anthony Calosa
4e68ac3807 add autosell toggle for rewards 2024-08-29 22:31:07 +08:00
kevlahnota
78bff0a8f9 Merge pull request #6010 from kevlahnota/master2
update player death transition
2024-08-29 19:36:16 +08:00
Anthony Calosa
f5ab73d32d update player death transition 2024-08-29 19:26:40 +08:00
Hans Mackowiak
239e327f0b ColorlessDamageSource as StaticAbility (#6007)
* ColorlessDamageSource as StaticAbility
2024-08-29 10:06:58 +02:00
kevlahnota
3111e73a63 Merge pull request #6009 from kevlahnota/master2
restrict menu and movement on player defeat dialog
2024-08-29 15:47:33 +08:00
kevlahnota
6a2f185b08 remove uncommited changes 2024-08-29 15:42:17 +08:00
Anthony Calosa
977c11ced0 retrict menu and movement on player defeat dialog 2024-08-29 14:45:54 +08:00
kevlahnota
96080ca479 Merge pull request #6002 from kevlahnota/master2
add resetPlayerLocation on defeat
2024-08-29 11:28:55 +08:00
Anthony Calosa
a3f8b0aca2 fix overlapping dialog, fix player position 2024-08-29 11:24:50 +08:00
Anthony Calosa
14c14b880d update message 2024-08-29 10:40:26 +08:00
Renato Filipe Vidal Santos
36bb086246 YBLB: Shellfish Scholar, Tasteful Offering, Tempest Trapper, Thought Rattle, Three Tree Battalion, Vigorous Farming (#5944) 2024-08-28 20:08:39 +00:00
tool4ever
229fd798fb Fix missing ChangesZoneAll (#6005) 2024-08-28 18:23:31 +00:00
tool4ever
756ba28a14 Some fixes (#6004)
* Fix NPE
2024-08-28 15:54:28 +00:00
Hans Mackowiak
4b533d22a0 StaticAbilityAssignNoCombatDamage (#5998)
* StaticAbilityAssignNoCombatDamage

---------

Co-authored-by: tool4ever <therealtoolkit@hotmail.com>
2024-08-28 17:18:36 +02:00
Anthony Calosa
24d4899cde add resetPlayerLocation on defeat 2024-08-28 21:54:48 +08:00
Renato Filipe Vidal Santos
51abd277d2 MB2: Fetching Garden, Gobland, The Heron Moon, Omenpath to Naya (#5989)
* Add files via upload

* Add files via upload

* Add files via upload

* Update CounterEnumType.java

* Add files via upload

* Add files via upload

* Update CounterEnumType.java
2024-08-28 09:24:48 +03:00
Jetz
a8351fadc7 Fix mapping copied commander effects between games 2024-08-27 20:35:10 -04:00
kevlahnota
53084f43c3 Merge pull request #5991 from Jetz72/fixes20240825
Translation support for functional variants
2024-08-27 12:43:35 +08:00
kevlahnota
27102729ab Merge pull request #5997 from hovergoat/master
Fix for crash when no multikicker cost is paid
2024-08-27 12:40:22 +08:00
hovergoat
7cf9ea0ded Merge branch 'Card-Forge:master' into master 2024-08-26 21:30:20 -04:00
hovergoat
7327d66743 Fixed crash when multikicker is 0 2024-08-26 21:30:05 -04:00
Paul Hammerton
d66666007c Merge pull request #5995 from paulsnoops/bnr_26_aug
Banned and Restricted Announcement for August 26, 2024
2024-08-26 20:57:15 +01:00
Paul Hammerton
c725a49f52 Banned and Restricted Announcement for August 26, 2024 2024-08-26 20:51:36 +01:00
Simisays
927c6fab58 Update sorins_boss_effect.txt (#5985) 2024-08-26 16:47:10 +03:00
Agetian
5890bdffc3 - Improve AI for Searing Blaze (#5987) 2024-08-26 16:45:22 +03:00
kevlahnota
11c0b12ec8 Merge pull request #5993 from kevlahnota/master2
fix actor placement GameHUD -> currentStage
2024-08-26 20:42:02 +08:00
Anthony Calosa
2442883501 adjust blur divisor 2024-08-26 20:27:47 +08:00
Anthony Calosa
c212c41a30 update avatar listener single tap/click set translucency, double tap/click set hud visibility 2024-08-26 20:00:17 +08:00
Anthony Calosa
284a4daf88 update actor groupings 2024-08-26 17:28:24 +08:00
Anthony Calosa
4a8776a2f7 fix actor placement GameHUD -> currentStage
- add hud transluscency via avatar/gamehud double click/tap
2024-08-26 16:58:45 +08:00
Jetz72
bba94d5a9e Merge branch 'Card-Forge:master' into fixes20240825 2024-08-26 00:26:28 -04:00
Jetz
4afc86b4b4 Support functional variants in translations 2024-08-26 00:25:43 -04:00
Renato Filipe Vidal Santos
17ffe17e9d MB2: Slumbering Waterways, Temur Elevator, Under-Construction Skyscraper, Wrenn and One (#5980)
* Add files via upload

* Add files via upload

* Add files via upload

* Add files via upload
2024-08-26 07:04:35 +03:00
kevlahnota
c1edd4a2f4 Merge pull request #5970 from misha-colbourne/hud-visibility-fix
Fixed missing elements from HUD in towns/dungeons/etc
2024-08-26 09:11:43 +08:00
Lykrast
bccc6d81b1 Unknown Event Chicago 2024 (+ edition for amsterdam) 2024-08-25 23:22:21 +02:00
Jetz
fd56341446 DetachedCardEffect GameCopier copying 2024-08-25 16:40:58 -04:00
kevlahnota
68bc50770d Merge pull request #5990 from kevlahnota/master2
update GameHUD items
2024-08-25 22:58:24 +08:00
Anthony Calosa
c13396f984 update GameHUD 2024-08-25 22:51:15 +08:00
Jetz
b97788d8eb DetachedCardEffect LKI copying 2024-08-25 09:58:59 -04:00
Hans Mackowiak
c3a2e67130 CopyPermanentEffect: use DefinedName for special copies (#5988)
* CopyPermanentEffect: use DefinedName for special copies
2024-08-25 10:44:15 +02:00
Hans Mackowiak
3ef0479d76 LandAbility: skip if already in Battlefield 2024-08-25 09:12:55 +02:00
Jetz
7b7dd0f7c3 Fix commander snapshotting
Fix DetachedCardEffect snapshottong
2024-08-24 16:35:35 -04:00
Jetz
34e5938f08 Remove "by Commander Effect" from SA list 2024-08-24 16:34:22 -04:00
kevlahnota
2dc025bf67 LDA Standard - August 7, 2024 2024-08-24 23:01:48 +08:00
tool4ever
30a358dda1 Fix Wheel of Potential (#5983)
* Wheel of Potential revision

* Logic cleanup

---------

Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
2024-08-24 14:25:36 +03:00
Paul Hammerton
6a503ccdbd Merge pull request #5984 from paulsnoops/edition_updates
Edition updates: DSK, SLD and add YBLB to formats
2024-08-24 09:31:30 +01:00
Paul Hammerton
1716fd2e1a Edition updates: DSK, SLD, YBLB (also add YBLB to formats) 2024-08-24 09:26:43 +01:00
kevlahnota
8f4e70aa04 Merge pull request #5982 from kevlahnota/master2
update PlayerStatisticScene, BlurUtils
2024-08-24 12:59:14 +08:00
Chris H
3522492c85 Fix bad logic check (#5981) 2024-08-24 07:51:57 +03:00
Anthony Calosa
e04451b962 update PlayerStatisticScene, BlurUtils
- make blur pixelized
2024-08-24 12:47:30 +08:00
kevlahnota
3bfef56d51 Update insatiable_frugivore.txt
- fixes 5977
2024-08-24 07:45:35 +08:00
Jetz
0b43d3ebf5 Merge branch 'master' into youreInCommand 2024-08-23 19:06:02 -04:00
Jetz
955314527a Single commander effect per player
Support DetachedCardEffect with no source card
2024-08-23 19:04:59 -04:00
Jetz
610488bc22 include components for RememberTargets 2024-08-23 18:55:52 -04:00
kevlahnota
ab11c10fd4 Update config.json
general playtest and some funny cards shouldn't be on adventure unless specified otherwise
2024-08-23 23:45:32 +08:00
kevlahnota
30ae922c5e Merge pull request #5974 from kevlahnota/master2
Update NewGameScene
2024-08-23 19:02:50 +08:00
TRT
45b333b8ac Fix NPE with Brilliant Ultimatum 2024-08-23 12:10:31 +02:00
Agetian
76f4113fb7 - First draft: fix AI for Fireball and Shatterskull Smashing (#5975) 2024-08-23 12:37:23 +03:00
Renato Filipe Vidal Santos
33e5d14ea5 Add files via upload (#5971) 2024-08-23 12:36:02 +03:00
Lykrast
8d433e019d 73 cards from Unknown Events 2023 (some being in mb2) (#5913)
* Unknown Philadelphia 2023 and Minenapolis 2023

* Barcelona 2023 what I could

* A few of the las vegas ones

* Questing role give to creature instead of being on aura

* Changed prizes to promo, should fix phila

And also put the you make the card on a special sheet, should fix a future issue if I got it right

* Fix the etb tapped from bloomburrow patch

Kept old wording for now cause those cards don't have oracle texts, might change if asked

* Las Vegas 2023 (what I could)

* Shortened set codes as suggested

* Fix edition change on las vegas ymtc
2024-08-23 12:35:52 +03:00
Anthony Calosa
b6485e7094 minor 2024-08-23 17:35:19 +08:00
Anthony Calosa
3df84ca71e remove duplicate function 2024-08-23 17:16:33 +08:00
Anthony Calosa
6bba3ee954 minor cleanup 2024-08-23 17:02:13 +08:00
Hans Mackowiak
77710cf1b0 refactor LandAbility to be created by CardFactory (#5047)
---------

Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
2024-08-23 10:57:33 +02:00
Anthony Calosa
c7c2cd74fe Update NewGameScene
- Hint TextButton -> ImageButton
- add Random Avatar Listener
- update NameGenerator Listener
- update disabled Menu text
- use AsyncAudio for Android
2024-08-23 16:53:07 +08:00
kevlahnota
a52e06fb82 Merge pull request #5963 from misha-colbourne/AdventureEnemyFreezeFix
Adventure enemy freeze fix
2024-08-23 13:10:43 +08:00
Agetian
45353b6d73 Fix Scry AI that requires targeting (Kozilek's Command) (#5972)
* - Fix Scry AI that requires targeting (Kozilek's Command)

* - Slight tweak to targeted Scry AI.
2024-08-23 07:38:42 +03:00
misha-colbourne
2ec0061640 Removed lingering outdated comment 2024-08-23 01:36:04 +01:00
misha-colbourne
b9c576ad5d Font tag size constants, cleaned up unused variables I added 2024-08-23 01:28:01 +01:00
misha-colbourne
478ad3a135 Font tag size constants, cleaned up unused variables I added 2024-08-23 00:24:49 +01:00
misha-colbourne
663a712852 Fixed missing elements from HUD when not on world map (now translucent instead of invisible) 2024-08-22 19:31:06 +01:00
Agetian
3ae72e9d8a - Fix AI assuming no token created for non-creature tokens 2024-08-22 12:35:46 +02:00
Renato Filipe Vidal Santos
8ba1edaba7 Update moonstone_harbinger.txt (#5966) 2024-08-22 07:16:54 +02:00
misha-colbourne
a445520ef5 Merge branch 'Card-Forge:master' into AdventureEnemyFreezeFix 2024-08-22 01:24:09 +01:00
misha-colbourne
7ffd7b1d63 Added check for frozen enemy to enemy idle anim condition 2024-08-22 01:19:25 +01:00
Sunnovah
3141293c29 Rename Reap the Tide.dck to Reap the Tides.dck (#5959) 2024-08-21 18:16:04 +00:00
tool4ever
064512ed83 Implement CR 800.4m (#189)
* Relocate effects instead of exiling
2024-08-21 18:14:13 +00:00
Sunnovah
38fb16c64f Rename Stalward Unity [C16] [2016].dck to Stalwart Unity [C16] [2016].dck (#5960) 2024-08-21 18:13:11 +00:00
Chris H
90fcb38fec Fix a few issues with boosters in quest mode 2024-08-21 13:27:49 -04:00
tool4ever
d369c500df Misc cleanup (#5958) 2024-08-21 17:47:25 +02:00
Renato Filipe Vidal Santos
3e2c0198fd Update oracle_en_vec.txt (#5956) 2024-08-21 10:30:15 +02:00
Hans Mackowiak
7ba2d02172 GameActionUtil: use Multikicker as KeywordExtraCost (#5881)
* GameActionUtil: use Multikicker as KeywordExtraCost

* ~ remove getMultiKickerManaCost

* ~ remove Announce$ Multikicker

* some AI tweaks

* Fix MultiKicker for AI

* Update ComputerUtilMana.java

* Update ComputerUtil.java
2024-08-21 10:25:47 +03:00
NimSpork
3df0a15d7d Update alharu_solemn_ritualist.txt (#5952) 2024-08-19 10:45:13 +00:00
Hans Mackowiak
492ff16c12 Keyword: add 'Bands with other' keyword (#5950) 2024-08-19 06:32:44 +02:00
Renato Filipe Vidal Santos
bb07351d4e Update cackling_observer.txt (#5949) 2024-08-18 17:28:43 +00:00
Chris H
d2178756b5 Declare Forge user agent (#5946) 2024-08-18 19:17:43 +02:00
Chris H
80cc302c99 Fix booster generation for editions without booster slots 2024-08-18 10:39:44 -04:00
Renato Filipe Vidal Santos
acf15a65a8 Glyph cleanup: August 2024 pass 2024-08-18 11:37:16 +00:00
Renato Filipe Vidal Santos
7b5f790fe4 Duplication cleanup: pass #1 (#5942) 2024-08-18 09:40:20 +00:00
Jetz
601f6a72c1 Merge branch 'master' into youreInCommand 2024-08-17 15:56:13 -04:00
Jetz
ec7f2be51c Merge branch 'master' into youreInCommand
# Conflicts:
#	forge-game/src/main/java/forge/game/player/Player.java
2024-08-17 15:40:38 -04:00
Jetz
6929231fd5 setCommanders rewrite 2024-08-17 15:21:44 -04:00
Chris H
600cf82308 Only grab BLB cards for Booster Slots. Ideally this would happen by default, but yknow how it goes. 2024-08-17 15:15:12 -04:00
tool4ever
1857d1795d Improve resetOriginalHost (#5939)
Co-authored-by: TRT <>
2024-08-17 09:58:34 +02:00
Renato Filipe Vidal Santos
852cdacb02 Add files via upload (#5868) 2024-08-17 09:58:09 +02:00
Renato Filipe Vidal Santos
fdef390c65 Add files via upload (#5867) 2024-08-17 09:57:58 +02:00
Renato Filipe Vidal Santos
26a5d5caf4 Add files via upload (#5866) 2024-08-17 09:57:45 +02:00
Renato Filipe Vidal Santos
fc80c84df9 Add files via upload (#5869)
Co-authored-by: tool4ever <therealtoolkit@hotmail.com>
2024-08-17 09:57:28 +02:00
Chris H
c2206d533d Fix some issues 2024-08-16 16:57:21 -04:00
Chris H
925819c83e Convert BLB to new Booster Slot definition 2024-08-16 16:57:21 -04:00
Chris H
4554dee721 Generate individual booster slots with individual replacement percentages
Convert MH3 to booster slot percentages
2024-08-16 16:57:21 -04:00
Paul Hammerton
658542309a Merge pull request #5938 from paulsnoops/edition_updates
Edition updates: FDN, MB2, YBLB
2024-08-16 11:42:40 +01:00
Paul Hammerton
5342518b98 YBLB 2024-08-16 11:39:52 +01:00
Paul Hammerton
668c5d64e8 eternal 2024-08-16 11:05:35 +01:00
Paul Hammerton
a2951abac8 Edition updates: FDN, MB2 2024-08-16 11:03:13 +01:00
kevlahnota
c06e97d57b Merge pull request #5937 from kevlahnota/master2
fix NPE
2024-08-16 10:29:35 +08:00
Anthony Calosa
de3b6b82cb fix NPE 2024-08-16 10:27:25 +08:00
Paul Hammerton
e590df1a08 Merge pull request #5934 from dracontes/rb-fdn-2
FDN: Felidar Savior, Helpful Hunter, Prideful Parent, Vengeful Bloodwitch
2024-08-15 17:07:51 +01:00
Renato Filipe Vidal Santos
0ac16b3b28 Update helpful_hunter.txt 2024-08-15 16:54:23 +01:00
Renato Filipe Vidal Santos
00a08d325d Update prideful_parent.txt 2024-08-15 16:53:48 +01:00
Renato Filipe Vidal Santos
7f150ce741 Update ajani_nacatl_pariah_ajani_nacatl_avenger.txt 2024-08-15 16:53:14 +01:00
Renato Filipe Vidal Santos
ec8dc5ff0c Update spirited_companion.txt 2024-08-15 16:52:42 +01:00
Renato Filipe Vidal Santos
4ce94b929f Add files via upload 2024-08-15 16:37:27 +01:00
Renato Filipe Vidal Santos
b7605ee1da Update desert_warfare.txt (#5926) 2024-08-15 17:27:31 +02:00
Jetz
6a53c187ad You're In Command + Support 2024-08-15 09:33:11 -04:00
Paul Hammerton
038374c3c5 Merge pull request #5931 from paulsnoops/edition_updates
Edition updates: FDN, SLD, YBLB
2024-08-15 10:46:44 +01:00
Paul Hammerton
d3fd7523e2 Edition updates: FDN, SLD, YBLB 2024-08-15 10:42:51 +01:00
Renato Filipe Vidal Santos
6ef5acbd51 Update planequake.txt (#5928) 2024-08-15 09:52:46 +02:00
Renato Filipe Vidal Santos
6f110c114a Update long_river_lurker.txt (#5927) 2024-08-15 09:52:18 +02:00
Chris H
df78ac9a73 Update karn_living_legacy.txt (#5930) 2024-08-15 08:44:45 +02:00
Simisays
9201ccb390 UNF last 3 attractions (#5845)
* update

* cleanup

* Update tunnel_of_love.txt
2024-08-15 05:26:20 +03:00
Chris H
8be414d9dd Blb release (#5929)
* [maven-release-plugin] prepare release forge-1.6.64

* [maven-release-plugin] prepare for next development iteration

* Update pom.xml

* Update AndroidManifest.xml

* Update pom.xml

* Update Forge.java

---------

Co-authored-by: GitHub Actions <actions@github.com>
2024-08-14 21:06:29 -04:00
Renato Filipe Vidal Santos
60d3b7a898 Update temporal_aperture.txt (#5922) 2024-08-14 19:50:08 +02:00
Paul Hammerton
bdade41a24 Merge pull request #5924 from paulsnoops/fix_mb2
Fix MB2
2024-08-14 10:57:35 +01:00
Paul Hammerton
0c06eaa04a Fix MB2 2024-08-14 10:53:28 +01:00
Paul Hammerton
6847247519 Merge pull request #5923 from paulsnoops/edition_updates
Edition updates: MB2, SLD, YBLB
2024-08-14 10:27:01 +01:00
Paul Hammerton
d112109d2a spacing 2024-08-14 10:22:11 +01:00
Paul Hammerton
fd43fa8829 Edition updates: MB2, SLD, YBLB 2024-08-14 10:16:09 +01:00
kevlahnota
024bf68040 Merge pull request #5920 from kevlahnota/master2
Update Sentry
2024-08-14 13:26:48 +08:00
Renato Filipe Vidal Santos
e89a4f6593 Update norns_fetchling.txt (#5893)
* Update norns_fetchling.txt

* Update norns_fetchling.txt
2024-08-14 06:42:36 +03:00
Renato Filipe Vidal Santos
f744642acb Update takklemaggot.txt (#5882) 2024-08-14 06:42:22 +03:00
Renato Filipe Vidal Santos
4f843052eb Add files via upload (#5878) 2024-08-14 06:41:54 +03:00
Anthony Calosa
4deff44f76 remove hint 2024-08-14 06:40:45 +08:00
Chris H
6886992009 Fix bad references for snapshots 2024-08-13 14:53:19 -04:00
tool4ever
67b18b2e08 Update scripts (#5919) 2024-08-13 19:37:43 +02:00
Anthony Calosa
4a2991588b Update Sentry libs
- fix Java Property on startup
2024-08-13 20:11:20 +08:00
Anthony Calosa
3541fe1157 Merge branch 'master' into master2 2024-08-13 18:06:34 +08:00
tool4ever
35b898cc5a Script fixes (#5912) 2024-08-13 08:30:14 +02:00
Renato Filipe Vidal Santos
61aaa8a715 Update ulamog_the_defiler.txt (#5915) 2024-08-13 08:29:44 +02:00
Renato Filipe Vidal Santos
fb4f36bb09 Fixing Rootwater Matriarch (#5909) 2024-08-13 08:24:06 +02:00
Anthony Calosa
425c8b830b Merge branch 'master' into master2 2024-08-13 05:54:11 +08:00
Chris H
9c40c21026 External IP check should use https 2024-08-12 16:28:20 -04:00
Anthony Calosa
73c31613c1 Merge branch 'master' into master2 2024-08-12 19:13:35 +08:00
Jetz72
8f77b1e3ce GamePieceType and isCollectible (#5889)
* GamePieceType and isCollectible.
Can no longer ante conjured cards.
Helper set of ZoneTypes that are part of the command zone.

* Faster GamePieceType evaluation

---------

Co-authored-by: Jetz <Jetz722@gmail.com>
2024-08-12 09:35:16 +02:00
Hans Mackowiak
825781446f Update TypeLists.txt
Add Snail
2024-08-12 09:20:52 +02:00
Agetian
ddfa841e5d - Add puzzle PS_BLB2. (#5911) 2024-08-12 06:00:01 +03:00
Fulgur14
6c5b6a0da4 Update cryptic_spires.txt (#5906)
I think it produces one mana of EACH color (I had AI use it to pay {2} UnlessCost). But I don't know how to fix that, so I have at least corrected the text.
2024-08-12 05:47:36 +03:00
Renato Filipe Vidal Santos
037a5d90dd Fixing Nykthos, Shrine to Nyx and other related cards (#5905)
* Update nykthos_shrine_to_nyx.txt

* Update astral_cornucopia.txt

* Update nyx.txt

* Update rhystic_cave.txt

* Update three_tree_city.txt

* Update three_tree_city.txt

* Update nyx_lotus.txt
2024-08-12 05:47:28 +03:00
tool4ever
e93b130a36 Merge pull request #5865 from tool4ever/uphill
Fix Uphill Battle
2024-08-11 20:26:46 +02:00
tool4ever
6c7600dd1b Merge pull request #5895 from Jetz72/code-cleanup
Miscallaneous Cleanup Part 3
2024-08-11 19:30:21 +02:00
kevlahnota
af060121cf Update Mobile Build (#5813)
* LibGDX Update

* unused import

* disable minimize on screen lock
2024-08-11 19:12:29 +02:00
tool4ever
d2c42071aa Fix token CMC when copying (#5898)
* Fix token CMC when copying

* Fix TDFC token copy using front CMC

---------

Co-authored-by: TRT <>
2024-08-11 19:09:59 +02:00
Renato Filipe Vidal Santos
05b7265473 Update overblaze.txt (#5886) 2024-08-11 17:30:43 +02:00
Paul Hammerton
85e608fb76 Merge pull request #5903 from paulsnoops/edition_updates
Edition updates: MB2, SLP
2024-08-11 11:13:20 +01:00
Paul Hammerton
79f715c8f7 Edition updates: MB2, SLP 2024-08-11 11:03:36 +01:00
Anthony Calosa
2dde6b4044 Merge branch 'master' into master2 2024-08-11 16:02:18 +08:00
Renato Filipe Vidal Santos
4d6d84f0b1 Update chrome_courier.txt (#5902) 2024-08-11 09:04:25 +02:00
Hans Mackowiak
9f8c5b96ec ~NPE fix 2024-08-11 07:58:30 +02:00
Renato Filipe Vidal Santos
e60194c265 Add files via upload (#5885) 2024-08-11 08:14:48 +03:00
Jetz
27046744a4 Cleanup - Unused imports 2024-08-10 13:14:53 -04:00
Jetz
2fb7ad0c7b Cleanup - Statement lambda -> expression lambda 2024-08-10 12:58:32 -04:00
Jetz
a7e1338eea Cleanup - valueOf -> parseInt 2024-08-10 12:55:49 -04:00
Jetz
f7d0929ea0 Cleanup - More Lambdas to method references 2024-08-10 12:54:16 -04:00
Jetz
4614c6c0c9 Cleanup - Map.getOrDefault and Map.computeIfAbsent 2024-08-10 12:48:52 -04:00
Jetz
bdc890c32c Cleanup - Collections.sort -> list.sort 2024-08-10 12:43:38 -04:00
Jetz
0ee46ff6ef Cleanup - .equals("") -> .isEmpty() 2024-08-10 12:28:18 -04:00
Jetz
9bbe4805a3 Cleanup - Redundant String.format 2024-08-10 12:21:50 -04:00
Jetz
daa9d59a67 Cleanup - addAll -> constructor parameter 2024-08-10 12:17:54 -04:00
Jetz
b417946032 Cleanup - PowerMock ignores for newer JDKs 2024-08-10 12:12:05 -04:00
Jetz
09c76a4dc8 Cleanup - File IO streams 2024-08-10 11:09:31 -04:00
Jetz
8e3d02f1aa Cleanup - Collection.addAll 2024-08-10 10:30:05 -04:00
Jetz
ae9877ce3c Cleanup - Collection.toArray 2024-08-10 10:25:35 -04:00
Jetz
158ff30ff8 Cleanup - Missing break from loop with no further consequences 2024-08-10 10:19:01 -04:00
Anthony Calosa
63fd172f34 Merge branch 'master' into master2 2024-08-10 21:44:41 +08:00
Paul Hammerton
fae5cfc87e Merge pull request #5887 from paulsnoops/edition_updates
Edition updates: MB2, SLD
2024-08-10 14:03:45 +01:00
Paul Hammerton
057ed2333d Merge pull request #5888 from paulsnoops/mb2_formats
Format updates: MB2
2024-08-10 14:01:16 +01:00
Paul Hammerton
cc6d3aa2e4 fix_tests 2024-08-10 14:00:57 +01:00
Paul Hammerton
c31385a943 Format updates: MB2 2024-08-10 13:56:44 +01:00
Paul Hammerton
134c7d5cf7 Edition updates: MB2, SLD 2024-08-10 13:51:46 +01:00
Anthony Calosa
7cd66d9742 Merge branch 'master' into master2 2024-08-10 18:58:53 +08:00
Hans Mackowiak
10f6d176bd DigEffect: fix moveParams reused 2024-08-10 12:03:33 +02:00
Renato Filipe Vidal Santos
64f6ebb3dd Update rush_of_dread.txt (#5884) 2024-08-10 09:01:31 +02:00
TRT
9fe6b06487 Clean up 2024-08-09 22:28:14 +02:00
tool4ever
e7e403bb3a Update moonstone_harbinger.txt 2024-08-09 21:56:53 +02:00
Hans Mackowiak
7128b386cf Update starlit_soothsayer.txt 2024-08-09 16:39:34 +02:00
Anthony Calosa
eeffb6bc89 Merge branch 'master' into master2 2024-08-09 19:17:22 +08:00
Renato Filipe Vidal Santos
a415a5fe9d Add files via upload (#5880) 2024-08-09 13:41:54 +03:00
Hans Mackowiak
a800bf681c GameActionUtil: store OptionalKeywordAmount in CastSA (#5853)
* GameActionUtil: store OptionalKeywordAmount in CastSA

* ~ rename and make into a Table
2024-08-08 22:16:17 +02:00
Fulgur14
021ac6c155 Update arthur_marigold_knight.txt (#5877)
* Update arthur_marigold_knight.txt
2024-08-08 20:28:25 +02:00
Fulgur14
508c0641ee Update dragonhawk_fates_tempest.txt (#5875) 2024-08-08 13:53:40 +02:00
Hans Mackowiak
54aba92c13 Update barkform_harvester.txt 2024-08-08 08:15:01 +02:00
Anthony Calosa
36a8df17b7 Merge branch 'master' into master2 2024-08-07 19:57:40 +08:00
Hans Mackowiak
0b4814542e CardFactory: add offspring imagekey (#5871) 2024-08-07 12:32:05 +02:00
TRT
22aa5d8e08 Fix Garth + Uphill Battle 2024-08-07 08:26:13 +02:00
Hans Mackowiak
0b1acbd71d Update AiController.java (#5863)
* Update AiController.java

Add RepParams for AddCounter

* Update check with new required params

---------

Co-authored-by: TRT <>
2024-08-07 07:17:46 +02:00
TRT
0a773c30bc Fix Uphill Battle 2024-08-06 21:11:22 +02:00
Renato Filipe Vidal Santos
e978c65d35 File end cleanup for August 2024: every relevant script folder except for 'upcoming' (#5854)
* Add files via upload

* Add files via upload
2024-08-06 19:19:54 +03:00
Anthony Calosa
c4c800c9fa Merge branch 'master' into master2 2024-08-06 21:18:41 +08:00
Hans Mackowiak
0e72dfb563 Update Card.java
Fix NullPTR
2024-08-06 15:13:15 +02:00
Paul Hammerton
a2deca2775 Merge pull request #5862 from paulsnoops/rebalance_05_08
Historic Rebalancing for August 05, 2024
2024-08-06 13:40:05 +01:00
Hans Mackowiak
11c3e88bdf Update incubator_c_0_0_a_phyrexian.txt
add missing ManaCost:no cost
2024-08-06 13:52:02 +02:00
Paul Hammerton
c4325cb0ba Historic Rebalancing for August 05, 2024 2024-08-06 12:48:19 +01:00
Agetian
f7547a4059 - Update cubes (enable Cogwork Librarian) (#5861) 2024-08-06 08:41:23 +03:00
Agetian
e64ed6f9ca Add MTGO Vintage Cube June 2024 (#5859)
* - Add puzzle PS_BLB1.

* - Add MTGO Vintage Cube June 2024.
2024-08-06 08:27:26 +03:00
Renato Filipe Vidal Santos
09cad83e85 Add files via upload (#5852) 2024-08-06 06:31:40 +03:00
tool4ever
6268448dfe Register LTB trigger extra during replacements (#5851)
Co-authored-by: TRT <>
2024-08-06 06:31:09 +03:00
Hans Mackowiak
140791ead7 Apply ReplaceAddCounter with ReplaceMoved for ETB Counter (#5791)
* Apply ReplaceAddCounter with ReplaceMoved for ETB Counter

* ~ fix EffectOnly for ETB Counters
2024-08-05 22:40:47 +02:00
Agetian
f186394457 - Add puzzle PS_BLB1. (#5850) 2024-08-05 20:44:05 +03:00
Renato Filipe Vidal Santos
3b749212d7 Delete forge-gui/tools/cardTemplateScript.py (#5844) 2024-08-05 10:23:22 +02:00
Renato Filipe Vidal Santos
42f829f0f1 Update eastfarthing_farmer.txt (#5846) 2024-08-05 10:03:17 +02:00
Renato Filipe Vidal Santos
95c35ae475 Update niko_aris.txt (#5848) 2024-08-05 09:36:16 +02:00
Renato Filipe Vidal Santos
baf4bc4fc7 Update custodi_squire.txt (#5847) 2024-08-05 09:35:34 +02:00
Hans Mackowiak
98eafe7fd3 Update star_charter.txt 2024-08-05 09:26:22 +02:00
Renato Filipe Vidal Santos
9f7a0374fd ETB update: Java code: Card.java, CardFactoryUtil.java (#5839)
* Add files via upload

* Update CardFactoryUtil.java
2024-08-05 07:06:29 +02:00
Hans Mackowiak
a0394634dd Update nearby_planet.txt 2024-08-05 07:04:56 +02:00
Renato Filipe Vidal Santos
011c2570f4 ETB update: 'tokenscripts', 'custom_cards' in \adventure (#5837)
* Add files via upload

* Add files via upload

* Update rg_1_1_dragon_flying_devour.txt
2024-08-05 07:02:08 +02:00
Renato Filipe Vidal Santos
a830b2e963 Add files via upload (#5842) 2024-08-05 07:01:58 +02:00
Anthony Calosa
a2a9eef7a0 Merge branch 'master' into master2 2024-08-05 05:08:42 +08:00
tool4ever
42bb3cf500 Fix Kozilek's Command allowing X>0 on cascade (#5808) 2024-08-04 21:58:19 +02:00
Renato Filipe Vidal Santos
e59c65de59 ETB update: Card folder 's', part 2 (#5829) 2024-08-04 21:57:51 +02:00
Renato Filipe Vidal Santos
45081ab045 Add files via upload (#5840) 2024-08-04 21:50:49 +02:00
Renato Filipe Vidal Santos
919538f33b Add files via upload (#5836) 2024-08-04 21:46:21 +02:00
Renato Filipe Vidal Santos
9253554289 ETB update: Card folder 's', part 8 (#5835)
* Add files via upload

* Update struggle_for_project_purity.txt
2024-08-04 21:46:17 +02:00
Renato Filipe Vidal Santos
64553eeccf Add files via upload (#5834) 2024-08-04 21:46:09 +02:00
Renato Filipe Vidal Santos
ab2126e56d Add files via upload (#5833) 2024-08-04 21:46:02 +02:00
Renato Filipe Vidal Santos
48e375625d Add files via upload (#5832) 2024-08-04 21:45:55 +02:00
Renato Filipe Vidal Santos
21907f8a9c ETB update: Card folder 's', part 4 (#5831)
* Add files via upload

* Update sisterhood_of_karn.txt
2024-08-04 21:45:46 +02:00
Renato Filipe Vidal Santos
820b6863a4 Add files via upload (#5830) 2024-08-04 21:45:39 +02:00
Renato Filipe Vidal Santos
ab4ea1965d ETB update: Card folder 's', part 1 (#5828)
* Add files via upload

* Update savvy_trader.txt
2024-08-04 21:45:27 +02:00
Renato Filipe Vidal Santos
b15d71748e ETB update: Java code: AiController.java 2024-08-04 20:52:10 +02:00
Renato Filipe Vidal Santos
e6dc3e193f ETB update: Java code: GameActionUtil.java 2024-08-04 20:51:12 +02:00
maulet218
c0f0494c51 Update mouse_trapper.txt (#5843) 2024-08-04 19:10:04 +02:00
Anthony Calosa
85d0a6368d Merge branch 'master' into master2 2024-08-04 18:20:40 +08:00
Paul Hammerton
b9f88568ce Merge pull request #5827 from paulsnoops/update_psgd
Edition updates: PSDG
2024-08-04 11:15:58 +01:00
Paul Hammerton
13f0e75b05 Edition updates: PSDG 2024-08-04 11:12:22 +01:00
tool4ever
40422f6c01 Update lizard_blades.txt (#5826)
Closes #5821
2024-08-04 12:09:29 +02:00
Renato Filipe Vidal Santos
b2bcbae028 Update and rename velican_dragon.txt to velukan_dragon.txt (#5816) 2024-08-04 13:06:12 +03:00
Paul Hammerton
2408d42c1b Merge pull request #5825 from dracontes/rb-etb-63
ETB update: Card folder 'r', part 4
2024-08-04 11:03:49 +01:00
Paul Hammerton
7ae3c175da Merge pull request #5809 from dracontes/rb-etb-51
ETB update: Card folder 'w', part 1
2024-08-04 11:00:56 +01:00
Paul Hammerton
42ab3e0b30 Merge pull request #5810 from dracontes/rb-etb-52
ETB update: Card folder 'w', part 2
2024-08-04 11:00:47 +01:00
Paul Hammerton
ba5b0b7de3 Merge pull request #5811 from dracontes/rb-etb-53
ETB update: Card folder 'v', part 1
2024-08-04 11:00:38 +01:00
Paul Hammerton
86ae216323 Merge pull request #5812 from dracontes/rb-etb-54
ETB update: Card folder 'v', part 2
2024-08-04 11:00:22 +01:00
Paul Hammerton
fb08136bfc Merge pull request #5814 from dracontes/rb-etb-55
ETB update: Card folder 'u'
2024-08-04 11:00:13 +01:00
Paul Hammerton
5f2af0b48f Merge pull request #5817 from dracontes/rb-etb-56
ETB update: Card folder 't', part 1
2024-08-04 11:00:03 +01:00
Paul Hammerton
81e24b0e5b Merge pull request #5818 from dracontes/rb-etb-57
ETB update: Card folder 't', part 2
2024-08-04 10:59:54 +01:00
Paul Hammerton
31665957ee Merge pull request #5819 from dracontes/rb-etb-58
ETB update: Card folder 't', part 3
2024-08-04 10:59:46 +01:00
Paul Hammerton
b158dd7727 Merge pull request #5820 from dracontes/rb-etb-59
ETB update: Card folder 't', part 4
2024-08-04 10:59:37 +01:00
Paul Hammerton
e104ba24d1 Merge pull request #5822 from dracontes/rb-etb-60
ETB update: Card folder 'r', part 1
2024-08-04 10:59:28 +01:00
Paul Hammerton
76e9093125 Merge pull request #5823 from dracontes/rb-etb-61
ETB update: Card folder 'r', part 2
2024-08-04 10:59:18 +01:00
Paul Hammerton
6090924333 Merge pull request #5824 from dracontes/rb-etb-62
ETB update: Card folder 'r', part 3
2024-08-04 10:59:08 +01:00
Renato Filipe Vidal Santos
40793a5438 Add files via upload 2024-08-04 09:43:02 +01:00
Renato Filipe Vidal Santos
bbdec4bbb6 Add files via upload 2024-08-04 09:41:24 +01:00
Renato Filipe Vidal Santos
2719707677 Add files via upload 2024-08-04 09:39:28 +01:00
Renato Filipe Vidal Santos
ad10f8f754 Add files via upload 2024-08-04 09:37:32 +01:00
Renato Filipe Vidal Santos
8c74cf6bc4 Update the_lost_and_the_damned.txt 2024-08-04 08:25:09 +01:00
Renato Filipe Vidal Santos
5edbe2711c Add files via upload 2024-08-04 08:19:51 +01:00
Renato Filipe Vidal Santos
341f53a32e Add files via upload 2024-08-04 08:17:54 +01:00
Renato Filipe Vidal Santos
d386012121 Add files via upload 2024-08-04 08:16:05 +01:00
Renato Filipe Vidal Santos
e31df628de Add files via upload 2024-08-04 08:14:13 +01:00
Agetian
5e951cc05c - Bloomburrow achievements by Marek14 (#5815) 2024-08-04 09:30:06 +03:00
Renato Filipe Vidal Santos
5d1fdcff2f Update unstable_amulet.txt 2024-08-04 06:20:01 +01:00
Renato Filipe Vidal Santos
28b176d322 Add files via upload 2024-08-04 06:12:26 +01:00
Anthony Calosa
e4106b8037 disable minimize on screen lock 2024-08-04 13:05:36 +08:00
Renato Filipe Vidal Santos
49d3467612 Delete forge-gui/res/cardsfolder/v/vona_de_ledo_the_antifex.txt 2024-08-04 06:04:24 +01:00
Renato Filipe Vidal Santos
3b5a533d05 Update vona_de_iedo_the_antifex.txt 2024-08-04 06:02:32 +01:00
Anthony Calosa
5f01fb09bb unused import 2024-08-04 12:52:55 +08:00
Renato Filipe Vidal Santos
0076dcb47d Add files via upload 2024-08-04 05:51:12 +01:00
Renato Filipe Vidal Santos
ab76367322 Add files via upload 2024-08-04 05:49:27 +01:00
Anthony Calosa
2cd3347429 LibGDX Update 2024-08-04 12:47:39 +08:00
Renato Filipe Vidal Santos
97e29b6aea Update wort_the_raidmother.txt 2024-08-04 05:44:04 +01:00
Renato Filipe Vidal Santos
2806c32e9e Add files via upload 2024-08-04 05:38:28 +01:00
Renato Filipe Vidal Santos
5663a4acfd Add files via upload 2024-08-04 05:36:42 +01:00
kevlahnota
7d1e9a4c64 Merge pull request #5789 from Fulgur14/Fulgur14-patch-32
Update arms_of_hadar.txt
2024-08-04 08:40:00 +08:00
kevlahnota
da941d5163 Merge pull request #5806 from dracontes/rb-etb-50
ETB update: Card folders 'q', 'x' to 'z'
2024-08-04 08:37:25 +08:00
kevlahnota
e38a93ebb3 Merge pull request #5805 from dracontes/rb-etb-49
ETB update: Card folder 'p', part 3
2024-08-04 08:37:13 +08:00
kevlahnota
7743572750 Merge pull request #5804 from dracontes/rb-etb-48
ETB update: Card folder 'p', part 2
2024-08-04 08:37:04 +08:00
kevlahnota
995e7d6ac3 Merge pull request #5803 from dracontes/rb-etb-47
ETB update: Card folder 'p', part 1
2024-08-04 08:36:51 +08:00
kevlahnota
9d96f93f02 Merge pull request #5802 from dracontes/rb-etb-46
ETB update: Card folder 'o', part 2
2024-08-04 08:36:45 +08:00
kevlahnota
8832c7186c Merge pull request #5801 from dracontes/rb-etb-45
ETB update: Card folder 'o', part 1
2024-08-04 08:36:30 +08:00
kevlahnota
71e3cdd401 Merge pull request #5800 from dracontes/rb-etb-44
ETB update: Card folder 'n', part 2
2024-08-04 08:36:20 +08:00
kevlahnota
edbd7f5a92 Merge pull request #5799 from dracontes/rb-etb-43
ETB update: Card folder 'n', part 1
2024-08-04 08:36:10 +08:00
kevlahnota
8b2ff70f16 Merge pull request #5796 from Simisays/MYRA
UNF Myra the Magnificent
2024-08-04 08:35:59 +08:00
kevlahnota
0e073ee6b0 Merge pull request #5795 from dracontes/rb-etb-42
ETB update: Card folder 'm', part 4
2024-08-04 08:35:19 +08:00
kevlahnota
a421e1f599 Merge pull request #5794 from dracontes/rb-etb-41
ETB update: Card folder 'm', part 3
2024-08-04 08:34:53 +08:00
kevlahnota
244cdba75e Merge pull request #5793 from dracontes/rb-etb-40
ETB update: Card folder 'm', part 2
2024-08-04 08:34:39 +08:00
kevlahnota
3c1276e2ec Merge pull request #5792 from dracontes/rb-etb-39
ETB update: Card folder 'm', part 1
2024-08-04 08:34:21 +08:00
kevlahnota
b496b4e17c Update whiskerquill_scribe.txt 2024-08-04 06:17:28 +08:00
Renato Filipe Vidal Santos
18fd38e075 Add files via upload 2024-08-03 19:25:55 +01:00
Renato Filipe Vidal Santos
0f3d0ecbd1 Add files via upload 2024-08-03 19:25:16 +01:00
Renato Filipe Vidal Santos
363a3592ea Add files via upload 2024-08-03 19:24:32 +01:00
Renato Filipe Vidal Santos
fff4520e31 Add files via upload 2024-08-03 19:23:28 +01:00
Renato Filipe Vidal Santos
52841af4cd Update phage_the_untouchable.txt 2024-08-03 19:10:55 +01:00
Renato Filipe Vidal Santos
0e5918bfb4 Update park_heights_pegasus.txt 2024-08-03 19:06:48 +01:00
Renato Filipe Vidal Santos
7d7e64c998 Update palace_siege.txt 2024-08-03 19:04:24 +01:00
Renato Filipe Vidal Santos
9c4ba92a1d Add files via upload 2024-08-03 18:59:48 +01:00
Renato Filipe Vidal Santos
04e6ed33e4 Add files via upload 2024-08-03 18:58:23 +01:00
Renato Filipe Vidal Santos
21d40115cb Add files via upload 2024-08-03 18:56:45 +01:00
Renato Filipe Vidal Santos
09a7fe93a5 Update outpost_siege.txt 2024-08-03 18:39:58 +01:00
Renato Filipe Vidal Santos
3d68c1b626 Add files via upload 2024-08-03 18:33:03 +01:00
Renato Filipe Vidal Santos
ae0c9d9095 Add files via upload 2024-08-03 18:31:34 +01:00
Renato Filipe Vidal Santos
0150b068c0 Update necromancy.txt 2024-08-03 18:01:23 +01:00
Renato Filipe Vidal Santos
df3106bbf5 Add files via upload 2024-08-03 17:57:54 +01:00
Renato Filipe Vidal Santos
d070d65972 Add files via upload 2024-08-03 17:56:20 +01:00
Paul Hammerton
e65813dffb Merge pull request #5797 from paulsnoops/edition_updates
Edition updates: SCH, SLD, SLP
2024-08-03 17:23:37 +01:00
Paul Hammerton
289874c118 Edition updates: SCH, SLD, SLP 2024-08-03 17:20:17 +01:00
Simisays
cc70e5dbc8 Create myra_the_magnificent.txt 2024-08-03 17:32:35 +02:00
Renato Filipe Vidal Santos
2d20602ff4 Add files via upload (#5788) 2024-08-03 17:53:49 +03:00
Renato Filipe Vidal Santos
831bb2d0ac Add files via upload (#5787) 2024-08-03 17:53:40 +03:00
Renato Filipe Vidal Santos
bfe8c85e15 Add files via upload (#5786) 2024-08-03 17:53:31 +03:00
Renato Filipe Vidal Santos
38507f7b28 Add files via upload (#5785) 2024-08-03 17:53:18 +03:00
Renato Filipe Vidal Santos
3bd59a50af Add files via upload (#5784) 2024-08-03 17:52:58 +03:00
Renato Filipe Vidal Santos
dbf5a6e4c4 ETB update: Card folder 'i', part 2 (#5783)
* Add files via upload

* Update invasion_of_new_capenna_holy_frazzle_cannon.txt

* Update invasion_of_segovia_caetus_sea_tyrant_of_segovia.txt
2024-08-03 17:52:47 +03:00
Renato Filipe Vidal Santos
5976241f15 ETB update: Card folder 'i', part 1 (#5782)
* Add files via upload

* Update icatian_moneychanger.txt

* Update icatian_moneychanger.txt

* Update ian_chesterton.txt
2024-08-03 17:52:39 +03:00
Renato Filipe Vidal Santos
2a8ca80759 Add files via upload (#5781) 2024-08-03 17:52:29 +03:00
Renato Filipe Vidal Santos
c0e67cb876 ETB update: Card folder 'h', part 2 (#5780)
* Add files via upload

* Update hopeful_vigil.txt

* Update hopeless_nightmare.txt
2024-08-03 17:52:22 +03:00
Renato Filipe Vidal Santos
ceffad4a3d Add files via upload (#5779) 2024-08-03 17:52:13 +03:00
Renato Filipe Vidal Santos
aa7a43fd9e ETB update: Card folders 'rebalanced', 'upcoming' (#5778)
* Add files via upload

* Add files via upload

* Update kassandra_eagle_bearer.txt

* Update yggdrasil_rebirth_engine.txt
2024-08-03 17:52:02 +03:00
Renato Filipe Vidal Santos
c94b85dafa Add files via upload (#5777) 2024-08-03 17:51:45 +03:00
Renato Filipe Vidal Santos
187fb396e8 ETB update: Card folder 'g', part 3 (#5776)
* Add files via upload

* Update grimgrin_corpse_born.txt

* Update grafdiggers_cage.txt

* Update grafdiggers_cage.txt
2024-08-03 17:51:37 +03:00
Renato Filipe Vidal Santos
72476dd8a1 ETB update: Card folder 'g', part 2 (#5775)
* Add files via upload

* Update gnawing_vermin.txt
2024-08-03 17:51:28 +03:00
Renato Filipe Vidal Santos
7628617044 ETB update: Card folder 'g', part 1 (#5774)
* Add files via upload

* Update ghitu_amplifier.txt
2024-08-03 17:51:19 +03:00
Renato Filipe Vidal Santos
b45a232e51 ETB update: Card folder 'f', part 3 (#5773)
* Add files via upload

* Update frontier_siege.txt
2024-08-03 17:50:51 +03:00
Renato Filipe Vidal Santos
7146e72a56 Add files via upload (#5772) 2024-08-03 17:50:41 +03:00
Renato Filipe Vidal Santos
623d4d5670 Add files via upload (#5771) 2024-08-03 17:50:32 +03:00
Renato Filipe Vidal Santos
ee94dbd401 ETB update: Card folder 'e', part 2 (#5770)
* Add files via upload

* Add files via upload
2024-08-03 17:50:23 +03:00
Renato Filipe Vidal Santos
09b3784e74 ETB update: Card folder 'e', part 1 (#5769)
* Add files via upload

* Update eastfarthing_farmer.txt

* Update epochrasite.txt

* Update epochrasite.txt
2024-08-03 17:50:15 +03:00
Renato Filipe Vidal Santos
e1f3aa42e7 Add files via upload (#5767) 2024-08-03 17:49:50 +03:00
Renato Filipe Vidal Santos
08ebcc6792 Add files via upload (#5766) 2024-08-03 17:49:42 +03:00
Renato Filipe Vidal Santos
1452a2bc62 ETB update: Card folder 'd', part 2 (#5764)
* Add files via upload

* Update diregraf_horde.txt
2024-08-03 17:49:34 +03:00
Renato Filipe Vidal Santos
11408f488a ETB update: Card folder 'd', part 1 (#5763)
* Add files via upload

* Update dance_of_the_dead.txt
2024-08-03 17:49:26 +03:00
Renato Filipe Vidal Santos
dc917e5ab6 Update myriad_construct.txt 2024-08-03 15:41:36 +01:00
Renato Filipe Vidal Santos
5e31dbb7db Update monastery_siege.txt 2024-08-03 15:33:50 +01:00
Renato Filipe Vidal Santos
803a8c154d Update mirrodin_besieged.txt 2024-08-03 15:30:14 +01:00
Renato Filipe Vidal Santos
2d5cd4870d Update master_chef.txt 2024-08-03 15:07:42 +01:00
Renato Filipe Vidal Santos
387da4441a Add files via upload 2024-08-03 14:56:27 +01:00
Paul Hammerton
aedcc83d00 Merge pull request #5790 from Simisays/Promos
New promos from Treasure chests and Legacy/Vintage championships
2024-08-03 14:55:46 +01:00
Renato Filipe Vidal Santos
a29ebd3f5a Add files via upload 2024-08-03 14:52:46 +01:00
Paul Hammerton
982c2eeab5 Update CardDbCardMockTestCase.java 2024-08-03 14:52:03 +01:00
Renato Filipe Vidal Santos
7c8c343583 Add files via upload 2024-08-03 14:48:52 +01:00
Paul Hammerton
30c10f5e08 Update CardDbCardMockTestCase.java 2024-08-03 14:46:03 +01:00
Renato Filipe Vidal Santos
6a5fb919a1 Add files via upload 2024-08-03 14:45:34 +01:00
Paul Hammerton
6539301787 Update Treasure Chests.txt 2024-08-03 14:40:07 +01:00
Paul Hammerton
1d443eb337 Update CardDbCardMockTestCase.java 2024-08-03 14:34:35 +01:00
Simisays
612df58b41 Update Treasure Chests.txt 2024-08-03 14:05:05 +02:00
Simisays
8f74e730cb Update Treasure Chests.txt 2024-08-03 14:03:49 +02:00
Simisays
f1b5b3570b update 2024-08-03 13:53:58 +02:00
Fulgur14
a3777ae42e Update arms_of_hadar.txt 2024-08-03 13:30:56 +02:00
tool4ever
16d3374314 Update rottenmouth_viper.txt 2024-08-02 20:05:58 +00:00
kevlahnota
730d9cc973 Merge pull request #5762 from kevlahnota/master2
fix ToggleButton
2024-08-02 22:10:35 +08:00
Anthony Calosa
157121f048 fix ToggleButton 2024-08-02 22:08:59 +08:00
tool4ever
8bc31ee567 Heirloom Epic and support (#5761)
Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
2024-08-02 11:17:52 +02:00
Glorax
3b29804568 Rottenmouth Viper (#5704) 2024-08-02 08:19:02 +00:00
tool4ever
51c78e952a Chief Engineer can't convoke for snow or colorless shards (#5760)
Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
2024-08-02 10:07:59 +02:00
tool4ever
46342ee8ef Update communal_brewing.txt 2024-08-02 09:56:37 +02:00
Fulgur14
ca68c6f3a9 Add files via upload 2024-08-02 09:56:37 +02:00
Fulgur14
e2017328a6 Update CounterEnumType.java 2024-08-02 09:56:37 +02:00
Renato Filipe Vidal Santos
d030419881 Update curse_of_the_restless_dead.txt 2024-08-02 09:37:26 +02:00
Renato Filipe Vidal Santos
32c89e9af1 Add files via upload 2024-08-02 09:37:26 +02:00
Renato Filipe Vidal Santos
691f500902 Add files via upload 2024-08-02 09:37:16 +02:00
Renato Filipe Vidal Santos
2dd4a09b80 Update citadel_siege.txt 2024-08-02 09:37:04 +02:00
Renato Filipe Vidal Santos
8e6b9fc835 Add files via upload 2024-08-02 09:37:04 +02:00
Renato Filipe Vidal Santos
e78539ff4d Update chaos_lord.txt 2024-08-02 09:36:52 +02:00
Renato Filipe Vidal Santos
605c22ac1e Update chainer_nightmare_adept.txt 2024-08-02 09:36:52 +02:00
Renato Filipe Vidal Santos
839699b7dd Update cemetery_gatekeeper.txt 2024-08-02 09:36:52 +02:00
Renato Filipe Vidal Santos
6b8fcac863 Add files via upload 2024-08-02 09:36:52 +02:00
Renato Filipe Vidal Santos
6038154a6d Update cartouche_of_zeal.txt 2024-08-02 09:36:40 +02:00
Renato Filipe Vidal Santos
49587334f8 Add files via upload 2024-08-02 09:36:40 +02:00
petersul
cc69fda264 Add Raccoon creature type 2024-08-02 09:17:10 +02:00
Jetz72
d62dfe1c8c Miscallaneous Cleanup Part 2 - Lambdas and Method References (#5737)
* Cleanup - Unnecessary Boxing

* Cleanup - Unnecessary Unboxing

* Cleanup - For-Each Loops

* Cleanup - `indexOf != -1` -> `contains`

* Cleanup - Merge identical catch blocks

* Cleanup - Try-with-resources

* Cleanup - System.lineSeparator

* Cleanup - Reference types to primitives
Some loops over Integers were switched to IntStreams to hopefully cut down on overall boxing.

* Cleanup - Manually filling and copying arrays

* Remove unused imports

* Switch a lambda to a method reference

* Cleanup - CardPredicate Aggregates to method references

* Cleanup - Other static functions to method references

* Cleanup - Ambiguous class reference
Unclear when or how this happened...

* Cleanup - Anonymous -> Method reference

* Cleanup - Anonymous -> Lambda

* Cleanup - Comparator helper methods

* Cleanup - final method in final class

* Cleanup - private final methods

* Remove unused imports

* Convert a couple more lambdas to comparators.

* Simplify creature type list comparison.

---------

Co-authored-by: Jetz <Jetz722@gmail.com>
Co-authored-by: tool4ever <therealtoolkit@hotmail.com>
2024-08-02 08:23:58 +03:00
Fulgur14
86ac0349ca Add files via upload (#5752) 2024-08-02 06:37:31 +03:00
tool4ever
f556f9474b Update grimgrin_corpse_born.txt 2024-08-01 20:01:44 +00:00
Chris H
5fc6d38954 Autoclose FileOutputStreams (#5753) 2024-08-01 21:22:40 +03:00
Chris H
e6379daf91 Localizer fallback to English 2024-08-01 09:17:34 -04:00
Agetian
0833dc45ff - Fix imports 2024-08-01 08:56:50 -04:00
Agetian
c081294f82 - Fix the AI sideboarding mode not loading on startup. 2024-08-01 08:56:50 -04:00
tool4EvEr
6a2c6b1cb3 add script 2024-08-01 14:04:42 +02:00
tool4EvEr
6028ba9e33 Fix mapping 2024-08-01 14:04:42 +02:00
tool4EvEr
fdd490030f Check for new trigger 2024-08-01 14:04:42 +02:00
Hans Mackowiak
23d0b05547 SacrificeOnce Trigger 2024-08-01 14:04:42 +02:00
Hans Mackowiak
a58a197945 Update DestroyEffect.java
remove Sacrifice$
2024-08-01 11:53:54 +02:00
Agetian
042887e4e1 - Move over MadSarkhanDragon logic, tweak DamageEachAi logic for Sarkhan as well 2024-08-01 11:53:54 +02:00
Hans Mackowiak
6131bfa938 Destroy: refactor fake into SacrificeAll 2024-08-01 11:53:54 +02:00
tool4EvEr
4218ea0fa8 TokenEffect no longer has state 2024-08-01 11:30:53 +02:00
Fulgur14
629726ada8 Update muerra_trash_tactician.txt (#5750) 2024-08-01 07:58:32 +02:00
Renato Filipe Vidal Santos
8154994f36 Add files via upload (#5741) 2024-08-01 08:14:18 +03:00
tool4ever
31275df288 Fix casting Chaotic Strike when no attacker gets declared (#5745) 2024-07-31 20:12:04 +00:00
Renato Filipe Vidal Santos
f31b693260 Update authority_of_the_consuls.txt (#5743) 2024-07-31 18:48:58 +00:00
Renato Filipe Vidal Santos
ec30d761fa ETB update: Card folder 'b', part 4 2024-07-31 18:09:36 +00:00
Renato Filipe Vidal Santos
79ef4ba950 ETB update: Card folder 'b', part 2 (#5740) 2024-07-31 18:07:03 +00:00
Renato Filipe Vidal Santos
91d6bbe8a2 ETB update: Card folder 'b', part 1 (#5739) 2024-07-31 18:04:33 +00:00
Renato Filipe Vidal Santos
babd3d253a ETB update: Card folder 'a', part 4 (#5724) 2024-07-31 17:55:17 +00:00
Renato Filipe Vidal Santos
6e4042fb57 ETB update: Card folder 'a', part 3 (#5723) 2024-07-31 17:55:06 +00:00
Renato Filipe Vidal Santos
cf398f7a7d ETB update: Card folder 'a', part 2 (#5722) 2024-07-31 17:54:54 +00:00
Fulgur14
0d18a64b86 11 BLB/BLC Expend cards (#5738)
* Update teapot_slinger.txt

* Add files via upload

* Update bakersbane_duo.txt
2024-07-31 17:03:30 +03:00
Chris H
c0230d1cb9 Add Expend and Teapot Slinger (#5731)
* Add Expend and Teapot Slinger

* Fixes

---------

Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
2024-07-31 11:21:41 +03:00
Chris H
92bfbb3a91 Bloomburrow draft (#5735) 2024-07-31 11:21:12 +03:00
Renato Filipe Vidal Santos
7d18fa87d4 ETB update: Card folder 'a', part 1 (#5721) 2024-07-31 08:50:39 +02:00
Chris H
a469b944d2 Update perch_protection.txt (#5736) 2024-07-31 07:03:12 +02:00
Fulgur14
499449e7ce Update season_of_the_burrow.txt (#5732) 2024-07-30 19:59:21 +00:00
Chris H
a0b2e056c1 Update parting_gust.txt 2024-07-30 16:08:25 +02:00
tool4EvEr
0a474c955a Fix Catastrophe allowing regeneration on land choice for creatures 2024-07-30 10:36:52 +02:00
Paul Hammerton
45ef20e765 Merge pull request #5726 from Fulgur14/Fulgur14-patch-25
Added the remaining BLB Seasons
2024-07-30 08:46:08 +01:00
Jetz72
ec9f6e2d2b Added attraction light icons (#5663)
Refactored functional variants to be merged in the card face rather than the card factory
Some variant characteristics now show in deck builder columns
Fixed loading progress amount
"[card] has neither ManaCost nor Color" warning now actually displays when these are missing.

Co-authored-by: Jetz <Jetz722@gmail.com>
Co-authored-by: tool4ever <therealtoolkit@hotmail.com>
2024-07-30 08:28:45 +03:00
kevlahnota
20ed52af4b Merge pull request #5725 from kevlahnota/master2
Fix stuck dialogue when reloading save
2024-07-30 06:42:56 +08:00
Anthony Calosa
8f6f8175bb Merge branch 'master' into master2 2024-07-30 06:03:56 +08:00
Glorax
df23f9263f Fix Hivespine Wolverine 2024-07-29 20:40:40 +00:00
Fulgur14
e758c364da Added Alania, Divergent Storm (#5714)
* Fix corner case of triggering for another Otter after flicker
2024-07-29 19:16:40 +00:00
Fulgur14
080ce4a477 Added the remaining BLB Seasons 2024-07-29 20:31:14 +02:00
Paul Hammerton
b7b78ec078 Fix Octomancer (#5727) 2024-07-29 18:24:33 +00:00
Fulgur14
49fa255f74 Update angel_of_indemnity.txt 2024-07-29 19:58:27 +02:00
Anthony Calosa
07e2582063 update 2024-07-30 01:06:52 +08:00
Anthony Calosa
5797c7ee5f Fix stuck dialogue when reloading save 2024-07-30 00:47:03 +08:00
Hans Mackowiak
7fb96c5f18 Pawprint (#5693)
* Pawprint
---------

Co-authored-by: Agetian <stavdev@mail.ru>
2024-07-29 16:32:46 +02:00
Chris H
dad04b5fe7 Fix adventure draft not being able to draft your 5th card 2024-07-29 10:26:15 -04:00
Jetz72
3968c7e197 Miscallaneous Cleanup (#5703)
* Cleanup - Unnecessary Boxing

* Cleanup - Unnecessary Unboxing

* Cleanup - For-Each Loops

* Cleanup - `indexOf != -1` -> `contains`

* Cleanup - Merge identical catch blocks

* Cleanup - Try-with-resources

* Cleanup - System.lineSeparator

* Cleanup - Reference types to primitives
Some loops over Integers were switched to IntStreams to hopefully cut down on overall boxing.

* Cleanup - Manually filling and copying arrays

* Remove unused imports

* Switch a lambda to a method reference

---------

Co-authored-by: Jetz <Jetz722@gmail.com>
2024-07-29 17:23:43 +03:00
Fulgur14
5d959ca545 TriggeredAttacker corrections (#5716)
* TriggeredAttacker corrections

* Fix view update

---------

Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
2024-07-29 16:17:18 +02:00
CCTV-1
232295d1c8 add missing key entry,translate new texts. (#5436) 2024-07-29 14:13:06 +00:00
kevlahnota
808ed67cdb Merge pull request #5718 from kevlahnota/master2
update Boss dialogue translations
2024-07-29 20:45:41 +08:00
Anthony Calosa
65ed02fe65 Merge branch 'master' into master2 2024-07-29 20:40:23 +08:00
Anthony Calosa
5d202a65af update Boss dialogue translations 2024-07-29 20:37:18 +08:00
Hans Mackowiak
752bb94eae Update lupinflower_village.txt
fix Oracle
2024-07-29 14:12:50 +02:00
Fulgur14
a38d8cc733 The gift cards of BLB/BLC (#5712)
* Add files via upload

* Fix gift check so it works before paying

* Update into_the_flood_maw.txt

* Update longstalk_brawl.txt

* Update mind_spiral.txt

* Update octomancer.txt

* Update parting_gust.txt

* Update sazacaps_brew.txt

* Update starforged_sword.txt

* Update parting_gust.txt

* Update scrapshooter.txt

* Update starfall_invocation.txt

* Update starforged_sword.txt

* Update coiling_rebirth.txt

---------

Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
Co-authored-by: tool4ever <therealtoolkit@hotmail.com>
2024-07-29 08:04:38 +03:00
tool4ever
95b93e1c37 Update cemetery_gatekeeper.txt 2024-07-29 06:30:10 +02:00
tool4ever
b4a0e14b4c Update long_river_lurker.txt 2024-07-29 06:24:06 +02:00
Fulgur14
63de75aeb7 Update anduril_flame_of_the_west.txt (#5715) 2024-07-29 06:13:50 +02:00
tool4ever
cb7954c776 Hero of Bretagard should only get one counter from merged creature death (#5710)
Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
2024-07-28 19:36:18 +03:00
Chris H
5c55d7b001 Set User agent to modern chrome (#5708) 2024-07-28 12:56:01 +03:00
kevlahnota
c52ce34f12 Merge pull request #5709 from kevlahnota/master2
enable Boss dialogue
2024-07-28 15:24:04 +08:00
Anthony Calosa
c9ee464b72 enable Boss dialogue 2024-07-28 15:19:18 +08:00
Anthony Calosa
e497f6ad59 Merge branch 'master' into master2 2024-07-28 08:21:24 +08:00
Fulgur14
49330cea66 Several minor updates (#5706) 2024-07-27 22:05:16 +00:00
Glorax
ce4451247a Fixes for Mistbreath Elder, Long River Lurker, Waterspout Warden (#5702)
thanks
2024-07-27 21:17:59 +00:00
Chris H
b143aaf141 Initial Gift development (#5691)
* Initial Gift development

* Update blooming_blast.txt

* Add Kitnap

* Add gift trigger

* Display fixes

---------

Co-authored-by: tool4ever <therealtoolkit@hotmail.com>
Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
2024-07-27 14:45:36 +03:00
Paul Hammerton
2cac1d7fa1 Merge pull request #5701 from paulsnoops/edition_updates
Edition updates: SLD
2024-07-27 11:28:00 +01:00
Paul Hammerton
50d8e5ac6f Edition updates: SLD 2024-07-27 11:19:30 +01:00
Paul Hammerton
3edffc6134 Merge pull request #5700 from paulsnoops/format_updates
Format updates for BLB & BLC
2024-07-27 11:02:09 +01:00
Paul Hammerton
a9f9d2a896 Format updates for BLB & BLC 2024-07-27 10:55:06 +01:00
tool4ever
76b3f6fbb7 Some fixes (#5699) 2024-07-27 07:53:00 +00:00
Chris H
27ed942d26 Update osteomancer_adept.txt (#5696) 2024-07-27 06:42:00 +00:00
kevlahnota
bf65653ec8 add Pawprint Icon (#5698) 2024-07-27 06:39:50 +00:00
Anthony Calosa
ca183b1087 add Pawprint Icon 2024-07-27 13:58:33 +08:00
tool4ever
46a22fadd2 Update mistbreath_elder.txt 2024-07-26 10:44:03 +02:00
tool4ever
e0e9be5903 Update ms_bumbleflower.txt 2024-07-26 10:35:36 +02:00
Hans Mackowiak
82b75131be Update gnawing_vermin.txt
Closes #5690
2024-07-26 09:57:32 +02:00
Hans Mackowiak
b65ee221ee Update mind_drill_assailant.txt
Closes #5689
2024-07-26 09:56:37 +02:00
Chris H
ea6e4db5da Rewrite the Readme to be more user facing 2024-07-25 22:13:16 -04:00
Chris H
691556fa64 Change Readme file to a contributing file 2024-07-25 22:13:16 -04:00
tool4ever
14257faca8 Update mistbreath_elder.txt 2024-07-25 22:18:57 +00:00
tool4ever
319be1b369 Update struggle_for_project_purity.txt 2024-07-25 16:39:23 +00:00
Chris H
0fddf0e22f Fix exploding commander costs (and damage) 2024-07-25 07:19:46 -04:00
tool4ever
3a8b5117e5 Fix Flowering Lumberknot (#5685) 2024-07-24 20:19:27 +00:00
tool4ever
ce0d641cdf Update thought_stalker_warlock.txt 2024-07-24 17:26:03 +02:00
tool4ever
2a2c25398d Update thought_stalker_warlock.txt 2024-07-24 17:25:31 +02:00
Chris H
404702c14d Fix preferences for Experimental restore 2024-07-24 11:09:20 -04:00
Hans Mackowiak
2c33bc7be9 Add ActivatorThisTurnCastEach (#5681) 2024-07-24 10:34:31 +02:00
tool4ever
b952b3ebb5 Update hired_claw.txt 2024-07-24 07:36:59 +02:00
Agetian
266a711324 Add puzzle PS_ACR1 (#5680)
* - Add puzzle PS_ACR1.

* - Cleanup.
2024-07-24 08:16:16 +03:00
tool4ever
07eae3c8d1 Update cardstates after creating token from prototype (#5676)
* Hotfix for Toggo rock

* Force update cardstate

* Clean up

---------

Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
2024-07-24 07:59:34 +03:00
Jetz
983f2d2856 Fixed QuestCommander deck editor, hopefully. 2024-07-23 18:17:59 -04:00
NCat39
74b27f881a Update information_dealer.txt (#5679)
Correcting Information Dealer to count opponent's Wizards as well as the controller's.
2024-07-23 16:32:36 +02:00
Hans Mackowiak
414fad88ff Update excalibur_sword_of_eden.txt 2024-07-23 11:08:56 +02:00
Hans Mackowiak
40d615abfc Update fountainport.txt 2024-07-23 09:27:23 +02:00
Simisays
f2e488af61 UNF 18 attraction cards (#5507)
* update

* Update CounterEnumType.java

* remove not working cards

* cleanup

* cleanup
2024-07-23 09:22:47 +03:00
tool4ever
76efa1be0d Improve anchor word handling (#5673)
* Support for Nowhere to Run
2024-07-22 20:07:36 +00:00
Hans Mackowiak
9a7bd1a9d7 Update hazels_brewmaster.txt 2024-07-22 13:39:52 +02:00
Fulgur14
c19c0a3258 19 BLB/BLC Offspring creatures (#5668) 2024-07-22 07:48:51 +00:00
tool4ever
ba62cf7ed2 MagicStack: apply statics before storing LKI (#5670) 2024-07-22 07:48:39 +00:00
tool4ever
fc803cdbda Ain't a normal month without a Henzie fix (#5671) 2024-07-22 07:19:28 +00:00
tool4ever
bf855aae82 Text change support for Class + Saga (#5666) 2024-07-21 12:56:56 +00:00
Fulgur14
9e20fd0dc2 3 Forage BLB cards (#5664) 2024-07-21 12:33:19 +00:00
tool4ever
f94a898032 Changing targets shouldn't allow different numbers (#5665) 2024-07-21 06:11:22 +00:00
Hans Mackowiak
9f172bad85 Keyword: Offspring (#5558)
* Keyword: Offspring

---------

Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
2024-07-21 07:54:37 +02:00
Hans Mackowiak
1a0f025ca7 forge-gui-mobile: fix symbolLookup init too early 2024-07-21 07:51:40 +02:00
Fulgur14
809bafbfa6 BLC cards + Villages (#5648)
* BLC cards + Villages

I can't get Fisher's Talent to produce Fish... there's a bug there somewhere.

* Add files via upload

* Update fishers_talent.txt

* Update fishers_talent.txt

* Update gourmands_talent.txt

* Update rolling_hamsphere.txt

* Update gourmands_talent.txt

---------

Co-authored-by: tool4ever <therealtoolkit@hotmail.com>
2024-07-21 07:12:37 +03:00
Fulgur14
3cb29e2914 Update marrow_gnawer.txt (#5662)
The new text actually dropped the creature condition, though it shouldn't ever matter.
2024-07-20 15:40:29 +00:00
Hans Mackowiak
95ae25e972 Add Forage Cost (#5633)
* Add Forage Cost

* ~ fix PaymentDecision for now

* TriggerForage: add Forage trigger

* CostForage: Add First Part of Human Sacrifice Food Logic

* Human ready, first Forage card

* AiCostDecision: Basic AI for Forage
2024-07-20 17:25:03 +03:00
tool4ever
f758a4127d Update mogg_mob.txt 2024-07-20 12:17:33 +00:00
Fulgur14
b74c2a88f9 Update brightcap_badger.txt (#5660) 2024-07-20 11:51:44 +00:00
tool4ever
478a562b94 Update hazel_of_the_rootbloom.txt (#5659)
Closes #5657
2024-07-20 11:51:17 +00:00
Paul Hammerton
ea83350b7a Merge pull request #5661 from paulsnoops/edition_update
Edition updates: BLB, BLC, PW24, SLD
2024-07-20 12:08:59 +01:00
Paul Hammerton
bd6c8ee0db Edition updates: BLB, BLC, PW24, SLD 2024-07-20 11:58:02 +01:00
tool4ever
47633ff406 Unattach with old card (#5656) 2024-07-20 06:50:39 +00:00
loud1990
936e90f662 Fixe P/T on 2 BLB creatures (#5658)
* Fixed p/t on 2 BLB creatures

fixed p/t on mouse trapper and sunshower druid

---------

Co-authored-by: tool4ever <therealtoolkit@hotmail.com>
2024-07-20 06:25:37 +02:00
Fulgur14
bef703de5e Added Short Bow and Alchemist's Talent (#5652) 2024-07-19 17:35:15 +00:00
Paul Hammerton
4770c3470d Merge pull request #5655 from paulsnoops/smol_fixes
fix Nightwhorl Hermit name
2024-07-19 18:25:09 +01:00
Paul Hammerton
83ecf939b4 fix Nightwhorl Hermit name 2024-07-19 18:21:54 +01:00
Paul Hammerton
c121e503d4 Merge pull request #5654 from paulsnoops/edition_updates
Edition updates: BLB, BLC, SPG
2024-07-19 18:10:01 +01:00
Paul Hammerton
2f964e2146 Edition updates: BLB, BLC, SPG 2024-07-19 18:04:15 +01:00
tool4ever
e86baf27be Fix Dour Port-Mage (#5651) 2024-07-19 16:09:04 +00:00
loud1990
0d322e3082 Added 11 BLB cards spoiled 7/18 (#5646) 2024-07-19 09:33:51 +02:00
Fulgur14
2b1c673ac1 BLB/BLC update 18-07 #3 (#5644) 2024-07-19 09:24:03 +02:00
Fulgur14
1c38babfc1 BLB/BLC update 18-07 #1 (#5643) 2024-07-19 09:23:32 +02:00
Fulgur14
8e18522526 BLB/BLC update 18-07 #2 (#5645) 2024-07-19 08:22:02 +02:00
kevlahnota
7f5850b71e Merge pull request #5647 from kevlahnota/newmaster
[Mobile] prevent crash using invalid theme
2024-07-19 11:36:00 +08:00
Anthony Calosa
eb5588c323 fix import 2024-07-19 11:11:23 +08:00
Anthony Calosa
1504f221fc update prefs 2024-07-19 10:55:23 +08:00
Anthony Calosa
83e23e59e7 update 2024-07-19 10:23:09 +08:00
Anthony Calosa
8fe5891c61 prevent crash using invalid theme 2024-07-19 10:06:07 +08:00
tool4ever
0efa98ee46 Update yggdrasil_rebirth_engine.txt 2024-07-18 08:14:25 +00:00
Fulgur14
3dd9d0385f 3 BLB cards + Supply counters (#5638) 2024-07-18 06:48:12 +00:00
Fulgur14
45c43a4d78 11 BLB cards (#5637) 2024-07-18 06:48:00 +00:00
kevlahnota
031fcf0fc9 update textrenderer (#5641)
try to prevent null
2024-07-18 14:27:44 +08:00
tool4ever
a24a810b16 Update wishing_well.txt 2024-07-17 20:51:04 +00:00
tool4ever
941e2381b5 Update splash_portal.txt 2024-07-17 20:50:23 +00:00
tool4ever
1448d1a36b Update portent_of_calamity.txt 2024-07-17 20:49:50 +00:00
Paul Hammerton
a2329756a6 Merge pull request #5639 from paulsnoops/edition_updates
Edition updates: BLB, BLC, SLD
2024-07-17 20:43:15 +01:00
Paul Hammerton
f68b653ece Edition updates: BLB, BLC, SLD 2024-07-17 20:36:27 +01:00
Agetian
d929dcaa28 - Add basic AI for The Capitoline Triad. (#5623) 2024-07-17 15:54:19 +03:00
maulet218
12a396adf9 Update es-ES.properties (#5626)
* Update es-ES.properties

Added:
- lblAddCommander
- lblAddDeckSection
- lblAddDeckSectionSelect
- lblAttractions
- lblConspiracies
Changed:
- lblfromconspiracydeck
- lbltoconspiracydeck

* Update es-ES.properties

Added:
-lblEditorLog
-lblPrimaryCharacteristic
Changed:
-lblShowCardPTOverlays
-nlShowCardOverlays
-lblCardPTOrLoyalty

* Update es-ES.properties

Added:
-cbExperimentalRestore
-nlExperimentalRestore
-lblAttractionDeckZone
-lblJunkyardZone
2024-07-17 15:54:09 +03:00
Fulgur14
645bd0c831 Added Blacksmith's Talent + Sword token (#5619)
* Added Blacksmith's Talent + Sword token

* Add files via upload

* Added Dour Port-Mage
2024-07-17 15:53:34 +03:00
Fulgur14
293263a58e Eddymurk Crab and Eluge, the Shoreless Sea (#5632)
* Eddymurk Crab and Eluge, the Shoreless Sea

* Update eluge_the_shoreless_sea.txt
2024-07-17 15:53:24 +03:00
tool4ever
4ccabf1c99 Update sigurd_jarl_of_ravensthorpe.txt 2024-07-17 09:54:17 +02:00
Fulgur14
7825e0a913 Some more BLB cards (#5629) 2024-07-17 08:35:02 +02:00
Simisays
fe81fce18e Update honored_dreyleader.txt (#5630) 2024-07-17 08:24:08 +02:00
Fulgur14
3843287bb4 8 BLB cards from Card Gallery Update (#5625) 2024-07-17 07:11:14 +03:00
Fulgur14
e930b1644c Gev, Scaled Scorch and Scavenger's Talent (#5627)
* Gev, Scaled Scorch and Scavenger's Talent

* Update scavengers_talent.txt

* Update scavengers_talent.txt
2024-07-17 07:11:01 +03:00
Paul Hammerton
0aed08518b Merge pull request #5624 from paulsnoops/edition_updates
Edition updates: BLB, BLC
2024-07-16 15:06:22 +01:00
Paul Hammerton
e89c0d3801 Edition updates: BLB, BLC 2024-07-16 15:02:36 +01:00
maulet218
c7315be6a3 Update es-ES.properties (#5621)
Added:
- lblAddCommander
- lblAddDeckSection
- lblAddDeckSectionSelect
- lblAttractions
- lblConspiracies
Changed:
- lblfromconspiracydeck
- lbltoconspiracydeck
2024-07-16 17:00:07 +03:00
Renato Filipe Vidal Santos
4cab57c486 Add files via upload (#5478) 2024-07-16 16:59:57 +03:00
Fulgur14
68f797174b Builder's Talent 2024-07-16 13:29:17 +00:00
tool4ever
dc3e0dda14 The Capitoline Triad and support (#5586) 2024-07-16 10:46:52 +02:00
Fulgur14
ed7cfe3404 3 BLB cards (#5618) 2024-07-16 08:00:55 +02:00
Chris H
05607ef21a Update dinosaurs_on_a_spaceship.txt (#5617) 2024-07-16 07:22:49 +02:00
Fulgur14
00aa3e8709 11 BLB cards (#5613)
* 11 BLB cards

* Update hazels_nocturne.txt

* Update jackdaw_savior.txt

* Update lunar_convocation.txt

* Update patchwork_banner.txt

* Update sinister_monolith.txt

* Update splash_portal.txt

* Update splash_portal.txt
2024-07-16 07:21:12 +03:00
Fulgur14
6d7e8c9899 Update cartouche_of_zeal.txt (#5614)
* Update cartouche_of_zeal.txt

* 5 BLB cards

* Add files via upload

* Add files via upload

* Update reptilian_recruiter.txt

* Update war_squeak.txt
2024-07-16 07:21:02 +03:00
Chris H
2ffc7d7e39 Update genku_future_shaper.txt (#5615) 2024-07-15 19:30:32 +00:00
Fulgur14
e4877bbe47 Update harvestrite_host.txt (#5612) 2024-07-15 15:50:36 +02:00
tool4ever
361b29284b Update yggdrasil_rebirth_engine.txt 2024-07-15 15:42:55 +02:00
tool4ever
41da7b753d Update airtight_alibi.txt 2024-07-15 10:38:45 +02:00
tool4ever
b35bca29e2 Update airtight_alibi.txt 2024-07-15 10:37:24 +02:00
tool4ever
4fa5bedafa Update innkeepers_talent.txt (#5607)
Closes #5605
2024-07-15 09:14:51 +02:00
Fulgur14
44a0620844 Hazardroot Herbalist 2024-07-15 07:48:59 +02:00
Fulgur14
be720d5876 Update bayleen_the_haymaker.txt (#5608) 2024-07-15 07:48:01 +02:00
tool4ever
c5203421d9 Support another case of reflexive triggers getting duplicated (#5594)
* Support another case of reflexive triggers getting duplicated

* Improve detection logic

---------

Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
2024-07-15 08:25:00 +03:00
Fulgur14
faa128f86d Token for Wick, Whorled Mind 2024-07-14 19:51:15 +00:00
tool4ever
8fe5bb2086 Fix missing checks (#5601) 2024-07-14 07:59:36 +00:00
Fulgur14
96ee06bd81 BLB scripts that might have gotten lost somewhere before (#5592) 2024-07-14 07:56:29 +00:00
tool4ever
7a6a7d6b0b CantPhase checks need to happen simultaneously (#5600) 2024-07-14 07:22:11 +00:00
tool4ever
f7a4c6419c Update shove_aside.txt 2024-07-14 06:30:47 +00:00
tool4ever
8c498d989c Update senu_keen_eyed_protector.txt (#5589)
Closes #5587
2024-07-14 06:19:05 +00:00
Fulgur14
07a9c79edb Update thistledown_players.txt (#5597) 2024-07-14 06:55:15 +02:00
Chris H
04e2c047cb Update valley_questcaller.txt (#5599) 2024-07-14 06:53:24 +02:00
tool4ever
64cf5a946c Moonstone Harbinger and support (#5591) 2024-07-13 20:42:12 +00:00
Renato Filipe Vidal Santos
ecd55c6c8d Update grip_of_chaos.txt (#5593) 2024-07-13 14:46:06 +00:00
TheLastNarwhal
59faa8665f Update Unfinity.txt to include eternal cards (#5516)
With the recent creation of the eternal category to fix Zur the Enchanter I figured it would also be a good time to fix that same issue with Unfinity.
2024-07-13 17:38:41 +03:00
Paul Hammerton
e6a37f7fc3 Merge pull request #5590 from paulsnoops/update_YOTJ
Edition updates: YOTJ
2024-07-13 12:05:12 +01:00
Paul Hammerton
6847dc8250 Edition updates: YOTJ 2024-07-13 12:00:37 +01:00
Paul Hammerton
85be1d5e40 Merge pull request #5585 from Fulgur14/Fulgur14-patch-55
6 BLB cards
2024-07-13 11:50:40 +01:00
Paul Hammerton
99ffc96d57 Merge pull request #5583 from Fulgur14/Fulgur14-patch-54
Final BLB batch for tonight.
2024-07-13 11:50:30 +01:00
Paul Hammerton
d3f0dcf3be Merge pull request #5588 from paulsnoops/edition_updates
Edition updates: BLB, BLC, M3C, SLD
2024-07-13 11:49:22 +01:00
Paul Hammerton
a8181badfb Edition updates: BLB, BLC, M3C, SLD 2024-07-13 11:42:36 +01:00
Fulgur14
fc75ea7c9b Update for_the_common_good.txt 2024-07-13 09:27:58 +02:00
Fulgur14
1e78e213be Update harvestrite_host.txt 2024-07-13 09:27:01 +02:00
Fulgur14
0595b83860 Update wishing_well.txt 2024-07-13 09:23:03 +02:00
Fulgur14
7d2666eb2e Update harvestrite_host.txt 2024-07-13 09:21:49 +02:00
Fulgur14
5e6bac35b0 Update for_the_common_good.txt 2024-07-13 09:19:53 +02:00
tool4ever
637f56ac8f Update whiskervale_forerunner.txt 2024-07-13 07:10:16 +00:00
Fulgur14
16d8fc6fb3 6 BLB cards 2024-07-13 08:45:52 +02:00
Agetian
f7ee001563 - Added puzzle PS_MH32. (#5584) 2024-07-13 08:32:18 +03:00
Renato Filipe Vidal Santos
94bc42b018 Update and rename vona_de_ledo_the_antifex.txt to vona_de_iedo_the_antifex.txt (#5582) 2024-07-13 07:47:08 +03:00
NCat39
4a6c51b4a8 Add files via upload (#5486)
Attempting to add UNF's Nearby Planet using the Omo effect from M3C (and to a lesser extent Planar Nexus from MH3) as a reference.

Tested card, seems to work as intended. The typeline is messier than with the Mistform Ultimus/changeling effect for creatures (Mistform displays "(All)" whereas the Omo version spells out the types), but it is consistent with the referenced Modern Horizons cards.
2024-07-13 07:46:41 +03:00
Fulgur14
6511a6312c Update whiskervale_forerunner.txt 2024-07-13 06:29:52 +02:00
Fulgur14
0e4c908b2c Add files via upload 2024-07-12 21:53:31 +02:00
tool4ever
c4ec3d5ad4 Update ghost_town.txt (#5581) 2024-07-12 13:55:35 +00:00
tool4ever
f6fd3e451d Update force_of_rage.txt 2024-07-12 15:29:32 +02:00
tool4ever
c7eef66ce2 Update icatian_moneychanger.txt 2024-07-12 15:14:11 +02:00
Fulgur14
08929b55dc Update ancient_stone_idol.txt (#5571)
* Update ancient_stone_idol.txt

* Add files via upload

* Add files via upload

* Update scales_of_shale.txt

* Update thought_shucker.txt

* Update mistbreath_elder.txt

* Update vren_the_relentless.txt

* Update mistbreath_elder.txt

* Update vren_the_relentless.txt
2024-07-12 15:49:19 +03:00
Fulgur14
ca98180914 Another BLB batch (#5572)
* Update chaos_charm.txt

* Update TypeLists.txt

* Add files via upload

* Update downwind_ambusher.txt

* Update feather_of_flight.txt

* Fix description

* Update artists_talent.txt

---------

Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
2024-07-12 15:49:08 +03:00
Fulgur14
ba986276a7 BLB 6 cards (#5577)
* BLB 6 cards

* Update driftgloom_coyote.txt
2024-07-12 15:48:59 +03:00
Fulgur14
81ec6e4d48 Added Persistent Marshstalker (#5578)
(Only new English card I could see.)
2024-07-12 15:48:48 +03:00
tool4ever
6c2c8cc6e8 Refresh active triggers after statics from ETB (#5580)
* Refresh active triggers after statics from ETB

* Style change

---------

Co-authored-by: TRT <>
2024-07-12 15:48:37 +03:00
Renato Filipe Vidal Santos
129cca0527 Fixing Bello's static ability 2024-07-12 08:36:32 +02:00
Paul Hammerton
9e8489aa1d Merge pull request #5570 from churrufli/netdecks0724
Net Decks Archive Updates
2024-07-11 18:08:27 +01:00
Churrufli
fe5ec2c241 Net Decks Archive Updates 2024-07-11 18:51:30 +02:00
Fulgur14
e416fe5f93 10 BLB cards (#5556)
* 10 BLB cards

Would Glarb work correctly with X-spells like that?

* Update finneas_ace_archer.txt

* Update cindering_cutthroat.txt

* Update bello_bard_of_the_brambles.txt

* Update bello_bard_of_the_brambles.txt

* Update beza_the_bounding_spring.txt

* Update glarb_calamitys_augur.txt

* Update glarb_calamitys_augur.txt
2024-07-11 18:09:30 +03:00
Chris H
31cf6a1c5d Update forge.sh (#5372)
https://github.com/Card-Forge/forge/issues/309
2024-07-11 16:58:46 +03:00
Fulgur14
386715399f Galewind Moose and Valley Floodcaller 2024-07-11 08:24:55 +00:00
tool4ever
d653ff9320 Update ygra_eater_of_all.txt 2024-07-11 07:37:34 +02:00
Fulgur14
54182e18a5 Update TypeLists.txt (#5567)
* Update TypeLists.txt

* Add files via upload

* Update brazen_collector.txt
2024-07-11 07:30:00 +03:00
Renato Filipe Vidal Santos
4ac37360da DSK: Doomsday Excruciator (#5497) 2024-07-10 20:55:14 +00:00
Chris H
f9565f5aae Revert "Add files via upload"
This reverts commit 74243c9208.
2024-07-10 15:08:32 -04:00
Chris H
a1b71f0bfa Revert "Update the_capitoline_triad.txt"
This reverts commit 3e0de33830.
2024-07-10 15:08:32 -04:00
Fulgur14
89ec6723cd 5 BLB cards (#5564)
* 5 BLB cards

* Update brambleguard_captain.txt

* Update sugar_coat.txt
2024-07-10 20:51:52 +03:00
Fulgur14
3e0de33830 Update the_capitoline_triad.txt 2024-07-10 13:51:29 -04:00
Fulgur14
74243c9208 Add files via upload 2024-07-10 13:51:29 -04:00
Paul Hammerton
d73eda7b64 Merge pull request #5565 from paulsnoops/edition_updates
Edition updates: BLB, BLC
2024-07-10 18:50:16 +01:00
Paul Hammerton
d0713b14c3 Edition updates: BLB, BLC 2024-07-10 18:07:34 +01:00
Fulgur14
091f33fe5d 6 BLB cards (#5561) 2024-07-10 16:45:11 +00:00
Chris H
761fcb0732 Add Smuggler Captain 2024-07-10 10:04:29 -04:00
Fulgur14
f7a3aa6f91 Update hazel_of_the_rootbloom.txt 2024-07-10 10:04:03 -04:00
Fulgur14
366518b0aa 10 BLB/BLC cards, batch 2 (#5559)
* 10 BLB/BLC cards, batch 2

* Update hazel_of_the_rootbloom.txt

* Update hunters_talent.txt

* Update kastral_the_windcrested.txt

* Update plumecreed_mentor.txt
2024-07-10 14:04:26 +03:00
Fulgur14
cf64c41ef5 10 BLB/BLC cards, batch 3 (#5560)
* 10 BLB/BLC cards, batch 3

* Update ms_bumbleflower.txt

* Update seedpod_squire.txt
2024-07-10 14:04:16 +03:00
Fulgur14
7e200eae8b Corrected apostrophes (#5551)
* Update Keyword.java

* Update overlord_of_the_hauntwoods.txt
2024-07-09 15:27:58 +02:00
tool4ever
9a7d8091ac Update LifeGainEffect.java (#5550)
Closes #5549
2024-07-09 12:12:52 +02:00
tool4ever
6b82cfa473 Update tricksters_elk.txt 2024-07-09 09:40:35 +02:00
Hans Mackowiak
423e866cb0 Keyword: Impending (#5544)
* Keyword: Impending

* Update overlord_of_the_hauntwoods.txt

---------

Co-authored-by: tool4ever <therealtoolkit@hotmail.com>
2024-07-09 08:33:23 +03:00
Renato Filipe Vidal Santos
8c0795c5eb July 2024 cleanup: folders 'c' to 'd' (#5519) 2024-07-08 19:40:09 +00:00
Renato Filipe Vidal Santos
a6d67aca24 July 2024 cleanup: folders 'e' to 'f' (#5520) 2024-07-08 19:39:58 +00:00
Renato Filipe Vidal Santos
92e05cd949 July 2024 cleanup: folders 'g' to 'h' (#5521) 2024-07-08 19:36:03 +00:00
Renato Filipe Vidal Santos
af1972d696 July 2024 cleanup: folders 'i' to 'l' (#5522) 2024-07-08 19:35:51 +00:00
Renato Filipe Vidal Santos
777576fabb July 2024 cleanup: folders 'm' to 'o' (#5523) 2024-07-08 19:30:08 +00:00
Renato Filipe Vidal Santos
aaa3fac93b July 2024 cleanup: folders 'p' to 'r', 'rebalanced' (#5524) 2024-07-08 19:01:03 +00:00
Renato Filipe Vidal Santos
e73f8ae8b7 DSK: Come Back Wrong 2024-07-08 18:22:31 +00:00
Renato Filipe Vidal Santos
7d36caca67 July 2024 cleanup: folder 's' (#5525) 2024-07-08 18:22:15 +00:00
Renato Filipe Vidal Santos
e66543d479 DSK: Enduring Tenacity 2024-07-08 09:45:11 +00:00
Renato Filipe Vidal Santos
b55cddb867 July 2024 cleanup: folders 'v' to 'z', 'tokenscripts' (#5527) 2024-07-07 16:51:18 +00:00
Renato Filipe Vidal Santos
484c9e4105 July 2024 cleanup: folders 'a' to 'b' (#5518) 2024-07-07 16:01:18 +00:00
Renato Filipe Vidal Santos
4b3270a6de July 2024 cleanup: folders 't' to 'u', 'upcoming' (#5526) 2024-07-07 11:13:28 +00:00
Renato Filipe Vidal Santos
bb9c6dfd76 July 2024 cleanup: code (#5536)
* Update ChooseGenericEffectAi.java

* Update CardTranslation.java

* Update AltWinAchievements.java

* Update altwin-achievements.txt

* Update EffectEffect.java
2024-07-07 13:37:01 +03:00
tool4ever
897741ba0a Fix LKI entering battlefield (#5543)
Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
2024-07-07 13:36:29 +03:00
Renato Filipe Vidal Santos
238c591081 Incidental cleanup pass #3 (#5286) 2024-07-07 07:11:59 +00:00
Agetian
f1e1c3d1dc SacCost AI hint for Cutthroat Centurion (#5542)
* - Correct names for MH3 achievement cards.

* - SacCost AI hint for Cutthroat Centurion.
2024-07-07 08:46:56 +03:00
Agetian
4b1b0880ef - Correct names for MH3 achievement cards. (#5541) 2024-07-07 08:41:20 +03:00
Agetian
912e3272d3 - MH3 achievements by Marek14. (#5539) 2024-07-07 08:16:12 +03:00
Fulgur14
001254e395 Update monastery_raid.txt 2024-07-06 21:01:43 +02:00
Fulgur14
cb1a4f8cd2 Update escape_detection.txt 2024-07-06 21:01:43 +02:00
Paul Hammerton
1177a73d52 Merge pull request #5534 from paulsnoops/ral_typo
BLB typo
2024-07-06 18:37:13 +01:00
Paul Hammerton
4e7b9e97e8 BLB typo 2024-07-06 18:33:12 +01:00
Paul Hammerton
31d40e73b4 Merge pull request #5533 from paulsnoops/edition_updates
Edition updates: BLB, FDN, M3C, PLG24
2024-07-06 18:29:02 +01:00
Paul Hammerton
6a4205b4f6 Edition updates: BLB, FDN, M3C, PLG24 2024-07-06 18:23:34 +01:00
Renato Filipe Vidal Santos
248c2a3d99 ACR: Ezio, Brash Novice (#5530) 2024-07-06 18:05:49 +02:00
tool4ever
10b78114bb Fix Bamboozling Beebles (#5531)
Co-authored-by: TRT <>
2024-07-06 18:05:06 +03:00
Simisays
b1f318e763 What must be done Crash fix (#5529) 2024-07-06 12:35:04 +02:00
tool4ever
e0592f8b92 Fix Esix copies not having mana cost (#5517)
Co-authored-by: TRT <>
2024-07-06 13:16:48 +03:00
Simisays
038ff62065 Update bandit_mutate.dck (#5528) 2024-07-06 13:16:20 +03:00
Simisays
d3e931cc37 Update AdventureEventController.java 2024-07-05 14:41:40 -04:00
Simisays
7046b108dd update 2024-07-05 14:41:40 -04:00
Fulgur14
ef11d37a00 Hopefully final ACR batch (#5514) 2024-07-05 19:01:51 +02:00
Hans Mackowiak
01cc878b4d Freerunning as calculateAmount (#5511)
* Freerunning as calculateAmount

* Fix desc

---------

Co-authored-by: TRT <>
2024-07-05 07:16:17 +03:00
Jetz
608beb0aac Fix Monoxa triggering on opponents' dice rolls. 2024-07-04 22:22:10 -04:00
Chris H
db31c15d41 Update phyrexian_portal.txt 2024-07-04 22:10:17 -04:00
Jetz
f63848f62e Don't treat avatar creature type as vanguard avatars 2024-07-04 22:05:42 -04:00
Simisays
aee1625a5e ACR 8 cards (#5480) 2024-07-03 22:11:45 +02:00
tool4ever
8b1cf9cfc0 Update eldrazi_confluence.txt 2024-07-03 21:34:35 +02:00
Chris H
c92dae1b99 Allow for eternal cards to not be filtered out by funny filter (#5505) 2024-07-03 16:46:41 +03:00
Chris H
81fa38cc27 If Commander going to hand, don't replace to command zone (#5504) 2024-07-03 16:46:07 +03:00
Chris H
3a61118ade Merge pull request #5357 from Jetz72/Attractions
Attraction Support
2024-07-02 11:02:43 -04:00
Jetz
c346fb02c5 Remove unused import. 2024-07-02 09:22:09 -04:00
Chris H
c46a4b6d3d Remove some memory allocations if we don't need it anymore 2024-07-01 23:01:04 -04:00
Chris H
b03b3517ea Backup Plan with hot swappable Input 2024-07-01 23:01:04 -04:00
Jetz
611e97706d Lifetime Pass Holder and RolledToVisitAttraction trigger condition.
Consolidated rollToVisitAttractions logic back into RollDiceEffect.
2024-07-01 19:38:33 -04:00
Paul Hammerton
7b3d98aabd Merge pull request #5499 from pfirpfel/mh3-draft-rankings
Add draft rankings for MH3
2024-07-01 22:42:09 +01:00
Paul Hammerton
5d9498c8f4 Early Winter fix (#5498) 2024-07-01 20:55:08 +02:00
Paul Hammerton
e1093b9b58 Merge pull request #5501 from paulsnoops/acr_formats
Add ACR to Modern, Legacy & Vintage
2024-07-01 14:59:21 +01:00
Paul Hammerton
56d376ec57 Merge pull request #5500 from paulsnoops/edition_updates
Edition updates: BLB, BLC, DSK, SLD
2024-07-01 14:58:48 +01:00
Paul Hammerton
58bdcedcbc Edition updates: BLB, BLC, DSK, SLD 2024-07-01 14:54:54 +01:00
Paul Hammerton
bde9ecf219 Add ACR to Modern, Legacy & Vintage 2024-07-01 14:49:49 +01:00
pfirpfel
c26db7cd99 Add draft rankings for MH3 2024-07-01 15:44:21 +02:00
fernandomfgomes
214edcfe6d Update AdventurePlayer.java
Both goldLoss and lifeLoss where not being set on creation + update difficulty. So regardless of difficulty chosen, on defeat the default value on the difficultyData class for the properties (0.2f) was being used
2024-07-01 08:46:34 -04:00
Renato Filipe Vidal Santos
43864ac24e FDN: Anthem of Champions, Nine-Lives Familiar (#5496) 2024-07-01 07:34:03 +02:00
Fulgur14
cc9e5cfd83 15 ACR/BLB/DSK cards (#5494) 2024-06-30 21:22:58 +02:00
tool4ever
cba5854de9 Update phyrexian_vindicator.txt 2024-06-30 16:31:32 +02:00
tool4ever
f8e9128248 Update edward_kenway.txt (#5492) 2024-06-30 16:11:11 +02:00
Paul Hammerton
b76d6797c1 Merge pull request #5489 from Card-Forge/tehdiplomat-patch-7
Update tempted_by_the_oriq.txt
2024-06-30 11:34:15 +01:00
Chris H
8add189909 Update tempted_by_the_oriq.txt 2024-06-29 19:35:42 -04:00
Fulgur14
80d05b12d2 My final ACR batch (#5476)
* Add files via upload

* Update misthioss_fury.txt

* Update senu_keen_eyed_protector.txt

* Update senu_keen_eyed_protector.txt

* Update phantom_blade.txt

* Update phantom_blade.txt

* Update sigurd_jarl_of_ravensthorpe.txt

* Update smoke_bomb.txt

* Update ratonhnhake_ton.txt
2024-06-29 21:41:39 +03:00
Renato Filipe Vidal Santos
be4e82e6d1 BLB: Three Tree City, Ral and its Otter token (#5471)
* Add files via upload

* Add files via upload

* Update ral_crackling_wit.txt

* Update three_tree_city.txt
2024-06-29 21:41:27 +03:00
Paul Hammerton
fd3014ff34 Merge pull request #5485 from paulsnoops/edition_updates
Edition updates: BLB, DSK, DSC, FDN
2024-06-29 12:19:51 +01:00
kevlahnota
d769da9b7d fix UnsupportedOperationException (#5488) 2024-06-29 13:41:43 +08:00
Chris H
a9d3150b34 Small fixes 2024-06-28 20:40:49 -04:00
Chris H
33f34231f4 Add remaining Conspiracy cards
- Archdemon of Paliano
- Canal Dredger
- Deal Broker
- Lore Seeker
2024-06-28 20:40:49 -04:00
Fulgur14
b9829eef92 MH3 Precon decks
I tried to assign the right image numbers, as the first image for most of cards is the extended version.
Since Overclocked Electromancer is still unimplemented, Creative Energy won't work yet.
2024-06-28 17:29:34 -04:00
Northmoc
8f4f1a8046 M3C: overclocked_electromancer + support 2024-06-28 17:29:07 -04:00
Paul Hammerton
55d52207e8 dots 2024-06-28 19:21:04 +01:00
Paul Hammerton
6a0faa3dc2 Edition updates: BLB, DSK, DSC, FDN 2024-06-28 19:20:10 +01:00
Paul Hammerton
1f9e01efaa Merge branch 'master' of https://github.com/Card-Forge/forge 2024-06-28 19:14:53 +01:00
Paul Hammerton
00a8cd7ab5 Oops 2024-06-28 19:13:59 +01:00
Paul Hammerton
ec6586256f Edition updates: BLB, DSK, DSC, FDN 2024-06-28 18:58:50 +01:00
Chris H
7fd974904f Update pom.xml 2024-06-28 13:52:59 -04:00
GitHub Actions
64b4b58399 [maven-release-plugin] prepare for next development iteration 2024-06-28 13:06:40 -04:00
GitHub Actions
463e4b1267 [maven-release-plugin] prepare release forge-1.6.63 2024-06-28 13:06:40 -04:00
Chris H
b2dd1d6f21 Update Forge.java 2024-06-28 13:06:40 -04:00
Chris H
4f0d5d587d Update pom.xml 2024-06-28 13:06:40 -04:00
Chris H
580133f7a6 Update AndroidManifest.xml 2024-06-28 13:06:40 -04:00
Chris H
b0c0d736e0 Genku trigger description 2024-06-27 11:49:20 -04:00
Simisays
857b38d1e5 ACR 9 cards (#5449) 2024-06-27 11:55:35 +00:00
Chris H
6324143587 Update evie_frye.txt 2024-06-27 10:29:47 +02:00
NishacIroCode
9cedbc8258 Missing up to one logic. 2024-06-27 10:28:51 +02:00
tool4ever
47cef07b91 Update canoptek_wraith.txt 2024-06-26 21:32:20 -04:00
Suthro
e446ca565f Update arna_kennerud_skycaptain.txt 2024-06-26 21:01:36 -04:00
Suthro
5952e0b37e Update arna_kennerud_skycaptain.txt 2024-06-26 21:01:36 -04:00
Suthro
fafabdacb3 Update genku_future_shaper.txt 2024-06-26 21:01:36 -04:00
Suthro
6743d01574 MH3: Arna Kennerüd, Skycaptain + 2 cards
MH3: Add card scripts for three MH3 cards, including token scripts:

- Arna Kennerüd, Skycaptain
- Genku, Future Shaper
- Thraben Charm
- 1/1 black Rat creature token with lifelink
- 1/2 blue Moonfolk creature token with flying
- 2/2 white Fox creature token with vigilance
2024-06-26 21:01:36 -04:00
Chris H
38796136f3 Crabomination 2024-06-26 21:00:29 -04:00
tool4ever
bb1feaa281 Update outlaws_fury.txt 2024-06-26 07:01:52 +02:00
Jetz
cfc33fd491 Cleanup a couple comments 2024-06-25 17:17:14 -04:00
tool4ever
ce34c94215 Cipher: do it like Epic (#5465)
Co-authored-by: TRT <>
2024-06-25 21:48:26 +03:00
tool4ever
4f6e775fef Update legion_warboss.txt 2024-06-25 11:52:29 +02:00
tool4ever
3d5786a98e Update krenko_tin_street_kingpin.txt 2024-06-25 10:33:03 +02:00
tool4ever
192dd9bf56 Update dream_halls.txt 2024-06-25 08:35:48 +02:00
tool4ever
4d0f1314e8 Update eivor_wolf_kissed.txt 2024-06-25 08:33:40 +02:00
tool4ever
a00f46ba85 Update arcane_heist.txt 2024-06-25 08:32:06 +02:00
Chris H
4207736809 Fix 1v1 draft matches 2024-06-24 23:13:59 -04:00
Jetz
da34acd210 Merge branch 'master' into Attractions
# Conflicts:
#	forge-game/src/main/java/forge/game/player/Player.java
2024-06-24 20:06:29 -04:00
Chris H
3ef9aa048a MH3 booster definition 2024-06-24 10:53:13 -04:00
Hans Mackowiak
d5ab4be451 Invasion Plans using Timestamp instead (#5458)
* Invasion Plans using ReplacementEffect instead

* StaticAbilityContinuous: use DeclaresAttackers and DeclaresBlockers with ts

* update scripts

* Update master_warcraft.txt

* Player: update DeclaresAttacker and DeclaresBlocker with getDefinedPlayers

---------

Co-authored-by: tool4ever <therealtoolkit@hotmail.com>
2024-06-24 14:48:20 +03:00
tool4ever
fe7043dd0d Update evie_frye.txt 2024-06-24 06:53:42 +00:00
tool4ever
72af32c982 Update desmond_miles.txt 2024-06-24 06:53:19 +00:00
tool4ever
5f74aec97d Update vault_11_voters_dilemma.txt 2024-06-23 22:36:58 +00:00
Simisays
4074a301f7 map fixes (#5460) 2024-06-23 18:47:52 +03:00
Jetz
f2cefc8cc1 Intervention for AI's gambling problem. 2024-06-23 11:36:13 -04:00
Jetz
1233f2bec9 Remove "Result:" prefix for notification messages with no source. 2024-06-23 11:30:25 -04:00
Jetz
1f77e02396 Merge remote-tracking branch 'origin/Attractions' into Attractions 2024-06-23 11:24:19 -04:00
Jetz
33c0e5dfd6 Merge branch 'master' into Attractions 2024-06-23 11:23:47 -04:00
Jetz72
6b0d237514 Merge branch 'Card-Forge:master' into Attractions 2024-06-23 11:22:19 -04:00
Jetz
85d42bfbcf Update for "visited this turn" per rules 2024-06-23 11:20:06 -04:00
Paul Hammerton
10cf8f6e61 Merge pull request #5457 from paulsnoops/edition_updates
Edition updates: ACR
2024-06-23 09:56:50 +01:00
Paul Hammerton
c9e4648a2e Edition updates: ACR 2024-06-23 09:47:11 +01:00
Agetian
e4f67afb82 - Fixed AI ignoring Mogg Bombers damage trigger. (#5456) 2024-06-23 10:20:52 +03:00
tool4ever
4c0d7ff18f Update hama_pashar_ruin_seeker.txt 2024-06-23 07:02:47 +00:00
Hans Mackowiak
e087f9564c ~ remove unused variables 2024-06-23 07:17:24 +02:00
Hans Mackowiak
0abbc2def3 StaticAbilityBlockRestict: remove Global Rules (#5454)
* StaticAbilityBlockRestict: remove Global Rules

* ~ remove rule

* ~ remove global num
2024-06-22 20:12:14 -04:00
Fulgur14
8c37a7347f ACR cards (#5441) 2024-06-22 19:22:43 +00:00
Chris H
d4469ca736 Add Spire Phantasm, Agent of Acquisitions, Cogwork Librarian, Leovold's Operative (#5437)
* Next few Draft cards

* Code review fixes

* Add Spire Phantasm

* Add Agent of Acquisitions, Cogwork Librarian, Leovold's Operative

* Some small fixes

* Getting closer

* Now the UI is updating

* Switch DraftPack to a delegate class

* Fix agent of acquisitions when AI drafts it
2024-06-22 13:42:29 +03:00
Paul Hammerton
e0d8bcf490 Merge pull request #5452 from paulsnoops/edition_updates
Edition updates: ACR, M3C, SLD
2024-06-22 08:29:34 +01:00
Paul Hammerton
fd6db7e00a Edition updates: ACR, M3C, SLD 2024-06-22 08:16:52 +01:00
tool4ever
50f7e4a33f Update arco_flagellant.txt 2024-06-22 06:01:27 +00:00
Chris H
fa1cdca3aa Update phelia_exuberant_shepherd.txt (#5450) 2024-06-22 05:59:26 +00:00
tool4ever
2ca1260272 Update satya_aetherflux_genius.txt 2024-06-21 21:35:02 +00:00
Paul Hammerton
e829b48f5b Merge pull request #5447 from paulsnoops/edition_updates
Edition updates: ACR
2024-06-21 17:59:23 +01:00
Paul Hammerton
b8f60ccbad Edition updates: ACR 2024-06-21 17:56:08 +01:00
Chris H
ba40634d7f Update wither_and_bloom.txt 2024-06-21 15:30:46 +02:00
Chris H
f226826819 Migrate mh3 (#5443)
* Migrate MH3 from upcoming

---------

Co-authored-by: Hans Mackowiak <hanmac@gmx.de>
2024-06-20 15:20:10 +02:00
Hans Mackowiak
dc02e5e52d Prowl: use sharesCreatureTypeWith 2024-06-20 12:08:19 +02:00
Jetz
3e6871ce86 Merge branch 'master' into Attractions
# Conflicts:
#	forge-core/src/main/java/forge/deck/DeckFormat.java
2024-06-19 22:58:49 -04:00
Jetz
657ebfda25 8 more attractions. 2024-06-19 19:03:29 -04:00
Paul Hammerton
145d4d347f Merge pull request #5442 from paulsnoops/edition_updates
Edition updates: ACR, SLD
2024-06-19 14:48:57 +01:00
Paul Hammerton
f1ffbe9887 oops 2024-06-19 14:42:47 +01:00
Paul Hammerton
3209fb4ca7 Edition updates: ACR, SLD 2024-06-19 14:41:06 +01:00
Hans Mackowiak
bbac9c4ded Keyword: Freerunning (#5439)
* Keyword: Freerunning

* Update Player.java
2024-06-19 15:25:37 +03:00
tool4ever
f864a17a49 Update guide_of_souls.txt 2024-06-19 05:32:38 +00:00
NishacIroCode
c67eae5a1a Commenting out ununsed code to remove warnings. 2024-06-18 22:18:03 -04:00
NishacIroCode
66ef931b58 Initial commit for Piper-like cards. 2024-06-18 22:18:03 -04:00
tool4ever
e082b66d68 Update kozileks_command.txt
Closes #5434
2024-06-18 12:29:48 +02:00
Simisays
c6c5d6476e Conflict free branches of Fulgur14 (#5429)
* Squashed commit of the following:

commit ef30be2d55
Author: Fulgur14 <54345051+Fulgur14@users.noreply.github.com>
Date:   Thu Jun 13 19:48:00 2024 +0200

    Add files via upload

* Squashed commit of the following:

commit 299ad40c2e
Author: Fulgur14 <54345051+Fulgur14@users.noreply.github.com>
Date:   Mon Jun 10 13:32:28 2024 +0200

    Add files via upload

commit 95d9b59232
Author: Fulgur14 <54345051+Fulgur14@users.noreply.github.com>
Date:   Mon Jun 10 12:13:25 2024 +0200

    Add files via upload

commit ce05867493
Merge: c04c76d3c2 9b327cf3d2
Author: Fulgur14 <54345051+Fulgur14@users.noreply.github.com>
Date:   Mon Jun 10 09:00:21 2024 +0200

    Merge branch 'Card-Forge:master' into master

commit c04c76d3c2
Merge: bb62d8fd8d f865496d23
Author: Fulgur14 <54345051+Fulgur14@users.noreply.github.com>
Date:   Thu May 30 23:11:34 2024 +0200

    Merge branch 'Card-Forge:master' into master

commit bb62d8fd8d
Merge: d0083a77b0 a61ea36c95
Author: Fulgur14 <54345051+Fulgur14@users.noreply.github.com>
Date:   Thu May 30 14:44:13 2024 +0200

    Merge branch 'Card-Forge:master' into master

commit d0083a77b0
Merge: 7ed0eb3cc3 2ddcaab59d
Author: Fulgur14 <54345051+Fulgur14@users.noreply.github.com>
Date:   Thu May 30 08:31:13 2024 +0200

    Merge branch 'Card-Forge:master' into master

commit 7ed0eb3cc3
Author: Fulgur14 <54345051+Fulgur14@users.noreply.github.com>
Date:   Wed May 29 18:45:31 2024 +0200

    Update architect_of_the_untamed.txt

* Delete forge-gui/res/cardsfolder/upcoming/the_capitoline_triad.txt

* Update khod_etlan_shiis_envoy.txt

* Update TypeLists.txt
2024-06-18 06:56:25 +02:00
Jetz
bf1f1ecb61 Pick-a-Beeble and The Most Dangerous Gamer.
Prize mechanic.
2024-06-17 19:03:23 -04:00
Agetian
1a5595dba1 - Added puzzle PS_MH31 (#5433) 2024-06-17 17:37:06 +03:00
Fulgur14
6831c90067 Add files via upload (#5431) 2024-06-17 09:05:42 +03:00
tool4ever
03c23902ac Update guide_of_souls.txt 2024-06-17 07:03:57 +02:00
Jetz
88c9559eea Mobile Deck Editor support for extra sections, including attractions. 2024-06-16 20:51:03 -04:00
Jetz
fbc475998e Support for programmatically setting the advanced search filter for the mobile card manager. 2024-06-16 19:54:20 -04:00
tool4ever
f43d3c090f Update flare_of_malice.txt 2024-06-16 08:06:33 +00:00
tool4ever
a83804a67d Update eldrazi_confluence.txt 2024-06-15 18:44:08 -04:00
Simisays
1250ed822e cleanup 2024-06-15 18:44:08 -04:00
tool4EvEr
2a5bed01b5 M3C 16 cards 2024-06-15 18:44:08 -04:00
tool4ever
55b648d39b Update path_of_annihilation.txt 2024-06-15 18:43:53 -04:00
Simisays
abacbb7019 cleanup 2024-06-15 18:43:53 -04:00
tool4EvEr
47d3aa143c 29 MH3 scripts 2024-06-15 18:43:53 -04:00
tool4ever
9070d6c0cd Update bespoke_battlewagon.txt 2024-06-15 18:43:38 -04:00
tool4ever
b60fcb0057 Update aerie_auxiliary.txt 2024-06-15 18:43:38 -04:00
Simisays
bb044dc921 Update monstrous_vortex.txt 2024-06-15 18:43:38 -04:00
Simisays
8ed0f9e1b4 cleanup 2024-06-15 18:43:38 -04:00
tool4EvEr
39d2240de1 29 MH3 scripts 2024-06-15 18:43:38 -04:00
Jetz
df40cdaea0 Made DeckSection.matchingSection more suitable for general use by shifting the responsibility of recognizing potential Commanders elsewhere. 2024-06-15 16:44:07 -04:00
Jetz
239735eaca Make countByName work for cards with multiple prints.
Add countByName to Deck
2024-06-15 12:39:38 -04:00
Simisays
4308cc3a77 MH3 9 cards (#5380) 2024-06-15 13:48:01 +00:00
Simisays
ae4fcc8b5a cleanup (#5427) 2024-06-14 22:24:41 +03:00
Hans Mackowiak
aacd75ab20 MH3: Emerge From (#5403)
* MH3: Emerge From

* ~ reuse Player
2024-06-14 18:06:19 +03:00
kevlahnota
14be75e711 add annihilator & exalted icon and update toxic icon (#5426)
* add annihilator icon and update toxic icon

* add exalted icon
2024-06-14 15:58:36 +03:00
tool4ever
a46702c395 Update possibility_storm.txt 2024-06-14 09:23:28 +02:00
Agetian
223f1792e6 - Added puzzle PS_OTJ4 (#5419) 2024-06-14 07:18:18 +03:00
Glorax
e0f3f13ccf Twisted Riddlekeeper (#5423)
* Add files via upload

* Update twisted_riddlekeeper.txt
2024-06-14 06:56:13 +03:00
Hans Mackowiak
4804dbc637 Keyword: Protection from each color (#5424) 2024-06-14 06:56:05 +03:00
tool4ever
7b651e1859 Update frenzied_gorespawn.txt 2024-06-13 20:09:17 +00:00
Fulgur14
c210eb6470 Update Conspiracy.txt 2024-06-12 10:57:43 -04:00
kevlahnota
f0fb245363 Merge pull request #5417 from kevlahnota/newmaster2
fix selectbox visibility
2024-06-12 19:26:49 +08:00
Anthony Calosa
b5c9dcbcb3 unused import 2024-06-12 19:17:53 +08:00
Anthony Calosa
bbf3486fc9 Merge branch 'master' into newmaster2 2024-06-12 19:16:17 +08:00
Anthony Calosa
37facd7e13 update selectbox BG 2024-06-12 19:03:16 +08:00
Anthony Calosa
e1cf9251db fix selectbox visibility 2024-06-12 18:52:15 +08:00
Chris H
50746d9a72 Draft matters with a vengeance (#5400)
* Next few Draft cards

* Whispergear Sneak

* Whispergear Sneak

* Code review fixes

* Fix index mapping

* Don't try to log if Draft doesnt have one
2024-06-12 09:18:12 +03:00
kevlahnota
5c02a580c3 Merge pull request #5414 from kevlahnota/newmaster2
update crack overlay simple progression
2024-06-12 13:55:02 +08:00
Northmoc
894ee36e79 M3C: final 2 "easy" cards (#5410) 2024-06-12 05:53:13 +00:00
tool4ever
00e0aa979c Script fixes (#5413) 2024-06-12 05:46:14 +00:00
Anthony Calosa
50c008669d update crack overlay simple progression 2024-06-12 11:42:29 +08:00
Northmoc
ca5a627035 MH3: wheel_of_potential + support (#5384)
* MH3: wheel_of_potential + support

* another go
2024-06-11 17:37:12 +03:00
Renato Filipe Vidal Santos
cf203a45b8 MH3 creature type update: Naga to Snake, Viashino to Lizard (#5402)
* Add files via upload

* Add files via upload

* Update TypeLists.txt

* Update rivaz_of_the_claw.txt

* Delete forge-gui/res/w/watchful_naga.txt

* Delete forge-gui/res/w/weaver_of_currents.txt

* Delete forge-gui/res/y/yurlok_of_scorch_thrash.txt

* Delete forge-gui/res/z/ziatoras_envoy.txt

* Delete forge-gui/res/z/zirilan_of_the_claw.txt

* Add files via upload
2024-06-11 17:37:02 +03:00
Paul Hammerton
1bdbf46ff2 Merge pull request #5409 from edg444/Planeswalker-Championship-Promos-Update
Update Planeswalker Championship Promos.txt
2024-06-11 13:29:56 +01:00
edg444
2300caab99 Update Planeswalker Championship Promos.txt
Two new cards
2024-06-11 07:22:05 -04:00
Paul Hammerton
210c47dfbc Merge pull request #5408 from paulsnoops/acr_update
Edition updates: ACR
2024-06-11 08:45:11 +01:00
Paul Hammerton
63966659ff Edition updates: ACR 2024-06-11 08:41:52 +01:00
Northmoc
5c0c89a78d M3C: exterminator_magmarch (#5397) 2024-06-11 07:17:04 +02:00
Hans Mackowiak
00daadc669 Delete forge-gui/tools/mtg-data.txt 2024-06-10 08:59:05 -04:00
Fulgur14
997cb7f9bb Added Phobos token script for The Spear of Leonidas (#5405) 2024-06-10 12:38:27 +02:00
kevlahnota
9b327cf3d2 Merge pull request #5401 from kevlahnota/newmaster2
Add Backup/Restore Data Adventure Mode
2024-06-10 06:10:41 +08:00
Jetz
614cc96f4f Support for adding Tabs to TabPageScreen 2024-06-09 13:31:04 -04:00
Simisays
9183ddf558 Large adventure update (#5398)
* Squashed commit of the following:

commit 2e0f844a2f40a622ffc0b55ed45f69a4d812fee6
Author: Simisays <67333662+Simisays@users.noreply.github.com>
Date:   Sat Jun 8 00:40:29 2024 +0200

    update

commit 25c21bf27f10fe6a78fb986f0a8ee6e7b0737978
Merge: d256832250 86154cccbd
Author: Simisays <67333662+Simisays@users.noreply.github.com>
Date:   Fri Jun 7 21:33:32 2024 +0200

    Merge remote-tracking branch 'upstream/master' into garruknahiri

commit d256832250168447543c3ca0980636e853ff3910
Author: Simisays <67333662+Simisays@users.noreply.github.com>
Date:   Wed Jun 5 19:45:29 2024 +0200

    update

commit b4b75fedc01ff1a739774194dba77aeeee46a0e7
Merge: 951440de0e 6b5412e7dc
Author: Simisays <67333662+Simisays@users.noreply.github.com>
Date:   Sun Jun 2 21:22:33 2024 +0200

    Merge remote-tracking branch 'upstream/master' into garruknahiri

commit 951440de0e9c0551238f5d1f6099b5c818c4555f
Author: Simisays <67333662+Simisays@users.noreply.github.com>
Date:   Fri May 31 23:29:14 2024 +0200

    update

commit f9a76ed16971afe94f0ee9e66332cff0e86f6e1b
Author: Simisays <67333662+Simisays@users.noreply.github.com>
Date:   Wed May 29 20:48:37 2024 +0200

    update

commit 6f2c153a91a1a71e8264aa49a745d44277926bb7
Merge: 6944cfb2b4 5119b72066
Author: Simisays <67333662+Simisays@users.noreply.github.com>
Date:   Mon May 27 23:33:56 2024 +0200

    Merge remote-tracking branch 'upstream/master' into garruknahiri

commit 6944cfb2b432672922de3e07ae6ad739c9b3b145
Author: Simisays <67333662+Simisays@users.noreply.github.com>
Date:   Mon May 27 23:33:15 2024 +0200

    cleanup

commit 440ea14bf064f5a42a897cb711b9963adc711f05
Merge: 84687d1002 9810264d82
Author: Simisays <67333662+Simisays@users.noreply.github.com>
Date:   Sun May 26 23:48:53 2024 +0200

    Merge remote-tracking branch 'upstream/master' into garruknahiri

commit 84687d100212a004f99b5d6b7f6bf73f065b7913
Author: Simisays <67333662+Simisays@users.noreply.github.com>
Date:   Sun May 26 23:48:45 2024 +0200

    update

commit 61abd7abf20fb71b32253923073161ef97e16f0e
Author: Simisays <67333662+Simisays@users.noreply.github.com>
Date:   Sat May 25 22:53:47 2024 +0200

    update

commit 12c9442e75146dfa2aff3b230c250d9a496896d6
Author: Simisays <67333662+Simisays@users.noreply.github.com>
Date:   Sat May 25 09:03:13 2024 +0200

    update

commit 57de9e398c08ebf4c1d879683d4b2fc49002005e
Merge: fa9c878d74 6694b5a327
Author: Simisays <67333662+Simisays@users.noreply.github.com>
Date:   Fri May 24 23:02:14 2024 +0200

    Merge remote-tracking branch 'upstream/master' into garruknahiri

commit fa9c878d74bc96296d2e13577940642ece84fc9f
Author: Simisays <67333662+Simisays@users.noreply.github.com>
Date:   Fri May 24 23:02:09 2024 +0200

    Update config.json

commit fc51b02e2728ffa31941c879da712c8b7a051951
Author: Simisays <67333662+Simisays@users.noreply.github.com>
Date:   Tue May 21 22:55:46 2024 +0200

    update

commit be24e7e6c97782430dd12234d006a0581556177e
Author: Simisays <67333662+Simisays@users.noreply.github.com>
Date:   Mon May 20 21:49:32 2024 +0200

    updateupdate

commit 3544b9715dfd21fa6b57ebd082691be8272ec44d
Author: Simisays <67333662+Simisays@users.noreply.github.com>
Date:   Sun May 19 23:30:44 2024 +0200

    update

commit 7fdf564c3f30466ae985cfd330c4ef64a013636d
Author: Simisays <67333662+Simisays@users.noreply.github.com>
Date:   Sun May 19 11:59:07 2024 +0200

    update

commit 3c46938f70104de142afae80dac75b1007b3f59f
Author: Simisays <67333662+Simisays@users.noreply.github.com>
Date:   Sat May 18 22:38:00 2024 +0200

    MOAR

commit 8c1126eb33073e6f4cd38b5734313de1c7454396
Author: Simisays <67333662+Simisays@users.noreply.github.com>
Date:   Sat May 18 22:37:47 2024 +0200

    update

commit aab99445192045dcbcee93d32826f604e39eeff0
Merge: 175312aab6 3309a48710
Author: Simisays <67333662+Simisays@users.noreply.github.com>
Date:   Thu May 16 23:34:17 2024 +0200

    Merge remote-tracking branch 'upstream/master' into garruknahiri

commit 175312aab690fbbc286171efece3e06944a3a32b
Author: Simisays <67333662+Simisays@users.noreply.github.com>
Date:   Thu May 16 23:34:11 2024 +0200

    update

commit 847191072fe1a8c71e81e1b4d0e5b79f1bd992e9
Author: Simisays <67333662+Simisays@users.noreply.github.com>
Date:   Mon May 13 19:18:52 2024 +0200

    update

commit a34f4ec0a9570be4f0ff0da4bb2512462efcebe1
Merge: babbfcfaa5 c7a138fc13
Author: Simisays <67333662+Simisays@users.noreply.github.com>
Date:   Sat May 11 13:41:42 2024 +0200

    Merge remote-tracking branch 'upstream/master' into garruknahiri

commit babbfcfaa54983a4f0916f5588c554a198749255
Author: Simisays <67333662+Simisays@users.noreply.github.com>
Date:   Fri May 10 23:40:12 2024 +0200

    hugemapupdate

commit ccbd5b907ad1a20d49d162ba7a2192a01fd7fc45
Author: Simisays <67333662+Simisays@users.noreply.github.com>
Date:   Thu May 9 23:24:45 2024 +0200

    updatre

commit 3f2d0cbc0123d20e7bb9414e49fc08f3330381a9
Author: Simisays <67333662+Simisays@users.noreply.github.com>
Date:   Thu May 9 13:01:08 2024 +0200

    update

commit 8f43aace8ad4434c56ae4e14bb3c1a02ee7c158a
Author: Simisays <67333662+Simisays@users.noreply.github.com>
Date:   Thu May 9 00:40:41 2024 +0200

    update

commit 585134cdb9347298d7138a32c3e5906c2993d70a
Merge: c51c6b119b a2deb08337
Author: Simisays <67333662+Simisays@users.noreply.github.com>
Date:   Wed May 8 18:42:43 2024 +0200

    Merge remote-tracking branch 'upstream/master' into garruknahiri

commit c51c6b119b72871cda3fcc0964d350d2e39830a2
Author: Simisays <67333662+Simisays@users.noreply.github.com>
Date:   Wed May 8 18:42:37 2024 +0200

    update

commit 4c4f1d70005668339dd7f14f244a7170fa231748
Merge: d4ac1939da 085b9e9735
Author: Simisays <67333662+Simisays@users.noreply.github.com>
Date:   Mon Apr 22 19:53:09 2024 +0200

    Merge remote-tracking branch 'upstream/master' into garruknahiri

commit d4ac1939daa16e77032978831a42c53d2139db01
Author: Simisays <67333662+Simisays@users.noreply.github.com>
Date:   Mon Apr 22 19:53:02 2024 +0200

    update

commit 1e1d7b7cef12b3ac5fb28c9ce7fede915e54a809
Merge: d872995ea6 fd2522e51c
Author: Simisays <67333662+Simisays@users.noreply.github.com>
Date:   Sun Apr 14 13:08:20 2024 +0200

    Merge branch 'Card-Forge:master' into garruknahiri

commit d872995ea63531e44bcb0ef2bf38b53b7a434ceb
Author: Simisays <67333662+Simisays@users.noreply.github.com>
Date:   Fri Jan 19 21:27:47 2024 +0100

    update

* temoraryrevert

* name changes

* Update shops.json

* Update config.json

* Update config.json

* d
2024-06-09 19:48:33 +03:00
Anthony Calosa
66f5704a8b update 2024-06-09 18:43:14 +08:00
Anthony Calosa
27ff643acc Merge branch 'master' into newmaster2 2024-06-09 18:35:14 +08:00
Anthony Calosa
d76453b8ad remove space 2024-06-09 18:22:49 +08:00
Anthony Calosa
6cdfe47d39 Add Backup/Restore Data Adventure Mode
- backup file should be on downloads directory
- fix some menu buttons double click/touch duplication
- update some translation
2024-06-09 18:15:45 +08:00
Northmoc
d06aab9a0b MH3: volatile_stormdrake + support (#5385) 2024-06-09 08:55:06 +03:00
Northmoc
ca197bb2bc M3C: 3 "easy" cards (#5396)
* aether_refinery, blaster_hulk

* benthic_anomaly
2024-06-09 08:53:30 +03:00
Hans Mackowiak
ac61d83941 Merge pull request #5399 from Glorax/master
Update atraxa_grand_unifier.txt
2024-06-09 07:12:55 +02:00
tool4ever
a9849696d3 CardRules: fix case with null tokens list (#5395)
* CardRules: fix NPE

* clean up

---------

Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
2024-06-09 07:08:45 +03:00
Glorax
681a543102 Update atraxa_grand_unifier.txt
Removed "horror" from creature types.
2024-06-08 14:44:58 -07:00
Jetz
1e5e1ba6c0 Redundant import 2024-06-08 12:36:20 -04:00
Anthony Calosa
f52a8e42c4 Merge branch 'master' into newmaster2 2024-06-08 11:25:11 +08:00
kevlahnota
cc08849132 Merge pull request #5394 from NimSpork/NimSpork-Gift-of-the-viper-fix
Update gift_of_the_viper.txt
2024-06-08 11:24:28 +08:00
Jetz
a3662079b4 Fix potential NPE. 2024-06-07 22:58:09 -04:00
Jetz
49e7576742 Merge remote-tracking branch 'origin/master' into Attractions
# Conflicts:
#	forge-core/src/main/java/forge/card/CardFace.java
#	forge-core/src/main/java/forge/card/CardRules.java
2024-06-07 22:13:24 -04:00
Jetz
279e1e520e Disambiguate requested print names 2024-06-07 21:59:59 -04:00
Jetz
8c8c8a779b AttractionsYouVisitedThisTurn and Squirrel Squatters
Untangled some oracle text methods in Card and CardState
Sly Spy, Everythingamajig, and two Garbage Elementals
Visit card text fix.
2 more Attractions
2024-06-07 21:36:10 -04:00
NimSpork
8625787b34 Update gift_of_the_viper.txt
Fix to give all counters
2024-06-07 21:56:12 +01:00
Anthony Calosa
75303a92e0 Merge branch 'master' into newmaster2 2024-06-07 18:36:39 +08:00
Paul Hammerton
86154cccbd Merge pull request #5389 from paulsnoops/edition_updates
Edition updates: SLD, SLP
2024-06-06 18:18:04 +01:00
tool4ever
32531ab285 18 M3C cards (#5325) 2024-06-06 17:16:09 +00:00
Paul Hammerton
fab03e5ad1 Merge pull request #5388 from paulsnoops/pauper_ban
Pauper ban: Cranial Ram
2024-06-06 18:14:40 +01:00
Paul Hammerton
6fc4fbaecb Edition updates: SLD, SLP 2024-06-06 18:14:13 +01:00
Paul Hammerton
95334a1c03 Pauper ban: Cranial Ram 2024-06-06 18:04:33 +01:00
Northmoc
b18223ce51 MH3: 2 "easy" cards (#5382)
* MH3: 2 "easy" cards

* update furious_rise
2024-06-06 11:52:02 -04:00
Northmoc
c91c6a13ac MH3: izzet_generatorium (#5386) 2024-06-06 13:37:56 +02:00
Anthony Calosa
e2ca3a1b0d Merge branch 'master' into newmaster2 2024-06-06 18:48:36 +08:00
Agetian
e0085790cc - Remove erroneous AILogic flag from Ecological Appreciation. (#5387) 2024-06-06 07:56:28 +03:00
tool4ever
e49dd53b20 Include TokenScripts when checking for DeckHints (#5379)
* Include TokenScripts when checking for DeckHints

* Fix test

* Add field for extra logic

---------

Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
2024-06-06 07:35:05 +03:00
Chris H
cb1c3ffee3 Fix DraftAction type 2024-06-05 23:55:49 -04:00
tool4ever
29508093a7 Update charix_the_raging_isle.txt 2024-06-05 15:37:38 +02:00
Anthony Calosa
af6cbf895e Merge branch 'master' into newmaster2 2024-06-05 18:58:01 +08:00
tool4EvEr
196cb3de4d Henzie fix 2024-06-05 11:38:00 +02:00
TRT
2fb300eeb6 Fix Wonderscape Sage 2024-06-05 11:37:30 +02:00
Hans Mackowiak
20fa6c35c4 Player counters removed this turn (#5377) 2024-06-05 11:36:52 +02:00
Northmoc
95a6443c11 MH3: 5 cards (#5373) 2024-06-04 20:30:06 +00:00
tool4ever
6a22d1d4ca Update rootless_yew.txt 2024-06-04 20:26:47 +00:00
Chris H
69a83ed129 Add Cogwork Grinder and combine some logic 2024-06-04 12:46:26 -04:00
tool4ever
9c9d2f2e45 Update paliano_the_high_city.txt 2024-06-04 12:46:26 -04:00
Chris H
b57ed2b165 Applying some code review comments 2024-06-04 12:46:26 -04:00
Chris H
7c9cf7f587 Add Paliano Vanguard 2024-06-04 12:46:26 -04:00
Chris H
edb85a18c4 Add Noble Banneret 2024-06-04 12:46:26 -04:00
Chris H
66bd484f27 Add Animus of Predation 2024-06-04 12:46:26 -04:00
Chris H
26ec757736 Show draft matters data in Card Detail Panel 2024-06-04 12:46:26 -04:00
Chris H
799fd4cc51 More draft matters 2024-06-04 12:46:26 -04:00
Chris H
4310fecc8b Unused imports 2024-06-04 12:46:26 -04:00
Chris H
7d4cb9b5a3 Trying to get Draft log in 2024-06-04 12:46:26 -04:00
Northmoc
db5d978934 MH3: detectives_phoenix + support (#5352) 2024-06-04 17:09:07 +02:00
Northmoc
57cd390238 UNF: magar_of_the_magic_strings.txt and support (#4105)
* UNF: magar_of_the_magic_strings.txt and support

* tweaks

* clean up

* revised
2024-06-04 16:46:33 +03:00
Paul Hammerton
14ddfa5680 Merge pull request #5369 from paulsnoops/mh3_formats
Add MH3, M3C, H2R to formats
2024-06-04 10:53:45 +01:00
Paul Hammerton
13d607df20 Add MH3, M3C, H2R to formats 2024-06-04 10:48:28 +01:00
mewtwo15026
5446b3dee3 MH3: Added Nadu, Trickster's Elk, Planar Genesis, Springheart Nantuko (#5356) 2024-06-04 10:12:49 +02:00
Paul Hammerton
fe0f58399c Merge pull request #5368 from Card-Forge/tehdiplomat-patch-2
Update The Brothers War Commander.txt
2024-06-04 08:30:33 +01:00
Chris H
5638974575 Update The Brothers War Commander.txt 2024-06-03 22:24:02 -04:00
Anthony Calosa
5aa556f617 Merge branch 'master' into newmaster2 2024-06-04 06:07:11 +08:00
kevlahnota
6012cde11b add Ward and Wither keyword icon (#5364)
-closes #5361
2024-06-03 17:31:33 +03:00
Anthony Calosa
6df802ce32 add Ward and Wither keyword icon
-closes #5361
2024-06-03 21:52:03 +08:00
Fulgur14
eec970eee6 Added Tricky Terrain precon (#5363)
* This is the first M3C precon that is supported
2024-06-03 12:50:40 +00:00
tool4ever
5e981fbee8 StaticAbilityAlternativeCost: next round of work (#5298) 2024-06-03 12:49:24 +00:00
Simisays
79514b1093 M3C 10 cards (#5360)
* Escaped isn't linked

* Fix Wonderscape Sage
2024-06-02 14:32:41 +00:00
Jetz
c6de232ac5 Merge remote-tracking branch 'origin/Attractions' into Attractions
# Conflicts:
#	forge-core/src/main/java/forge/card/CardRules.java
2024-06-02 09:35:10 -04:00
Jetz
beed2ad669 Merge fixes, performance tweaks, updated Unfinity's Editions file 2024-06-02 09:32:42 -04:00
Jetz
b36827292f Merge fixes, performance tweaks, updated Unfinity's Editions file 2024-06-02 09:28:36 -04:00
Simisays
6b5412e7dc Update veko_deaths_doorkeeper.txt (#5358) 2024-06-02 08:16:22 +00:00
mtwilliams14
639ce29d9a One MH3 Card (#5355)
Added Etherium Pteramander Script
2024-06-02 07:02:14 +00:00
tool4ever
d567ece5c6 Etched Slith and support (#5349) 2024-06-02 06:54:28 +00:00
Jetz
1b07896afe Merge branch 'master' into Attractions
# Conflicts:
#	forge-core/src/main/java/forge/card/CardRules.java
2024-06-02 02:16:31 -04:00
Jetz
174db0cac6 I think I see why nobody wanted to do this 2024-06-02 02:08:36 -04:00
kevlahnota
64e38b0b50 Fix NPE 2024-06-02 06:17:52 +08:00
tool4ever
d49126d95c Fix Emissary of Soulfire (#5350) 2024-06-01 16:55:58 +00:00
tool4ever
6a672eedb5 Fix Conflagrate (#5348) 2024-06-01 12:05:55 +00:00
Fulgur14
5c54b83f6d Two MH3 cards (#5331)
* Update architect_of_the_untamed.txt

* Add files via upload

* Update sage_of_the_unknowable.txt

---------

Co-authored-by: tool4ever <therealtoolkit@hotmail.com>
2024-06-01 13:33:18 +03:00
Paul Hammerton
9247e48c4d Merge pull request #5347 from paulsnoops/edition_updates
Edition updates: M3C, MH3
2024-06-01 10:02:20 +01:00
Paul Hammerton
f2826c2e75 Edition updates: M3C, MH3 2024-06-01 09:54:56 +01:00
Hans Mackowiak
60dc7753f4 ~ fix Omo, Queen of Vesuva 2024-06-01 10:42:50 +02:00
Chris H
fc74fc6dba Update vexing_bauble.txt 2024-06-01 05:14:08 +02:00
Northmoc
ca12539063 MH3: 3 cards (#5344) 2024-05-31 17:42:52 +02:00
Jackie Ng
ce97c264ed MH3: Kozilek's Unsealing (#5343) 2024-05-31 17:38:21 +02:00
Northmoc
114fb76c61 MH3: 3 cards that start with A (#5322) 2024-05-31 14:08:55 +03:00
tool4ever
6f3c2269e0 3 MH3 cards (#5324)
* Quest for the Necropolis

Official preview showed the mana cost, so I can implement it now.

* Emrakul's Messenger

Seem to have slipped between the cracks.

* Hydroelectric Specimen // Hydroelectric Laboratory

Possible now since the official preview revealed the back face.

* Update hydroelectric_specimen_hydroelectric_laboratory.txt

* Update quest_for_the_necropolis.txt

---------

Co-authored-by: Fulgur14 <54345051+Fulgur14@users.noreply.github.com>
2024-05-31 14:08:15 +03:00
Paul Hammerton
cac5bc318c Fix Razorgrass Ambush name (#5342) 2024-05-31 12:36:17 +02:00
Paul Hammerton
4ebed27da8 Merge pull request #5341 from paulsnoops/edition_updates
Edition updates: M3C, MH3
2024-05-31 09:42:57 +01:00
Paul Hammerton
46a8399192 Edition updates: M3C, MH3 2024-05-31 09:35:37 +01:00
Fulgur14
f865496d23 Added Depth Defiler, corrected Furnace Hellkite (#5339) 2024-05-30 19:35:53 +00:00
Fulgur14
a61ea36c95 Add files via upload (#5327) 2024-05-30 10:25:15 +00:00
Paul Hammerton
08fa7cd3db Fix Infernal Captor (#5338) 2024-05-30 08:34:18 +00:00
Paul Hammerton
0b81dbcc56 Merge pull request #5337 from paulsnoops/pal99_fix
PAL99: Remove fake Island
2024-05-30 09:15:07 +01:00
Paul Hammerton
fcfdcf41bb PAL99: Remove fake Island 2024-05-30 09:11:33 +01:00
Paul Hammerton
f91eb7ccf6 Merge pull request #5319 from edg444/Karn-Patch
Update Arena League 1999.txt
2024-05-30 09:02:10 +01:00
Paul Hammerton
9fc7abe7ff Merge pull request #5336 from paulsnoops/edition_updates
Edition updates: M3C, MH3
2024-05-30 08:56:36 +01:00
Fulgur14
15a1b85309 Changed apostrophe in Legion Leadership (#5335) 2024-05-30 07:54:50 +00:00
tool4ever
b8d644933a Another 10 MH3 cards (#5307)
Co-authored-by: Fulgur14 <54345051+Fulgur14@users.noreply.github.com>
2024-05-30 07:54:22 +00:00
tool4ever
6ec2871dd3 Nyxborn Unicorn and Omo, Queen of Vesuva (#5323) 2024-05-30 07:53:38 +00:00
Paul Hammerton
cb1e8a7e57 oops 2024-05-30 08:52:55 +01:00
Paul Hammerton
abd294a99f Edition updates: M3C, MH3 2024-05-30 08:51:32 +01:00
tool4ever
2ddcaab59d Some fixes (#5320)
Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
2024-05-30 08:32:08 +03:00
Glorax
60b4c998ba Update titans_vanguard.txt (#5332) 2024-05-29 20:31:39 +00:00
tool4ever
538fe1a391 MH3 15 cards (#5308) 2024-05-29 15:25:34 +00:00
Renato Filipe Vidal Santos
1a4d4ada13 Update shifting_woodland.txt (#5321) 2024-05-29 15:20:57 +00:00
Northmoc
54e369917a YOTJ Heist (#5304) 2024-05-29 17:18:32 +03:00
edg444
6834f86b4b Update Arena League 1999.txt
Added #8, Karn, Silver Golem
2024-05-29 10:03:10 -04:00
Northmoc
895b7b54c5 MH3: nethergoyf.txt + support (#5311) 2024-05-29 12:58:50 +02:00
Renato Filipe Vidal Santos
9fa35cb90e Update oko_the_ringleader.txt (#5317) 2024-05-28 20:12:58 +00:00
Renato Filipe Vidal Santos
f4d15605cd Fixing Planeswalker's Mischief, Psychic Theft (#5316) 2024-05-28 18:10:50 +00:00
Simisays
33797755eb MH3 10 cards (#5296) 2024-05-28 17:16:04 +00:00
Paul Hammerton
52fe09dd3e Merge pull request #5315 from paulsnoops/edition_updates
Edition updates: MH3
2024-05-28 17:48:32 +01:00
Paul Hammerton
78b77a0923 Edition updates: MH3 2024-05-28 17:45:14 +01:00
tool4ever
0b7a16a769 Another 10 MH3 cards (#5309) 2024-05-28 15:21:08 +02:00
Agetian
dfd060bb0f - Add puzzles PS_OTJ2 and PS_OTJ3. (#5314) 2024-05-28 08:17:03 +02:00
tool4ever
bc8ce731d6 MH3 10 cards (#5310)
* Add files via upload

* Update rosecot_knight.txt

* Update static_prison.txt

* Update glyph_elemental.txt

* Update hexgold_slith.txt

* Update inspired_inventor.txt

* Update muster_the_departed.txt

* Update wrath_of_the_skies.txt

---------

Co-authored-by: Fulgur14 <54345051+Fulgur14@users.noreply.github.com>
2024-05-28 07:13:47 +03:00
Fulgur14
5119b72066 Update bloodbriar.txt (#5306) 2024-05-27 10:36:18 +00:00
Agetian
9810264d82 Fix capitalization for caracal.atlas reference (#5302)
* - PreDH: Avoid warnings, exclude some sets that aren't yet in Forge

* - Enable PreDH format as always available to the player.

* - Fix capitalization for Caracal file name
2024-05-26 18:39:15 +03:00
tool4ever
7a56873f97 Fix Scapeshift returning Lake of the Dead + Swamp which it can sacrifice (#5300) 2024-05-26 14:06:52 +00:00
Hans Mackowiak
610697b744 Fix Image not loading on some skins (#5301) 2024-05-26 07:50:24 +00:00
Hans Mackowiak
bfba7ea773 Update razorlash_transmogrant.txt 2024-05-25 22:14:22 +02:00
Simisays
a2e7ddd2e2 MH3 10 cards (#5292) 2024-05-25 12:33:13 +00:00
tool4ever
651d01ab76 Panharmonicon fix for Nadu, Winged Wisdom (#5297) 2024-05-25 12:28:59 +00:00
Paul Hammerton
42cd2ec210 Merge pull request #5295 from paulsnoops/edition_updates
Edition updates: MH3
2024-05-25 10:26:28 +01:00
Paul Hammerton
aa0db7b6ea artist 2024-05-25 10:16:03 +01:00
Paul Hammerton
e46366f0df Edition updates: MH3 2024-05-25 10:13:21 +01:00
Fulgur14
59b5b5b8e2 Update devourer_of_destiny.txt (#5294) 2024-05-25 08:40:38 +00:00
Simisays
861497a883 MH3 10 double faced cards (#5284)
* update

* cleanup

* Update drowner_of_truth_drowned_jungle.txt
2024-05-25 08:25:35 +03:00
Simisays
6694b5a327 MH3 10 cards (#5280) 2024-05-24 18:57:24 +00:00
Paul Hammerton
1745ab5c85 Merge pull request #5291 from paulsnoops/edition_updates
Edition updates: MH3
2024-05-24 18:50:23 +01:00
Paul Hammerton
4afad70acf Edition updates: MH3 2024-05-24 18:39:29 +01:00
Glorax
d180de0225 Update eldritch_immunity.txt (#5287) 2024-05-24 05:27:48 +00:00
Paul Hammerton
8ca194127f Merge pull request #5285 from paulsnoops/edition_updates
Edition updates: MH3
2024-05-23 21:04:06 +01:00
Paul Hammerton
bf8f404a66 Edition updates: MH3 2024-05-23 21:00:23 +01:00
tool4ever
c0d1046326 Fix Mirror-Shield Hoplite (#5278)
Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
2024-05-23 08:48:58 +03:00
Agetian
0824c7daff Enable PreDH format in the deck editor (#5282)
* - PreDH: Avoid warnings, exclude some sets that aren't yet in Forge

* - Enable PreDH format as always available to the player.
2024-05-23 08:00:57 +03:00
Paul Hammerton
599f11699a Merge pull request #5279 from Glorax/master
Update Modern Horizons 3.txt
2024-05-22 20:49:03 +01:00
Glorax
f26f1a10f5 Update Modern Horizons 3.txt 2024-05-22 11:20:05 -07:00
Glorax
7f80188f41 Update Modern Horizons 3.txt 2024-05-22 11:19:19 -07:00
Glorax
b3056564cf Update Modern Horizons 3.txt 2024-05-22 11:12:29 -07:00
dependabot[bot]
a647735c74 ---
updated-dependencies:
- dependency-name: com.google.guava:guava
  dependency-type: direct:production
...

Signed-off-by: dependabot[bot] <support@github.com>
2024-05-22 11:13:02 -04:00
Paul Hammerton
d0165f9104 Merge pull request #5274 from paulsnoops/edition_updates
Edition updates: H2R, M3C, MH3, SLD, SPG
2024-05-22 08:35:06 +01:00
Paul Hammerton
f583cce75f Edition updates: H2R, M3C, MH3, SLD, SPG 2024-05-22 08:30:15 +01:00
Paul Hammerton
c08ffd1808 Merge pull request #5272 from Glorax/master
Updates to MH3 editions files
2024-05-22 08:12:39 +01:00
Agetian
172d39c57a - PreDH: Avoid warnings, exclude some sets that aren't yet in Forge (#5273) 2024-05-22 08:03:24 +03:00
Glorax
6469b88ea3 Update Modern Horizons 3 Commander.txt 2024-05-21 14:19:40 -07:00
Glorax
83fe8dc8f0 Update Modern Horizons 3.txt 2024-05-21 14:14:44 -07:00
Glorax
f40196d869 Update Modern Horizons 3 Commander.txt 2024-05-21 13:24:02 -07:00
TheLastNarwhal
035a77aab0 Adding PreDH format (#5251)
I believe I included all legal sets, though I did omit a fair few promo sets since I couldn't tell if they would contain illegal modern cards. The legal sets are New Phyrexia and everything that came before it. Also, I couldn't figure out what the "Order" part was, so I left it blank.
2024-05-21 20:55:59 +03:00
Paul Hammerton
90baa7a170 Merge pull request #5271 from paulsnoops/curly
Replace curly quotes
2024-05-21 18:55:45 +01:00
Paul Hammerton
6986aad2ca one more 2024-05-21 18:52:15 +01:00
Paul Hammerton
3c77c1ed8b Replace curly quotes 2024-05-21 18:51:16 +01:00
Simisays
176472561a MH3 20 cards (#5255) 2024-05-21 18:57:00 +02:00
Suthro
5c179e33ee MH3: 3 new Flipwalkers (#5263) 2024-05-21 18:41:46 +02:00
tool4ever
2d79cd761b Update ChooseGenericEffectAi.java 2024-05-21 14:22:32 +02:00
Agetian
a06b29ccd6 Comment tweak (#5270)
* - Basic AI logic for Tireless Provisioner.

* - Comment tweak
2024-05-21 14:34:43 +03:00
Agetian
f10330c5b7 - Basic AI logic for Tireless Provisioner. (#5269) 2024-05-21 14:32:23 +03:00
Chris H
6087167673 Draft Matters - How many cards you've drafted this round (#5203) 2024-05-21 11:36:59 +02:00
Paul Hammerton
6eebb1861f Merge pull request #5259 from Klisz/davinky
ACR Leonardo da Vinci
2024-05-21 08:33:59 +01:00
Paul Hammerton
5ef5e15b6c Merge pull request #5253 from Glorax/master
Update Modern Horizons 3.txt
2024-05-21 08:33:40 +01:00
Klisz
7c6b4eeb21 Update leonardo_da_vinci.txt 2024-05-20 14:09:43 -06:00
Chris H
e43d86055a Update otj.rnk 2024-05-20 09:15:05 -04:00
Suthro
8eb57e2369 MH3: Emrakul, the World Anew + 2 cards (#5258)
* MH3: Emrakul, the World Anew + 2 cards

MH3: Add card scripts for three MH3 cards:

- Emrakul, the World Anew
- Grist, Viracious Larva // Grist, the Plague Swarm
- Phlage, Titan of Fire's Fury

* Update grist_voracious_larva_grist_the_plague_swarm.txt
2024-05-20 08:38:58 +03:00
Fulgur14
cef0da3df7 Update tarmogoyf.txt
The token has a defined name, so it shouldn't have "Token" in it.
2024-05-20 06:11:50 +02:00
Klisz
1686170888 Update leonardo_da_vinci.txt
I think this should be correct, based on my reading of other scripts that use both Remember and Imprint, like Break Out, but I'm not super well versed on the differences and relations between those two things. I have tested it both with and without Rest in Peace in play and it does seem to work as it should, though.
2024-05-19 16:18:48 -06:00
Hans Mackowiak
e0f2d126dc FSkinProp: use Icons File for IMAGE type too 2024-05-19 12:19:09 +02:00
tool4ever
2194c1af84 Clean params (#5260) 2024-05-19 09:26:19 +00:00
Klisz
02f4c78daa Create leonardo_da_vinci.txt 2024-05-18 21:16:10 -06:00
junytang
0e491838fc Update Simplified Chinese cards translation (#5019) 2024-05-18 13:42:46 +00:00
add-le
43e8de400e French translations 2200+ translations (#4800)
* all 175 ONE fr-FR translation

* add missing french labels
2024-05-18 13:41:56 +00:00
Simisays
11d0c54023 MH3 10 cards (#5250) 2024-05-18 13:32:58 +00:00
Hans Mackowiak
d384da986b add ManaCostShard Map and cleanup Desktop and Mobile (#5215)
* add ManaCostShard Map and cleanup Desktop

* refactor mobile and remove SourceFile enum

* refactor mobile using ManaCostShard

* Fix Phyrexian Symbols and better String=>SkinProp mapping
2024-05-18 12:13:19 +02:00
Hans Mackowiak
c71c2c25e1 TokenAi: do not create Token that can't block in Response 2024-05-18 05:59:52 +02:00
Glorax
ddd1924e93 Update Modern Horizons 3.txt 2024-05-17 11:30:21 -07:00
Hans Mackowiak
3309a48710 AI: Basic Logic for Destroy RE 2024-05-16 20:19:07 +02:00
Hans Mackowiak
cb1c6a8676 Umbra armor rename 2024-05-16 20:19:07 +02:00
tool4EvEr
6f27c56b21 Planar Nexus and support 2024-05-16 18:36:24 +02:00
Paul Hammerton
303a1144d4 Merge pull request #5248 from Card-Forge/tehdiplomat-patch-2
Update wave_goodbye.txt
2024-05-16 15:31:55 +01:00
Chris H
c0497d53d4 Update wave_goodbye.txt 2024-05-16 09:50:09 -04:00
tool4ever
87988eede7 Effect cleanup and fixes (#5247)
* Fix script ordering

* Remove obsolete code

* Fix Zethi copies not entering the stack sequentially
2024-05-16 15:34:42 +02:00
Renato Filipe Vidal Santos
d9148e361a Cleanup following up on PR #5229 (#5246) 2024-05-15 20:14:51 +00:00
Simisays
0381cdf493 M3C 12 cards (#5224) 2024-05-15 19:40:35 +00:00
tool4ever
8614d05456 Panglacial Wurm: support altcosts (#5243) 2024-05-15 17:06:21 +02:00
Chris H
dfaba28acc Update lulu_forgetful_hollyphant.txt (#5241) 2024-05-15 16:42:53 +03:00
Hans Mackowiak
41f9c33475 CardFactoryUtil: added Equip Flag back for AltCost 2024-05-15 08:00:58 +02:00
Paul Hammerton
503b83857b PCEL: Deb Thomas (#5238) 2024-05-14 13:42:18 +02:00
Hans Mackowiak
2ca4dd345e CantChangeDayTime: StaticAbility instead of GlobalRule 2024-05-14 13:11:39 +02:00
Paul Hammerton
c5b275c906 Merge pull request #5233 from tool4ever/fix13
Refactor Maestros Ascendancy
2024-05-14 09:23:42 +01:00
Paul Hammerton
d858d9c381 Merge pull request #5237 from Card-Forge/plague_of_vermin_crash
Fix plague of vermin crash
2024-05-14 09:23:18 +01:00
Chris H
e317ffbe4c Fix plague of vermin crash 2024-05-13 23:21:25 -04:00
tool4EvEr
1ff32b17e2 AI hints 2024-05-13 20:27:04 +02:00
Paul Hammerton
decd8f8f8e Merge pull request #5234 from paulsnoops/13_05_bar
Banned and Restricted Announcement for May 13, 2024
2024-05-13 18:08:34 +01:00
Paul Hammerton
6570b08ace Banned and Restricted Announcement for 13 May, 2024 2024-05-13 18:03:30 +01:00
tool4EvEr
26ef0966ea Refactor Maestros Ascendancy 2024-05-13 16:38:11 +02:00
tool4ever
333da0d599 Update rictus_robber.txt 2024-05-12 20:19:15 +00:00
Renato Filipe Vidal Santos
e489e61d0a Incidental cleanup pass #2 (#5231) 2024-05-12 13:25:14 +00:00
tool4ever
9b54ecfe12 Some fixes (#5230)
* Fix bad Discord change

* Fix Risen Executioner using X shard

* Fix Marshland Bloodcaster

* Clean up
2024-05-12 12:11:06 +00:00
edg444
a20c0e8ccf Exile Graveyards Oracle Update + Minor Typos (#5229) 2024-05-12 11:51:21 +00:00
Renato Filipe Vidal Santos
600da3e80b Incidental cleanup pass #1 (#5228) 2024-05-11 21:16:59 +00:00
Paul Hammerton
3838359536 Merge pull request #5227 from paulsnoops/sld_update
Edition updates: SLD
2024-05-11 13:41:15 +01:00
Paul Hammerton
15568f90ca Edition updates: SLD 2024-05-11 13:35:03 +01:00
Chris H
c7a138fc13 Adding turbofog Adventure opponent (#5225) 2024-05-11 10:57:30 +03:00
Chris H
6152f75d9e Restore manual updater 2024-05-10 19:15:33 -04:00
Hans Mackowiak
0dcd0f4d61 StaticAbilityAlternativeCost: only set EffectZone if Param exist (#5223) 2024-05-10 08:57:17 +02:00
Paul Hammerton
9426575d25 MH3: Flare of Duplication (#5222) 2024-05-10 08:45:44 +03:00
Chris H
ab597c6755 Update TypeLists.txt (#5221) 2024-05-09 16:29:37 +02:00
Simisays
81b1cb9eff YOTJ 6 cards (#5211) 2024-05-09 12:24:03 +00:00
Paul Hammerton
8d1b6b44e3 Merge pull request #5220 from paulsnoops/sld_update
Edition updates: SLD
2024-05-09 10:17:54 +01:00
Paul Hammerton
f9fa406135 Edition updates: SLD 2024-05-09 10:03:41 +01:00
tool4ever
f60718b7b5 Some fixes (#5219)
Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
2024-05-08 22:06:04 +03:00
Paul Hammerton
a2deb08337 Merge pull request #5216 from paulsnoops/update_sld
Edition updates: M3C, SLD
2024-05-08 10:18:13 +01:00
Paul Hammerton
5e5ce654ba Edition updates: M3C, SLD 2024-05-08 10:15:00 +01:00
Renato Filipe Vidal Santos
11776b0b67 Adventure Mode cleanup: quest.json files (#5214)
* Add files via upload

* Add files via upload

* Update quests.json
2024-05-08 08:01:22 +03:00
Renato Filipe Vidal Santos
a979be95b3 Adventure Mode custom card cleanup (#5212)
* Add files via upload

* Update grolnoks_skin.txt

* Update scarecrow_totem.txt
2024-05-07 20:36:31 +03:00
Renato Filipe Vidal Santos
e14ab980b5 Hybrid mana notation cleanup (#5210)
* Add files via upload

* Update maelstrom_muse.txt
2024-05-07 09:53:58 +03:00
Paul Hammerton
5a27d1159b Merge pull request #5209 from paulsnoops/brawl_fix
Add BIG & OTJ to Brawl
2024-05-06 19:08:01 +01:00
Paul Hammerton
58fc91d424 Add BIG & OTJ to Brawl 2024-05-06 19:05:05 +01:00
Simisays
cad5945f91 YOTJ 8 cards (#5205) 2024-05-06 17:55:49 +00:00
tool4ever
96c517c49f Fix AI failing to pay Spree-like charm because it didn't see final cost (#5208)
Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
2024-05-06 20:31:45 +03:00
Agetian
4532fab999 - LDA deckgen info (May 2024, MKM+OTJ) (#5206) 2024-05-06 13:19:29 +03:00
Renato Filipe Vidal Santos
a10e3b48c3 Update xira_boss_effect.txt (#5202) 2024-05-06 09:35:47 +03:00
Hans Mackowiak
31ab875d6e ManaCostShard: add Hybrid Colorless (#5199)
* ManaCostShard: add Hybrid Colorless

* Add Hybrid Colorless Sprite

* fix CostReduction for ColorlessHybrid

---------

Co-authored-by: tool4ever <therealtoolkit@hotmail.com>
2024-05-06 08:21:01 +03:00
tool4ever
e49d57851f Fix Watcher of Hours triggering from Dust of Moments cast by opponent (#5204)
Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
2024-05-05 16:36:14 +03:00
Simisays
4ac97d467b YOTJ 10 cards (#5198)
* update

* Update ruby_collector.txt

* add

* Update Alchemy Thunder Junction.txt

* Update Alchemy Thunder Junction.txt

* cleanup
2024-05-05 16:36:07 +03:00
tool4ever
021cf3efc4 Clean up some obsolete payment checks (#5190) 2024-05-04 19:42:07 +00:00
Renato Filipe Vidal Santos
0c936170fc Tribal to Kindred update (#5186) 2024-05-04 19:39:42 +00:00
Renato Filipe Vidal Santos
d1170fbee6 Update champions_of_tyr.txt (#5201) 2024-05-04 19:19:12 +00:00
Simisays
3416d3d60e M3C Twins of Discord (#5185) 2024-05-04 18:15:14 +00:00
tool4ever
fda34f5e89 Fix ValidStack (#5200) 2024-05-04 18:06:03 +00:00
Renato Filipe Vidal Santos
bcccd6c8fd Update vexyr_ich_tekiks_heir.txt (#5193) 2024-05-04 12:23:44 +00:00
Paul Hammerton
be1451b502 Merge pull request #5196 from paulsnoops/yotj_formats
Add YOTJ to formats
2024-05-04 08:18:36 +01:00
Paul Hammerton
259d27c4c4 Merge pull request #5195 from paulsnoops/edition_updates
Edition updates: SLD, YOTJ
2024-05-04 08:17:44 +01:00
Paul Hammerton
28c0032b2a Add YOTJ to formats 2024-05-04 08:15:24 +01:00
Paul Hammerton
603ae72040 Edition updates: SLD, YOTJ 2024-05-04 08:10:05 +01:00
Chris H
410d720b37 Update otj.rnk 2024-05-02 22:25:01 -04:00
tool4ever
249c259dbf Fix Vexing Puzzlebox (#5180) 2024-05-02 20:16:35 +00:00
Hans Mackowiak
732259f78b CardFactoryUtil: fix Emerge Stack Description 2024-05-02 19:29:32 +02:00
tool4ever
9d5b35ed98 MH3: Herigast, Erupting Nullkite (#5188) 2024-05-02 16:15:11 +02:00
Paul Hammerton
cf71167536 Merge pull request #5181 from paulsnoops/edition_updates
Edition updates: MC3, MH3, SLD, YOTJ
2024-04-30 22:59:40 +01:00
Paul Hammerton
1d71c7fe04 Edition updates: MC3, MH3, SLD, YOTJ 2024-04-30 22:53:01 +01:00
Fulgur14
4dc782eb57 MH3: Added some cards from the leaks article (#5178) 2024-04-30 20:59:11 +00:00
Fulgur14
87422bf66c Nulldrifter (#5161) 2024-04-30 16:08:48 +00:00
tool4ever
ef7f74cedd Update return_the_favor.txt 2024-04-30 06:11:19 +00:00
Renato Filipe Vidal Santos
baf9effbb2 Cleaning repeated text: Folders 's' to 'u' (#5171) 2024-04-29 18:45:23 +00:00
tool4ever
b67d196ef8 Update scripts (#5175)
Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.60>
2024-04-29 13:30:40 +03:00
Renato Filipe Vidal Santos
b9ceb8eb96 Cleaning repeated text: Folders 'a' to 'c' (#5167) 2024-04-29 08:50:32 +02:00
Renato Filipe Vidal Santos
8d19d4547f Cleaning repeated text: Folders 'p' to 'r', 'rebalanced' (#5170) 2024-04-28 20:10:50 +00:00
Renato Filipe Vidal Santos
5c2ba0489f Cleaning repeated text: Folders 'd' to 'h' 2024-04-28 20:10:37 +00:00
Renato Filipe Vidal Santos
3e1b1d77cf Cleaning repeated text: Folders 'i' to 'o' 2024-04-28 09:32:34 +00:00
Renato Filipe Vidal Santos
5e7c2712a1 Cleaning repeated text: Folders 'v' to 'z', 'tokenscripts' (#5172) 2024-04-28 09:13:04 +00:00
Hans Mackowiak
10141306ee Update rictus_robber.txt
fixed pt
2024-04-27 13:10:51 +02:00
Hans Mackowiak
001c4d9302 Update rictus_robber.txt 2024-04-26 13:45:15 +02:00
tool4ever
87da29bbcf Update consuming_ashes.txt 2024-04-26 11:56:50 +02:00
Agetian
e2f4c2cfa7 - Move Concert Kaboomist out of upcoming. (#5162) 2024-04-26 09:36:50 +03:00
Northmoc
0a9782514e YMKM: concert_kaboomist + support (#4900)
Co-authored-by: Agetian <stavdev@mail.ru>
2024-04-26 09:33:50 +03:00
Chris H
106e3acf2a Update Forge.java 2024-04-25 23:38:16 -04:00
Chris H
f5caa34604 Update pom.xml 2024-04-25 23:38:16 -04:00
Chris H
65e704788f Update AndroidManifest.xml 2024-04-25 23:38:16 -04:00
GitHub Actions
8a8c77c4ae [maven-release-plugin] prepare for next development iteration 2024-04-25 19:29:38 -04:00
GitHub Actions
a4591fe3ac [maven-release-plugin] prepare release forge-1.6.62 2024-04-25 19:29:38 -04:00
Hans Mackowiak
9d333b3c37 Update HumanCostDecision.java
Try c in different names cost
2024-04-25 07:40:44 -04:00
Agetian
958a850add - Basic AI support. 2024-04-25 07:40:44 -04:00
Hans Mackowiak
5e16be58cc fix import 2024-04-25 07:40:44 -04:00
Hans Mackowiak
659c760e6a Transmuation Font: first try 2024-04-25 07:40:44 -04:00
Agetian
a9c97aac2c AI Sideboarding Mode toggle as a Preferences option (#5136)
* - Initial commit for the AI sideboarding mode toggle.

* - Tweak the parameter value to correspond to the enum.

* - Consistency.
2024-04-25 14:19:47 +03:00
tool4ever
c3a9ec062c Remove pseudokicker (#5157) 2024-04-25 08:46:01 +00:00
tool4ever
7e828fd654 Fix X shards in combat tax missing from total cost (#5154) 2024-04-25 07:32:42 +00:00
Agetian
c20c214b9c UNF Embiggen - take four (#5156)
* - UNF Embiggen by tehdiplomat

* - Undo some obsolete changes.

---------

Co-authored-by: Chris H <zenchristo@gmail.com>
2024-04-25 10:19:07 +03:00
Renato Filipe Vidal Santos
56d9c88919 Cost$ cleanup: Main event: Folder 't' part 3 2024-04-24 20:30:02 +00:00
Renato Filipe Vidal Santos
e4664f05da Cost$ cleanup: Main event: Folder 't' part 2 (#5152) 2024-04-24 20:29:49 +00:00
Renato Filipe Vidal Santos
a24d88cba7 Cost$ cleanup: Main event: Folder 't' part 1 (#5151) 2024-04-24 20:29:39 +00:00
Renato Filipe Vidal Santos
4bc82b1983 Cost$ cleanup: Main event: Folder 'v' 2024-04-24 20:29:27 +00:00
Renato Filipe Vidal Santos
aa2c258c0f Cost$ cleanup: Main event: Folder 'w' part 2 2024-04-24 20:29:16 +00:00
Renato Filipe Vidal Santos
da0c59e4c8 Cost$ cleanup: Main event: Folder 'w' part 1 2024-04-24 20:29:04 +00:00
Paul Hammerton
4c61a300a0 Merge pull request #5147 from dracontes/cleanup-rld-nonpermcost-main-48
Cost$ cleanup: Main event: Folder 's' part 7
2024-04-24 19:06:07 +01:00
Paul Hammerton
8ca16f1457 Merge pull request #5146 from dracontes/cleanup-rld-nonpermcost-main-47
Cost$ cleanup: Main event: Folder 's' part 6
2024-04-24 19:05:57 +01:00
Paul Hammerton
1e87524474 Merge pull request #5145 from dracontes/cleanup-rld-nonpermcost-main-46
Cost$ cleanup: Main event: Folder 's' part 5
2024-04-24 19:05:49 +01:00
Renato Filipe Vidal Santos
15661bb011 Update sway_of_the_stars.txt 2024-04-24 17:40:04 +01:00
Renato Filipe Vidal Santos
6f55c88f11 Cost$ cleanup: Main event: Folder 's' part 4 2024-04-24 16:33:33 +00:00
Renato Filipe Vidal Santos
f496b2b68f Cost$ cleanup: Main event: Folder 's' part 3 2024-04-24 16:30:44 +00:00
Renato Filipe Vidal Santos
8fceede483 Cost$ cleanup: Main event: Folder 's' part 2 2024-04-24 16:27:47 +00:00
Renato Filipe Vidal Santos
019355d326 Cost$ cleanup: Main event: Folder 's' part 1 (#5141) 2024-04-24 16:24:55 +00:00
Renato Filipe Vidal Santos
43b13d8bfe Add files via upload 2024-04-24 17:09:53 +01:00
Renato Filipe Vidal Santos
7a303ac378 Add files via upload 2024-04-24 17:07:41 +01:00
Renato Filipe Vidal Santos
b69a351f5a Add files via upload 2024-04-24 17:02:01 +01:00
Renato Filipe Vidal Santos
c1df406bb7 Cost$ cleanup: Main event: Folders 'rebalanced', 'u', 'y', & 'z' (#5138)
* Add files via upload

* Update a-unholy_heat.txt

* Update unholy_heat.txt

* Rename Invasion_of_kamigawa_rooftop_saboteurs.txt to invasion_of_kamigawa_rooftop_saboteurs.txt
2024-04-24 18:29:35 +03:00
Agetian
dc8fc56e36 - Add puzzle PS_OTJ1. (#5140)
- Tweak the name of PS_MKM puzzles.
2024-04-24 18:26:10 +03:00
Paul Hammerton
d9a6acc10b Merge pull request #5135 from dracontes/cleanup-rld-nonpermcost-main-40
Cost$ cleanup: Main event: Folder 'r' part 4
2024-04-24 10:59:45 +01:00
Paul Hammerton
99a7060b79 Merge pull request #5134 from dracontes/cleanup-rld-nonpermcost-main-39
Cost$ cleanup: Main event: Folder 'r' part 3
2024-04-24 10:59:38 +01:00
Paul Hammerton
40967c16ea Merge pull request #5133 from dracontes/cleanup-rld-nonpermcost-main-38
Cost$ cleanup: Main event: Folder 'r' part 2
2024-04-24 10:59:31 +01:00
Paul Hammerton
3f13b3a25d Merge pull request #5132 from dracontes/cleanup-rld-nonpermcost-main-37
Cost$ cleanup: Main event: Folder 'r' part 1
2024-04-24 10:59:22 +01:00
Renato Filipe Vidal Santos
d981120969 Cost$ cleanup: Main event: Folder 'q' 2024-04-24 10:21:35 +02:00
Renato Filipe Vidal Santos
137ce4c6e0 Cost$ cleanup: Main event: Folder 'p' part 3 2024-04-24 10:21:10 +02:00
Renato Filipe Vidal Santos
0f692fd10d Cost$ cleanup: Main event: Folder 'p' part 2 2024-04-24 10:20:57 +02:00
Renato Filipe Vidal Santos
552675484b Cost$ cleanup: Main event: Folder 'p' part 1 2024-04-24 10:20:47 +02:00
Renato Filipe Vidal Santos
09bd9d8861 Cost$ cleanup: Main event: Folder 'o' (#5127) 2024-04-24 10:20:11 +02:00
Renato Filipe Vidal Santos
b8705b55a0 Cost$ cleanup: Main event: Folder 'n' 2024-04-24 10:17:21 +02:00
Renato Filipe Vidal Santos
4b289151c1 Cost$ cleanup: Main event: Folder 'm' part 3 2024-04-24 10:16:50 +02:00
Renato Filipe Vidal Santos
20732adbd2 Cost$ cleanup: Main event: Folder 'm' part 2 (#5124) 2024-04-24 10:16:23 +02:00
Renato Filipe Vidal Santos
b8bbe66087 Cost$ cleanup: Main event: Folder 'm' part 1 2024-04-24 10:16:03 +02:00
Renato Filipe Vidal Santos
886473ffb6 Update restore_balance.txt 2024-04-24 06:12:24 +01:00
Hans Mackowiak
d5a384886b Update rakish_crew.txt 2024-04-24 07:01:17 +02:00
Agetian
9f13d36799 Deck-based AI hints metadata + predefined sideboarding plan support (#5113)
* - Support for AI hints in deck metadata.
- Support for pre-planned sideboarding using an AI hint.

* - Fix imports.

* - NPE prevention for cases when the AI has no sideboard.
2024-04-24 07:56:01 +03:00
Renato Filipe Vidal Santos
2967d466fe Add files via upload 2024-04-24 02:31:32 +01:00
Renato Filipe Vidal Santos
bc4b6ac9e5 Add files via upload 2024-04-24 02:27:16 +01:00
Renato Filipe Vidal Santos
0a29b113d5 Add files via upload 2024-04-24 02:22:03 +01:00
Renato Filipe Vidal Santos
8e31830a09 Add files via upload 2024-04-24 02:08:54 +01:00
Hans Mackowiak
b4b8d05260 Update rubblebelt_runner.txt 2024-04-23 21:24:26 +02:00
Renato Filipe Vidal Santos
c9768a1bfa Cost$ cleanup: Main event: Folder 'l' part 2 2024-04-23 16:49:39 +02:00
Renato Filipe Vidal Santos
fda67967ac Cost$ cleanup: Main event: Folder 'l' part 1 2024-04-23 16:49:21 +02:00
Paul Hammerton
2cd3e20a72 Merge pull request #5118 from dracontes/cleanup-rld-nonpermcost-main-25
Cost$ cleanup: Main event: Folders 'j' & 'k'
2024-04-23 11:23:49 +01:00
Paul Hammerton
c3e90c2846 Merge pull request #5117 from dracontes/cleanup-rld-nonpermcost-main-24
Cost$ cleanup: Main event: Folder 'i' part 2
2024-04-23 09:37:16 +01:00
Paul Hammerton
71c5a1c4ac Merge pull request #5116 from dracontes/cleanup-rld-nonpermcost-main-23
Cost$ cleanup: Main event: Folder 'i' part 1
2024-04-23 09:37:07 +01:00
Paul Hammerton
748a462357 Merge pull request #5122 from paulsnoops/edition_updates
Edition updates: PCBB, SLD
2024-04-23 09:36:25 +01:00
Paul Hammerton
9aca35dc46 Edition updates: PCBB, SLD 2024-04-23 09:32:52 +01:00
Paul Hammerton
b999a83197 Merge pull request #5115 from dracontes/cleanup-rld-nonpermcost-main-22
Cost$ cleanup: Main event: Folder 'h' part 2
2024-04-23 08:44:36 +01:00
Paul Hammerton
d0029427af Merge pull request #5114 from dracontes/cleanup-rld-nonpermcost-main-21
Cost$ cleanup: Main event: Folder 'h' part 1
2024-04-23 08:44:24 +01:00
Renato Filipe Vidal Santos
c71a45b16d Fixing Overzealous Muscle granting indestructible to players and not itself (#5119) 2024-04-22 19:27:25 +00:00
Renato Filipe Vidal Santos
ccb06b405d Add files via upload 2024-04-22 17:18:34 +01:00
Renato Filipe Vidal Santos
632da8f6f3 Add files via upload 2024-04-22 17:06:50 +01:00
Renato Filipe Vidal Santos
d7e49c48f7 Add files via upload 2024-04-22 17:05:37 +01:00
Renato Filipe Vidal Santos
86b19af531 Add files via upload 2024-04-22 16:44:18 +01:00
Renato Filipe Vidal Santos
1093c2712c Add files via upload 2024-04-22 16:40:42 +01:00
Renato Filipe Vidal Santos
4be58dd1d6 Cost$ cleanup: Main event: Folder 'g' part 2 2024-04-22 14:44:35 +02:00
Renato Filipe Vidal Santos
141c53e182 Cost$ cleanup: Main event: Folder 'g' part 1 2024-04-22 10:14:21 +00:00
Renato Filipe Vidal Santos
db6ea41104 Cost$ cleanup: Main event: Folder 'f' part 3 2024-04-22 08:55:40 +00:00
Renato Filipe Vidal Santos
ed4b19a72f Cost$ cleanup: Main event: Folder 'f' part 2 (#5108) 2024-04-22 08:55:18 +00:00
Renato Filipe Vidal Santos
1bb46ca9f2 Cost$ cleanup: Main event: Folder 'f' part 1 2024-04-22 08:54:58 +00:00
Renato Filipe Vidal Santos
d0d1c1d517 Cost$ cleanup: Main event: Folder 'e' part 2 (#5106) 2024-04-22 07:00:08 +00:00
Renato Filipe Vidal Santos
856245a8cc Cost$ cleanup: Main event: Folder 'e' part 1 (#5105) 2024-04-22 06:59:53 +00:00
Renato Filipe Vidal Santos
505733907a Cost$ cleanup: Main event: Folder 'd' part 3 2024-04-22 06:59:38 +00:00
Renato Filipe Vidal Santos
85ad884282 Cost$ cleanup: Main event: Folder 'd' part 2 (#5101) 2024-04-22 06:59:23 +00:00
Renato Filipe Vidal Santos
e5a8660d56 Cost$ cleanup: Main event: Folder 'd' part 1 (#5100) 2024-04-22 06:59:13 +00:00
Renato Filipe Vidal Santos
940c3fc0b9 Cost$ cleanup: Main event: Folder 'c' part 3 (#5097) 2024-04-22 06:59:01 +00:00
Hans Mackowiak
5a4a4bafc6 CardFactoryUtil: fix Squad Trigger for Copy 2024-04-21 23:08:51 +02:00
Renato Filipe Vidal Santos
5408dd7844 Cost$ cleanup: Main event: Folder 'd' part 4 2024-04-21 17:43:18 +00:00
Renato Filipe Vidal Santos
b3c7ef5f4f Cost$ cleanup: Main event: Folder 'c' part 4 2024-04-21 17:39:22 +00:00
Renato Filipe Vidal Santos
69f53b3c7c Cost$ cleanup: Main event: Folder 'c' part 1 2024-04-21 15:28:19 +00:00
tool4ever
c698bc8847 Update comeuppance.txt 2024-04-21 15:23:27 +00:00
Renato Filipe Vidal Santos
35fd172513 Cost$ cleanup: Main event: Folder 'c' part 2 2024-04-21 15:21:57 +00:00
Agetian
40c7bccd39 Basic AI sideboarding framework (#5089)
* - Add OTJ achievements by Marek14.

* - AI hint for Transcendence.

* - Basic AI sideboarding framework.

* - Basic AI sideboarding framework.

* - Add an option to allow planeswalkers to replace creatures.

* - Add an option to only allow shared types for cards exchanged during sideboarding.

* - Comment tweak

* - Modifications according to recommendations.

* - Logic tweak for lastOutcome.
2024-04-21 17:20:59 +03:00
Paul Hammerton
648105f49b ACR: Hidden Blade, MH3: Psychic Frog & Scurry of Gremlins (#5094) 2024-04-21 12:13:55 +00:00
Paul Hammerton
3c62024752 Merge pull request #5085 from dracontes/cleanup-rld-nonpermcost-main-5
Cost$ cleanup: Main event: Folder 'b' part 3
2024-04-21 12:09:01 +01:00
Paul Hammerton
95fe32ef15 Merge pull request #5084 from dracontes/cleanup-rld-nonpermcost-main-4
Cost$ cleanup: Main event: Folder 'b' part 2
2024-04-21 12:08:43 +01:00
Renato Filipe Vidal Santos
72f1290a7e Cost$ cleanup: Main event: Folder 'b' part 1 2024-04-21 10:23:54 +00:00
tool4ever
7206703676 Fix ResolvedLimit check always passing during LTB LKI (#5092) 2024-04-21 10:20:06 +00:00
Renato Filipe Vidal Santos
eb27e5092d Cost$ cleanup: Main event: Folder 'a' part 1 2024-04-21 08:53:57 +00:00
tool4ever
9fb6d8a1f6 Remove obsolete logic (#5090) 2024-04-21 08:27:11 +00:00
Renato Filipe Vidal Santos
83ad6a5423 Cost$ cleanup: Main event: Folder 'a' part 2 2024-04-20 22:19:31 +00:00
Agetian
085b9e9735 AI hint for Transcendence (#5088)
* - Add OTJ achievements by Marek14.

* - AI hint for Transcendence.
2024-04-20 22:14:07 +03:00
Agetian
dd1d7fa907 - Add OTJ achievements by Marek14. (#5087) 2024-04-20 22:11:27 +03:00
Jetz72
8fe39bca9b Discord, Lord of Disharmony + Support (#5073)
* Discord, Lord of Disharmony + Support

* Prevent AI use for now.

* Include chosen name's description in text box

* Clean up DescriptionFromChosenName

* Remove blank lines from Discord card script

---------

Co-authored-by: Jetz <Jetz722@gmail.com>
2024-04-20 20:32:27 +03:00
Renato Filipe Vidal Santos
63d387d3ad Cleaning up extraneous SpellDescription$ on Soulfire Grand Master-like replacement effects on spell resolution (#5086) 2024-04-20 15:18:00 +00:00
Renato Filipe Vidal Santos
143a9acdf8 Cost$ cleanup: straggler pass #3 (#5076) 2024-04-20 13:53:32 +00:00
tool4ever
2efcace2b6 Some fixes (#5079)
* Clean up CardTypes syntax

* Riku counting fix
2024-04-20 13:40:43 +00:00
Renato Filipe Vidal Santos
fd453dce07 Typo cleanup pass #4 (#5046) 2024-04-20 13:03:14 +00:00
Renato Filipe Vidal Santos
78d6ed1df4 Add files via upload 2024-04-20 12:13:55 +01:00
Renato Filipe Vidal Santos
5198d99501 Add files via upload 2024-04-20 12:11:20 +01:00
Renato Filipe Vidal Santos
74ccba26af Update dust_animus.txt (#5080) 2024-04-20 10:05:21 +00:00
tool4ever
1587c95ca1 Fix Doomsday Confluence asking for X twice (#5071) 2024-04-19 16:45:39 +00:00
Paul Hammerton
8769ad693b Merge pull request #5074 from paulsnoops/otj_migrate_last
OTJ: Migrate last cards from upcoming
2024-04-19 14:37:55 +01:00
Paul Hammerton
a2ded0b97b OTJ: Migrate last cards from upcoming 2024-04-19 14:34:36 +01:00
Chris H
7e5a1c9e09 Add boosters info for OTJ 2024-04-19 07:19:43 -04:00
Renato Filipe Vidal Santos
25a083025e Cost$ cleanup: straggler pass #2 2024-04-18 19:59:00 +00:00
Renato Filipe Vidal Santos
a619b8c9e2 Cost$ cleanup: straggler pass #1 2024-04-18 19:24:59 +00:00
tool4ever
ff57334192 Some fixes (#5067) 2024-04-18 19:24:41 +00:00
tool4ever
2bb068789f Update pest_control.txt 2024-04-18 09:54:08 +02:00
Paul Hammerton
c8840f8f16 Merge pull request #5065 from Agetian/ai-subterranean-schooler
Add AI implementation for Subterranean Schooler
2024-04-18 08:47:22 +01:00
Paul Hammerton
74931f1323 Merge pull request #5062 from Simisays/Catsanddogs
Raining Cats and Dogs [SLD] [2024] commander precon
2024-04-18 08:47:11 +01:00
Renato Filipe Vidal Santos
c34bd5fd6c ACR: Altaïr, Haystack, The Animus (#5061)
* Add files via upload

* Update CounterEnumType.java

* Update haystack.txt

* Update altair_ibn_laahad.txt

* Update the_animus.txt

* Update haystack.txt

* Update altair_ibn_laahad.txt
2024-04-18 10:35:36 +03:00
Agetian
c611b9ba0f - Add AI implementation for Subterranean Schooler.
- AI shouldn't miss triggers with AF Explore.
2024-04-18 10:34:05 +03:00
Simisays
94608ac125 Create Raining Cats and Dogs [SLD] [2024].dck 2024-04-17 23:32:06 +02:00
Fulgur14
41525a1c2a Three remaining OTC decks (#5060)
* Added Desert Bloom [OTC]

* Three remaining OTC decks
2024-04-17 19:09:25 +03:00
tool4ever
914dd180e1 Remove AltCost SVar (#5057) 2024-04-17 08:31:17 +02:00
Renato Filipe Vidal Santos
16f9868929 OTC: Forger's Foundry, Savvy Trader, Smirking Spelljacker, Smoldering Stagecoach (#5009) 2024-04-17 08:30:52 +02:00
Agetian
40bd23d998 - Add puzzle PS_MKM4. (#5059) 2024-04-17 07:46:02 +03:00
Paul Hammerton
0c9d2635e3 OTJ: Last three cards (#5058) 2024-04-17 07:26:13 +03:00
Fulgur14
fb03a8eadf Added Desert Bloom [OTC] (#5056) 2024-04-16 20:04:18 +00:00
Paul Hammerton
829f49ec86 Migrate upcoming for OTJ release 2024-04-16 12:07:53 -04:00
Northmoc
3b8ec7fcda Merge pull request #5010 from Northmoc/spree2
OTJ: more spree cards and polish
2024-04-16 11:20:17 -04:00
Northmoc
53934bd9b1 OTJ: more spree cards and polish 2024-04-16 11:00:00 -04:00
Northmoc
982db244a6 OTJ: obeka_splitter_of_seconds + support (#5013) 2024-04-16 16:49:04 +02:00
tool4ever
bcaadd0765 Remove Alternative Cost KW (#5050) 2024-04-16 16:00:16 +02:00
tool4ever
4ccbc9baa6 Fix for Morph via CopyCard$ (#5049) 2024-04-16 12:17:55 +02:00
Simisays
9e0fa7c65d OTC 10 cards (#5033)
* update

* cleanup + 4 more

* Update angelic_sell_sword.txt

* Update charred_graverobber.txt
2024-04-16 07:16:02 +03:00
Renato Filipe Vidal Santos
b332d22611 Resolving ValidDesc$ vs ValidDescription$ (#5042)
* Add files via upload

* Update ChooseCardNameEffect.java
2024-04-16 07:15:51 +03:00
Hans Mackowiak
4d26228ca6 Alternative Cost For ActivatedAbilities and Spells (#5037)
* Rework Alternative Cost + MayPlay
2024-04-15 14:12:39 +02:00
Renato Filipe Vidal Santos
d3e471f6e0 BLB: Bria, Byrke, Mabel (#5043) 2024-04-15 08:08:44 +00:00
tool4ever
04b995ed7e Don't transform X shards of UnlessCost before paying (#5041)
* Refactor fake X shard on UnlessCost
2024-04-15 08:07:56 +00:00
Hans Mackowiak
af0da10fc9 Update simulacrum_synthesizer.txt 2024-04-15 09:45:01 +02:00
Hans Mackowiak
5db3a6f882 Update generous_plunderer.txt 2024-04-15 09:44:12 +02:00
Renato Filipe Vidal Santos
981f5553b6 Typo cleanup pass #3 (#5039) 2024-04-14 18:23:11 +00:00
Chris H
3bd88b4ba0 UNF Starlight Spectacular (#5040) 2024-04-14 18:08:19 +00:00
Paul Hammerton
1671f1f6c4 crowd_fix 2024-04-14 11:44:21 -04:00
Paul Hammerton
3cfcde6436 last_one 2024-04-14 11:44:21 -04:00
Paul Hammerton
5ff58bd75e two_more 2024-04-14 11:44:21 -04:00
Paul Hammerton
986d74b4fe add_more_fix_stuff 2024-04-14 11:44:21 -04:00
Paul Hammerton
5d01936dc6 add_cards 2024-04-14 11:44:21 -04:00
Paul Hammerton
d3ddb326b7 Assist cards from BBD 2024-04-14 11:44:21 -04:00
Michael Lo
fd2522e51c BLB Lumra, Bellow of the Woods (#5025) 2024-04-14 10:11:04 +00:00
Renato Filipe Vidal Santos
f11130b11c Typo cleanup pass #2 (#5036) 2024-04-14 09:26:55 +00:00
Renato Filipe Vidal Santos
d0aec3dddd OTC: Discreet Retreat, Dream-Thief's Bandana, Dune Chanter (#5034) 2024-04-14 07:49:51 +00:00
Hans Mackowiak
5a6041b6ba ForgeScript: More Flags as Keywords 2024-04-14 09:39:23 +02:00
Hans Mackowiak
d6422688b8 MagicStack: ThisTurnActivated 2024-04-14 06:13:11 +02:00
Renato Filipe Vidal Santos
abba1c7230 OTC: Kirri, Leyline Dowser, Lock and Load (#5032)
* Add files via upload

* Update leyline_dowser.txt

* Update show_of_confidence.txt

* Update honor_worn_shaku.txt

* Update leyline_dowser.txt

* Update leyline_dowser.txt

* Update show_of_confidence.txt

* Update leyline_dowser.txt

* Update lock_and_load.txt
2024-04-13 18:51:46 +03:00
Simisays
cab01c430e BIG 4 cards (#5027) 2024-04-13 15:05:17 +00:00
Renato Filipe Vidal Santos
b2fbd20771 Animate effect cleanup pass #2.5 (#5022) 2024-04-13 12:45:50 +00:00
nthoron
efe7acdab4 Four OTC cards (#5018) 2024-04-13 12:43:33 +00:00
Renato Filipe Vidal Santos
7d70213d73 OTC: Orochi Soul-Reaver, Pyretic Charge, Sand Scout (#5028) 2024-04-13 12:43:09 +00:00
tool4EvEr
7d6bb4d4f2 Display improvements 2024-04-13 08:31:45 -04:00
Chris H
0d67236656 Remove unused imports 2024-04-13 08:31:45 -04:00
Chris H
f41d876384 Basic refund should refund to the paying player, not the main activator 2024-04-13 08:31:45 -04:00
TRT
291411e847 Support AI assisting 2024-04-13 08:31:45 -04:00
Chris H
d2e3b4826d Initial commit for Assist 2024-04-13 08:31:45 -04:00
Hans Mackowiak
ffbef63390 Ascend: without SpellAbility.blessing flag 2024-04-13 11:46:12 +02:00
Paul Hammerton
4cfa415cd1 Merge pull request #5031 from paulsnoops/edition_updates
Edition updates: PMEI, SLD
2024-04-13 10:19:40 +01:00
Paul Hammerton
cc4c6afe1f Edition updates: PMEI, SLD 2024-04-13 10:15:25 +01:00
Paul Hammerton
c4010ee12e Merge pull request #5029 from paulsnoops/otj_formats
Add OTJ, OTC, OTP, BIG to formats
2024-04-13 09:54:39 +01:00
Paul Hammerton
6abfa543b1 Add OTJ, OTC, OTP, BIG to formats 2024-04-13 09:50:42 +01:00
Hans Mackowiak
c312f3c29c Embalm and Eternalize use Keyword and Refactor Copy 2024-04-13 09:19:10 +02:00
Morgenmvffel
ded1bc971f 2 otc cards (#5004) 2024-04-13 06:59:27 +00:00
Simisays
7de340cff5 BIG 3 cards 2024-04-13 06:58:48 +00:00
Simisays
c9d40949da BIG 10 cards (#5012) 2024-04-13 06:58:15 +00:00
Northmoc
996bb88c6a OTJ: last easy cards (#5014) 2024-04-12 18:48:32 +03:00
Northmoc
9675000f1b OTJ: taii_wakeen_perfect_shot + support (#5015) 2024-04-12 18:48:22 +03:00
tool4ever
839d040c8b Fix Orvar (#5021)
Co-authored-by: TRT <>
2024-04-12 18:48:10 +03:00
Northmoc
9975d68f04 fix crashes issue4472 (#5008) 2024-04-12 18:47:56 +03:00
Hans Mackowiak
f310948398 Outlast: use Keyword for check (#5020) 2024-04-12 09:08:52 +02:00
Renato Filipe Vidal Santos
864f67f468 Typo cleanup pass #1 (#5017) 2024-04-12 06:04:19 +02:00
Renato Filipe Vidal Santos
f6a02b84f7 OTC: Thieving Varmint, Thunderclap Drake, Tower Winder (#5000)
* Add files via upload

* Update brenard_ginger_sculptor.txt

* Update synth_infiltrator.txt

* Update halsin_emerald_archdruid.txt

* Update hedge_whisperer.txt

* Update jolrael_voice_of_zhalfir.txt

* Update awakener_druid.txt

* Update balduvian_frostwaker.txt

* Update ignition_team.txt

* Update koth_of_the_hammer.txt

* Update roaring_earth.txt

* Update woodwraith_corrupter.txt

* Update thunderclap_drake.txt
2024-04-11 20:32:38 +03:00
Renato Filipe Vidal Santos
617d350e34 Animate effect cleanup pass #1 (#5006)
* Update angels_tomb.txt

* Update atarka_monument.txt

* Update ojutai_monument.txt

* Update dromoka_monument.txt

* Update kolaghan_monument.txt

* Update silumgar_monument.txt

* Update azorius_keyrune.txt

* Update boros_keyrune.txt

* Update dimir_keyrune.txt

* Update gruul_keyrune.txt

* Update izzet_keyrune.txt

* Update simic_keyrune.txt

* Update orzhov_keyrune.txt

* Update rakdos_keyrune.txt

* Update golgari_keyrune.txt

* Update selesnya_keyrune.txt

* Update cave_of_the_frost_dragon.txt

* Update den_of_the_bugbear.txt

* Update hall_of_storm_giants.txt

* Update hive_of_the_eye_tyrant.txt

* Update lair_of_the_hydra.txt

* Update celestial_colonnade.txt

* Update creeping_tar_pit.txt

* Update lavaclaw_reaches.txt

* Update raging_ravine.txt

* Update stirring_wildwood.txt

* Update chronatog_totem.txt

* Update foriysian_totem.txt

* Update phyrexian_totem.txt

* Update thunder_totem.txt

* Update weatherseed_totem.txt

* Update faerie_conclave.txt

* Update forbidding_watchtower.txt

* Update ghitu_encampment.txt

* Update spawning_pool.txt

* Update treetop_village.txt

* Update hissing_quagmire.txt

* Update lumbering_falls.txt

* Update needle_spires.txt

* Update shambling_vent.txt

* Update wandering_fumarole.txt

* Update nantuko_monastery.txt

* Update svogthos_the_restless_tomb.txt

* Update restless_bivouac.txt

* Update restless_cottage.txt

* Update restless_fortress.txt

* Update restless_spire.txt

* Update restless_vinestalk.txt

* Update restless_reef.txt

* Update restless_prairie.txt

* Update restless_vents.txt

* Update restless_ridgeline.txt

* Update restless_anchorage.txt

* Update stuffed_bear.txt

* Update surge_engine.txt

* Update trove_warden.txt
2024-04-11 20:32:17 +03:00
Chris H
b1ae12374b Update RollPlanarDiceAi.java 2024-04-11 09:22:15 -04:00
Chris H
c162db40c4 Update and rename GAM_12_Palantír of Orthanc based deck_20_0.dck to GAM_12_Palantir of Orthanc based deck_20_0.dck 2024-04-10 21:18:06 -04:00
Simisays
8f93560ff3 BIG 5 cards (#4999) 2024-04-10 15:01:58 +02:00
Renato Filipe Vidal Santos
8714ae8711 OTC: Vengeful Regrowth, Vihaan, We Ride at Dawn (#4998)
* Add files via upload

* Update vexing_puzzlebox.txt
2024-04-10 07:13:55 +03:00
Simisays
b3816224ff OTJ 10 cards (#4982)
* 7 cards

* Update quick_draw.txt

* Update quick_draw.txt

* Update peerless_ropemaster.txt

* 3 more

* cleanup
2024-04-10 07:13:43 +03:00
Agetian
e8fbeae710 AI Pump tweaks for abilities with a sacrifice self cost + Witch's Clinic AI hint. (#4990)
* - Add puzzle PS_PIP1.

* - Fix advanced Flash logic messing with PlayEffect AI (e.g. Discover X or transformed Battle)

* - Better tweak to Flash logic conditions

* - Some tweaks to the Pump logic involving decisions on a self-sacrifice ability.
- AI targeting hint for Witch's Clinic.

* OTJ 20 cards (#4963)

* update

* update + 9 more

* + cleanup and six cards

* cleanup

* update

* update

* Four new OTJ cards (#4987)

* Four new OTJ cards

Added Resilient Roadrunner, Raucous Entertainer, Reach for the Sky, and Redrock Sentinel.

* Update redrock_sentinel.txt

* Update raucous_entertainer.txt

---------

Co-authored-by: tool4ever <therealtoolkit@hotmail.com>

* Add files via upload (#4984)

---------

Co-authored-by: Simisays <67333662+Simisays@users.noreply.github.com>
Co-authored-by: nthoron <51097546+nthoron@users.noreply.github.com>
Co-authored-by: tool4ever <therealtoolkit@hotmail.com>
Co-authored-by: Renato Filipe Vidal Santos <45150760+dracontes@users.noreply.github.com>
2024-04-09 22:02:48 +03:00
Hans Mackowiak
096c026ee9 CardType: Outlaw fix (#4997) 2024-04-09 21:40:49 +03:00
tool4ever
5ac6dd7d94 Misc tidy (#4994)
* VATS fix
2024-04-09 18:30:11 +00:00
tool4ever
5354c1159e Fix mana doublers not working during payment (#4995)
Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.59>
2024-04-09 20:52:46 +03:00
Northmoc
b8bd2f030e OTJ spree cards (#4991)
two more

2 more
2024-04-09 20:20:31 +03:00
Northmoc
a34da2b8a0 some more saddle polish (#4992) 2024-04-09 20:20:23 +03:00
edg444
a28c9d478d Minor Patch (#4993)
* Update walking_skyscraper.txt

CARDNAME -> this spell

* Update stoic_rebuttal.txt

CARDNAME -> this spell

* Update lightning_core_excavator.txt

CARDNAME -> It

* Update the_circle_of_loyalty.txt

CARDNAME -> This spell
2024-04-09 10:58:05 -04:00
Northmoc
5edcc9925c OTJ: felix_five_boots + support (#4955) 2024-04-09 16:23:47 +02:00
Renato Filipe Vidal Santos
3712dec09d Add files via upload (#4984) 2024-04-09 12:30:38 +03:00
nthoron
097d0689b5 Four new OTJ cards (#4987)
* Four new OTJ cards

Added Resilient Roadrunner, Raucous Entertainer, Reach for the Sky, and Redrock Sentinel.

* Update redrock_sentinel.txt

* Update raucous_entertainer.txt

---------

Co-authored-by: tool4ever <therealtoolkit@hotmail.com>
2024-04-09 12:30:29 +03:00
Agetian
8e053bbbfe Fix advanced Flash logic messing with PlayEffectAi (#4989)
* - Add puzzle PS_PIP1.

* - Fix advanced Flash logic messing with PlayEffect AI (e.g. Discover X or transformed Battle)

* - Better tweak to Flash logic conditions
2024-04-09 12:30:08 +03:00
Simisays
56d67e26cc OTJ 20 cards (#4963)
* update

* update + 9 more

* + cleanup and six cards

* cleanup

* update

* update
2024-04-09 07:42:35 +03:00
Agetian
bb2b22d09e - Add puzzle PS_PIP1. (#4988) 2024-04-09 07:41:42 +03:00
Chris H
ecd2f904e5 Freeze the stack just before we start paying for things so the ability equality matches 2024-04-08 21:45:32 -04:00
Northmoc
1daaae5f1b OTJ: riku_of_many_paths + support (#4954)
* OTJ: riku_of_many_paths + support

* v2

* refactor
2024-04-08 19:22:51 +03:00
Chris H
152ad0b0af Fix committed typo 2024-04-08 10:11:52 -04:00
Chris H
518e30284f Stash snapshot after loading game state 2024-04-08 10:11:52 -04:00
Chris H
1a2de095db Fix restoration referencing the wrong game when restoring game entities 2024-04-08 10:11:52 -04:00
Chris H
6d5579c4b8 Fix some more places where gaame elements were reusing old game versions 2024-04-08 10:11:52 -04:00
Chris H
2c04b08ae8 Java doesn't shortcircuit &= 2024-04-08 10:11:52 -04:00
Chris H
96f1178d68 SHould fix duplicating mana and duplicating spells on stack 2024-04-08 10:11:52 -04:00
Chris H
91259f4d8b Code review comments 2024-04-08 10:11:52 -04:00
Chris H
175c25145d Experimental Snapshots for undoing spell/abilities 2024-04-08 10:11:52 -04:00
Chris H
9eb50f441a Update Forge.java 2024-04-08 13:30:25 +02:00
Paul Hammerton
ecba62df67 Merge pull request #4980 from paulsnoops/sld_update
Edition updates: SLD
2024-04-08 09:36:35 +01:00
Paul Hammerton
a1de6698a4 Edition updates: SLD 2024-04-08 09:31:40 +01:00
loud1990
1a5b2e450e Add OTJ Pillage the Bog (#4978) 2024-04-08 08:27:11 +02:00
tool4ever
a8211c3da3 Fix ChangeZone* not always shuffling (#4976)
* Support nicknames for non-rebranded

* Fix ChangeZone* not always shuffling
2024-04-07 20:28:23 +00:00
Renato Filipe Vidal Santos
f664afd4a4 OTJ: Sheriff of Safe Passage, Shoot the Sheriff, Silver Deputy, Slickshot Lockpicker, Spinewoods Armadillo, Step Between Worlds (#4967) 2024-04-07 20:28:09 +00:00
Simisays
0ad0eae8ba OTJ 10 cards (#4974) 2024-04-07 16:46:41 +02:00
Paul Hammerton
92c6b06e68 Merge pull request #4975 from paulsnoops/edition_updates
Edition updates: BIG, OTC, OTJ, OTP, SLD
2024-04-07 13:33:58 +01:00
Paul Hammerton
6339065aea Edition updates: BIG, OTC, OTJ, OTP, SLD 2024-04-07 13:28:28 +01:00
Chris H
d7386138ea Manually update android versions (#4969) 2024-04-07 13:51:18 +03:00
Northmoc
4dde9e549f Affinity keyword tweaks (OTJ + WHO) (#4951)
* OTJ: hellspur_brute + support

* banish_to_another_universe update

* v2
2024-04-07 13:51:11 +03:00
loud1990
f46dd9beec Create slick_sequence (#4966) 2024-04-07 09:52:03 +00:00
Northmoc
98f8a031a5 OTJ: more saddle support and cards (#4947) 2024-04-07 08:27:25 +00:00
tool4ever
2c7556de92 Some fixes (#4970) 2024-04-07 08:25:45 +00:00
Chris H
c3eebafbff Update Mystery Booster Playtest Cards.txt (#4968) 2024-04-07 07:23:39 +00:00
loud1990
729eaf90d3 Create razzle-dazzler (#4965) 2024-04-06 21:36:43 +00:00
Paul Hammerton
de8526f918 Merge pull request #4958 from churrufli/master
Net Decks Archive Updates
2024-04-06 20:48:50 +01:00
Hans Mackowiak
171e9dfc83 update tishanas_tidebinder: ForgetOnMoved and ClearRemembered 2024-04-06 14:38:07 +02:00
Northmoc
bd7a489b49 OTJ: luxurious_locomotive + support (#4952) 2024-04-06 08:54:03 +00:00
Renato Filipe Vidal Santos
c729196170 OTJ: Spinewoods Paladin, Stagecoach Security, Steer Clear, Sterling Hound, Sterling Keykeeper, Stingerback Terror (#4964) 2024-04-06 08:55:53 +02:00
Simisays
d01cb9a325 OTJ 13 cards (#4948) 2024-04-05 19:11:44 +00:00
Simisays
c18d1ae855 8 more 2024-04-05 19:17:09 +02:00
Renato Filipe Vidal Santos
a9a3169cd4 OTJ: Omenport Vigilante, Slickshot Vault-Buster, Stoic Sphinx, Take for a Ride, Take the Fall, Throw from the Saddle (#4950) 2024-04-05 16:38:39 +00:00
loud1990
2614db0c7a Add Kraum, Violent Cacophony OTJ (#4959) 2024-04-05 16:25:32 +00:00
tool4ever
41d2c28891 Update some scripts (#4949)
* Simplify bad effects
2024-04-05 15:22:45 +02:00
Hans Mackowiak
a5e3b93ea3 Update stormclaw_rager.txt 2024-04-05 09:02:19 +02:00
Northmoc
80b3526ec1 YMKM: perforator_crocodile + support (#4889) 2024-04-05 08:12:53 +02:00
Churrufli
988e9f79eb Net Decks Archive Updates 2024-04-05 00:04:52 +02:00
Hans Mackowiak
0c53827c6d Update leering_onlooker.txt 2024-04-04 17:29:59 +02:00
Hans Mackowiak
7fceb76615 Update acolyte_of_aclazotz.txt 2024-04-04 17:29:27 +02:00
Paul Hammerton
10a2f8b3f1 Merge pull request #4953 from paulsnoops/edition_updates
Edition updates: BIG, OTJ, OTP, PW24, SPG
2024-04-04 10:02:30 +01:00
Paul Hammerton
fe6551e0f3 Edition updates: BIG, OTJ, OTP, PW24, SPG 2024-04-04 09:58:03 +01:00
Northmoc
1898f22edd tweak for Ward keyword display (#4912) 2024-04-04 08:40:43 +03:00
Simisays
759ff52ccf YMKM 10 cards (#4861)
* update

* update

* update

* Update woodland_investigation.txt

* update

* Cleanup

* Update mapping_the_maze.txt
2024-04-03 19:38:11 +03:00
Michael Lo
d154655cea Add a card from MH3 (#4944) 2024-04-03 07:59:40 +02:00
Renato Filipe Vidal Santos
952aa104ca OTJ: Thunder Salvo, Trick Shot, Vault Plunderer 2024-04-03 07:59:25 +02:00
GitHub Actions
cf0a72cbc6 [maven-release-plugin] prepare for next development iteration 2024-04-02 20:58:59 -04:00
GitHub Actions
a1fc524a98 [maven-release-plugin] prepare release forge-1.6.61 2024-04-02 20:58:59 -04:00
Northmoc
342843f07b YMKM: tajic_legions_valor + support (#4898) 2024-04-02 22:07:43 +00:00
Simisays
db43f74104 OTJ 13 cards (#4936) 2024-04-02 22:07:13 +00:00
Paul Hammerton
ca73962db3 Merge pull request #4941 from paulsnoops/edition_updates
Edition updates: OTJ, OTP
2024-04-02 12:06:34 +01:00
Paul Hammerton
c767bb5900 Edition updates: OTJ, OTP 2024-04-02 12:01:59 +01:00
tool4ever
a9be4c5c75 Refactor Magnigoth Treefolk (#4940) 2024-04-02 10:27:31 +02:00
junytang
2f708ad030 Update Simplified Chinese cards translation based on Scryfall data (#4676) 2024-04-02 08:23:49 +03:00
Renato Filipe Vidal Santos
8bfc0bebf5 OTJ: Tomb Trawler, Trash the Town, Treasure Dredger (#4935)
* Add files via upload

* Update trash_the_town.txt
2024-04-02 08:16:57 +03:00
Renato Filipe Vidal Santos
84adf8ffb9 OTJ: The Key to the Vault, This Town Ain't Big Enough, Thunder Lasso (#4939)
* Add files via upload

* Update ao_the_dawn_sky.txt

* Update keldon_flamesage.txt
2024-04-02 08:16:44 +03:00
tool4ever
6808c08d83 Fix DefinedLandwalk (#4937)
Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.59>
2024-04-02 08:16:25 +03:00
tool4ever
45cb50a639 Update evidence_examiner.txt 2024-04-01 17:43:02 +00:00
Renato Filipe Vidal Santos
8af0abea10 OTJ: Tumbleweed Rising, Unfortunate Accident, Vengeful Townsfolk (#4934) 2024-04-01 10:50:11 +00:00
Renato Filipe Vidal Santos
b6693b5450 BIG: Oltec Matterweaver, Vaultborn Tyrant (#4932) 2024-04-01 10:50:00 +00:00
Renato Filipe Vidal Santos
f45588a4fb OTJ: Claim Jumper, Dance of the Tumbleweeds, Demonic Ruckus, Roxanne (#4931) 2024-04-01 07:27:32 +00:00
Simisays
29b4084637 OTJ 16 cards (#4925) 2024-04-01 07:27:21 +00:00
Simisays
53dcc99cde Create junk_jet.txt (#4933) 2024-04-01 07:27:10 +00:00
tool4ever
68bd6ca432 Support "As Long As" duration (#4930) 2024-04-01 07:24:45 +00:00
tool4ever
247ec8c79b Fix Boneyard Scourge triggering from itself dying (#4924) 2024-03-31 10:36:46 +00:00
Paul Hammerton
7254b267f6 Merge pull request #4929 from paulsnoops/edition_updates
Edition updates: OTJ, SCH, SPG
2024-03-31 10:33:46 +01:00
Paul Hammerton
bab5853cce Edition updates: OTJ, SCH, SPG 2024-03-31 10:30:51 +01:00
Paul Hammerton
91e22b18cd Merge pull request #4906 from dracontes/otj-reloaded-10
OTJ: Annie Flash, Kellan, Gisa
2024-03-31 10:23:35 +01:00
Paul Hammerton
4dfc6defba Merge pull request #4927 from dracontes/otj-reloaded-14
OTJ: Another Round, Archmage's Newt, Betrayal at the Vault
2024-03-31 10:21:50 +01:00
Paul Hammerton
1479af1a6f Merge pull request #4928 from dracontes/otj-reloaded-15
OTJ: Visage Bandit, Voracious Varmint, Wrangler of the Damned
2024-03-31 10:21:38 +01:00
Renato Filipe Vidal Santos
ea983c74bd Update wrangler_of_the_damned.txt 2024-03-30 22:30:16 +00:00
Renato Filipe Vidal Santos
623513c431 Update archmages_newt.txt 2024-03-30 22:28:00 +00:00
tool4ever
fab71f026d Merge branch 'master' into otj-reloaded-10 2024-03-30 23:08:38 +01:00
tool4ever
fe98ebc318 Update kellan_the_kid.txt 2024-03-30 22:00:28 +00:00
Paul Hammerton
195fd02610 Merge pull request #4920 from Simisays/OJ3
OTJ 10 cards
2024-03-30 20:17:19 +00:00
Paul Hammerton
f16d170069 Merge pull request #4896 from Simisays/YMKM2
YMKM 6 cards
2024-03-30 20:17:05 +00:00
Renato Filipe Vidal Santos
9c0da822c2 Update wrangler_of_the_damned.txt 2024-03-30 20:15:33 +00:00
Renato Filipe Vidal Santos
3f711e21ea Update visage_bandit.txt 2024-03-30 20:14:34 +00:00
Renato Filipe Vidal Santos
e142aaa9fd Add files via upload 2024-03-30 20:10:23 +00:00
Renato Filipe Vidal Santos
937bf9f8ba Update archmages_newt.txt 2024-03-30 18:10:51 +00:00
Renato Filipe Vidal Santos
ec12f155cb Add files via upload 2024-03-30 18:05:03 +00:00
Paul Hammerton
893221f5df Merge pull request #4926 from paulsnoops/edition_updates
Edition updates: BIG, OTC, OTJ, OTP, SLD, SPG
2024-03-30 17:51:02 +00:00
Paul Hammerton
8051b22825 Edition updates: BIG, OTC, OTJ, OTP, SLD, SPG 2024-03-30 17:37:06 +00:00
Renato Filipe Vidal Santos
b3f2cd6157 Update kellan_the_kid.txt 2024-03-30 16:40:59 +00:00
tool4ever
6bef51f60d TargetsForEachPlayer restriction (#4914)
* Targets for each player don't fizzle if only one card changes controller
2024-03-30 15:52:11 +00:00
Simisays
1b31a5a37b Update arid_archway.txt 2024-03-30 16:40:11 +01:00
Simisays
5698c771e5 Update binding_negotiation.txt 2024-03-30 12:24:42 +01:00
Northmoc
6afdf206c9 OTJ: TriggerBecomesPlotted (and other Plot related stuff) (#4923)
* OTJ: TriggerBecomesPlotted

* fixes, "it becomes plotted," and cards

* remove facedown

* doc_aurlock_grizzled_genius + support
2024-03-30 08:07:25 +03:00
tool4ever
a001a22c97 Update snarlfang_vermin.txt 2024-03-29 23:06:56 +00:00
Simisays
f5cac9992e Update snarlfang_vermin.txt 2024-03-29 23:56:54 +01:00
Simisays
8c64a44337 Update baron_bertram_graywater.txt 2024-03-29 23:03:04 +01:00
Simisays
fa06c0df99 Update snarlfang_vermin.txt 2024-03-29 19:53:26 +01:00
Simisays
74f12360bc Update snarlfang_vermin.txt 2024-03-29 19:48:52 +01:00
Simisays
59b46a224e Update beastbond_outcaster.txt 2024-03-29 19:37:47 +01:00
Simisays
b9bdeaa61e 3 more + cleanup 2024-03-29 19:30:41 +01:00
tool4ever
b66f6e176c Fix MoJhoSto NPE (#4922) 2024-03-29 11:17:13 +00:00
tool4ever
e332369eba Fix scripts (#4921)
* Remove dead params

* Fix scripts

---------

Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.59>
2024-03-29 06:55:00 +03:00
Northmoc
99e305e612 OTC face cards (#4919) 2024-03-29 06:52:15 +03:00
Simisays
e0ca0645c3 Update snarlfang_vermin.txt 2024-03-28 22:25:20 +01:00
Simisays
27cbb1e18a cleanup 2024-03-28 22:07:38 +01:00
Simisays
70c5a0f616 update 2024-03-28 22:02:55 +01:00
Simisays
3e7966b465 update 2024-03-28 21:59:53 +01:00
Renato Filipe Vidal Santos
db027fdda1 OTJ: Geralf, Unscrupulous Contractor, Vadmir (#4918)
* Add files via upload

* Update vadmir_new_blood.txt
2024-03-28 14:28:15 -04:00
Northmoc
c601758615 YMKM: lurking_spinecrawler (#4890) 2024-03-28 18:26:11 +00:00
Northmoc
8319f9b2c4 OTJ: "committed a crime this turn" support (#4917) 2024-03-28 17:49:03 +00:00
Renato Filipe Vidal Santos
82e9d56ec7 OTJ: Ertha Jo, Marchesa, Vial Smasher (#4916)
* Add files via upload

* Update ertha_jo_frontier_mentor.txt

* Update ertha_jo_frontier_mentor.txt
2024-03-28 10:00:55 -04:00
Renato Filipe Vidal Santos
961bd49566 OTJ: Rakdos, Satoru, Vraska (#4913)
* Add files via upload

* Update vraska_the_silencer.txt

* Update rakdos_the_muscle.txt

* Update vraska_the_silencer.txt

* Update vraska_the_silencer.txt

* Update rakdos_the_muscle.txt
2024-03-28 06:58:31 +03:00
Simisays
99f098147d OTJ 9 cards + 2 new tokens (#4915)
* update

* Update frontier_seeker.txt

* 4 more

* Update tinybones_joins_up.txt
2024-03-28 06:58:23 +03:00
Simisays
83bf174147 Update veko_deaths_doorkeeper.txt 2024-03-27 22:36:04 +01:00
Hans Mackowiak
ce62cbcb08 Landwalk static (#4907)
* Landwalk Static + Ignore
2024-03-27 22:15:44 +01:00
Fulgur14
cda35a572c Draft of PIP decks (#4899) 2024-03-27 16:31:03 +00:00
Northmoc
1172e6d3d6 PIP: C.A.M.P. + support 2024-03-27 12:24:10 -04:00
Renato Filipe Vidal Santos
4c4d0ea219 Update witch_king_sky_scourge.txt 2024-03-27 16:22:20 +00:00
Renato Filipe Vidal Santos
53136bf5bc Update wild_wasteland.txt 2024-03-27 16:21:04 +00:00
Renato Filipe Vidal Santos
0946e07468 Update sword_of_forge_and_frontier.txt 2024-03-27 16:19:24 +00:00
Renato Filipe Vidal Santos
9343de2350 Update a-ardent_dustspeaker.txt 2024-03-27 16:17:44 +00:00
Renato Filipe Vidal Santos
fb4c713efd Update rob_the_archives.txt 2024-03-27 16:16:21 +00:00
Renato Filipe Vidal Santos
7309d1f644 Update quintorius_kand.txt 2024-03-27 16:14:29 +00:00
Renato Filipe Vidal Santos
82e4854e8a Update ardent_dustspeaker.txt 2024-03-27 16:10:39 +00:00
Renato Filipe Vidal Santos
62021fd8d2 Update annie_flash_the_veteran.txt 2024-03-27 16:08:39 +00:00
Renato Filipe Vidal Santos
17845bd975 Update kellan_the_kid.txt 2024-03-27 15:53:30 +00:00
Northmoc
806a654ee4 PIP: vault_21_house_gambit (#4909) 2024-03-27 15:48:04 +00:00
Renato Filipe Vidal Santos
cd182ccd4c Update gisa_the_hellraiser.txt 2024-03-27 15:40:25 +00:00
Renato Filipe Vidal Santos
47ec9b21a5 Update ovika_enigma_goliath.txt 2024-03-27 15:39:55 +00:00
Renato Filipe Vidal Santos
93544ee91b Update annie_flash_the_veteran.txt 2024-03-27 15:37:39 +00:00
Hans Mackowiak
ca362664b7 MagicStack: fix fizzle removing too much Targets (#4873)
* MagicStack: fix fizzle removing too much Targets

* Fix Dead Ringers

* Clean up useless check
2024-03-27 15:03:11 +00:00
Northmoc
fb6e944b45 YMKM: roalesk_prime_specimen + support (#4903)
* roalesk_prime_specimen + support

* allow added abilities to show on face-down cards
2024-03-27 14:57:42 +00:00
Northmoc
38c5fee296 PIP: aradesh_the_founder + support (#4904) 2024-03-27 14:37:00 +00:00
Simisays
e1b3baba70 OTJ Remaining 8 deserts + 2 more (#4905) 2024-03-27 07:26:16 +01:00
Renato Filipe Vidal Santos
af916ff58e Update kellan_the_kid.txt 2024-03-27 02:28:32 +00:00
Renato Filipe Vidal Santos
e4fa6bbd43 Update kellan_the_kid.txt 2024-03-27 02:21:00 +00:00
Renato Filipe Vidal Santos
05e4cce30f Update kellan_the_kid.txt 2024-03-27 02:08:42 +00:00
Renato Filipe Vidal Santos
64f78f316d Update kellan_the_kid.txt 2024-03-26 21:59:50 +00:00
Renato Filipe Vidal Santos
93533dda58 Update Outlaws of Thunder Junction.txt 2024-03-26 20:58:22 +00:00
Renato Filipe Vidal Santos
2021f26a20 Add files via upload 2024-03-26 20:10:03 +00:00
Renato Filipe Vidal Santos
8e28699f5e Add files via upload 2024-03-26 20:09:22 +00:00
Simisays
e0d2b34768 further cleanup 2024-03-26 20:54:59 +01:00
Simisays
fd1da36b6b cleanup 2024-03-26 20:49:15 +01:00
Northmoc
555fe32ad9 YMKM: ominous_lockbox + support (#4891) 2024-03-26 18:52:28 +01:00
Agetian
a273ead6cb Add Modern LDA deck info (MKM), genetic AI decks (Standard and Modern up to MKM), MTGO Vintage Cube (February 2024) (#4892)
* - Add February 2024 genetic AI decks.

* - Add Modern LDA deck info (MKM).

* - Add MTGO Vintage Cube (February 2024).
2024-03-26 20:28:00 +03:00
Renato Filipe Vidal Santos
d0d3686f82 ACR: Cleopatra, Ezio (Blade), Eivor (#4901) 2024-03-26 17:30:09 +01:00
Renato Filipe Vidal Santos
1149d7b486 OTJ: Insatiable Avarice, Vraska Joins Up (#4902)
* Add files via upload

* Update Outlaws of Thunder Junction.txt
2024-03-26 10:59:41 -04:00
Northmoc
ae816c36b4 YMKM: 2 cards that don't need engine support! (#4895) 2024-03-26 09:54:06 +01:00
tool4ever
263f12a1ec Update trial_of_a_time_lord.txt 2024-03-26 08:19:20 +01:00
Renato Filipe Vidal Santos
de6cde6538 OTJ: Duelist of the Mind, Hell to Pay 2024-03-25 22:03:42 +00:00
Simisays
2b862ed4cf update 2024-03-25 21:33:29 +01:00
Renato Filipe Vidal Santos
4d2fb84404 OTJ: Ghired, Selvala, Sterling Supplier (#4894) 2024-03-25 19:34:58 +00:00
Northmoc
23e45f5164 YMKM: rampaging_ursaguana + support (#4893) 2024-03-25 22:10:22 +03:00
Agetian
a784d9548d Add an option to auto-generate LDA decks for the AI in Adventure mode (#4859)
* - Add Standard archetype LDA deck generation info for the latest sets (by kevlanhota)

* - Add an option to auto-generate LDA decks for the AI in Adventure mode (as opposed to choosing from a curated pool)

* - Use the existing getModern method.
- Add getLegacy method similar to the other formats + use it in the LDA generation code.
- Unify formatting for getXXX in GameFormat.

* - A better name for the feature (since it doesn't use the actual genetic AI algorithm)
2024-03-25 19:29:43 +03:00
Renato Filipe Vidal Santos
54d9e55a74 OTJ: At Knifepoint, Intrepid Stablemaster, Magebane Lizard, Marauding Sphinx, Ornery Tumblewagg (#4886)
* Add files via upload

* Update at_knifepoint.txt

* Update wanted_griffin.txt
2024-03-25 11:31:15 -04:00
tool4ever
cfd96d6b52 The Celestial Toymaker and support (#4877)
* The Celestial Toymaker and support

* Fix split cards for Raul
2024-03-25 14:07:27 +01:00
Northmoc
6efb609761 YMKM: case_of_the_market_melee + support (#4879) 2024-03-25 14:07:00 +01:00
tool4ever
68f85bd3dd Fix Rose, Cutthroat Raider (#4888)
Closes #4887
2024-03-25 14:01:13 +01:00
Chris H
7c616c536d Add Expert-Level Safe (#4856) 2024-03-25 07:50:37 +01:00
Renato Filipe Vidal Santos
c7f69aea83 Add files via upload (#4885) 2024-03-25 05:54:34 +03:00
Renato Filipe Vidal Santos
05dc745a1e OTJ: Bristlepack Sentry, Lavaspur Boots, Malcolm, the Eyes (#4884) 2024-03-24 17:42:48 +00:00
Hans Mackowiak
506821c14c Keyword: Plot (#4809)
* Keyword: Plot first draft

* Pass LKI check

---------

Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.59>
2024-03-24 18:20:12 +03:00
Fulgur14
a7bb454a10 Added Deadly Disguise (MKC), changed name of Incubator token. (#4882)
* Add files via upload

* Add files via upload

* Update incubator_c_0_0_a_phyrexian.txt

Was lacking "Token" in the name.

* Corrected typo in raven_of_fell_omens.txt

* Update raven_of_fell_omens.txt
2024-03-24 18:19:39 +03:00
tool4ever
69cda588eb Update hancock_ghoulish_mayor.txt 2024-03-24 15:04:43 +00:00
Renato Filipe Vidal Santos
d43d99f3bc Add files via upload (#4883) 2024-03-24 16:52:37 +03:00
Hans Mackowiak
3479a782ff ~ update incubator token 2024-03-24 13:38:55 +01:00
Hans Mackowiak
401da1196c ~ fix raven of fell omens 2024-03-24 13:37:37 +01:00
Hans Mackowiak
46e3f5f357 Update raven_of_fell_omens.txt 2024-03-24 11:50:53 +01:00
Renato Filipe Vidal Santos
cb07056da2 OTJ: Rodeo Pyromancers, Rooftop Assassin, Wanted Griffin (#4881)
* Add files via upload

* Add files via upload
2024-03-24 12:25:14 +03:00
Northmoc
72580781af MKC: Boltbender + support (#4850)
* MKC: Boltbender + support

* v2
2024-03-24 06:58:42 +03:00
Renato Filipe Vidal Santos
de69086d10 BIG: Sword of Wealth and Power & Nexus of Becoming (#4876)
* Add files via upload

* Add files via upload

* Update sword_of_wealth_and_power.txt

* Update sword_of_wealth_and_power.txt
2024-03-24 06:58:21 +03:00
Northmoc
132341d91e YMKM: juggle_the_performance + support (#4880) 2024-03-24 06:58:14 +03:00
Renato Filipe Vidal Santos
db2b8b5a13 OTJ: Conduit Pylons, Creosote Heath, Festering Gulch 2024-03-23 20:16:51 +00:00
tool4ever
f07c294d76 Update relive_the_past.txt 2024-03-23 19:35:17 +00:00
tool4ever
5e2a69f2cb Refactor scripts! (#4874) 2024-03-23 16:48:44 +00:00
Fulgur14
9928e0d876 Add files via upload (#4875) 2024-03-23 19:45:29 +03:00
Hans Mackowiak
ec87534998 OTJ: Commit Crime (#4870)
* OTJ: Commit Crime

* Update raven_of_fell_omens.txt

---------

Co-authored-by: tool4ever <therealtoolkit@hotmail.com>
2024-03-23 19:45:13 +03:00
Renato Filipe Vidal Santos
3a2f5dd4b8 CLU: Memory Vampire & Ordruun Mentor (#4872)
* Add files via upload

* Add files via upload

* Update ordruun_mentor.txt
2024-03-23 19:44:57 +03:00
Northmoc
6e7602f721 YMKM: izzet_polarizer + support (#4864) 2024-03-23 16:07:08 +00:00
Northmoc
0864ae272c MKC: feather_radiant_arbiter + support (#4862) 2024-03-23 14:00:44 +00:00
tool4ever
7977933261 Suppressor Skyguard and support (#4871) 2024-03-23 13:59:50 +00:00
Renato Filipe Vidal Santos
73dddd6e1d PIP: Mysterious Stranger (#4866) 2024-03-23 13:46:04 +00:00
Northmoc
fcc199fdb4 YMKM: sleuth_instructor + support (#4863) 2024-03-23 13:45:46 +00:00
tool4ever
0400dc14ab Fix NPE (#4869) 2024-03-23 09:19:43 +00:00
Simisays
1de77da079 CLUE 3 cards (#4854) 2024-03-23 08:42:15 +00:00
Northmoc
34f2fa846d MKC: prisoners_dilemma + support (#4860) 2024-03-23 08:42:04 +00:00
Chris H
6757ffdc56 Update case_of_the_locked_hothouse.txt (#4832) 2024-03-23 08:36:17 +00:00
tool4ever
b01bcd0045 AbilityUtils LKI support (#4851)
Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.59>
2024-03-22 17:30:13 +03:00
Fulgur14
a5666ffc18 Added Revenant Recon (MKC) (#4858)
* Add files via upload

* Add files via upload

* Add files via upload
2024-03-22 17:30:05 +03:00
Renato Filipe Vidal Santos
24a328fc4f PIP:The Prydwen & The Nipton Lottery (#4852) 2024-03-22 09:13:40 +01:00
Agetian
79c1c52875 - Add Standard archetype LDA deck generation info for the latest sets (by kevlanhota) (#4857) 2024-03-22 08:11:21 +03:00
Fulgur14
7ff5a929fd Added the Mutant Menace (PIP) deck (#4847)
* Add files via upload

* Add files via upload
2024-03-22 06:45:33 +03:00
Northmoc
4976da4c20 MKC: 2 "easy" cards (#4848)
* 2 cards

* ai

* Update otherworldly_escort.txt

---------

Co-authored-by: tool4ever <therealtoolkit@hotmail.com>
2024-03-22 06:45:19 +03:00
Simisays
b28acfe2b6 PIP Jason Bright, Glowing Prophet and support (#4853)
* update

* Update jason_bright_glowing_prophet.txt
2024-03-22 06:45:07 +03:00
tool4ever
d2e780b75c Fix Turf War targeting freeze with enough lands but only same controller (#4855)
Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.59>
2024-03-22 06:44:46 +03:00
Northmoc
c4996955c7 MKC: mob_verdict + support (#4836) 2024-03-21 13:02:05 +01:00
Simisays
407db2ef68 PIP 5 vault cards + 4 more (#4829) 2024-03-21 09:27:32 +01:00
Hans Mackowiak
abfb74eee3 Card: differ between Game and Layer Timestamp (#4840)
* Card: differ between Game and Layer Timestamp

---------

Co-authored-by: tool4ever <therealtoolkit@hotmail.com>
Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.59>
2024-03-21 09:19:21 +01:00
Suthro
f3949180e2 MKC: Duskana, the Rage Mother + 6 cards (#4708) 2024-03-21 08:34:17 +01:00
tool4ever
7f7bc711f3 Fix Pure Intentions (#4845)
* Fix Pure Intentions

* Remove obsolete stuff

---------

Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.59>
2024-03-20 19:46:14 +03:00
Northmoc
93a52a4263 fix 4812 (#4835)
* fix 4812

* remove check
2024-03-20 06:21:58 +03:00
Simisays
b616bec93c Adventure minor patches (#4839)
* adventure updates

* Update barbariancamp_goblin_3.tmx

* remove invisible gold

* Update barbariancamp_goblin_3.tmx
2024-03-20 06:01:46 +03:00
tool4ever
5415c6190d Script fixes (#4838) 2024-03-19 21:18:16 +00:00
tool4ever
3676614d1c ReplaceDiscard doesn't exist (#4833)
* ReplaceDiscard doesn't exist
2024-03-19 18:13:33 +00:00
Hans Mackowiak
34789c57fe CardType: add isOutlaw (#4827) 2024-03-19 06:14:16 +03:00
Renato Filipe Vidal Santos
3b067c2865 PIP: Three Dog, Veronica, Vexing Radgull (#4831) 2024-03-18 17:57:20 +00:00
Simisays
ba21869e43 PIP 14 cards (#4824) 2024-03-18 08:17:48 +01:00
tool4ever
40f281bcf5 Support for Vault 11: Voter's Dilemma (#4828)
* Fix Triassic Egg

* Support for Vault 11: Voter's Dilemma

* Fix Summoning Trap

* Support Vault nicknames

* Fix NPE
2024-03-18 08:17:32 +01:00
Hans Mackowiak
9b58a3cfac Keyword: Saddle (#4807)
* Keyword: Saddle

* AlterAttribute Logic for Suspected and Saddled
2024-03-17 08:56:16 +00:00
beemaisonp
4351eff67e Update Urza, Academy Headmaster target selection (#4825)
Updates Urza, Academy Headmaster specific targeting code to use targetRestrictions var from the sub abilities (where the targeting restrictions are actually specified) instead of the top level SpellAbility where targetRestrictions = null.
2024-03-16 16:51:35 +03:00
Chris H
c5192b3be2 Update magosi_the_waterveil.txt (#4823) 2024-03-15 16:36:29 +01:00
tool4ever
f372ef87fe Improve simultaneous handling with ChangeZoneAll (#4820)
Co-authored-by: TRT <>
2024-03-15 11:31:04 +03:00
Hans Mackowiak
7e37d086c6 Merge pull request #4822 from Agetian/master
Fix Agitator Ant crashing the game
2024-03-15 06:42:36 +01:00
Agetian
fb4a341ecd - Fix Agitator Ant crashing. 2024-03-15 08:30:15 +03:00
tool4ever
4c03a36617 Update yorvo_lord_of_garenbrig.txt 2024-03-14 21:31:48 +00:00
Agetian
8c1bafea87 - Added MKM alt wincon achievement by Marek14. (#4821)
- Added puzzle PS_MKM3.
2024-03-14 17:28:08 +03:00
tool4ever
82d17436ab Fix Captain's Hook Unattach triggering and sacrificing even if it gets destroyed before Equip ability resolves (#4818)
* Fix equipping even when destroyed

* Fix not losing life from Yurlok via Power Sink
2024-03-14 09:58:22 +01:00
Hans Mackowiak
25a620c6cd Keyword: Spree (#4815)
* Keyword: Spree

---------

Co-authored-by: tool4EvEr <tool4EvEr@192.168.0.59>
2024-03-13 09:39:14 +01:00
Chris H
9c2986e3c4 Add Luck Bobblehead (#4816) 2024-03-13 06:43:00 +01:00
tool4ever
99040ad496 Tinybones, the Pickpocket and support (#4806)
* Tinybones, the Pickpocket and support

* Remove duplicated text
2024-03-13 06:42:24 +01:00
Chris H
f57eb7a3dc Setup a test bed for the future 2024-03-12 11:41:28 -04:00
Chris H
8fa4baaa88 Move copy functions to new service 2024-03-12 11:41:28 -04:00
Paul Hammerton
959aa74f02 Merge pull request #4814 from paulsnoops/bar_march_11
Banned and Restricted Announcement for March 11, 2024
2024-03-11 17:54:30 +00:00
Paul Hammerton
3ca1c64823 Banned and Restricted Announcement for March 11, 2024 2024-03-11 17:45:25 +00:00
Chris H
21be2c4bb3 Disable opengl acceleration 2024-03-10 21:41:09 -04:00
Simisays
e8da91fcb6 PIP 10 cards (#4798) 2024-03-10 16:11:34 +00:00
Simisays
9d3c20094e PIP 8 cards (#4795) 2024-03-10 14:21:12 +00:00
Hans Mackowiak
024b958539 RadiationRework: use Trigger for InternalRadiation (#4799)
* RadiationRework: use Trigger for InternalRadiation

* InternalRadiationEffect: use GameAction::mill

* Radiation: use Num Param instead of Add/Remove like Poison

* Update bloatfly_swarm.txt

* Player: fix removeRadiationEffect on setCounter

---------

Co-authored-by: tool4ever <therealtoolkit@hotmail.com>
2024-03-10 17:18:40 +03:00
Paul Hammerton
29d31071b7 Fix MKM draft rank (#4797) 2024-03-10 07:58:31 +00:00
tool4ever
dc5f139a52 New mill triggers (#4801) 2024-03-10 07:57:07 +00:00
tool4ever
6b54962078 Update cataclysmic_gearhulk.txt 2024-03-08 21:07:33 +00:00
tool4ever
aebec196ef Update escaped_shapeshifter.txt 2024-03-08 11:39:59 +01:00
tool4ever
5e72b8dd1c Update gruff_triplets.txt 2024-03-08 11:26:48 +01:00
Paul Hammerton
182ea20bc5 Merge pull request #4796 from paulsnoops/edition_updates
Edition updates: OLGC, OVNT, PEWK, PMEI
2024-03-08 10:15:12 +00:00
Paul Hammerton
9752a5e455 file_name 2024-03-08 10:10:36 +00:00
Paul Hammerton
30b9b7f81a fix_name 2024-03-08 10:09:32 +00:00
Paul Hammerton
8359fa3df8 Edition updates: OLGC, OVNT, PEWK, PMEI 2024-03-08 10:08:04 +00:00
F4llen
8034bfe6c3 Update to Quest opponent icons list, quests and info (#4740)
* Update Opponent quest icons
2024-03-07 13:22:56 -05:00
Simisays
e1e59a6251 PIP 5 cards (#4788)
* Support Nightkin Ambusher
2024-03-07 09:07:27 +00:00
tool4ever
bd442ccc0c Update and rename butch_deLoria_tunnel_snake.txt to butch_deloria_tunnel_snake.txt 2024-03-07 07:21:04 +01:00
Renato Filipe Vidal Santos
5abb5e6fbf PIP: Well Rested & Wasteland Raider (#4792) 2024-03-06 14:45:03 +01:00
Northmoc
8c7283d02c WHO: caught_in_a_parallel_universe.txt + support (#4093)
* WHO: caught_in_a_parallel_universe.txt + support

* coward_killer.txt tidy

* human_time_lord_meta_crisis + support

* more tweaks for grenzos_rebuttal and similar
2024-03-06 08:02:22 +01:00
tool4ever
3b90a746d3 Update osgood_operation_double.txt 2024-03-06 07:31:07 +01:00
GitHub Actions
aa4eba0c33 [maven-release-plugin] prepare for next development iteration 2024-03-05 14:02:09 -05:00
GitHub Actions
0db8025766 [maven-release-plugin] prepare release forge-1.6.60 2024-03-05 14:02:09 -05:00
26152 changed files with 489060 additions and 281422 deletions

View File

@@ -4,6 +4,7 @@ about: Create a report to help us improve
title: ''
labels: ''
assignees: ''
type: 'Bug'
---
@@ -31,7 +32,6 @@ If applicable, add screenshots to help explain your problem.
**Smartphone (please complete the following information):**
- Device: [e.g. iPhone6]
- OS: [e.g. iOS8.1]
- Browser [e.g. stock browser, safari]
- Version [e.g. 22]
**Additional context**

View File

@@ -4,6 +4,7 @@ about: Suggest an idea for this project
title: ''
labels: ''
assignees: ''
type: 'Feature'
---

View File

@@ -2,10 +2,21 @@ name: Publish Desktop Forge
on:
workflow_dispatch:
inputs:
debug_enabled:
type: boolean
description: 'Run the build with tmate debugging enabled (https://github.com/marketplace/actions/debugging-with-tmate)'
required: false
default: false
release_android:
type: boolean
description: 'Also try to release android build'
required: false
default: false
jobs:
build:
if: github.repository_owner == 'Card-Forge'
runs-on: ubuntu-latest
permissions:
contents: write
@@ -14,10 +25,10 @@ jobs:
steps:
- uses: actions/checkout@v3
- name: Set up JDK 11
- name: Set up JDK 17
uses: actions/setup-java@v3
with:
java-version: '11'
java-version: '17'
distribution: 'temurin'
cache: 'maven'
server-id: cardforge-repo
@@ -32,10 +43,134 @@ jobs:
run: |
git config user.email "actions@github.com"
git config user.name "GitHub Actions"
- name: Build/Install/Publish to GitHub Packages Apache Maven
- name: Install old maven (3.8.1)
run: |
curl -o apache-maven-3.8.1-bin.tar.gz https://archive.apache.org/dist/maven/maven-3/3.8.1/binaries/apache-maven-3.8.1-bin.tar.gz
tar xf apache-maven-3.8.1-bin.tar.gz
export PATH=$PWD/apache-maven-3.8.1/bin:$PATH
export MAVEN_HOME=$PWD/apache-maven-3.8.1
mvn --version
- name: Setup tmate session
uses: mxschmitt/action-tmate@v3
if: ${{ github.event_name == 'workflow_dispatch' && inputs.debug_enabled }}
- name: Setup android requirements
if: ${{ github.event_name == 'workflow_dispatch' && inputs.release_android }}
run: |
JAVA_HOME=${JAVA_HOME_17_X64} ${ANDROID_SDK_ROOT}/cmdline-tools/latest/bin/sdkmanager --sdk_root=$ANDROID_SDK_ROOT --install "build-tools;35.0.0" "platform-tools" "platforms;android-35"
cd forge-gui-android
echo "${{ secrets.FORGE_KEYSTORE }}" > forge.keystore.asc
gpg -d --passphrase "${{ secrets.FORGE_KEYSTORE_PASSPHRASE }}" --batch forge.keystore.asc > forge.keystore
cd -
mkdir -p ~/.m2/repository/com/simpligility/maven/plugins/android-maven-plugin/4.6.2
cd ~/.m2/repository/com/simpligility/maven/plugins/android-maven-plugin/4.6.2
curl -L -o android-maven-plugin-4.6.2.jar https://github.com/Card-Forge/android-maven-plugin/releases/download/4.6.2/android-maven-plugin-4.6.2.jar
curl -L -o android-maven-plugin-4.6.2.pom https://github.com/Card-Forge/android-maven-plugin/releases/download/4.6.2/android-maven-plugin-4.6.2.pom
cd -
mvn install -Dmaven.test.skip=true
mvn dependency:tree
- name: Build/Install/Publish Desktop to GitHub Packages Apache Maven
if: ${{ github.event_name == 'workflow_dispatch' && !inputs.release_android }}
run: |
export DISPLAY=":1"
Xvfb :1 -screen 0 800x600x8 &
mvn -U -B clean -P windows-linux install release:clean release:prepare release:perform -T 1C -Dcardforge-repo.username=${{ secrets.FTP_USERNAME }} -Dcardforge-repo.password=${{ secrets.FTP_PASSWORD }}
export _JAVA_OPTIONS="-Xmx2g"
d=$(date +%m.%d)
# build only desktop and only try to move desktop files
mvn -U -B clean -P windows-linux install -DskipTests -Dskip.flatten=true -e -T 1C release:clean release:prepare release:perform
mkdir izpack
# move bz2 and jar from work dir to izpack dir
mv /home/runner/work/forge/forge/forge-installer/*/*.{bz2,jar} izpack/
# move desktop build.txt and version.txt to izpack
mv /home/runner/work/forge/forge/forge-gui-desktop/target/classes/*.txt izpack/
cd izpack
ls
echo "GIT_TAG=`echo $(git describe --tags --abbrev=0)`" >> $GITHUB_ENV
env:
GITHUB_TOKEN: ${{ github.token }}
- name: Build/Install/Publish Desktop+Android to GitHub Packages Apache Maven
if: ${{ github.event_name == 'workflow_dispatch' && inputs.release_android }}
run: |
export DISPLAY=":1"
Xvfb :1 -screen 0 800x600x8 &
export _JAVA_OPTIONS="-Xmx2g"
d=$(date +%m.%d)
# build both desktop and android
mvn -U -B clean -P windows-linux,android-release-build install -e -Dcardforge-repo.username=${{ secrets.FTP_USERNAME }} -Dcardforge-repo.password=${{ secrets.FTP_PASSWORD }} -Dandroid.sdk.path=/usr/local/lib/android/sdk -Dandroid.buildToolsVersion=35.0.0
mkdir izpack
# move bz2 and jar from work dir to izpack dir
mv /home/runner/work/forge/forge/forge-installer/*/*.{bz2,jar} izpack/
# move desktop build.txt and version.txt to izpack
mv /home/runner/work/forge/forge/forge-gui-desktop/target/classes/*.txt izpack/
# move android apk and assets.zip
mv /home/runner/work/forge/forge/forge-gui-android/target/*-signed-aligned.apk izpack/
mv /home/runner/work/forge/forge/forge-gui-android/target/assets.zip izpack/
cd izpack
ls
echo "GIT_TAG=`echo $(git describe --tags --abbrev=0)`" >> $GITHUB_ENV
env:
GITHUB_TOKEN: ${{ github.token }}
- name: Upload snapshot to GitHub Prerelease
uses: ncipollo/release-action@v1
env:
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
name: Release ${{ env.GIT_TAG }}
tag: ${{ env.GIT_TAG }}
artifacts: izpack/*
allowUpdates: true
removeArtifacts: true
makeLatest: true
- name: 🔧 Install XML tools
run: |
sudo apt-get update
sudo apt-get install -y libxml2-utils
- name: 🔼 Bump versionCode in root POM
id: bump_version
run: |
cd /home/runner/work/forge/forge/
current_version=$(xmllint --xpath "//*[local-name()='versionCode']/text()" pom.xml)
echo "Current versionCode: $current_version"
IFS='.' read -r major minor patch <<< "${current_version}"
new_patch=$(printf "%02d" $((10#$patch + 1)))
new_version="${major}.${minor}.${new_patch}"
sed -i -E "s|<versionCode>.*</versionCode>|<versionCode>${new_version}</versionCode>|" pom.xml
echo "version_code=${new_version}" >> $GITHUB_OUTPUT
- name: ♻️ Restore {revision} in child POMs
run: |
find . -name pom.xml ! -path "./pom.xml" | while read -r pom; do
sed -i -E 's|<version>2\.0+\.[0-9]+(-SNAPSHOT)?</version>|<version>${revision}</version>|' "$pom"
done
- name: 💾 Commit restored {revision}
run: |
# Add only pom.xml files
find . -name pom.xml -exec git add {} \;
# Commit if there are changes
if git diff --cached --quiet; then
echo "No pom.xml changes to commit."
else
git commit -m "Restore POM files for preparation of next release" || echo "No changes to commit"
git push
fi
- name: Send failure notification to Discord
if: failure() # This step runs only if the job fails
run: |
curl -X POST -H "Content-Type: application/json" \
-d "{\"content\": \"🔴 Release Build Failed in branch: \`${{ github.ref_name }}\` by \`${{ github.actor }}\`.\nCheck logs: ${{ github.server_url }}/${{ github.repository }}/actions/runs/${{ github.run_id }}\"}" \
${{ secrets.DISCORD_AUTOMATION_WEBHOOK }}

View File

@@ -20,10 +20,10 @@ jobs:
steps:
- uses: actions/checkout@v3
- name: Set up JDK 8
- name: Set up JDK 17
uses: actions/setup-java@v3
with:
java-version: '8'
java-version: '17'
distribution: 'temurin'
cache: 'maven'
server-id: cardforge-repo
@@ -31,20 +31,20 @@ jobs:
server-password: ${{ secrets.FTP_PASSWORD }}
settings-path: ${{ github.workspace }} # location for the settings.xml file
- name: Install old maven (3.6.3)
- name: Install old maven (3.8.1)
run: |
curl -o apache-maven-3.6.3-bin.tar.gz https://archive.apache.org/dist/maven/maven-3/3.6.3/binaries/apache-maven-3.6.3-bin.tar.gz
tar xf apache-maven-3.6.3-bin.tar.gz
export PATH=$PWD/apache-maven-3.6.3/bin:$PATH
export MAVEN_HOME=$PWD/apache-maven-3.6.3
curl -o apache-maven-3.8.1-bin.tar.gz https://archive.apache.org/dist/maven/maven-3/3.8.1/binaries/apache-maven-3.8.1-bin.tar.gz
tar xf apache-maven-3.8.1-bin.tar.gz
export PATH=$PWD/apache-maven-3.8.1/bin:$PATH
export MAVEN_HOME=$PWD/apache-maven-3.8.1
mvn --version
- name: Install android SDK
uses: maxim-lobanov/setup-android-tools@v1
with:
packages: |
platforms;android-26
build-tools;30.0.3
platforms;android-35
build-tools;35.0.0
- name: Install virtual framebuffer (if not available) to allow running GUI on a headless server
run: |
@@ -71,11 +71,11 @@ jobs:
- name: Install Android maven plugin
run: |
mkdir -p ~/.m2/repository/com/simpligility/maven/plugins/android-maven-plugin/4.6.1
cd ~/.m2/repository/com/simpligility/maven/plugins/android-maven-plugin/4.6.1
curl -L -o android-maven-plugin-4.6.1.jar https://github.com/Card-Forge/android-maven-plugin/releases/download/4.6.1/android-maven-plugin-4.6.1.jar
curl -L -o android-maven-plugin-4.6.1.pom https://github.com/Card-Forge/android-maven-plugin/releases/download/4.6.1/android-maven-plugin-4.6.1.pom
#mvn install:install-file -Dfile=android-maven-plugin-4.6.1.jar -DgroupId=com.simpligility.maven.plugins -DartifactId=android-maven-plugin -Dversion=4.6.1 -Dpackaging=jar
mkdir -p ~/.m2/repository/com/simpligility/maven/plugins/android-maven-plugin/4.6.2
cd ~/.m2/repository/com/simpligility/maven/plugins/android-maven-plugin/4.6.2
curl -L -o android-maven-plugin-4.6.2.jar https://github.com/Card-Forge/android-maven-plugin/releases/download/4.6.2/android-maven-plugin-4.6.2.jar
curl -L -o android-maven-plugin-4.6.2.pom https://github.com/Card-Forge/android-maven-plugin/releases/download/4.6.2/android-maven-plugin-4.6.2.pom
#mvn install:install-file -Dfile=android-maven-plugin-4.6.2.jar -DgroupId=com.simpligility.maven.plugins -DartifactId=android-maven-plugin -Dversion=4.6.2 -Dpackaging=jar
cd -
mvn install -Dmaven.test.skip=true
mvn dependency:tree
@@ -83,7 +83,7 @@ jobs:
- name: Build/Install/Publish to GitHub Packages Apache Maven
run: |
export _JAVA_OPTIONS="-Xmx2g"
mvn -U -B -P android-release-build,android-release-sign,android-release-upload install -e -Dsign.keystore=forge.keystore -Dsign.alias=Forge -Dsign.storepass=${{ secrets.SIGN_STORE_PASS }} -Dsign.keypass=${{ secrets.SIGN_STORE_PASS }} -Dcardforge-repo.username=${{ secrets.FTP_USERNAME }} -Dcardforge-repo.password=${{ secrets.FTP_PASSWORD }} -Dandroid.sdk.path=/usr/local/lib/android/sdk -Dandroid.buildToolsVersion=30.0.3 -Dmaven.test.skip=true
mvn -U -B -P android-release-build,android-release-upload install -e -Dcardforge-repo.username=${{ secrets.FTP_USERNAME }} -Dcardforge-repo.password=${{ secrets.FTP_PASSWORD }} -Dandroid.sdk.path=/usr/local/lib/android/sdk -Dandroid.buildToolsVersion=35.0.0 -Dmaven.test.skip=true
env:
GITHUB_TOKEN: ${{ github.token }}

View File

@@ -0,0 +1,19 @@
name: Remove stale branches
on:
workflow_dispatch:
schedule:
- cron: "0 0 * * *" # Everday at midnight
jobs:
remove-stale-branches:
if: github.repository_owner == 'Card-Forge'
name: Remove Stale Branches
runs-on: ubuntu-latest
steps:
- uses: fpicalausa/remove-stale-branches@v2.1.0
with:
dry-run: false # Check out the console output before setting this to false
ignore-unknown-authors: true
ignore-branches-with-open-prs: true
default-recipient: tehdiplomat

View File

@@ -0,0 +1,132 @@
name: Create Snapshot Desktop and Android
on:
workflow_dispatch:
inputs:
debug_enabled:
type: boolean
description: 'Run the build with tmate debugging enabled (https://github.com/marketplace/actions/debugging-with-tmate)'
required: false
default: false
schedule:
# * is a special character in YAML so you have to quote this string
- cron: '00 18 * * *'
jobs:
build:
if: github.repository_owner == 'Card-Forge'
runs-on: ubuntu-latest
permissions:
contents: write
deployments: write
packages: write
steps:
- uses: actions/checkout@v3
- name: Set up JDK 17
uses: actions/setup-java@v3
with:
java-version: '17'
distribution: 'temurin'
cache: 'maven'
server-id: cardforge-repo
server-username: ${{ secrets.FTP_USERNAME }}
server-password: ${{ secrets.FTP_PASSWORD }}
settings-path: ${{ github.workspace }} # location for the settings.xml file
- name: Install virtual framebuffer (if not available) to allow running GUI on a headless server
run: command -v Xvfb >/dev/null 2>&1 || { sudo apt update && sudo apt install -y xvfb; }
- name: Configure Git User
run: |
git config user.email "actions@github.com"
git config user.name "GitHub Actions"
- name: Install old maven (3.8.1)
run: |
curl -o apache-maven-3.8.1-bin.tar.gz https://archive.apache.org/dist/maven/maven-3/3.8.1/binaries/apache-maven-3.8.1-bin.tar.gz
tar xf apache-maven-3.8.1-bin.tar.gz
export PATH=$PWD/apache-maven-3.8.1/bin:$PATH
export MAVEN_HOME=$PWD/apache-maven-3.8.1
mvn --version
- name: Set Up Android tools
run: |
JAVA_HOME=${JAVA_HOME_17_X64} ${ANDROID_SDK_ROOT}/cmdline-tools/latest/bin/sdkmanager --sdk_root=$ANDROID_SDK_ROOT --install "build-tools;35.0.0" "platform-tools" "platforms;android-35"
- name: Extract Android keystore
run: |
ls
cd forge-gui-android
echo "${{ secrets.FORGE_KEYSTORE }}" > forge.keystore.asc
gpg -d --passphrase "${{ secrets.FORGE_KEYSTORE_PASSPHRASE }}" --batch forge.keystore.asc > forge.keystore
cd -
- name: Setup tmate session
uses: mxschmitt/action-tmate@v3
if: ${{ github.event_name == 'workflow_dispatch' && inputs.debug_enabled }}
- name: Install Android maven plugin
run: |
mkdir -p ~/.m2/repository/com/simpligility/maven/plugins/android-maven-plugin/4.6.2
cd ~/.m2/repository/com/simpligility/maven/plugins/android-maven-plugin/4.6.2
curl -L -o android-maven-plugin-4.6.2.jar https://github.com/Card-Forge/android-maven-plugin/releases/download/4.6.2/android-maven-plugin-4.6.2.jar
curl -L -o android-maven-plugin-4.6.2.pom https://github.com/Card-Forge/android-maven-plugin/releases/download/4.6.2/android-maven-plugin-4.6.2.pom
#mvn install:install-file -Dfile=android-maven-plugin-4.6.2.jar -DgroupId=com.simpligility.maven.plugins -DartifactId=android-maven-plugin -Dversion=4.6.2 -Dpackaging=jar
cd -
mvn install -Dmaven.test.skip=true
mvn dependency:tree
- name: Build/Install/Publish to GitHub Packages Apache Maven
run: |
export DISPLAY=":1"
Xvfb :1 -screen 0 800x600x8 &
export _JAVA_OPTIONS="-Xmx2g"
d=$(date +%m.%d)
# build both desktop and android
mvn -U -B clean -P windows-linux,android-release-build install -e -Dcardforge-repo.username=${{ secrets.FTP_USERNAME }} -Dcardforge-repo.password=${{ secrets.FTP_PASSWORD }} -Dandroid.sdk.path=/usr/local/lib/android/sdk -Dandroid.buildToolsVersion=35.0.0
mkdir izpack
# move bz2 and jar from work dir to izpack dir
mv /home/runner/work/forge/forge/forge-installer/*/*.{bz2,jar} izpack/
# move desktop build.txt and version.txt to izpack
mv /home/runner/work/forge/forge/forge-gui-desktop/target/classes/*.txt izpack/
# move android apk and assets.zip
mv /home/runner/work/forge/forge/forge-gui-android/target/*-signed-aligned.apk izpack/
mv /home/runner/work/forge/forge/forge-gui-android/target/assets.zip izpack/
cd izpack
# rename files and append date
for file in *.jar; do
bname="${file%.*}"
echo "file renamed to ${bname}-${d}.jar"
mv "${bname}.jar" "${bname}-${d}.jar"
done
for file in *.bz2; do
# remove .bz2
fname="${file%.*}"
# remove .tar
bname="${fname%.*}"
echo "file renamed to ${bname}-${d}.tar.bz2"
mv "${fname}.bz2" "${bname}-${d}.tar.bz2"
done
ls
env:
GITHUB_TOKEN: ${{ github.token }}
- name: Upload snapshot to GitHub Prerelease
uses: ncipollo/release-action@v1
env:
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
name: Daily Snapshot
tag: daily-snapshots
prerelease: true
artifacts: izpack/*
allowUpdates: true
removeArtifacts: true
- name: Send failure notification to Discord
if: failure() # This step runs only if the job fails
run: |
curl -X POST -H "Content-Type: application/json" \
-d "{\"content\": \"🔴 Snapshot Build Failed in branch: \`${{ github.ref_name }}\` by \`${{ github.actor }}\`.\nCheck logs: ${{ github.server_url }}/${{ github.repository }}/actions/runs/${{ github.run_id }}\"}" \
${{ secrets.DISCORD_AUTOMATION_WEBHOOK }}

View File

@@ -8,10 +8,11 @@ on:
description: 'Run the build with tmate debugging enabled (https://github.com/marketplace/actions/debugging-with-tmate)'
required: false
default: false
schedule:
# * is a special character in YAML so you have to quote this string
- cron: '00 19 * * *'
#upload_package:
# type: boolean
# description: 'Upload the completed Android package'
# required: false
# default: true
jobs:
build:
@@ -24,10 +25,10 @@ jobs:
steps:
- uses: actions/checkout@v3
- name: Set up JDK 8
- name: Set up JDK 17
uses: actions/setup-java@v3
with:
java-version: '8'
java-version: '17'
distribution: 'temurin'
cache: 'maven'
server-id: cardforge-repo
@@ -35,19 +36,17 @@ jobs:
server-password: ${{ secrets.FTP_PASSWORD }}
settings-path: ${{ github.workspace }} # location for the settings.xml file
- name: Install old maven (3.6.3)
- name: Install old maven (3.8.1)
run: |
curl -o apache-maven-3.6.3-bin.tar.gz https://archive.apache.org/dist/maven/maven-3/3.6.3/binaries/apache-maven-3.6.3-bin.tar.gz
tar xf apache-maven-3.6.3-bin.tar.gz
export PATH=$PWD/apache-maven-3.6.3/bin:$PATH
export MAVEN_HOME=$PWD/apache-maven-3.6.3
curl -o apache-maven-3.8.1-bin.tar.gz https://archive.apache.org/dist/maven/maven-3/3.8.1/binaries/apache-maven-3.8.1-bin.tar.gz
tar xf apache-maven-3.8.1-bin.tar.gz
export PATH=$PWD/apache-maven-3.8.1/bin:$PATH
export MAVEN_HOME=$PWD/apache-maven-3.8.1
mvn --version
- name: Set Up Android tools
run: |
JAVA_HOME=${JAVA_HOME_11_X64} ${ANDROID_SDK_ROOT}/cmdline-tools/latest/bin/sdkmanager --sdk_root=$ANDROID_SDK_ROOT "platform-tools"
JAVA_HOME=${JAVA_HOME_11_X64} ${ANDROID_SDK_ROOT}/cmdline-tools/latest/bin/sdkmanager --sdk_root=$ANDROID_SDK_ROOT --install "platforms;android-26"
JAVA_HOME=${JAVA_HOME_11_X64} ${ANDROID_SDK_ROOT}/cmdline-tools/latest/bin/sdkmanager --sdk_root=$ANDROID_SDK_ROOT --install "build-tools;30.0.3"
JAVA_HOME=${JAVA_HOME_17_X64} ${ANDROID_SDK_ROOT}/cmdline-tools/latest/bin/sdkmanager --sdk_root=$ANDROID_SDK_ROOT --install "build-tools;35.0.0" "platform-tools" "platforms;android-35"
- name: Install virtual framebuffer (if not available) to allow running GUI on a headless server
run: |
@@ -74,11 +73,11 @@ jobs:
- name: Install Android maven plugin
run: |
mkdir -p ~/.m2/repository/com/simpligility/maven/plugins/android-maven-plugin/4.6.1
cd ~/.m2/repository/com/simpligility/maven/plugins/android-maven-plugin/4.6.1
curl -L -o android-maven-plugin-4.6.1.jar https://github.com/Card-Forge/android-maven-plugin/releases/download/4.6.1/android-maven-plugin-4.6.1.jar
curl -L -o android-maven-plugin-4.6.1.pom https://github.com/Card-Forge/android-maven-plugin/releases/download/4.6.1/android-maven-plugin-4.6.1.pom
#mvn install:install-file -Dfile=android-maven-plugin-4.6.1.jar -DgroupId=com.simpligility.maven.plugins -DartifactId=android-maven-plugin -Dversion=4.6.1 -Dpackaging=jar
mkdir -p ~/.m2/repository/com/simpligility/maven/plugins/android-maven-plugin/4.6.2
cd ~/.m2/repository/com/simpligility/maven/plugins/android-maven-plugin/4.6.2
curl -L -o android-maven-plugin-4.6.2.jar https://github.com/Card-Forge/android-maven-plugin/releases/download/4.6.2/android-maven-plugin-4.6.2.jar
curl -L -o android-maven-plugin-4.6.2.pom https://github.com/Card-Forge/android-maven-plugin/releases/download/4.6.2/android-maven-plugin-4.6.2.pom
#mvn install:install-file -Dfile=android-maven-plugin-4.6.2.jar -DgroupId=com.simpligility.maven.plugins -DartifactId=android-maven-plugin -Dversion=4.6.2 -Dpackaging=jar
cd -
mvn install -Dmaven.test.skip=true
mvn dependency:tree
@@ -86,40 +85,30 @@ jobs:
- name: Build/Install/Publish to GitHub Packages Apache Maven
run: |
export _JAVA_OPTIONS="-Xmx2g"
d=$(date +%m-%d)
# Replace date in forge-gui-mobile/src/forge/Forge.java
sed -i -e "s/-SNAPSHOT/-SNAPSHOT-${d}/g" forge-gui-mobile/src/forge/Forge.java
mvn -U -B -P android-release-build,android-release-sign install -e -Dsign.keystore=forge.keystore -Dsign.alias=Forge -Dsign.storepass=${{ secrets.SIGN_STORE_PASS }} -Dsign.keypass=${{ secrets.SIGN_STORE_PASS }} -Dcardforge-repo.username=${{ secrets.FTP_USERNAME }} -Dcardforge-repo.password=${{ secrets.FTP_PASSWORD }} -Dandroid.sdk.path=/usr/local/lib/android/sdk -Dandroid.buildToolsVersion=30.0.3 -Dmaven.test.skip=true
mkdir -p forge-gui-android/target/upload
mv forge-gui-android/target/*-signed-aligned.apk forge-gui-android/target/upload/
mv forge-gui-android/target/assets.zip forge-gui-android/target/upload/
cd forge-gui-android/target/upload/
# Get the first APK file in the folder
mvn -U -B -P android-release-build install -e -Dcardforge-repo.username=${{ secrets.FTP_USERNAME }} -Dcardforge-repo.password=${{ secrets.FTP_PASSWORD }} -Dandroid.sdk.path=/usr/local/lib/android/sdk -Dandroid.buildToolsVersion=35.0.0 -Dmaven.test.skip=true
mkdir upload
mv /home/runner/work/forge/forge/forge-gui-android/target/*-signed-aligned.apk upload/
mv /home/runner/work/forge/forge/forge-gui-android/target/assets.zip upload/
mv /home/runner/work/forge/forge/forge-gui-android/target/classes/assets/version.txt upload/
cd upload
ls
apk_file=$(find . -maxdepth 1 -type f -name '*.apk' -print -quit)
if [ -n "$apk_file" ]; then
version=$(echo "$apk_file" | grep -oP 'forge-android-\K\d+\.\d+\.\d+-SNAPSHOT' | sed 's/-signed-aligned.apk//')
echo "APK File: $apk_file"
echo "Version: $version"
mv *.apk "forge-android-$version-$d-signed-aligned.apk"
echo "$version-$d" > version.txt
else
echo "No .apk files found in the specified folder."
fi
cd -
env:
GITHUB_TOKEN: ${{ github.token }}
- name: 📂 Sync files
uses: SamKirkland/FTP-Deploy-Action@v4.3.4
#if: ${{ inputs.upload_package }}
with:
server: ftp.cardforge.org
username: ${{ secrets.FTP_USERNAME }}
password: ${{ secrets.FTP_PASSWORD }}
local-dir: forge-gui-android/target/upload/
local-dir: upload/
server-dir: downloads/dailysnapshots/
state-name: .ftp-deploy-android-sync-state.json
- name: Send failure notification to Discord
if: failure() # This step runs only if the job fails
run: |
curl -X POST -H "Content-Type: application/json" \
-d "{\"content\": \"🔴 Android Snapshot Build Failed in branch: \`${{ github.ref_name }}\` by \`${{ github.actor }}\`.\nCheck logs: ${{ github.run_url }}\"}" \
${{ secrets.DISCORD_AUTOMATION_WEBHOOK }}

View File

@@ -8,9 +8,6 @@ on:
description: 'Run the build with tmate debugging enabled (https://github.com/marketplace/actions/debugging-with-tmate)'
required: false
default: false
schedule:
# * is a special character in YAML so you have to quote this string
- cron: '30 18 * * *'
jobs:
build:
@@ -23,10 +20,10 @@ jobs:
steps:
- uses: actions/checkout@v3
- name: Set up JDK 11
- name: Set up JDK 17
uses: actions/setup-java@v3
with:
java-version: '11'
java-version: '17'
distribution: 'temurin'
cache: 'maven'
server-id: cardforge-repo
@@ -45,7 +42,7 @@ jobs:
run: |
export DISPLAY=":1"
Xvfb :1 -screen 0 800x600x8 &
mvn -U -B clean -P windows-linux install -T 1C -Dcardforge-repo.username=${{ secrets.FTP_USERNAME }} -Dcardforge-repo.password=${{ secrets.FTP_PASSWORD }}
mvn -U -B clean -P windows-linux install -T 1C -Dcardforge-repo.username=${{ secrets.FTP_USERNAME }} -Dcardforge-repo.password=${{ secrets.FTP_PASSWORD }}
env:
GITHUB_TOKEN: ${{ github.token }}
@@ -55,13 +52,27 @@ jobs:
- name: Rename before upload
run: |
mkdir tarball
# If this works just gotta figure out how to append datetime
mv /home/runner/.m2/repository/forge/forge-gui-desktop/*/*.bz2 tarball/
cd tarball
out="$(basename -s .tar.bz2 *)"
d=$(date +%m-%d)
mv "${out}.tar.bz2" "${out}-${d}.tar.bz2"
mkdir izpack
# move bz2 and jar from work dir to izpack dir
mv /home/runner/work/forge/forge/forge-installer/*/*.{bz2,jar} izpack/
# move desktop build.txt to izpack
mv /home/runner/work/forge/forge/forge-gui-desktop/target/classes/build.txt izpack/
cd izpack
d=$(date +%m.%d)
# rename files and append date
for file in *.jar; do
bname="${file%.*}"
echo "file renamed to ${bname}-${d}.jar"
mv "${bname}.jar" "${bname}-${d}.jar"
done
for file in *.bz2; do
# remove .bz2
fname="${file%.*}"
# remove .tar
bname="${fname%.*}"
echo "file renamed to ${bname}-${d}.tar.bz2"
mv "${fname}.bz2" "${bname}-${d}.tar.bz2"
done
- name: 📂 Sync files
uses: SamKirkland/FTP-Deploy-Action@v4.3.4
@@ -69,13 +80,16 @@ jobs:
server: ftp.cardforge.org
username: ${{ secrets.FTP_USERNAME }}
password: ${{ secrets.FTP_PASSWORD }}
local-dir: tarball/
local-dir: izpack/
server-dir: downloads/dailysnapshots/
exclude: |
*.jar
*.pom
*.repositories
*.xml
- name: Send failure notification to Discord
if: failure() # This step runs only if the job fails
run: |
curl -X POST -H "Content-Type: application/json" \
-d "{\"content\": \"🔴 Desktop Snapshot Build Failed in branch: \`${{ github.ref_name }}\` by \`${{ github.actor }}\`.\nCheck logs: ${{ github.run_url }}\"}" \
${{ secrets.DISCORD_AUTOMATION_WEBHOOK }}

28
.github/workflows/sync-wiki.yml vendored Normal file
View File

@@ -0,0 +1,28 @@
name: Publish wiki
on:
push:
branches: [master]
paths:
- docs/**
- .github/workflows/sync-wiki.yml
workflow_dispatch:
concurrency:
group: publish-wiki
cancel-in-progress: true
permissions:
contents: write
jobs:
publish-wiki:
if: github.repository_owner == 'Card-Forge'
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- name: fix md links for Gollum
run: find ${{ github.workspace }}/docs/ -type f -name "*.md" -exec sed -i -E 's|(\[[^]]+]\()([^)]+\/)*([^).]+).md\)|\1\3)|g' '{}' \;
- name: fix image links for Gollum
run: find ${{ github.workspace }}/docs/ -type f -name "*.png" -exec mv '{}' ${{ github.workspace }}/docs/ \;
- uses: Andrew-Chen-Wang/github-wiki-action@v5
with:
path: docs
preprocess: false
strategy: init

View File

@@ -0,0 +1,60 @@
name: Test Android build
on:
push:
paths: [ 'forge-gui-android/**' ]
pull_request:
paths: [ 'forge-gui-android/**' ]
jobs:
build:
runs-on: ubuntu-latest
permissions:
contents: write
deployments: write
packages: write
strategy:
matrix:
java: [ '17' ]
name: Test with Java ${{ matrix.Java }}
steps:
- uses: actions/checkout@v3
- name: Set up JDK 17
uses: actions/setup-java@v3
with:
java-version: ${{ matrix.java }}
distribution: 'temurin'
cache: 'maven'
- name: Install old maven (3.8.1)
run: |
curl -o apache-maven-3.8.1-bin.tar.gz https://archive.apache.org/dist/maven/maven-3/3.8.1/binaries/apache-maven-3.8.1-bin.tar.gz
tar xf apache-maven-3.8.1-bin.tar.gz
export PATH=$PWD/apache-maven-3.8.1/bin:$PATH
export MAVEN_HOME=$PWD/apache-maven-3.8.1
mvn --version
- name: Set Up Android tools
run: |
JAVA_HOME=${JAVA_HOME_17_X64} ${ANDROID_SDK_ROOT}/cmdline-tools/latest/bin/sdkmanager --sdk_root=$ANDROID_SDK_ROOT --install "build-tools;35.0.0" "platform-tools" "platforms;android-35"
- name: Install Android maven plugin
run: |
mkdir -p ~/.m2/repository/com/simpligility/maven/plugins/android-maven-plugin/4.6.2
cd ~/.m2/repository/com/simpligility/maven/plugins/android-maven-plugin/4.6.2
curl -L -o android-maven-plugin-4.6.2.jar https://github.com/Card-Forge/android-maven-plugin/releases/download/4.6.2/android-maven-plugin-4.6.2.jar
curl -L -o android-maven-plugin-4.6.2.pom https://github.com/Card-Forge/android-maven-plugin/releases/download/4.6.2/android-maven-plugin-4.6.2.pom
#mvn install:install-file -Dfile=android-maven-plugin-4.6.2.jar -DgroupId=com.simpligility.maven.plugins -DartifactId=android-maven-plugin -Dversion=4.6.2 -Dpackaging=jar
cd -
mvn install -Dmaven.test.skip=true
mvn dependency:tree
- name: Install virtual framebuffer (if not available) to allow running GUI on a headless server
run: command -v Xvfb >/dev/null 2>&1 || { sudo apt update && sudo apt install -y xvfb; }
- name: Run build in virtual framebuffer
run: |
export DISPLAY=":1"
Xvfb :1 -screen 0 800x600x8 &
mvn -U -B -P android-test-build verify -e -T 1C -Dandroid.sdk.path=$ANDROID_SDK_ROOT -Dandroid.buildToolsVersion=35.0.0 -Dmaven.test.skip=true

View File

@@ -7,7 +7,7 @@ jobs:
runs-on: ubuntu-latest
strategy:
matrix:
java: [ '8', '11' ]
java: ['17', '21']
name: Test with Java ${{ matrix.Java }}
steps:
- uses: actions/checkout@v3
@@ -26,4 +26,4 @@ jobs:
run: |
export DISPLAY=":1"
Xvfb :1 -screen 0 800x600x8 &
mvn -U -B clean -P windows-linux test
mvn -U -B clean test

View File

@@ -14,10 +14,10 @@ jobs:
steps:
- uses: actions/checkout@v3
- name: Set up JDK 11
- name: Set up JDK 17
uses: actions/setup-java@v3
with:
java-version: '11'
java-version: '17'
distribution: 'temurin'
cache: 'maven'
server-id: cardforge-repo

10
.gitignore vendored
View File

@@ -12,6 +12,7 @@
.settings
.classpath
.project
.checkstyle
# Ignore VS Code config files
@@ -24,6 +25,8 @@
nbactions.xml
# Ignore flattened pom
.flattened-pom.xml
# Ignore binaries, temp files and test output, everywhere
@@ -63,6 +66,9 @@ forge-gui-mobile-dev/testAssets
forge-gui/res/cardsfolder/*.bat
# Generated changelog file
forge-gui/release-files/CHANGES.txt
forge-gui/res/PerSetTrackingResults
forge-gui/res/decks
forge-gui/res/layouts
@@ -84,3 +90,7 @@ forge-gui/tools/PerSetTrackingResults
*.tiled-session
/forge-gui/res/adventure/*.tiled-project
/forge-gui/res/adventure/*.tiled-session
# Ignore python temporaries
__pycache__
*.pyc

View File

@@ -1,33 +0,0 @@
Summary
(Summarize the bug encountered concisely)
Steps to reproduce
(How one can reproduce the issue - this is very important. Specific cards and specific actions especially)
Which version of Forge are you on (Release, Snapshot? Desktop, Android?)
What is the current bug behavior?
(What actually happens)
What is the expected correct behavior?
(What you should see instead)
Relevant logs and/or screenshots
(Paste/Attach your game.log from the crash - please use code blocks (```)) Also, provide screenshots of the current state.
Possible fixes
(If you can, link to the line of code that might be responsible for the problem)
/label ~needs-investigation

View File

@@ -1,15 +0,0 @@
Summary
(Summarize the feature you wish concisely)
Example screenshots
(If this is a UI change, please provide an example screenshot of how this feature might work)
Feature type
(Where in Forge does this belong? e.g. Quest Mode, Deck Editor, Limited, Constructed, etc.)
/label ~feature request

View File

@@ -1,18 +1,6 @@
<!--
Derived from: https://stackoverflow.com/a/67002852
-->
<settings xmlns="http://maven.apache.org/SETTINGS/1.2.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.2.0 http://maven.apache.org/xsd/settings-1.2.0.xsd">
<mirrors>
<mirror>
<id>4thline-repo-http-unblocker</id>
<mirrorOf>4thline-repo</mirrorOf>
<name></name>
<url>http://4thline.org/m2</url>
</mirror>
</mirrors>
<servers>
<server>
<id>cardforge-repo</id>
@@ -20,4 +8,4 @@
<password>${cardforge-repo.password}</password>
</server>
</servers>
</settings>
</settings>

195
CONTRIBUTING.md Normal file
View File

@@ -0,0 +1,195 @@
# Contributing to Forge
[Official repo](https://github.com/Card-Forge/forge.git).
Dev instructions here: [Getting Started](https://github.com/Card-Forge/forge/wiki) (Somewhat outdated)
## Requirements / Tools
- your favourite Java IDE (IntelliJ, Eclipse, VSCodium, Emacs, Vi...)
- Java JDK 17 or later
- Git
- Git client (optional)
- Maven
- GitHub account
- Libgdx (optional: familiarity with this library is helpful for mobile platform development)
- Android SDK (optional: for Android releases)
- RoboVM (optional: for iOS releases) (TBD: Current status of support by libgdx)
## Project Quick Setup
- Login into GitHub with your user account and fork the project.
- Clone your forked project to your local machine
- Go to the project location on your machine. Run Maven to download all dependencies and build a snapshot. Example for Windows & Linux: `mvn -U -B clean -P windows-linux install`
## IntelliJ
IntelliJ is the recommended IDE for Forge development. Quick start guide for [setting up the Forge project within IntelliJ](https://github.com/Card-Forge/forge/wiki/IntelliJ-setup).
## Eclipse
Eclipse includes Maven integration so a separate install is not necessary. For other IDEs, your mileage may vary.
At this time, Eclipse is not the recommended IDE for Forge development.
### Project Setup
- Follow the instructions for cloning from GitHub. You'll need to setup an account and your SSH key.
If you are on a Windows machine you can use Putty with TortoiseGit for SSH keys. Run puttygen.exe to generate the key -- save the private key and export
the OpenSSH public key. If you just leave the dialog open, you can copy and paste the key from it to your GitHub profile under
"SSH keys". Run pageant.exe and add the private key generated earlier. TortoiseGit will use this for accessing GitHub.
- Fork the Forge git repo to your GitHub account.
- Clone your forked repo to your local machine.
- Make sure the Java SDK is installed -- not just the JRE. Java 17 or newer required. If you execute `java -version` at the shell or command prompt, it should report version 17 or later.
- Install Eclipse 2021-12 or later for Java. Launch it.
- Create a workspace. Go to the workbench. Right-click inside of Package Explorer > Import... > Maven > Existing Maven Projects > Navigate to root path of the local forge repo and
ensure everything is checked > Finish.
- Let Eclipse run through building the project. You may be prompted for resolving any missing Maven plugins -- accept the ones offered. You may see errors appear in the "Problems" tab. These should
be automatically resolved as plug-ins are installed and Eclipse continues the build process. If this is the first time for some plug-in installs, Eclipse may prompt you to restart. Do so. Be patient
for this first time through.
- Once everything builds, all errors should disappear. You can now advance to Project launch.
### Project Launch
#### Desktop
This is the standard configuration used for releasing to Windows / Linux / MacOS.
- Right-click on forge-gui-desktop > Run As... > Java Application > "Main - forge.view" > Ok
- The familiar Forge splash screen, etc. should appear. Enjoy!
#### Mobile (Desktop dev)
This is the configuration used for doing mobile development using the Windows / Linux / MacOS front-end. Knowledge of libgdx is helpful here.
- Right-click on forge-gui-mobile-dev > Run As... > Java Application > "Main - forge.app" > Ok.
- A view similar to a mobile phone should appear. Enjoy!
### Eclipse / Android SDK Integration
Google no longer supports Android SDK releases for Eclipse. use IntelliJ.
#### Android SDK
TBD
##### Windows
TBD
##### Linux / Mac OSX
TBD
#### Android Plugin for Eclipse
TBD
#### Android Platform
In Intellij, if the SDK Manager is not already running, go to Tools > Android > Android SDK Manager. Install the following options / versions:
- Android SDK Build-tools 35.0.0
- Android 15 (API 35) SDK Platform
#### Proguard update
Standalone Proguard 7.6.0 is included with the project (proguard.jar) under forge-gui-android > tools and supports up to Java 23 (latest android uses Java 17).
#### Android Build
TBD
#### Android Deploy
TBD
#### Android Debugging
TBD
### Windows / Linux SNAPSHOT build
SNAPSHOT builds can be built via the Maven integration in Eclipse.
1. Create a Maven build for the forge top-level project. Right-click on the forge project. Run as.. > Maven build...
- On the Main tab, set Goals: clean install, set Profiles: windows-linux
2. Run forge Maven build. If everything built, you should see "BUILD SUCCESS" in the Console View.
The resulting snapshot will be found at: forge-gui-desktop/target/forge-gui-desktop-[version]-SNAPSHOT
## Card Scripting
Visit [this page](https://github.com/Card-Forge/forge/wiki/Card-scripting-API) for information on scripting.
Card scripting resources are found in the forge-gui/res/ path.
## General Notes
### Project Hierarchy
Forge is divided into 4 primary projects with additional projects that target specific platform releases. The primary projects are:
- forge-ai
- forge-core
- forge-game
- forge-gui
The platform-specific projects are:
- forge-gui-android
- forge-gui-desktop
- forge-gui-ios
- forge-gui-mobile
- forge-gui-mobile-dev
#### forge-ai
The forge-ai project contains the computer opponent logic for gameplay. It includes decision-making algorithms for specific abilities, cards and turn phases.
#### forge-core
The forge-core project contains the core game engine, card mechanics, rules engine, and fundamental game logic. It includes the implementation of Magic: The Gathering rules, card interactions, and the game state management system.
#### forge-game
The forge-game project handles the game session management, player interactions, and game flow control. It includes implementations for multiplayer support, game modes, matchmaking, and game state persistence. This module bridges the core game engine with the user interface and networking components.
#### forge-gui
The forge-gui project contains the user interface components and rendering logic for the game. It includes the main game window, card displays, player interactions, and the scripting resource definitions in the res/ path.
#### forge-gui-android
Libgdx-based backend targeting Android. Requires Android SDK and relies on forge-gui-mobile for GUI logic.
#### forge-gui-desktop
Java Swing based GUI targeting desktop machines.
Screen layout and game logic revolving around the GUI is found here. For example, the overlay arrows (when enabled) that indicate attackers and blockers, or the targets of the stack are defined and drawn by this.
#### forge-gui-ios
Libgdx-based backend targeting iOS. Relies on forge-gui-mobile for GUI logic.
#### forge-gui-mobile
Mobile GUI game logic utilizing [libgdx](https://libgdx.badlogicgames.com/) library. Screen layout and game logic revolving around the GUI for the mobile platforms is found here.
#### forge-gui-mobile-dev
Libgdx backend for desktop development for mobile backends. Utilizes LWJGL. Relies on forge-gui-mobile for GUI logic.

261
README.md
View File

@@ -1,230 +1,105 @@
# Forge
# ⚔️ Forge: The Magic: The Gathering Rules Engine
[Official repo](https://github.com/Card-Forge/forge.git).
Dev instructions here: [Getting Started](https://github.com/Card-Forge/forge/wiki) (Somewhat outdated)
[Discord channel](https://discord.gg/HcPJNyD66a)
Join the **Forge community** on [Discord](https://discord.gg/HcPJNyD66a)!
[![Test build](https://github.com/Card-Forge/forge/actions/workflows/test-build.yaml/badge.svg)](https://github.com/Card-Forge/forge/actions/workflows/test-build.yaml)
## Requirements / Tools
---
- you favourite Java IDE (IntelliJ, Eclipse, VSCodium, Emacs, Vi...)
- Java JDK 8 or later (some IDEs such as Eclipse require JDK11+, whereas the Android build currently only works with JDK8)
- Git
- Git client (optional)
- Maven
- GitHub account
- Libgdx (optional: familiarity with this library is helpful for mobile platform development)
- Android SDK (optional: for Android releases)
- RoboVM (optional: for iOS releases) (TBD: Current status of support by libgdx)
## ✨ Introduction
## Project Quick Setup
**Forge** is a dynamic and open-source **Rules Engine** tailored for **Magic: The Gathering** enthusiasts. Developed by a community of passionate programmers, Forge allows players to explore the rich universe of MTG through a flexible, engaging platform.
- Login into GitHub with your user account and fork the project.
**Note:** Forge operates independently and is not affiliated with Wizards of the Coast.
- Clone your forked project to your local machine
---
- Go to the project location on your machine. Run Maven to download all dependencies and build a snapshot. Example for Windows & Linux: `mvn -U -B clean -P windows-linux install`
## 🌟 Key Features
## Eclipse
- **🌐 Cross-Platform Support:** Play on **Windows, Mac, Linux,** and **Android**.
- **🔧 Extensible Architecture:** Built in **Java**, Forge encourages developers to contribute by adding features and cards.
- **🎮 Versatile Gameplay:** Dive into single-player modes or challenge opponents online!
Eclipse includes Maven integration so a separate install is not necessary. For other IDEs, your mileage may vary.
---
### Project Setup
## 🛠️ Installation Guide
- Follow the instructions for cloning from GitHub. You'll need to setup an account and your SSH key.
### 📥 Desktop Installation
1. **Latest Releases:** Download the latest version [here](https://github.com/Card-Forge/forge/releases/latest).
2. **Snapshot Build:** For the latest development version, grab the `forge-gui-desktop` tarball from our [Snapshot Build](https://github.com/Card-Forge/forge/releases/tag/daily-snapshots).
- **Tip:** Extract to a new folder to prevent version conflicts.
3. **User Data Management:** Previous players data is preserved during upgrades.
4. **Java Requirement:** Ensure you have **Java 17 or later** installed.
If you are on a Windows machine you can use Putty with TortoiseGit for SSH keys. Run puttygen.exe to generate the key -- save the private key and export
the OpenSSH public key. If you just leave the dialog open, you can copy and paste the key from it to your GitHub profile under
"SSH keys". Run pageant.exe and add the private key generated earlier. TortoiseGit will use this for accessing GitHub.
### 📱 Android Installation
- _(Note: **Android 11** is the minimum requirements with at least **6GB RAM** to run smoothly. You need to enable **"Install unknown apps"** for Forge to initialize and update itself)_
- Download the **APK** from the [Snapshot Build](https://github.com/Card-Forge/forge/releases/tag/daily-snapshots). On the first launch, Forge will automatically download all necessary assets.
- Fork the Forge git repo to your GitHub account.
---
- Clone your forked repo to your local machine.
## 🎮 Modes of Play
- Make sure the Java SDK is installed -- not just the JRE. Java 8 or newer required. If you execute `java -version` at the shell or command prompt, it should report version 1.8 or later.
Forge offers various exciting gameplay options:
- Install Eclipse 2018-12 or later for Java. Launch it.
### 🌍 Adventure Mode
Embark on a thrilling single-player journey where you can:
- Explore an overworld map.
- Challenge diverse AI opponents.
- Collect cards and items to boost your abilities.
- Create a workspace. Go to the workbench. Right-click inside of Package Explorer > Import... > Maven > Existing Maven Projects > Navigate to root path of the local forge repo and
ensure everything is checked > Finish.
<img width="1282" height="752" alt="Shandalar World" src="https://github.com/user-attachments/assets/9af31471-d688-442f-9418-9807d8635b72" />
- Let Eclipse run through building the project. You may be prompted for resolving any missing Maven plugins -- accept the ones offered. You may see errors appear in the "Problems" tab. These should
be automatically resolved as plug-ins are installed and Eclipse continues the build process. If this is the first time for some plug-in installs, Eclipse may prompt you to restart. Do so. Be patient
for this first time through.
### 🔍 Quest Modes
Engage in focused gameplay without the overworld exploration—perfect for quick sessions!
- Once everything builds, all errors should disappear. You can now advance to Project launch.
<img width="1282" height="752" alt="Quest Duels" src="https://github.com/user-attachments/assets/b9613b1c-e8c3-4320-8044-6922c519aad4" />
### Project Launch
### 🤖 AI Formats
Test your skills against AI in multiple formats:
- **Sealed**
- **Draft**
- **Commander**
- **Cube**
#### Desktop
For comprehensive gameplay instructions, visit our [Gameplay Guide](https://github.com/Card-Forge/forge/wiki/Gameplay-Guide).
This is the standard configuration used for releasing to Windows / Linux / MacOS.
<img width="1282" height="752" alt="Sealed" src="https://github.com/user-attachments/assets/ae603dbd-4421-4753-a333-87cb0a28d772" />
- Right-click on forge-gui-desktop > Run As... > Java Application > "Main - forge.view" > Ok
---
- The familiar Forge splash screen, etc. should appear. Enjoy!
## 💬 Support & Community
#### Mobile (Desktop dev)
Need help? Join our vibrant Discord community!
- 📜 Read the **#rules** and explore the **FAQ**.
- ❓ Ask your questions in the **#help** channel for assistance.
This is the configuration used for doing mobile development using the Windows / Linux / MacOS front-end. Knowledge of libgdx is helpful here.
---
- Right-click on forge-gui-mobile-dev > Run As... > Java Application > "Main - forge.app" > Ok.
## 🤝 Contributing to Forge
- A view similar to a mobile phone should appear. Enjoy!
We love community contributions! Interested in helping? Check out our [Contributing Guidelines](CONTRIBUTING.md) for details on how to get started.
### Eclipse / Android SDK Integration
---
Google no longer supports Android SDK releases for Eclipse. That said, it is still possible to build and debug Android platforms.
## About Forge
#### Android SDK
Forge aims to deliver an immersive and customizable Magic: The Gathering experience for fans around the world.
Reference SO for obtaining a specific release: https://stackoverflow.com/questions/27043522/where-can-i-download-an-older-version-of-the-android-sdk
### 📊 Repository Statistics
##### Windows
| Metric | Count |
|----------------|-------------------------------------------------------------|
| **⭐ Stars:** | [![GitHub stars](https://img.shields.io/github/stars/Card-Forge/forge?style=flat-square)](https://github.com/Card-Forge/forge/stargazers) |
| **🍴 Forks:** | [![GitHub forks](https://img.shields.io/github/forks/Card-Forge/forge?style=flat-square)](https://github.com/Card-Forge/forge/network) |
| **👥 Contributors:** | [![GitHub contributors](https://img.shields.io/github/contributors/Card-Forge/forge?style=flat-square)](https://github.com/Card-Forge/forge/graphs/contributors) |
Download the following archived version of the Android SDK: http://dl-ssl.google.com/android/repository/tools_r25.2.3-windows.zip. Install it somewhere on your machine. This is referenced
in the following instructions as your 'Android SDK Install' path.
---
##### Linux / Mac OSX
TBD
#### Android Plugin for Eclipse
Google's last plugin release does not work completely with target's running Android 7.0 or later. Download the ADT-24.2.0-20160729.zip plugin
from: https://github.com/khaledev/ADT/releases
In Eclipse go to: Help > Install New Software... > Add > Name: ADT Update, Click on the "Archive:" button and navigate to the downloaded ADT-24.2.0-20160729.zip file > Add. Install all "Developer Tools". Eclipse
should restart and prompt you to run the SDK Manager. Launch it and continue to the next steps below.
#### Android Platform
In Eclipse, if the SDK Manager is not already running, go to Window > Android SDK Manager. Install the following options / versions:
- Android SDK Build-tools 26.0.1
- Android 8.0.0 (API 26) SDK Platform
- Google USB Driver (in case your phone is not detected by ADB)
Note that this will populate additional tools in the Android SDK install path extracted above.
#### Proguard update
The Proguard included with the Android SDK Build-tools is outdated and does not work with Java 1.8. Download Proguard 6.0.3 or later (last tested with 7.0.1) from https://github.com/Guardsquare/proguard
- Go to the Android SDK install path. Rename the tools/proguard/ path to tools/proguard-4.7/.
- Extract your Proguard version to the Android SDK install path under tools/. You will need to either rename the dir proguard-<your-version> to proguard/ or, if your filesystem supports it, use a symbolic link (the later is highly recommended), such as `ln -s proguard proguard-<your-version>`.
#### Android Build
The Eclipse plug-ins do NOT support building things for Android. They do however allow you to use the debugger so you can still set breakpoints and trace
things out. The steps below show how to generate a debug Android build.
1) Create a Maven build for the forge top-level project. Right-click on the forge project. Run as.. > Maven build...
- On the Main tab, set Goals: clean install
2) Run forge Maven build. If everything built, you should see "BUILD SUCCESS" in the Console View.
3) Right-click on the forge-gui-android project. Run as.. > Maven build...
- On the Main tab, set Goals: install, Profiles: android-debug
- On the Environment tab, you may need to define the variable ANDROID_HOME with the value containing the path to your Android SDK installation. For example, Variable: ANDROID_HOME, Value: Your Android SDK install path here.
4) Run the forge-gui-android Maven build. This may take a few minutes. If everything worked, you should see "BUILD SUCCESS" in the Console View.
Assuming you got this far, you should have an Android forge-android-[version].apk in the forge-gui-android/target path.
#### Android Deploy
You'll need to have the Android SDK install path platform-tools/ path in your command search path to easily deploy builds.
- Open a command prompt. Navigate to the forge-gui-android/target/ path.
- Connect your Android device to your dev machine.
- Ensure the device is visible using `adb devices`
- Remove the old Forge install if present: `adb uninstall forge.app`
- Install the new apk: `adb install forge-android-[version].apk`
#### Android Debugging
Assuming the apk is installed, launch it from the device.
In Eclipse, launch the DDMS. Window > Perspective > Open Perspective > Other... > DDMS. You should see the forge app in the list. Highlight the app, click on the green debug button and a
green debug button should appear next to the app's name. You can now set breakpoints and step through the source code.
### Windows / Linux SNAPSHOT build
SNAPSHOT builds can be built via the Maven integration in Eclipse.
1) Create a Maven build for the forge top-level project. Right-click on the forge project. Run as.. > Maven build...
- On the Main tab, set Goals: clean install, set Profiles: windows-linux
2) Run forge Maven build. If everything built, you should see "BUILD SUCCESS" in the Console View.
The resulting snapshot will be found at: forge-gui-desktop/target/forge-gui-desktop-[version]-SNAPSHOT
## IntelliJ
Quick start guide for [setting up the Forge project within IntelliJ](https://github.com/Card-Forge/forge/wiki/IntelliJ-setup).
## Card Scripting
Visit [this page](https://github.com/Card-Forge/forge/wiki/Card-scripting-API) for information on scripting.
Card scripting resources are found in the forge-gui/res/ path.
## General Notes
### Project Hierarchy
Forge is divided into 4 primary projects with additional projects that target specific platform releases. The primary projects are:
- forge-ai
- forge-core
- forge-game
- forge-gui
The platform-specific projects are:
- forge-gui-android
- forge-gui-desktop
- forge-gui-ios
- forge-gui-mobile
- forge-gui-mobile-dev
#### forge-ai
#### forge-core
#### forge-game
#### forge-gui
The forge-gui project includes the scripting resource definitions in the res/ path.
#### forge-gui-android
Libgdx-based backend targeting Android. Requires Android SDK and relies on forge-gui-mobile for GUI logic.
#### forge-gui-desktop
Java Swing based GUI targeting desktop machines.
Screen layout and game logic revolving around the GUI is found here. For example, the overlay arrows (when enabled) that indicate attackers and blockers, or the targets of the stack are defined and drawn by this.
#### forge-gui-ios
Libgdx-based backend targeting iOS. Relies on forge-gui-mobile for GUI logic.
#### forge-gui-mobile
Mobile GUI game logic utilizing [libgdx](https://libgdx.badlogicgames.com/) library. Screen layout and game logic revolving around the GUI for the mobile platforms is found here.
#### forge-gui-mobile-dev
Libgdx backend for desktop development for mobile backends. Utilizes LWJGL. Relies on forge-gui-mobile for GUI logic.
**📄 License:** [GPL-3.0](LICENSE)
<div align="center" style="display: flex; align-items: center; justify-content: center;">
<div style="margin-left: auto;">
<a href="#top">
<img src="https://img.shields.io/badge/Back%20to%20Top-000000?style=for-the-badge&logo=github&logoColor=white" alt="Back to Top">
</a>
</div>
</div>

117
adventure-editor/pom.xml Normal file
View File

@@ -0,0 +1,117 @@
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<artifactId>forge</artifactId>
<groupId>forge</groupId>
<version>${revision}</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>adventure-editor</artifactId>
<packaging>jar</packaging>
<name>Adventure Editor</name>
<build>
<sourceDirectory>src/main/java</sourceDirectory>
<resources>
<resource>
<directory>${project.basedir}</directory>
<includes>
<include>**/gear.gif</include>
</includes>
</resource>
</resources>
<finalName>adventure-editor</finalName>
<plugins>
<plugin>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>17</source>
<target>17</target>
</configuration>
</plugin>
<plugin>
<groupId>com.google.code.maven-replacer-plugin</groupId>
<artifactId>replacer</artifactId>
<version>1.5.3</version>
<executions>
<execution>
<phase>package</phase>
<goals>
<goal>replace</goal>
</goals>
</execution>
</executions>
<configuration>
<basedir>${basedir}/${configSourceDirectory}</basedir>
<filesToInclude>adventure-editor.sh, adventure-editor.command, adventure-editor.cmd</filesToInclude>
<outputBasedir>${project.build.directory}</outputBasedir>
<outputDir>.</outputDir>
<regex>false</regex>
<replacements>
<replacement>
<token>$project.build.finalName$</token>
<value>${project.build.finalName}-jar-with-dependencies.jar</value>
</replacement>
</replacements>
</configuration>
</plugin>
<plugin>
<artifactId>maven-assembly-plugin</artifactId>
<configuration>
<attach>false</attach>
<descriptorRefs>
<descriptorRef>jar-with-dependencies</descriptorRef>
</descriptorRefs>
<archive>
<manifest>
<mainClass>forge.adventure.Main</mainClass>
<addDefaultImplementationEntries>true</addDefaultImplementationEntries>
</manifest>
<manifestEntries>
<SplashScreen-Image>splash/gear.gif</SplashScreen-Image>
</manifestEntries>
</archive>
</configuration>
<executions>
<execution>
<id>make-assembly</id>
<!-- this is used for inheritance merges -->
<phase>package</phase>
<!-- bind to the packaging phase -->
<goals>
<goal>single</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
<dependencies>
<dependency>
<groupId>forge</groupId>
<artifactId>forge-gui</artifactId>
<version>${project.version}</version>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>forge</groupId>
<artifactId>forge-gui-mobile</artifactId>
<version>${project.version}</version>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>org.jetbrains</groupId>
<artifactId>annotations</artifactId>
<version>26.0.1</version>
<scope>compile</scope>
</dependency>
</dependencies>
<properties>
<maven.compiler.source>17</maven.compiler.source>
<maven.compiler.target>17</maven.compiler.target>
</properties>
</project>

Binary file not shown.

After

Width:  |  Height:  |  Size: 414 KiB

View File

@@ -0,0 +1,24 @@
@echo off
pushd %~dp0
java -version 1>nul 2>nul || (
echo no java installed
popd
exit /b 2
)
for /f tokens^=2^ delims^=.-_^+^" %%j in ('java -fullversion 2^>^&1') do set "jver=%%j"
if %jver% LEQ 16 (
echo unsupported java
popd
exit /b 2
)
if %jver% GEQ 17 (
java -Xmx4096m -Dfile.encoding=UTF-8 -jar $project.build.finalName$
popd
exit /b 0
)
popd

View File

Before

Width:  |  Height:  |  Size: 90 KiB

After

Width:  |  Height:  |  Size: 90 KiB

View File

Before

Width:  |  Height:  |  Size: 90 KiB

After

Width:  |  Height:  |  Size: 90 KiB

View File

Before

Width:  |  Height:  |  Size: 222 KiB

After

Width:  |  Height:  |  Size: 222 KiB

View File

@@ -0,0 +1,21 @@
package forge.adventure;
import forge.GuiMobile;
import forge.adventure.editor.EditorMainWindow;
import forge.adventure.util.Config;
import forge.gui.GuiBase;
import java.nio.file.Files;
import java.nio.file.Paths;
/**
* Main entry point
*/
public class Main {
public static void main(String[] args) {
GuiBase.setInterface(new GuiMobile(Files.exists(Paths.get("./res"))?"./":"../forge-gui/"));
GuiBase.setDeviceInfo(null, 0, 0, System.getProperty("user.home") + "/Downloads/");
new EditorMainWindow(Config.instance());
}
}

View File

@@ -2,7 +2,9 @@ package forge.adventure.editor;
import forge.adventure.data.DialogData;
import javax.swing.*;
import javax.swing.JSpinner;
import javax.swing.JTextField;
import javax.swing.SpinnerNumberModel;
import javax.swing.event.ChangeEvent;
import javax.swing.event.ChangeListener;
@@ -158,9 +160,9 @@ public class ActionEdit extends FormPanel {
advanceQuestFlag.setText(currentData.advanceQuestFlag);
advanceCharacterFlag.setText(currentData.advanceCharacterFlag);
battleWithActorID.setText("" + currentData.battleWithActorID);
activateObjectID.setText("" + currentData.battleWithActorID);
deleteMapObject.setText("" + currentData.deleteMapObject);
battleWithActorID.setText(String.valueOf(currentData.battleWithActorID));
activateObjectID.setText(String.valueOf(currentData.battleWithActorID));
deleteMapObject.setText(String.valueOf(currentData.deleteMapObject));
setColorIdentity.setText(currentData.setColorIdentity);
addLife.getModel().setValue(currentData.addLife);
addReputation.getModel().setValue(currentData.addMapReputation);

View File

@@ -0,0 +1,144 @@
package forge.adventure.editor;
import forge.adventure.data.DialogData;
import javax.swing.DefaultListCellRenderer;
import javax.swing.DefaultListModel;
import javax.swing.JButton;
import javax.swing.JComponent;
import javax.swing.JLabel;
import javax.swing.JList;
import javax.swing.JToolBar;
import javax.swing.event.ChangeEvent;
import javax.swing.event.ChangeListener;
import java.awt.BorderLayout;
import java.awt.Component;
import java.awt.event.ActionListener;
/**
* Editor class to edit configuration, maybe moved or removed
*/
public class ActionEditor extends JComponent {
DefaultListModel<DialogData.ActionData> model = new DefaultListModel<>();
JList<DialogData.ActionData> list = new JList<>(model);
JToolBar toolBar = new JToolBar("toolbar");
ActionEdit edit = new ActionEdit();
boolean updating;
public class RewardDataRenderer extends DefaultListCellRenderer {
@Override
public Component getListCellRendererComponent(
JList list, Object value, int index,
boolean isSelected, boolean cellHasFocus) {
JLabel label = (JLabel) super.getListCellRendererComponent(list, value, index, isSelected, cellHasFocus);
if (!(value instanceof DialogData.ActionData))
return label;
/*DialogData.ActionData action=(DialogData.ActionData) value;
StringBuilder builder=new StringBuilder();
if(action.type==null||action.type.isEmpty())
builder.append("Action");
else
builder.append(action.type);*/
label.setText("Action");
return label;
}
}
public void addButton(String name, ActionListener action) {
JButton newButton = new JButton(name);
newButton.addActionListener(action);
toolBar.add(newButton);
}
public ActionEditor() {
list.setCellRenderer(new RewardDataRenderer());
list.addListSelectionListener(e -> ActionEditor.this.updateEdit());
addButton("add", e -> ActionEditor.this.addAction());
addButton("remove", e -> ActionEditor.this.remove());
addButton("copy", e -> ActionEditor.this.copy());
BorderLayout layout = new BorderLayout();
setLayout(layout);
add(list, BorderLayout.LINE_START);
add(toolBar, BorderLayout.PAGE_START);
add(edit, BorderLayout.CENTER);
edit.addChangeListener(e -> emitChanged());
}
protected void emitChanged() {
if (updating)
return;
ChangeListener[] listeners = listenerList.getListeners(ChangeListener.class);
if (listeners != null && listeners.length > 0) {
ChangeEvent evt = new ChangeEvent(this);
for (ChangeListener listener : listeners) {
listener.stateChanged(evt);
}
}
}
private void copy() {
int selected = list.getSelectedIndex();
if (selected < 0)
return;
DialogData.ActionData data = new DialogData.ActionData(model.get(selected));
model.add(model.size(), data);
}
private void updateEdit() {
int selected = list.getSelectedIndex();
if (selected < 0)
return;
edit.setCurrentAction(model.get(selected));
}
void addAction() {
DialogData.ActionData data = new DialogData.ActionData();
model.add(model.size(), data);
}
void remove() {
int selected = list.getSelectedIndex();
if (selected < 0)
return;
model.remove(selected);
}
public void setAction(DialogData.ActionData[] actions) {
model.clear();
if (actions == null)
return;
for (int i = 0; i < actions.length; i++) {
if (actions[i].grantRewards.length > 0) {
continue; //handled in separate editor and joined in on save, will get duplicated if it appears here
}
model.add(i, actions[i]);
}
}
public DialogData.ActionData[] getAction() {
DialogData.ActionData[] action = new DialogData.ActionData[model.getSize()];
for (int i = 0; i < model.getSize(); i++) {
action[i] = model.get(i);
}
return action;
}
public void clear() {
updating = true;
model.clear();
updating = false;
}
public void addChangeListener(ChangeListener listener) {
listenerList.add(ChangeListener.class, listener);
}
}

View File

@@ -51,12 +51,12 @@ public class BiomeEdit extends FormPanel {
add(terrain);
add(structures);
name.getDocument().addDocumentListener(new DocumentChangeListener(() -> BiomeEdit.this.updateTerrain()));
tilesetName.getDocument().addDocumentListener(new DocumentChangeListener(() -> BiomeEdit.this.updateTerrain()));
color.getDocument().addDocumentListener(new DocumentChangeListener(() -> BiomeEdit.this.updateTerrain()));
name.getDocument().addDocumentListener(new DocumentChangeListener(BiomeEdit.this::updateTerrain));
tilesetName.getDocument().addDocumentListener(new DocumentChangeListener(BiomeEdit.this::updateTerrain));
color.getDocument().addDocumentListener(new DocumentChangeListener(BiomeEdit.this::updateTerrain));
collision.addChangeListener(e -> BiomeEdit.this.updateTerrain());
spriteNames.getEdit().getDocument().addDocumentListener(new DocumentChangeListener(() -> BiomeEdit.this.updateTerrain()));
enemies.getEdit().getDocument().addDocumentListener(new DocumentChangeListener(() -> BiomeEdit.this.updateTerrain()));
spriteNames.getEdit().getDocument().addDocumentListener(new DocumentChangeListener(BiomeEdit.this::updateTerrain));
enemies.getEdit().getDocument().addDocumentListener(new DocumentChangeListener(BiomeEdit.this::updateTerrain));
terrain.addChangeListener(e -> BiomeEdit.this.updateTerrain());
@@ -64,7 +64,7 @@ public class BiomeEdit extends FormPanel {
startPointY.addChangeListener(e -> BiomeEdit.this.updateTerrain());
noiseWeight.addChangeListener(e -> BiomeEdit.this.updateTerrain());
distWeight.addChangeListener(e -> BiomeEdit.this.updateTerrain());
tilesetAtlas.getEdit().getDocument().addDocumentListener(new DocumentChangeListener(() -> BiomeEdit.this.updateTerrain()));
tilesetAtlas.getEdit().getDocument().addDocumentListener(new DocumentChangeListener(BiomeEdit.this::updateTerrain));
width.addChangeListener(e -> BiomeEdit.this.updateTerrain());
height.addChangeListener(e -> BiomeEdit.this.updateTerrain());
refresh();

View File

@@ -45,17 +45,16 @@ public class BiomeStructureDataMappingEditor extends JComponent {
JList list, Object value, int index,
boolean isSelected, boolean cellHasFocus) {
JLabel label = (JLabel) super.getListCellRendererComponent(list, value, index, isSelected, cellHasFocus);
if(!(value instanceof BiomeStructureData.BiomeStructureDataMapping))
if(!(value instanceof BiomeStructureData.BiomeStructureDataMapping biomeData))
return label;
BiomeStructureData.BiomeStructureDataMapping data=(BiomeStructureData.BiomeStructureDataMapping) value;
// Get the renderer component from parent class
label.setText(data.name);
label.setText(biomeData.name);
if(editor.data!=null)
{
SwingAtlas itemAtlas=new SwingAtlas(Config.instance().getFile(editor.data.structureAtlasPath));
if(itemAtlas.has(data.name))
label.setIcon(itemAtlas.get(data.name));
if(itemAtlas.has(biomeData.name))
label.setIcon(itemAtlas.get(biomeData.name));
else
{
ImageIcon img=itemAtlas.getAny();
@@ -135,8 +134,8 @@ public class BiomeStructureDataMappingEditor extends JComponent {
add("color:",color);
add("collision:",collision);
name.getDocument().addDocumentListener(new DocumentChangeListener(() -> BiomeStructureDataMappingEdit.this.update()));
color.getDocument().addDocumentListener(new DocumentChangeListener(() -> BiomeStructureDataMappingEdit.this.update()));
name.getDocument().addDocumentListener(new DocumentChangeListener(BiomeStructureDataMappingEdit.this::update));
color.getDocument().addDocumentListener(new DocumentChangeListener(BiomeStructureDataMappingEdit.this::update));
collision.addChangeListener(e -> BiomeStructureDataMappingEdit.this.update());
refresh();
}

View File

@@ -45,7 +45,7 @@ public class BiomeStructureEdit extends FormPanel {
add(center);
add(data);
structureAtlasPath.getDocument().addDocumentListener(new DocumentChangeListener(() -> BiomeStructureEdit.this.updateStructure()));
structureAtlasPath.getDocument().addDocumentListener(new DocumentChangeListener(BiomeStructureEdit.this::updateStructure));
x.addChangeListener(e -> BiomeStructureEdit.this.updateStructure());
@@ -55,8 +55,8 @@ public class BiomeStructureEdit extends FormPanel {
randomPosition.addChangeListener(e -> BiomeStructureEdit.this.updateStructure());
N.addChangeListener(e -> BiomeStructureEdit.this.updateStructure());
sourcePath.getDocument().addDocumentListener(new DocumentChangeListener(() -> BiomeStructureEdit.this.updateStructure()));
maskPath.getDocument().addDocumentListener(new DocumentChangeListener(() -> BiomeStructureEdit.this.updateStructure()));
sourcePath.getDocument().addDocumentListener(new DocumentChangeListener(BiomeStructureEdit.this::updateStructure));
maskPath.getDocument().addDocumentListener(new DocumentChangeListener(BiomeStructureEdit.this::updateStructure));
periodicInput.addChangeListener(e -> BiomeStructureEdit.this.updateStructure());
ground.addChangeListener(e -> BiomeStructureEdit.this.updateStructure());
symmetry.addChangeListener(e -> BiomeStructureEdit.this.updateStructure());

View File

@@ -27,7 +27,7 @@ public class BiomeTerrainEdit extends FormPanel {
center.add("resolution:",resolution);
add(center,preview);
spriteName.getDocument().addDocumentListener(new DocumentChangeListener(() -> BiomeTerrainEdit.this.updateTerrain()));
spriteName.getDocument().addDocumentListener(new DocumentChangeListener(BiomeTerrainEdit.this::updateTerrain));
min.addChangeListener(e -> BiomeTerrainEdit.this.updateTerrain());
max.addChangeListener(e -> BiomeTerrainEdit.this.updateTerrain());

View File

@@ -40,8 +40,8 @@ public class DialogOptionEdit extends FormPanel {
add(middle);
name.getDocument().addDocumentListener(new DocumentChangeListener(() -> DialogOptionEdit.this.updateDialog()));
text.getDocument().addDocumentListener(new DocumentChangeListener(() -> DialogOptionEdit.this.updateDialog()));
name.getDocument().addDocumentListener(new DocumentChangeListener(DialogOptionEdit.this::updateDialog));
text.getDocument().addDocumentListener(new DocumentChangeListener(DialogOptionEdit.this::updateDialog));
}

View File

@@ -25,9 +25,8 @@ public class DialogOptionEditor extends JComponent{
JList list, Object value, int index,
boolean isSelected, boolean cellHasFocus) {
JLabel label = (JLabel) super.getListCellRendererComponent(list, value, index, isSelected, cellHasFocus);
if(!(value instanceof DialogData))
if(!(value instanceof DialogData dialog))
return label;
DialogData dialog=(DialogData) value;
StringBuilder builder=new StringBuilder();
if(dialog.name==null||dialog.name.isEmpty())
builder.append("[[Blank Option]]");

View File

@@ -49,12 +49,7 @@ public class DialogTree extends JPanel {
public void addSelectionListener(){
//subscribe to valueChanged, change to that object in edit pane
dialogTree.getSelectionModel().addTreeSelectionListener(new TreeSelectionListener() {
@Override
public void valueChanged(TreeSelectionEvent e) {
emitChanged(e);
}
});
dialogTree.getSelectionModel().addTreeSelectionListener(this::emitChanged);
}

View File

@@ -0,0 +1,97 @@
package forge.adventure.editor;
import forge.adventure.util.Config;
import javax.swing.JButton;
import javax.swing.JDialog;
import javax.swing.JFrame;
import javax.swing.JOptionPane;
import javax.swing.JTabbedPane;
import javax.swing.JToolBar;
import javax.swing.UIManager;
import java.awt.BorderLayout;
import java.awt.Desktop;
import java.awt.EventQueue;
import java.awt.event.WindowAdapter;
import java.awt.event.WindowEvent;
import java.io.File;
import java.security.CodeSource;
import java.util.ArrayList;
import java.util.List;
/**
* Editor class to edit configuration, maybe moved or removed
*/
public class EditorMainWindow extends JFrame {
public final static WorldEditor worldEditor = new WorldEditor();
JTabbedPane tabs = new JTabbedPane();
public EditorMainWindow(Config config) {
UIManager.LookAndFeelInfo[] var1 = UIManager.getInstalledLookAndFeels();
for (UIManager.LookAndFeelInfo info : var1) {
if ("Nimbus".equals(info.getName())) {
try {
UIManager.setLookAndFeel(info.getClassName());
} catch (Throwable ignored) {
}
break;
}
}
this.setDefaultCloseOperation(JFrame.DO_NOTHING_ON_CLOSE);
this.addWindowListener(new WindowAdapter() {
@Override
public void windowClosing(WindowEvent e) {
setVisible(false);
System.exit(0);
}
});
BorderLayout layout = new BorderLayout();
JToolBar toolBar = new JToolBar("toolbar");
JButton newButton = new JButton("GDX Particle Editor Tool");
newButton.addActionListener(e -> EventQueue.invokeLater(() -> {
newButton.setEnabled(false);
try {
CodeSource codeSource = EditorMainWindow.class.getProtectionDomain().getCodeSource();
File jarFile = new File(codeSource.getLocation().toURI().getPath());
String jarDir = jarFile.getParentFile().getPath();
Desktop.getDesktop().open(new File(jarDir + "/gdx-particle-editor.jar"));
} catch (Exception ex) {
new ErrorDialog("Error", ex.getMessage());
newButton.setEnabled(true);
}
}));
JButton quit = new JButton("Quit");
quit.addActionListener(e -> System.exit(0));
toolBar.add(newButton);
toolBar.add(quit);
setLayout(layout);
toolBar.setFloatable(false);
add(toolBar, BorderLayout.NORTH);
add(tabs, BorderLayout.CENTER);
tabs.addTab("World", worldEditor);
tabs.addTab("POI", new PointOfInterestEditor());
tabs.addTab("Items", new ItemsEditor());
tabs.addTab("Enemies", new EnemyEditor());
tabs.addTab("Quests", new QuestEditor());
setSize(config.getSettingData().width, config.getSettingData().height);
setLocationRelativeTo(null);
setVisible(true);
}
static class ErrorDialog {
public ErrorDialog(String title, String message) {
List<Object> options = new ArrayList<>();
JButton ok = new JButton("OK");
options.add(ok);
JOptionPane pane = new JOptionPane(message, JOptionPane.PLAIN_MESSAGE, JOptionPane.DEFAULT_OPTION, null, options.toArray());
JDialog dlg = pane.createDialog(JOptionPane.getRootFrame(), title);
ok.addActionListener(e -> {
dlg.setVisible(false);
System.exit(0);
});
dlg.setResizable(false);
dlg.setVisible(true);
}
}
}

View File

@@ -42,8 +42,8 @@ public class EffectEditor extends JComponent {
lifeModifier.addChangeListener(e -> EffectEditor.this.updateEffect());
moveSpeed.addChangeListener(e -> EffectEditor.this.updateEffect());
colorView.addChangeListener(e -> EffectEditor.this.updateEffect());
name.getDocument().addDocumentListener(new DocumentChangeListener(() -> EffectEditor.this.updateEffect()));
startBattleWithCard.getEdit().getDocument().addDocumentListener(new DocumentChangeListener(() -> EffectEditor.this.updateEffect()));
name.getDocument().addDocumentListener(new DocumentChangeListener(EffectEditor.this::updateEffect));
startBattleWithCard.getEdit().getDocument().addDocumentListener(new DocumentChangeListener(EffectEditor.this::updateEffect));
if(opponent!=null)
opponent.addChangeListener(e -> EffectEditor.this.updateEffect());
@@ -57,9 +57,9 @@ public class EffectEditor extends JComponent {
currentData.name=name.getText();
currentData.changeStartCards=((Integer)changeStartCards.getValue()).intValue();
currentData.lifeModifier= ((Integer)lifeModifier.getValue()).intValue();
currentData.moveSpeed= ((Float)moveSpeed.getValue()).floatValue();
currentData.changeStartCards = (Integer) changeStartCards.getValue();
currentData.lifeModifier = (Integer) lifeModifier.getValue();
currentData.moveSpeed = (Float) moveSpeed.getValue();
currentData.startBattleWithCard = startBattleWithCard.getList();
currentData.colorView = colorView.isSelected();
currentData.opponent = opponent.currentData;

View File

@@ -289,7 +289,7 @@ public class EnemyEdit extends FormPanel {
tags.add(e.nextElement());
}
tags.removeIf(q -> q.isEmpty());
tags.removeIf(String::isEmpty);
currentData.questTags = tags.toArray(currentData.questTags);
QuestController.getInstance().refresh();
filterExisting(enemyModel);

View File

@@ -4,8 +4,6 @@ import forge.adventure.util.Config;
import javax.swing.*;
import javax.swing.filechooser.FileNameExtensionFilter;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.io.File;
import java.io.IOException;
@@ -21,12 +19,7 @@ public class FilePicker extends Box {
super(BoxLayout.X_AXIS);
this.fileEndings = fileEndings;
findButton.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent e) {
FilePicker.this.find();
}
});
findButton.addActionListener(e -> FilePicker.this.find());
add(edit);
add(findButton);

View File

@@ -14,6 +14,6 @@ public class FloatSpinner extends JSpinner{
}
public float floatValue()
{
return ((Float)getValue()).floatValue();
return (Float) getValue();
}
}

View File

@@ -15,6 +15,6 @@ public class IntSpinner extends JSpinner {
}
public int intValue()
{
return ((Integer)getValue()).intValue();
return (Integer) getValue();
}
}

View File

@@ -38,10 +38,10 @@ public class ItemEdit extends JComponent {
add(effect);
add(new Box.Filler(new Dimension(0,0),new Dimension(0,Integer.MAX_VALUE),new Dimension(0,Integer.MAX_VALUE)));
nameField.getDocument().addDocumentListener(new DocumentChangeListener(() -> ItemEdit.this.updateItem()));
equipmentSlot.getDocument().addDocumentListener(new DocumentChangeListener(() -> ItemEdit.this.updateItem()));
description.getDocument().addDocumentListener(new DocumentChangeListener(() -> ItemEdit.this.updateItem()));
iconName.getDocument().addDocumentListener(new DocumentChangeListener(() -> ItemEdit.this.updateItem()));
nameField.getDocument().addDocumentListener(new DocumentChangeListener(ItemEdit.this::updateItem));
equipmentSlot.getDocument().addDocumentListener(new DocumentChangeListener(ItemEdit.this::updateItem));
description.getDocument().addDocumentListener(new DocumentChangeListener(ItemEdit.this::updateItem));
iconName.getDocument().addDocumentListener(new DocumentChangeListener(ItemEdit.this::updateItem));
cost.addChangeListener(e -> ItemEdit.this.updateItem());
questItem.addChangeListener(e -> ItemEdit.this.updateItem());
effect.addChangeListener(e -> ItemEdit.this.updateItem());
@@ -57,7 +57,7 @@ public class ItemEdit extends JComponent {
currentData.description=description.getText();
currentData.iconName=iconName.getText();
currentData.questItem=questItem.isSelected();
currentData.cost=((Integer) cost.getValue()).intValue();
currentData.cost= (Integer) cost.getValue();
}
public void setCurrentItem(ItemData data)

View File

@@ -27,17 +27,16 @@ public class ItemsEditor extends JComponent {
JList list, Object value, int index,
boolean isSelected, boolean cellHasFocus) {
JLabel label = (JLabel) super.getListCellRendererComponent(list, value, index, isSelected, cellHasFocus);
if(!(value instanceof ItemData))
if(!(value instanceof ItemData item))
return label;
ItemData Item=(ItemData) value;
// Get the renderer component from parent class
label.setText(Item.name);
label.setText(item.name);
if(itemAtlas==null)
itemAtlas=new SwingAtlas(Config.instance().getFile(Paths.ITEMS_ATLAS));
if(itemAtlas.has(Item.iconName))
label.setIcon(itemAtlas.get(Item.iconName));
if(itemAtlas.has(item.iconName))
label.setIcon(itemAtlas.get(item.iconName));
else
{
ImageIcon img=itemAtlas.getAny();

View File

@@ -2,10 +2,23 @@ package forge.adventure.editor;
import forge.adventure.data.AdventureQuestData;
import javax.swing.*;
import javax.swing.AbstractAction;
import javax.swing.BoxLayout;
import javax.swing.DefaultListModel;
import javax.swing.JButton;
import javax.swing.JCheckBox;
import javax.swing.JLabel;
import javax.swing.JList;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTabbedPane;
import javax.swing.JTextArea;
import javax.swing.JTextField;
import javax.swing.KeyStroke;
import javax.swing.event.ListDataEvent;
import javax.swing.event.ListDataListener;
import java.awt.*;
import java.awt.BorderLayout;
import java.awt.Dimension;
import java.awt.event.ActionEvent;
import java.util.ArrayList;
import java.util.Enumeration;
@@ -285,7 +298,7 @@ public class QuestEdit extends FormPanel {
}
setVisible(true);
updating=true;
id.setText(currentData.getID() + "");
id.setText(String.valueOf(currentData.getID()));
name.setText(currentData.name);
description.setText(currentData.description);
synopsis.setText(currentData.synopsis);

View File

@@ -26,9 +26,8 @@ public class QuestEditor extends JComponent {
JList list, Object value, int index,
boolean isSelected, boolean cellHasFocus) {
JLabel label = (JLabel) super.getListCellRendererComponent(list, value, index, isSelected, cellHasFocus);
if(!(value instanceof AdventureQuestData))
if(!(value instanceof AdventureQuestData quest))
return label;
AdventureQuestData quest=(AdventureQuestData) value;
// Get the renderer component from parent class
label.setText(quest.name);

View File

@@ -26,9 +26,8 @@ public class QuestStageEditor extends JComponent{
JList list, Object value, int index,
boolean isSelected, boolean cellHasFocus) {
JLabel label = (JLabel) super.getListCellRendererComponent(list, value, index, isSelected, cellHasFocus);
if(!(value instanceof AdventureQuestStage))
if(!(value instanceof AdventureQuestStage stageData))
return label;
AdventureQuestStage stageData=(AdventureQuestStage) value;
label.setText(stageData.name);
//label.setIcon(new ImageIcon(Config.instance().getFilePath(stageData.sourcePath))); //Type icon eventually?
return label;

View File

@@ -25,10 +25,10 @@ public class RewardEdit extends FormPanel {
TextListEdit colors =new TextListEdit(new String[] { "White", "Blue", "Black", "Red", "Green" });
TextListEdit rarity =new TextListEdit(new String[] { "Basic Land", "Common", "Uncommon", "Rare", "Mythic Rare" });
TextListEdit subTypes =new TextListEdit();
TextListEdit cardTypes =new TextListEdit(Arrays.asList(CardType.CoreType.values()).stream().map(CardType.CoreType::toString).toArray(String[]::new));
TextListEdit superTypes =new TextListEdit(Arrays.asList(CardType.Supertype.values()).stream().map(CardType.Supertype::toString).toArray(String[]::new));
TextListEdit cardTypes =new TextListEdit(Arrays.stream(CardType.CoreType.values()).map(CardType.CoreType::toString).toArray(String[]::new));
TextListEdit superTypes =new TextListEdit(Arrays.stream(CardType.Supertype.values()).map(CardType.Supertype::toString).toArray(String[]::new));
TextListEdit manaCosts =new TextListEdit();
TextListEdit keyWords =new TextListEdit(Arrays.asList(Keyword.values()).stream().map(Keyword::toString).toArray(String[]::new));
TextListEdit keyWords =new TextListEdit(Arrays.stream(Keyword.values()).map(Keyword::toString).toArray(String[]::new));
JComboBox colorType =new JComboBox(new String[] { "Any", "Colorless", "MultiColor", "MonoColor"});
JTextField cardText =new JTextField();
private boolean updating=false;
@@ -58,18 +58,18 @@ public class RewardEdit extends FormPanel {
probability.addChangeListener(e -> RewardEdit.this.updateReward());
count.addChangeListener(e -> RewardEdit.this.updateReward());
addMaxCount.addChangeListener(e -> RewardEdit.this.updateReward());
cardName.getDocument().addDocumentListener(new DocumentChangeListener(() -> RewardEdit.this.updateReward()));
itemName.getDocument().addDocumentListener(new DocumentChangeListener(() -> RewardEdit.this.updateReward()));
editions.getEdit().getDocument().addDocumentListener(new DocumentChangeListener(() -> RewardEdit.this.updateReward()));
colors.getEdit().getDocument().addDocumentListener(new DocumentChangeListener(() -> RewardEdit.this.updateReward()));
rarity.getEdit().getDocument().addDocumentListener(new DocumentChangeListener(() -> RewardEdit.this.updateReward()));
subTypes.getEdit().getDocument().addDocumentListener(new DocumentChangeListener(() -> RewardEdit.this.updateReward()));
cardTypes.getEdit().getDocument().addDocumentListener(new DocumentChangeListener(() -> RewardEdit.this.updateReward()));
superTypes.getEdit().getDocument().addDocumentListener(new DocumentChangeListener(() -> RewardEdit.this.updateReward()));
manaCosts.getEdit().getDocument().addDocumentListener(new DocumentChangeListener(() -> RewardEdit.this.updateReward()));
keyWords.getEdit().getDocument().addDocumentListener(new DocumentChangeListener(() -> RewardEdit.this.updateReward()));
cardName.getDocument().addDocumentListener(new DocumentChangeListener(RewardEdit.this::updateReward));
itemName.getDocument().addDocumentListener(new DocumentChangeListener(RewardEdit.this::updateReward));
editions.getEdit().getDocument().addDocumentListener(new DocumentChangeListener(RewardEdit.this::updateReward));
colors.getEdit().getDocument().addDocumentListener(new DocumentChangeListener(RewardEdit.this::updateReward));
rarity.getEdit().getDocument().addDocumentListener(new DocumentChangeListener(RewardEdit.this::updateReward));
subTypes.getEdit().getDocument().addDocumentListener(new DocumentChangeListener(RewardEdit.this::updateReward));
cardTypes.getEdit().getDocument().addDocumentListener(new DocumentChangeListener(RewardEdit.this::updateReward));
superTypes.getEdit().getDocument().addDocumentListener(new DocumentChangeListener(RewardEdit.this::updateReward));
manaCosts.getEdit().getDocument().addDocumentListener(new DocumentChangeListener(RewardEdit.this::updateReward));
keyWords.getEdit().getDocument().addDocumentListener(new DocumentChangeListener(RewardEdit.this::updateReward));
colorType.addActionListener((e -> RewardEdit.this.updateReward()));
cardText.getDocument().addDocumentListener(new DocumentChangeListener(() -> RewardEdit.this.updateReward()));
cardText.getDocument().addDocumentListener(new DocumentChangeListener(RewardEdit.this::updateReward));
}
@@ -122,7 +122,7 @@ public class RewardEdit extends FormPanel {
updating=true;
typeField.setSelectedItem(currentData.type);
probability.setValue(new Double(currentData.probability));
probability.setValue((double) currentData.probability);
count.setValue(currentData.count);
addMaxCount.setValue(currentData.addMaxCount);
cardName.setText(currentData.cardName);

View File

@@ -68,12 +68,7 @@ public class StructureEditor extends JComponent{
add(edit,BorderLayout.CENTER);
edit.addChangeListener(new ChangeListener() {
@Override
public void stateChanged(ChangeEvent e) {
emitChanged();
}
});
edit.addChangeListener(e -> emitChanged());
}
protected void emitChanged() {
ChangeListener[] listeners = listenerList.getListeners(ChangeListener.class);

View File

@@ -5,7 +5,7 @@ import com.badlogic.gdx.graphics.g2d.TextureAtlas;
import com.badlogic.gdx.utils.Array;
import javax.imageio.ImageIO;
import javax.swing.*;
import javax.swing.ImageIcon;
import java.awt.image.BufferedImage;
import java.io.IOException;
import java.util.ArrayList;
@@ -65,7 +65,7 @@ public class SwingAtlas {
return new ImageIcon(img.getSubimage(sprite.left,sprite.top, sprite.width, sprite.height).getScaledInstance((int) (imageSize*(sprite.width/(float)sprite.height)),imageSize,SCALE_FAST));
}
catch (IOException e)
catch (Exception e)
{
return null;
}

View File

@@ -3,10 +3,17 @@ package forge.adventure.editor;
import forge.adventure.data.BiomeData;
import forge.adventure.data.BiomeTerrainData;
import javax.swing.*;
import javax.swing.DefaultListCellRenderer;
import javax.swing.DefaultListModel;
import javax.swing.JButton;
import javax.swing.JComponent;
import javax.swing.JLabel;
import javax.swing.JList;
import javax.swing.JToolBar;
import javax.swing.event.ChangeEvent;
import javax.swing.event.ChangeListener;
import java.awt.*;
import java.awt.BorderLayout;
import java.awt.Component;
import java.awt.event.ActionListener;
/**
@@ -29,11 +36,11 @@ public class TerrainsEditor extends JComponent{
if(!(value instanceof BiomeTerrainData))
return label;
BiomeTerrainData terrainData=(BiomeTerrainData) value;
StringBuilder builder=new StringBuilder();
/*StringBuilder builder=new StringBuilder();
builder.append("Terrain");
builder.append(" ");
builder.append(terrainData.spriteName);
label.setText(builder.toString());
builder.append(terrainData.spriteName);*/
label.setText("Terrain " + terrainData.spriteName);
return label;
}
}
@@ -60,12 +67,7 @@ public class TerrainsEditor extends JComponent{
add(edit,BorderLayout.CENTER);
edit.addChangeListener(new ChangeListener() {
@Override
public void stateChanged(ChangeEvent e) {
emitChanged();
}
});
edit.addChangeListener(e -> emitChanged());
}
protected void emitChanged() {
ChangeListener[] listeners = listenerList.getListeners(ChangeListener.class);

View File

@@ -9,8 +9,6 @@ import forge.adventure.util.Config;
import forge.adventure.util.Paths;
import javax.swing.*;
import javax.swing.event.ListSelectionEvent;
import javax.swing.event.ListSelectionListener;
import java.awt.*;
import java.io.File;
import java.io.IOException;
@@ -45,9 +43,8 @@ public class WorldEditor extends JComponent {
JList list, Object value, int index,
boolean isSelected, boolean cellHasFocus) {
JLabel label = (JLabel) super.getListCellRendererComponent(list, value, index, isSelected, cellHasFocus);
if(!(value instanceof BiomeData))
if(!(value instanceof BiomeData biome))
return label;
BiomeData biome=(BiomeData) value;
// Get the renderer component from parent class
label.setText(biome.name);
@@ -81,12 +78,7 @@ public class WorldEditor extends JComponent {
public WorldEditor() {
list.setCellRenderer(new BiomeDataRenderer());
list.addListSelectionListener(new ListSelectionListener() {
@Override
public void valueChanged(ListSelectionEvent e) {
WorldEditor.this.updateBiome();
}
});
list.addListSelectionListener(e -> WorldEditor.this.updateBiome());
BorderLayout layout = new BorderLayout();
setLayout(layout);
add(tabs);

Binary file not shown.

68
docs/AI.md Normal file
View File

@@ -0,0 +1,68 @@
# About Forge's Artificial Intelligence
The AI is *not* "trained". It uses basic rules and can be easy to overcome knowing it's weaknesses.
The AI is:
* Best with Aggro and midrange decks
* Poor to Ok in control decks
* Pretty bad for most combo decks
If you want to train a model for the AI, please do. We would love to see something like that implemented in Forge.
# AI Matches from Command Line
The AI can battle itself in the command line, allowing the tests to be performed on headless servers or on computers that have poor graphic performance, and when you just don't need to see the match. This can be useful if you want to script testing of decks, test a large tournament, or just bash 100's of games out to see how well a deck performs.
Please understand, the AI is still the AI, and it's limitations exist even against itself. Games can lag and become almost unbearably long when the AI has a lot to think about, and you can't see what's on the table for it to play against. It's best if you set up the tournament and walk away, you can analyze logs later, results are printed at the end.
## Syntax
`sim -d <deck1[.dck]> ... <deckX[.dck]> -D [path] -n [N] -f [F] -t [T] -p [P] -q`
In linux and mac, command line arguments are not currently passed through the sh script, please call `java -jar` manually, instead of the exe.
- `sim` - "Simulation Mode" forces Forge to not start the GUI and automatically runs the AI matches in command line. Enables all other switches for simulation mode.
- `-d <deck1[.dck]> ... <deckX[.dck]>` - Space separated list of deck files, in `-f` game type path. (For example; If `-f` is set to Commander, decks from `<userdata>/decks/commander/` will be searched. If `-f` is not set then default is `<userdata>/decks/constructed/`.) Names must use quote marks when they contain spaces.
- `deck1.dck` - Literal deck file name, when the value has ".dck" extension.
- `deck` - A meta deck name of a deck file.
- `-D [path]` - [path] is absolute directory path to load decks from. (Overrides path for `-d`.)
- `-n [N]` - [N] number of games, just flat test the AI multiple times. Default is 1.
- `-m [M]` - [M] number of matches, best of [M] matches. (Overrides -n) Recommended 1, 3, or 5. Default is 1.
- `-f [F]` - Runs [F] format of game. Default is "constructed" (other options may not work, list extracted from code)
- `Commander`
- `Oathbreaker`
- `TinyLeaders`
- `Brawl`
- `MomirBasic`
- `Vanguard`
- `MoJhoSto`
- `-t [T]` - for Tournament Mode, [T] for type of tournament.
- `Bracket` - See wikipedia for [Bracket Tournament](https://en.wikipedia.org/wiki/Bracket_(tournament))
- `RoundRobin` - See wikipedia for [Round Robin Tournaments](https://en.wikipedia.org/wiki/Round-robin_tournament)
- `Swiss` - See wikipedia for [Swiss Pairing Tournaments](https://en.wikipedia.org/wiki/Swiss-system_tournament)
- `-p [P]` - [P] number of players paired, only used in tournament mode. Default is 2.
- `-q` - Quiet Mode, only prints the result not the entire log.
## Examples
In linux and macos you must run forge by evoking java and calling the jar, currently command line parameters are not passed through the script. The forge jar filename is truncated in these examples from `forge-whatever-version-youre-on.jar` to `forge.jar`.
In Windows, if you use the EXE file as described below, the simulation runs in the background and output is sent to the forge log file only. If you want to have output to the console, please use the `java -jar` evocation of forge.
To simulate a basic three games of two decks (deck1 and deck2 must be meta deck names of decks in `<userdata>\decks\constructed\`):
- Windows/Linux/MacOS: `java -jar forge.jar sim -d deck1 deck2 -n 3`
- Windows: `.\forge.exe sim -d deck1 deck2 -n 3`
To simulate a single 3-player Commander game (deck1, deck2, and deck3 must be meta deck names of decks in `<userdata>\decks\commander\`):
- Windows/Linux/MacOS: `java -jar forge.jar sim -d deck1 deck2 deck3 -f commander`
- Windows: `.\forge.exe sim -d deck1 deck2 deck3 -f commander`
To simulate a round robin tournament; best of three, with all decks in a directory:
- Windows/Linux/MacOS: `java -jar forge.jar sim -D /path/to/DecksFolder/ -m 3 -t RoundRobin`
- Windows: `.\forge.exe sim -D C:\DecksFolder\ -m 3 -t RoundRobin`
To simulate a swiss tournament; best of three, all decks in a directory, 3 player pairings:
- Windows/Linux/MacOS: `java -jar forge.jar sim -D /path/to/DecksFolder/ -m 3 -t Swiss -p 3`
- Windows: `.\forge.exe sim -D C:\DecksFolder\ -m 3 -t Swiss -p 3`
***
Each game ends with an announcement of the winner, and the current status of the match.

12
docs/Adventure-Mode.md Normal file
View File

@@ -0,0 +1,12 @@
# What is Adventure Mode?
Adventure mode is a work-in-progress game mode where you explore the ever-changing landscape of Shandalar, duel creatures to earn gold and new cards to battle the various bosses. You can visit towns to buy equipment and cards, and crawl through dungeons to find artifacts and loot to help you on your journey. Adventure mode is an awesome reimagining of the original "Shandalar" 1997 PC Game in Forge, even though the scope of adventure is much broader and we don't constrain ourselves to the lore of the plane of Shandalar. You can play Shandalar on Desktop (Linux, Windows, IOS) or on Android devices.
# How to run?
1. Step 1: Download the latest version of Forge https://downloads.cardforge.org/dailysnapshots/
2. Step 2: Make sure you have the required version of the JDK (https://www.oracle.com/be/java/technologies/downloads/)
3. Step 3: Launch the adventure mode from the "adventure.exe" file included in the forge version (on android, the adventure version should be embedded into the main Forge program)
4. Step 4: In order to have pictures show up make sure you enable "automatically download missing card images" in the settings. This should automatically download the picture of the card as you encounter them in game.

109
docs/Card-Images.md Normal file
View File

@@ -0,0 +1,109 @@
# About
Card images are assets used to represent the real cards in game. You DO NOT need images to play forge, however representing real cards is a nice ability forge provides. These images can be any image set you like, or custom images too.
Primarily there are two types of images you'll care about; cards, and tokens.
**Cards** - are the primary card image files, and can be generic (as all cards of the same name have the same rules) or per set since there may be different art work in different editions. Typically these are scans of the original cards and are provided by forge's FTP, or scryfall. You can customize a full generic set, or any edition if you desire... (you could for example, blur every card image and play a literal "blind" or "farsighted" game.)
**Tokens** - are the images for the cards replacing a generic "1/1 zombie" for example. These are less frequently updated, and are typically the bulk of what is missing when doing an audit. However, these are probably where the more true "custom" replacements are available, with either custom artwork, or modified of other existing.
# Downloading
Due to charges in Forges hosting and scryfall terms you can no longer predownload card images. Turn on auto download in forge to download card images when first viewed.
## In Forge Auto Download:
**Download Missing Images - Setting**
- This will download the images from the sources as the game requests the image in situ.
- This can be useful if you don't want to have copies of every card... You can do small pre-caching by loading your decks in the deck editor prior to playing to download just those images.
## Bulk Download Sites: (Not in game)
- [http://download.austeregrim.net](http://download.austeregrim.net)
- Note from user AustereGrim;
> I provide my site for free for bulk downloading the entire image catalog. So you don't need to give those spam sites more advertising spots. If the server is loaded bandwidth is shared, right now it's not heavily used so please feel free to download the 4+gb zips, or the individual zips if you need sets. They are the images Kev has uploaded to my site, and the Zips are updated nightly automatically.
**(I'm not gatekeeping, please if you have a private location for bulk downloads or for alternate or custom arts, you can update this wiki too or let us know in the discord. I'll be happy to update the wiki page with additional sources.)**
# Storage
Card images are stored in `pics/cards`, and tokens in `pics/tokens`, in the Cache folder for forge:
- **Windows** - `C:\Users\<username>\appdata\local\forge\Cache\`
- You'll need to enable hidden folders.
- **Android 11+** - `Internal Storage/Android/obb/forge.app/Forge/cache/`
- *_NOTE: You need a third party File Manager to access the obb folder and allow storage access permission_*
- **Android 8 to 10** - `Internal Storage/Forge/cache/`
- **Linux** - `/home/<username>/.cache/forge/`
- **MacOS** - `/Users/<username>/Library/caches/forge/`
- Use `Command + Shift + .` to show hidden files.
# Subfolders
If you don't care about the edition's version of cards, images can be stored in the root directory of the cards folder.
`/cache/pics/cards/`
If you want the edition's versions of the cards, they need to go under the edition's code subfolder.
`/cache/pics/cards/AFR` for example for Adventures in the Forgotten Realms.
# File Naming
**File Names:**
- Cards file names follow a simple principle: `Card Name#.border.ext`
- `Card Name` - Card Name with spaces.
- `#` - Alternate Art number; if more than one art exists for the card.
- `border` - Border Type; fullborder, crop. (I don't know all of them.)
- `ext` - Extension, jpg or png are supported.
**Alternate images:**
Alternate images are defined as cards with the same name in the set's edition file, if the edition file does not have the alternate listed forge will not see the alternate there!
**Standard Alternate Arts:**
So for example the AFR set (as most sets) shows these 4 versions of swamp;
```
270 L Swamp @Piotr Dura
271 L Swamp @Sarah Finnigan
272 L Swamp @Titus Lunter
273 L Swamp @Adam Paquette
```
The file naming would be represented by a number after the name:
```
Swamp1.fullborder.jpg
Swamp2.fullborder.jpg
Swamp3.fullborder.jpg
Swamp4.fullborder.jpg
```
**Additional Alternate Arts:**
They may also be listed separately as "extended arts", "showcase", or "borderless" in the same editions file:
```
[cards]
90 U Black Dragon @Mark Zug
```
and
```
[borderless]
291 U Black Dragon @Jason A. Engle
```
Where the files are:
```
black dragon1.fullborder.jpg
black dragon2.fullborder.jpg
```
**Forcing an Alternate:**
Renaming and creating a second of an existing card **will not work**, for example creating two "Burning hands" which does not have alternate art;
```
burning hands1.fullborder.jpg
burning hands2.fullborder.jpg
```
Forge will not see either of those, and will probably download the missing `burning hands.fullborder.jpg` for you. Similarly adding a 3rd black dragon `black dragon3.fullborder.jpg` will **not** work either.

View File

@@ -0,0 +1,900 @@
AbilityFactory parses differently from the Keyword parser. Your Ability line will look more like this:
`A:{AB/SP/DB/ST}$ <AFSubclass> | {Necessary$ Parameters} | {Separated$ By} | {Pipes$ Here} | [Optional$ Values]`
In most cases, each AF subclass implements both the Spell and Ability.
Much of the code is shared, so creating the data object will look very similar.
- **AB** is for Activated Abilities
- **SP** is for Spell
- **DB** is for Drawback and many abilities that are subsidiary to other things, like replacements. They are only used to chain AFs together, and will never be the root AF
- **ST** is for Static, this gets used in case the API should resolve without using the stack<br> (e.g. the unique *Circling Vultures* special action is directly implemented in the script this way)
>*NOTE:*
> - these factories are refactored from time to time (often to adapt to new sets), so while some entries could be slightly outdated, the base information should still be correct
> - a few factories also have _*All_ variants, these are slowly being phased out
> - some parameters are only added for very exotic cards, these won't be included here to keep the focus on understanding the general concepts of scripting
> - when in doubt you can always cross check with the [available APIs](https://github.com/Card-Forge/forge/tree/master/forge-game/src/main/java/forge/game/ability/effects) code
# Common Parameters
## Cost / UnlessCost
`Cost$ <AbilityCost>` is the appropriate way to set the cost of the ability. Currently for spells, any additional costs including the original Mana cost need to appear in the Cost parameter in the AbilityFactory. For each card that uses it, the order in which the cost is paid will always be the same.
Secondary abilities such as the DB executed by triggers or replacements (usually) don't need costs. (This is one reason to use DB over AB in these cases.)
Read more about it in [Costs](Costs)
## ValidTgts / Defined
Most effects need to know (at least implicitly) which players or objects they're trying to affect. There are two different ways for that:
- `ValidTgts` will need to be used for abilities that target
- if your ability instead describes on what it's applied use `Defined`
Read more about it in [Affected / Targets](Targeting)
## Restrictions / Conditions
Restrictions limit when abilities can be put on the stack and Conditions apply during resolving. Common examples are Putrid Leech's only activate this once per turn or different cards that can activate from Zones like the Hand or the Graveyard.
Read more about it in [Restriction](Restrictions)
## SpellDescription
SpellDescription is how the text of the ability will display on the card and in the option dialog for cards with multiple abilities.
The SpellDescription for secondary abilities (both AB and DB) is now displayed when (and if) the ability prompts for user input in the prompt pane so it is useful to put some nice text there.
## StackDescription
*(Optional)* StackDescription is the description the ability will have on the stack. This is automatically generated by the effect, but may be overridden using this parameter. This is sometimes needed with complex effects, when the generated text can't handle some details. Properties of the spell can be accessed like this: {c:Targeted}. You can reuse the spell text by just putting `SpellDescription` or `None` to leave it empty.
## Remember*
Remembering is often needed when a card becomes a new object, which is then further affected by the ability. Typical example: [Flicker](https://github.com/Card-Forge/forge/blob/master/forge-gui/res/cardsfolder/f/flicker.txt)<br>
Because cards keep their remembered parts when changing zones manual [cleanup](#Cleanup) is usually required.
## AI params
`IsCurse$ True` - For effects that are normally treated positive e.g. Pump
`AITgts$ BetterThanEvalRating.130`
# Factories (in Alphabetical Order)
## AlterLife
AlterLife is for Abilities that Alter a player's life total.
### GainLife
Have a player gain the specified amount of life.
`A:AB$ GainLife | Cost$ T | LifeAmount$ 1 | SpellDescription$ You gain 1 life.`
LifeAmount$ is required. This is how much life you will gain.
Defined is optional, if it appears the defined player(s) gain life.
Target is optional, if it appears and Defined doesn't then targeted player(s) gain life.
### LoseLife
Have a player lose the specified amount of life.
`A:AB$ LoseLife | Cost$ Sac<1/CARDNAME> | ValidTgts$ Player | TgtPrompt$ Target a player to lose a life | LifeAmount$ 1 | SpellDescription$ Target player loses 1 life.`
`A:SP$ LoseLife | Cost$ 2 B | Defined$ Opponent | LifeAmount$ 2 | SpellDescription$ Each opponent loses 2 life.`
LifeAmount$ is required. This is how much life will be lost.
Target is optional. If Target doesn't appear then Defined will be used.
Remember, if Defined is missing, the default for Players is "You"
Part of resolving sets the **SVar AFLifeLost** to the amount of life lost by all players.
### SetLife
SetLife sets one or both player's life total to a specified value (i.e.
"your life total becomes 20" or "Target player's life total is equal to
the number of cards in your graveyard").
`A:SP$ SetLife | Cost$ 7 W W | ValidTgts$ Player | TgtPrompt$ Select target player | LifeAmount$ 20 | SpellDescription$ Target player's life total becomes 20.`
Parameters:
LifeAmount (required) - the value to set the life total(s) to
Defined is optional. If it exists, it will be used. Target is optional.
If it exists and defined doesn't it will be used. Default player is "You".
### ExchangeLife
ExchangeLife switches the Life total of two players.
`A:AB$ ExchangeLife | Cost$ 6 T | ValidTgts$ Player | TargetMin$ 2 | TargetMax$ 2 | TgtPrompt$ Select target player | SpellDescription$ Two target players exchange life totals.`
One of Defined or Target is required, since there needs to be two
Players exchanging life If Defined it will be used. If Target exists and
defined doesn't it will be used.
If there aren't two determined players by the SA, the activating player is added as the second player.
## Animate
Animate handles animation effects like "This card becomes a 5/5
green creature with flying until end of turn." It is designed to handle
color changing, type changing, P/T setting, and granting/removing abilities.
`A:SP$Animate | Cost$ G | ValidTgts$ Land | TgtPrompt$ Select target land | Power$ 3 | Toughness$ 3 | Types$ Creature | SpellDescription$ Until end of turn, target land becomes a 3/3 creature that's still a land.`
`A:AB$Animate | Cost$ 1 B | Defined$ Self | Power$ 1 | Toughness$ 1 | Types$ Creature,Skeleton | Colors$ Black | Abilities$ ABRegen | SpellDescription$ CARDNAME becomes a 1/1 black Skeleton creature with "B: Regenerate this creature" until end of turn. It's still a land. (If it regenerates, the next time it would be destroyed this turn, it isn't. Instead tap it, remove all damage from it, and remove it from combat.)`
`SVar:ABRegen:AB$Regenerate | Cost$ B | SpellDescription$ Regenerate CARDNAME.`
`A:AB$Animate | Cost$ 2 R G | Defined$ Self | Power$ 3 | Toughness$ 3 | Types$ Creature,Elemental | Colors$ Red,Green | Triggers$ TrigAttack | SpellDescription$ Until end of turn, CARDNAME becomes a 3/3 red and green Elemental creature with "Whenever this creature attacks, put a +1/+1 counter on it." It's still a land.`
`SVar:TrigAttack:Mode$ Attacks | ValidCard$ Creature.Self | Execute$ TrigPutCounter | TriggerDescription$ Whenever CARDNAME attacks, put a +1/+1 counter on it.`
`SVar:TrigPutCounter:AB$PutCounter | Cost$ 0 | Defined$ Self | CounterType$ P1P1 | CounterNum$ 1`
Parameters:
- Power (required) - the power to assign to the animated card
- Toughness (required) - the toughness to assign to the animated card
- Types (optional) - the additional types to give the animated card;
comma delimited
- OverwriteTypes (optional) - set to True if the animated being should
have these types **instead** as opposed to **in addition to**
- RemoveTypes (optional) - a list of types to Remove from the animated
card
- ChosenType (optional) - overrides types before it and just will add
the ChosenType
- Keywords (optional) - a " & " delimited list of keywords to give the
animated being (just like AB$Pump)
- HiddenKeywords (optional) - a " & " delimited list of hidden
keywords to give the animated being (just like AB$Pump)
- RemoveKeywords (optional) - a " & " delimited list of keywords to
remove from the animated being (just like AB$Debuff)
- Colors (optional) - a comma-delimited list of Colors to give to the
animated being (capitalized and spelled out) (ChosenColor accepted)
- Abilities (optional) - a comma-delimited list of SVar names which
contain abilities that should be granted to the animated being
- OverwriteAbilities - Remove Abilities from animated being
- Triggers (optional) - a comma-delimited list of SVar names which
contain triggers that should be granted to the animated being
- OverwriteTriggers - Remove/suppress triggers from animated being
- staticAbilities (optional) - a comma-delimited list of SVar names
which contain static abilities that should be granted to the
animated being
- OverwriteStatics- Remove static abilities from animated being
- OverwriteReplacements - Remove replacement effects from animated
being
- RemoveAllAbilities - Remove all Abilities, Triggers, Statics, and
Replacement effects
- sVars(optional) - a comma-delimited list of SVars that should be
granted to the animated being
- Duration (Default is end of turn)
- Permanent
- UntilEndOfCombat - if the effect should last only until End of Combat instead of End of Turn
- UntilHostLeavesPlay - if the effect should last as long as the host is still in play
- UntilYourNextUpkeep
- UntilControllerNextUntap
- UntilYourNextTurn
Target is optional, will be used if possible. Defined is optional, will be used if no Targets (Self by default)
## Attach
Attach is being used directly only for Auras, primarily for Aura Spells, but also for Auras entering the battlefield by some effect.
`AB$ Attach | Cost$ R R | ValidTgts$ Creature | AILogic$ Pump`
Parameters:
- Object (optional) - This is the Object that will be Attached
(generally the Source Card for Auras)
- AILogic - AI Logic tells the AI which base AI code it should use for
Attaching
- GainControl - Gains Control of the Attached Permanent (Control
Magic)
- Curse - A Generic Curse the AI has a handful of checks to see
what the most appropriate Target is.
- Pump - A Generic Pump. The AI has a handful of checks to see
what the most appropriate Target is.
- ChangeType - For Attachments that change types. Evil Presence is
a good example. This logic should be expanded.
- KeepTapped - For Attachments that keep a Permanent tapped. The
AI will also check for a few things like Vigilance, and another
KeepTapped Aura. Paralyzing Grasp is a good example.
Attach separates the actually granting of abilities from the attaching to permanents to streamline how things work.
## BecomeMonarch
## Bond
Soulbonding two creatures. Only used internally by the engine.
## Branch
Sometimes, an ability might do certain things when a specific condition is true, and other things if not. This can be implemented by using `Branch`.
The branch evaluates the SVar specified by the property `BranchConditionSVar`, using the comparison defined with `BranchConditionSVarCompare` (such as `GTY`, `LT1`, etc). Depending on whether the condition evaluated to true or false, the subability defined by `TrueSubAbility` or `FalseSubAbility` is executed.
The example below is for "Composer of Spring", which allows either a "land" or a "land or creature" to be put on the battlefield, depending on the number of enchantments in play under your control.
```
SVar:TrigBranch:DB$ Branch | BranchConditionSVar$ X | BranchConditionSVarCompare$ GE6 | TrueSubAbility$ PutLandCreature | FalseSubAbility$ PutLand
SVar:PutLand:DB$ ChangeZone | Origin$ Hand | Destination$ Battlefield | Tapped$ True | ChangeType$ Land.YouOwn
SVar:PutLandCreature:DB$ ChangeZone | Origin$ Hand | Destination$ Battlefield | Tapped$ True | ChangeType$ Creature.YouOwn,Land.YouOwn
SVar:X:Count$Valid Enchantment.YouCtrl
```
## Charm
This allows cards that have a mode to be chosen to occur after a trigger.
Parameters
- CharmNum - Number of Modes to Choose
- Choices - A Comma delimited list of SVars containing the Modes
## Choose*
These can be used to chain effects together. However for common cases many effects already support this directly, e.g. `PutCounter | Choices$``.<br>
Besides making the script shorter using such shortcuts usually also helps the AI making better use of the effect.
### ChooseType
This can be used when you are asked to choose a card type or creature type.
- Type - Required - Can be Card or Creature
- InvalidTypes - Optional - Use to specify any type that cannot be chosen (ex: "Choose any creature type except Wall")
The Defined is for target players.
## Clash
This AF handles clashing. It takes two special parameters: WinSubAbility and
OtherwiseSubAbility. They are both optional and work the same way,
namely that it contains the name of an SVar that in turn contains a
drawback to be executed. The example below is for Release the Ants.
`A:SP$ DealDamage | Cost$ 1 R | Tgt$ TgtCP | NumDmg$ 1 | SubAbility$ DBClash | SpellDescription$ Release the Ants deals 1 damage to target creature or player. Clash with an opponent. If you win, return CARDNAME to its owner's hand.`
`SVar:DBClash:DB$ Clash | WinSubAbility$ DBReturn`
`SVar:DBReturn:DB$ ChangeZone | Defined$ Self | Origin$ Stack | Destination$ Hand`
## Cleanup
A non-functional, maintenance AF used for Cleaning up certain Variables before a Spell finishes Resolving.
Parameters
- ClearRemembered$ (optional) Set to True to clear this card's
remembered list. Generally useful for Cards that Remember a card, do
something to it, then need to forget it once it's done.
- ClearImprinted$ (optional) Set to True to clear the list of
imprinted cards.
- ClearChosenX$ (optional) Set to True to clear the chosen X value.
- ClearTriggered$ (optional) Set to True to clear any delayed triggers
produced by this card.
- ClearCoinFlips$ (optional) Set to True to clear the remembered coin
flip result.
- ClearChosenCard$ (optional) Set to True to clear the chosen cards.
- ForgetDefined$ (optional) If present, remove the specified cards
from this card's remembered list.
## Control
### GainControl
Example: Act of Aggression
`A:SP$ GainControl | Cost$ 3 PR PR | ValidTgts$ Creature.OppCtrl | TgtPrompt$ Select target creature an opponent controls. | LoseControl$ EOT | Untap$ True | AddKWs$ Haste | SpellDescription$ Gain control of target creature an opponent controls until end of turn. Untap that creature. It gains haste until end of turn.`
Parameters:
- NewController(Targeted player, if there is no target player, the
default is the ActivatingPlayer)
- AllValid(all valid types, no targets)
- LoseControl(LeavesPlay, Untap, LoseControl, EOT(end of turn))
### ControlExchange
### ControlSpell
## Copy*
### CopyPermanent
Copies a permanent on the battlefield.
Parameters:
- NumCopies - optional - the number of copies to put onto the
battlefield. Supports SVar:X:????.
- Keywords - optional - a list of keywords to add to the copies
- AtEOT - optional
- Sacrifice - set to this is copy should be sacrificed at End of
Turn
- Exile - set to this is copy should be exiled at End of Turn
### CopySpellAbility
Copies a spell on the stack (Twincast, etc.).
## Counter
Countering Spells or Abilities.
`A:SP$ Counter | Cost$ 1 U | TargetType$ Spell | TgtPrompt$ Select target spell | ValidTgts$ Card | UnlessCost$ 3 | SpellDescription$ Counter target spell unless its controller pays 3.`
`A:SP$ Counter | Cost$ U | TgtPrompt$ Select target Activated or Triggered Ability | ValidTgts$ Card | TargetType$ Activated,Triggered | SpellDescription$ Counter target activated or triggered ability.`
`A:SP$ Counter | Cost$ G | TargetType$ Spell | ValidTgts$ Instant,Aura | TargetValidTargeting$ Permanent.YouCtrl | SpellDescription$ Counter target instant or Aura spell that targets a permanent you control. `
Parameters
- TargetType - Can be Spell,Activated,Triggered. If more than one,
just put a comma in between.
- ValidTgts - a "valid" expression for types of source card (if you
don't know what it is it's just "Card")
- TargetValidTargeting- a "valid" expression for targets of this
spell's target
- Destination - send countered spell to: (only applies to Spells; ignored for Abilities)
- Graveyard (Default)
- Exile
- TopDeck
- Hand
- BottomDeck
- Shuffle
## Counters*
Factories to handle counters on cards.
### Poison
Poison gives a player the specified number of poison counters.
`A:AB$ Poison | Cost$ B T | ValidTgts$ Player | TgtPrompt$ Select target player | Num$ 2 | SpellDescription$ Target player gets 2 poison counters.`
Parameters:
- Num (required) - the number of poison counters to give
Target is optional and used if available. Defined is optional and used if no Target (defaults to "You").
### PutCounter
Put any type of counter on a game object.
`A:AB$ PutCounter | Cost$ T | CounterType$ CHARGE | CounterNum$1 | SpellDescription$ Put a charge counter on CARDNAME.`
`A:SP$ PutCounter | Cost$ G | Tgt$ TgtC | CounterType$ P1P1 | CounterNum$ 1 | SpellDescription$ Put a charge counter on CARDNAME.`
Target is optional. If no Target is provided, the permanent will put counters on itself.
- CounterType (required) specifies the type of counter and should
appear in all caps. It should be one of the values in the Counters
enum.
- CounterNum (required) specifies how many counters will be put on
the chosen card.
### PutCounterAll
Put any type of counter on all valid cards.
- CounterType (required) specifies the type of counter and should
appear in all caps. It should be one of the values in the Counters
enum.
- CounterNum (required) specifies how many counters will be put on
the chosen cards.
- ValidCards (required) specifies the cards to add counters to.
### RemoveCounter
Remove any type of counter from a card.
Target is optional. If no Target is provided, the permanent will remove
counters from itself.
- CounterType (required) specifies the type of counter and should
appear in all caps. It should be one of the values in the Counters
enum.
- CounterNum (required) specifies how many counters will be removed
from the chosen card.
- UpTo is optional. If an effect states you may remove "up to X
counters", set this to True.
### RemoveCounterAll
Remove any type of counter from all valid cards.
- CounterType$ (required) specifies the type of counter and should
appear in all caps. It should be one of the values in the Counters
enum.
- CounterNum$ (required) specifies how many counters will be removed
from the chosen cards.
- ValidCards$ (required) specifies the card to remove counters from.
### Proliferate
No own parameters.
### MoveCounters
Used for cards that Move Counters on Resolution, requiring the Host card
to have Counters for the Move to occur.
Parameters
- Source - The Source of the Moving Counters
- Defined - The Destination of the Moving Counters
- CounterType - The type of counter to move.
- CounterNum - The number of counters to move.
## Damage
### DealDamage
Deal damage to a specified player or permanent.
`A:AB$ DealDamage | Cost$ T | Tgt$ TgtCP | NumDmg$ 1 | SpellDescription$ CARDNAME deals 1 damage to target creature or player.`
NumDmg is required. This is the amount of damage dealt.
### EachDamage
## Debuff
Parameters
- Keywords
- Duration
An AbilityFactory for Removing Keywords, either temporarily or for longer durations.
## Destroy
These APIs handles destruction of cards on the battlefield.
`A:SP$Destroy | Cost$ 1 W W | ValidTgts$ Artifact,Enchantment | TgtPrompt$ Select target artifact or enchantment | SpellDescription$ Destroy target artifact or enchantment.`
## Effect
Effect is an oddball of the AF family. Where usually AFs have similarities to each other to help with AI use, Effect doesn't fall under that jurisdiction. In general, an effect is some type of SA that
lasts longer than its resolution.
A good example is High Tide. For the rest of the turn, High Tide makes
all Islands produce an extra mana. It doesn't matter if the Island was
in play, if it turned into an Island after High Tide was cast, any of that.
`A:SP$ Effect | Cost$ U | Name$ High Tide Effect | Triggers$ IslandTrigger | SVars$ TrigMana | SpellDescription$ Until end of turn, whenever a player taps an Island for mana, that player adds U to his or her mana pool (in addition to the mana the land produces).`
`SVar:IslandTrigger:Mode$ TapsForMana | ValidCard$ Island | Execute$ TrigMana | TriggerDescription$ Whenever a player taps an Island for mana, that player adds U to his or her mana pool (in addition to the mana the land produces).`
`SVar:TrigMana:AB$Mana | Cost$ 0 | Produced$ U | Amount$ 1`
Effect is most similar to Token as it creates a pseudo-permanent, except
Effect creates in the command zone rather than the battlefield. It stays
active there for a set Duration.
Parameters
- Abilities,Triggers,SVars are comma separated lists which contain
SVars that point to the appropriate type that the Effect will gain.
- Duration is how long the Effect lasts. Right now, most effects will
last Until End of Turn. In the future, they may have other
conditions.
Duration$ Permanent for effects that have no specific Duration.
- Stackable$ False - Most Effects are assumed to be Stackable. By
setting the Stackable Flag to False, the AI will know having a
second one in play is useless, so will save it's Resource for
something else.
- Image - a file\_name\_without\_extension (image needs to reside in
the tokens directory)
## Explore
## Fight
## Fog
Fog is an ability based on the original Fog spell. "Prevent all combat
damage that would be dealt this turn." While this could be done with an
effect, the specialized nature of the AI gives it its own AF.
## Game outcome
### GameDraw
### GameLoss
### GameWin
### RestartGame
Used in the script of *Karn Liberated*
## Goad
## Investigate
## Mana
For lands or other permanent to produce mana.
`A:AB$ Mana | Cost$ T | Produced$ <ManaType> | SpellDescription$ Add W to your mana pool.`
In this example ManaType would be W.
## Manifest
## PermanentState
API for things that alter a permanent's state.
### Phases
### SetState
Changing a cards State. This is mostly for Flip Cards or the Transform mechanic.
### Tap
`A:AB$ Tap | Cost$ R | ValidTgts$ Wall | TgtPrompt$ Select target wall | SpellDescription$ Tap target wall.`
### TapOrUntap
### Untap
`A:AB$ Untap | Cost$ G | ActivationLimit$ 1| SpellDescription$ Untap CARDNAME. Activate this ability only once each turn.`
`A:SP$ Untap | Cost$ W | ValidTgts$ Permanent | TgtPrompt$ Select target permanent | SpellDescription$ Untap target permanent.`
Target is optional. If not provided, will untap the permanent with this ability.
## Play
Playing a card or cards as part of SA. The player may have to make a
choice about which card to play if there are more choices than the
number of cards to play.
Sunbird's Invocation uses many of the parameters.
Amount - How many cards can be played (a non-negative integer or "All").
Valid - Selection criteria for valid cards from the zone to cast.
ValidSA - Applied after Valid, this will filter based on all spells of the cards.
ValidZone - The zone to look in to determine the valid cards.
ShowCards - Other cards in the zone to show when selecting valid cards.
Optional - Casting the card is optional.
RememberPlayed - Remember the card played.
ForgetRemembered - Remove all remembered cards from the source (but only
if a card was successfully played)
ForgetTargetRemembered - Remove the played card from remembered cards
(but only if it was successfully played)
WithoutManaCost - The card can be cast without mana payment.
## PreventDamage
AF damage prevention effects.
- A:SP$ PreventDamage | Cost$ W | ValidTgts$ Creature | Amount$ 3
| TgtPrompt$ Select target creature | SpellDescription$ Prevent
the next 3 damage that would be dealt to target creature this
turn.
## Protection
Protection grants protection from colors or cards types, or creature
types. Anything that has "Protection from ..."
Gains - required - the thing to gain protection from (green, artifacts,
Demons, etc.) or "Choice" if you can choose one of...
Choices - optional
- if Gains$ Choice then this is a comma-delimited list of choices
## Pump
This factory handles pumping creatures power/toughness or granting abilities to permanents (usually creatures).
- A:AB$ Pump | Cost$ R | NumAtt$ +1 | SpellDescription$ CARDNAME
gets +1/+0 until end of turn.
- A:SP$ Pump | Cost$ 1 U | ValidTgts$ Creature | KW$ Shroud|
SpellDescription$ Target creature gains shroud until end of
turn. | TgtPrompt$ Select target creature.
Target is optional. If it's not provided, the activating permanent will be pumped.
NumAtt$ is optional, will pump Power.
NumDef$ is optional, will pump Toughness.
KW$ is optional, will give temporary keywords.
## Regenerate
Regenerate is similar to abilities like Pump. But for creating
Regeneration shields.
- A:AB$ Regenerate | Cost$ B | SpellDescription$ Regenerate
CARDNAME
- A:SP$ Regenerate | Cost$ W | ValidTgts$ Creature | TgtPrompt$
Select target creature | SpellDescription$ Regenerate target
creature.
Target is optional. If not provided, will regenerate the permanent with this ability.
## Repeat
Repeat the specified ability.
### Repeat
`A:SP$ Repeat | Cost$ 3 B B | RepeatSubAbility$ DBDig | RepeatOptional$ True`
- MaxRepeat - optional - the maxium times to repeat, execute repeat
ability at least once
- RepeatSubAbility - required - setup subability to repeat
- RepeatOptional - optional - you make the choice whether to repeat
the process
- RepeatPresent, RepeatCompare, RepeatDefined, RepeatCheckSVar,
RepeatSVarCompare - optional - condition check
### RepeatEach
- RepeatSubAbility - required - to set up repeat subability
- RepeatCards - to repeat for each valid card (zone: present zone of
the valid repeat cards, default: battlefield)
- DefinedCards
- RepeatPlayers - to repeat for each valid player
- RepeatCounters - to repeat for each valid counters
## Reveal
### RevealHand
Look at a player's hand.
Target or Defined is required.
`A:AB$ RevealHand | Cost$ T | ValidTgts$ Player | TgtPrompt$ Select target player | SpellDescription$ Look at target player's hand.`
### Reveal
`A:AB$ Reveal | Cost$ 2 U T | Defined$ You | RevealValid$ Card.Blue | AnyNumber$ True | RememberRevealed$ True`
Parameters:
- RevealValid: to limit the valid cards.
- AnyNumber
- Random
- RememberRevealed: to remember the cards revealed
### PeekAndReveal
This AF is very similar to things that Dig can do, but handle a much
simpler form, with less complex coding underneath. Similar to how
RearrangeTopOfLibrary could be handled with Dig.
Primarily used with cards that allow you to Peek at the top card of your
library, and allow you to reveal it if it's of a certain type. The
Kinship cards fit this bill perfectly, so they are used to simplify the
complex popups that would be required if using multiple Dig
SubAbilities.
RevealOptional - Whether or not the Reveal is optional.
RememberRevealed - Whether to remember the revealed cards (after
filtering by Valid)
RememberPeeked - Whether to remember the peeked cards (only if they are
not revealed\!)
RevealValid - defaults to Card, but allows you to set a specific
ValidType if you can only have certain things
PeekAmount - defaults to 1, but allows you to peek at multiple cards if
possible
## RollDice
## Sacrifice
Usually you choose a player and that player has to sacrifice something
`A:SP$ Sacrifice | Cost$ 1 B | ValidTgts$ Player | SacValid$ Creature | SacMessage$ Creature | Amount$ 2 | SpellDescription$ Target player sacrifices a creature.`
Destroy$ True - An optional parameter for destroying permanents target
player chooses (eg: Burning of Xinye, or Imperial Edict).
`A:SP$ Sacrifice | Cost$ 1 B | ValidTgts$ Opponent | SacValid$ Creature | SacMessage$ Creature | Destroy$ True | SpellDescription$ Target opponent chooses a creature he or she controls. Destroy it.`
## Scry
`A:AB$ Scry | Cost$ 1 T | ScryNum$ 2`
## StoreSVar
## Token
Token simply lets you create tokens of any type.
`A:SP$ Token | Cost$ 3 W U | TokenImage$ W 1 1 Bird Flying | TokenAmount$ X | TokenName$ Bird | TokenTypes$ Creature,Bird | TokenOwner$ You | TokenColors$ Blue | TokenPower$ 1 | TokenToughness$ 1 | TokenKeywords$ Flying`
This ability factory does not take a target. All the parameters are
mandatory except for TokenKeywords. If you provide a non-integer for
TokenAmount, TokenPower or TokenToughness the AF will attempt to look for
an SVar of that name and interpret it's contents as a Count$ line. Worth
noting is that TokenTypes and TokenColors are simple commaseparated
lists while TokenKeywords is a list where the items are separated by
"\<\>". If TokenImage is not provided, the factory will attempt to
construct a filename on it's own. TokenOwner can use Defined-like
parameters, such as "You" "Opponent" or the new Triggered-Variables.
You can also use the parameters TokenAbilities$, TokenTriggers$ and
TokenSVars$ to give the created tokens any number of either. For
example, here's how Growth Spasm creates an Eldrazi Spawn token complete
with ability.
SVar:DBToken:DB$Token | TokenAmount$ 1 | TokenName$ Eldrazi Spawn | TokenTypes$ Creature,Eldrazi,Spawn | TokenOwner$ You | TokenColors$ Colorless | TokenPower$ 0 | TokenToughness$ 1 | TokenAbilities$ ABMana SVar:ABMana:AB$Mana | Cost$ Sac<1/CARDNAME> | Produced$ 1 | Amount$ 1 | SpellDescription$ Add 1 to your mana pool.
As another example, here's Mitotic Slimes' use of TokenTriggers$:
T:Mode$ ChangesZone | Origin$ Battlefield | Destination$ Graveyard | ValidCard$ Card.Self | Execute$ TrigTokenSenior | TriggerDescription$ When CARDNAME is put into a graveyard from the battlefield, put two 2/2 green Ooze creature tokens onto the battlefield. They have "When this creature is put into a graveyard, put two 1/1 green Ooze creature tokens onto the battlefield."
SVar:TrigTokenSenior:AB$ Token | Cost$ 0 | TokenImage$ g 2 2 ooze | TokenName$ Ooze | TokenTypes$ Creature,Ooze | TokenColors$ Green | TokenOwner$ You | TokenPower$ 2 | TokenToughness$ 2 | TokenAmount$ 2 | TokenTriggers$ TriggerJunior | TokenSVars$ TrigTokenJunior
SVar:TriggerJunior:Mode$ ChangesZone | Origin$ Battlefield | Destination$ Graveyard | ValidCard$ Card.Self | Execute$ TrigTokenJunior | TriggerDescription$ When this creature is put into a graveyard, put two 1/1 green Ooze creature tokens onto the battlefield. SVar:TrigTokenJunior:AB$Token | Cost$ 0 | TokenImage$ g 1 1 ooze | TokenName$ Ooze | TokenTypes$ Creature,Ooze | TokenColors$ Green | TokenOwner$ You | TokenPower$ 1 | TokenToughness$ 1 | TokenAmount$ 2
## Trigger
If possible split the SpellDescription$ of the the effect so the part for the trigger can become the StackDescription directly.
### DelayedTrigger
### ImmediateTrigger
## Turn structure
### AddPhase
### AddTurn
`A:SP$ AddTurn | Cost$ 1 U | NumTurns$ 1 | SpellDescription$ Take an extra turn after this one.`
### EndTurn
### ReverseTurnOrder
### SkipPhase
### SkipTurn
## ZoneAffecting
For specific effects that handle zones in a specific manner
### ChangeZone
ChangeZone is a united front of any card that changes zone. This does
not include: drawing, discarding, destroying, or milling, as these
represent specific words on which triggers and replacements can react.
There are two primary forms, but the distinction is handled mostly in
the codebase. The only thing that is required is to set appropriate parameters.
Origin and Destination are both required.
Origin is where the card is coming from.
Destination is where the card is going to. If Destination is Library, a
LibraryPosition is recommended, but not required. **Default value of the
LibraryPosition is 0.** 0 represents the top of the library, -1 represents the bottom.
There are two primary versions of ChangeZone.
#### Hidden Origin
The first is hidden, generally used for Origin zones that are not known
information, like the Library or the Hand. The choice of "What card is
changing zones?" happens during resolution.
`A:SP$ ChangeZone | Cost$ W | Origin$ Library | Destination$ Library | LibraryPosition$ 0 | ChangeType$ Artifact,Enchantment | ChangeNum$ 1 | SpellDescription$ Search your library for an artifact or enchantment card and reveal that card. Shuffle your library, then put the card on top of it.`
`A:AB$ ChangeZone | Cost$ T | Origin$ Hand | Destination$ Battlefield | ChangeType$ Land | ChangeNum$ 1 | Optional$ True | SpellDescription$ You may put a land card from your hand onto the battlefield.`
For Hidden, things like ChangeType and ChangeNum are used to restrict
what can ChangeZone, and how many do. There are two parameters special
to Hidden Origin:
"Chooser" defines which player has to decide which card changes zone
(example You, Opponent).
"Mandatory" most of these abilities are not mandatory, but some are.
#### Known Origin
The second is known, generally used for Origin zones that are known
information, like the Battlefield or the Graveyard. The choice of "What
card is changing zones?" happens on activation, generally by targeting.
`A:AB$ ChangeZone | Cost$ 1 U T | TgtPrompt$ Choose target artifact card in your graveyard | ValidTgts$ Artifact.YouCtrl | Origin$ Graveyard | Destination$ Library | SpellDescription$ Put target artifact card from your graveyard on top of your library.`
`A:SP$ ChangeZone | Cost$ U U | ValidTgts$ Permanent | TgtPrompt$ Select target permanent | Origin$ Battlefield | Destination$ Hand | SpellDescription$ Return target permanent to its owner's hand.`
For Known, since it just uses Target, normal target parameters are used in this Scenario.
### ChangeZoneResolve
This is a helper AF, for chained effects that create multiple permanents which should enter the battlefield at the same time.
To use it, you need to set the param "ChangeZoneTable" on the first effect and then call this at the end.
This is supported by the following effects:
- Amass
- CopyPermanent
- RepeatEach (_NOTE: if you wrap the creation, you don't need to call this AF on its own_)
- Token
### Dig
Dig is for an ability that does basically this: "You look at the X cards
of your Library, put Y of them somewhere, then put the rest somewhere."
Think of Impulse.
- DigNum - Required - look at the top number of cards of your library.
- Reveal - Optional - for abilities that say "Reveal the top X cards
of your library". Default is false.
- SourceZone - Optional - the zone to dig in. Default is Library.
- DestinationZone - Optional - the zone to put the Y cards in. Default
is Hand.
- LibraryPosition - Optional - if DestinationZone is Library, use this
to specify position. Default is -1 (bottom of library).
- ChangeNum - Optional - the number of cards to move to the
DestinationZone (or "All" when it's for things like "put all lands
revealed this way into your hand"). Default is 1.
- ChangeValid - Optional - use this to specify if "you may move an
artifact to DestinationZone". Default is any Card.
- AnyNumber - Optional - use if you can move any number of Cards to
DestinationZone. Default is false. (think of Lead the Stampede)
- Optional - Optional - set this if you "may" move a card to
DestinationZone. Default is false.
- DestinationZone2 - Optional - the zone to put the rest of the cards
in. If it is library, you are prompted for the order. Default is
Library.
- LibraryPosition2 - Optional - if DestinationZone2 is Library, use
this to specify position. Default is -1 (bottom of library).
### DigUntil
### Discard
`A:AB$ Discard | Cost$ T | ValidTgts$ Opponent | NumCards$ 1 | Mode$ TgtChoose | SpellDescription$ Target opponent discards a card. `
- NumCards - the number of cards to be discarded (may be integer or X)
- Mode - the mode of discard - should match spDiscard
- Random
- TgtChoose
- RevealYouChoose
- Hand
- DiscardValid - a ValidCards syntax for acceptable cards to discard
- UnlessType - a ValidCards expression for "discard X unless you
discard <Type>"
### Draw
`A:AB$ Draw | Cost$ 1 Sac<1/CARDNAME> | NumCards$ 1 | SpellDescription$ Draw a card.`
### Mill
`A:AB$ Mill | Cost$ 2 T | NumCards$ 2 | ValidTgts$ Player | TgtPrompt$ Choose a player to mill | SpellDescription$ Target player puts the top two cards of his or her library into his or her graveyard.`
### RearrangeTopOfLibrary
### Shuffle
Used for shuffling a player's library
- Optional - Set this parameter if the user should be
prompted Yes/No to shuffle the given library. Default is false.
### TwoPiles
## Vote

View File

@@ -0,0 +1,356 @@
A reference guide for scripting cards using the API parsed by the Forge engine.
# Base Structure
By opening any file in the /res/cardsfolder folder you can see the basic structure of how the data is created.<br>
Here's an example of a vanilla creature:
```
Name:Vanilla Creature
ManaCost:2 G
Types:Creature Beast
PT:2/2
Oracle:
```
The name of this card is Vanilla Creature.<br>
It's casting cost is {2}{G}.<br>
It has the types Creature and Beast.<br>
It has a Power-Toughness of 2/2.<br>
It will not display any additional text in the card's template.<br>
If a card has two faces, use AlternateMode:{CardStateName} in the front face and separate both by a new line with the text "ALTERNATE".
There are a few other properties that will appear in many cards. These are
| Property | Description
| - | -
|`A`|[Ability effect](AbilityFactory)
|`AI`|RemoveDeck:<br />* `All`<br />This will prevent the card from appearing in random AI decks. It is applicable for cards the AI can't use at all like Dark Ritual and also for cards that the AI could use, but only ineffectively like Tortoise Formation. The AI won't draft these cards.<br />* `Random`<br /> This will prevent the card from appearing in random decks. It is only applicable for cards that are too narrow for random decks like Root Cage or Into the North. The AI won't draft these cards.<br />* `NonCommander`<br />
|`Colors`|Color(s) of the card<br /><br />When a card's color is determined by a color indicator rather than shards in a mana cost, this property must be defined. If no identifier is needed, this property should be omitted.<br /><br />* `Colors:red` - This is used on Kobolds of Kher Keep, which has a casting cost of {0} and requires a red indicator to make it red.<br /><br />* `Colors:red,green` - Since Arlinn, Embraced by the Moon has no casting cost (it's the back of a double-faced card), the red and green indicator must be included.
|`DeckHints`|AI-related hints for a deck including this card<br /><br />To improve synergy this will increase the rank of of all other cards that share some of its DeckHints types. This helps with smoothing the selection so cards without these Entries won't be at an unfair disadvantage.<br /><br />The relevant code can be found in the [CardRanker](https://git.cardforge.org/core-developers/forge/-/blob/master/forge-gui/src/main/java/forge/gamemodes/limited/CardRanker.java) class.
|`DeckNeeds`|This can be considered a stronger variant when the AI should not put this card into its deck unless it has whatever other type is specified. The way this works is "inverted": it will directly decrease the rank of the card unless other cards are able to satisfy its types.<br />If a card demands more than one kind of type you can reuse it:<br />`DeckNeeds:Type$Human & Type$Warrior` will only find Human Warrior compared to `DeckNeeds:Type$Human\|Warrior` which is either
|`DeckHas`|specifies that the deck now has a certain ability (like, token generation or counters) so that the drafting/deckbuilding AI knows that it now meets requirements for DeckHints/DeckNeeds. This is actually very useful since many of these (such as `Ability$Graveyard, Ability$Token, Ability$Counters`) are not deduced by parsing the abilities, so an explicit hint is necessary. Using the other types is also supported in case the implicit parsing wouldn't find it.<br />It doesn't require exact matching to have an effect but cards that care about multiple entries for a given type will be judged higher if a card seems to provide even "more" synergy for it.<br />Example:<br />Chishiro has two abilities so `DeckHas:Ability$Token & Ability$Counters` is used, therefore score for `DeckNeeds:Ability$Token\|Counters` is increased
|`K`|Keyword (see below)
|`Loyalty`|Number of starting loyalty counters
|`ManaCost`|Cost to cast the card shown in mana shards<br /><br />This property is required. It has a single parameter that is a mana cost.<br /><br />* `ManaCost:no cost` for cards that cannot be cast<br />* `ManaCost:1 W W` sets the casting cost to {1}{W}{W}
|`Name`|Name of the card<br /><br />A string of text that serves as the name of the card. Note that the registered trademark symbol cannot be included, and this property must have at least one character.<br /><br />Example:<br />* `Name:A Display of My Dark Power` sets the card's name to "A Display of My Dark Power"
|`Oracle`|The current Oracle text used by the card.<br /><br />We actually have a Python Script that runs to be able to fill in this information, so don't worry about manually editing a lot of cards when Wizards decides to change the rules. <br /><br />This field is used by the Deck Editor to allow non-Legendary Creatures to be marked as potential commanders. Make sure "CARDNAME can be your commander." appears in the oracle text.
|`PT`|Power and toughness
|`R`|[Replacement effect](Replacements)
|`S`|[Static ability](static-abilities)
|`SVar`|String variable. Used throughout scripting in a handful of different ways.
|`T`|[Triggered ability](Triggers)
|`Text`|Additional text that needs to be displayed on the CardDetailPanel that doesn't have any spell/ability that generates a description for it, for example "CARDNAME can be your commander." or "X can't be 0.".
|`Types`|Card types and subtypes<br /><br />Include all card types and subtypes, separated by spaces.<br /><br />Example:<br />* `Types:Enchantment Artifact Creature Golem` for a card that reads Enchantment Artifact Creature -- Golem
Rarity and Set info are now defined in edition definition files. These can be found at /res/reditions path.
## Conventions
- filename: all lowercase, skip special characters, underscore for spaces
- Unix(LF) line endings
- use empty lines only when separating multiple faces on a card
- try to avoid writing default params to keep scripts concise
- e.g. just `SP$ Draw` instead of `SP$ Draw | Defined$ You | NumCards$ 1`
# Keywords
All keywords need to be prepended with "K:" to be parsed correctly. Each keyword must appear on a separate line.
## Keywords without Parameters
This section is for Keywords that require no additional parameters and are one or two words long. Most of these you would see exactly on cards in the game.<br>
Examples:
- Cascade
- Changeling
- Cipher
- Conspire
- Convoke
- Deathtouch
- Defender
- Delve
- Devoid
- Double Strike
- Epic
- Exalted
- Fear
- First Strike
- Flanking
- Flash
- Flying
- Forestwalk
- Fuse
- Haste
- Hideaway
- Horsemanship
- Indestructible
- Infect
- Intimidate
- Islandwalk
- Landfall
- Legendary landwalk
- Lifelink
- Living Weapon
- Menace
- Mentor
- Mountainwalk
- Nonbasic landwalk
- Persist
- Plainswalk
- Prowess
- Provoke
- Reach
- Rebound
- Retrace
- Riot
- Shadow
- Shroud
- Snow forestwalk
- Snow islandwalk
- Snow landwalk
- Snow mountainwalk
- Snow plainswalk
- Snow swamp walk
- Soulbond
- Split second
- Storm
- Sunburst
- Swampwalk
- Totem Armor
- Trample
- Unblockable
- Undying
- Vigilance
- Wither
## Keywords with parameters
- Adapt:{cost}
- AdjustLandPlays:{params}
- Afterlife:{N}
- AlternateAdditionalCost:{cost}
- Amplify:{cost}:{validType(comma separated)}
- Annihilator:{magnitude}
- Bloodthirst:{magnitude}
- Bestow:{cost}
- Bushido:{magnitude}
- CantBeBlockedByAmount {xMath}
- Champion:{validType}
- CostChange:{params}
- Crew:{cost}
- Cumulative upkeep:{cost}:{Description}
- Cycling:{cost}
- Dash:{cost}
- Devour:{magnitude}
- Dredge:{magnitude}
- Echo:{cost}
- Emerge:{cost}
- Enchant {params} \[Curse\]
- Enchant {Type}
- Entwine:{cost}
- Equip:{cost}
- etbCounter:{CounterType}:{CounterAmount}
- ETBReplacement:{Control/Copy/Other}:{AbilitySVar}\[:Optional\]
- Evoke:{cost}
- Fabricate:{cost}
- Fading:{FadeCounters}
- Flashback:{cost}
- Foretell:{cost}
- Fortify:{cost}
- Graft:{value}
- Haunt:{ability}:{Description}
- Hexproof:{ValidCards}:{Description}
- Kicker:{cost}
- Level up:{cost}
- Madness:{cost}
- ManaConvert:
- maxLevel:{magnitude}
- MayEffectFromOpeningHand:{Effect}
- Miracle:{cost}
- Modular:{magnitude}
- Monstrosity:{cost}
- [Mega]Morph:{cost}
- Multikicker:{magnitude}
- Mutate:{cost}
- Ninjutsu:{cost}
- Outlast:{cost}
- Partner:{CardName}
- Poisonous {magnitude}
- PreventAllDamageBy {ValidCards}
- Protection:{ValidCards}:{Description}
- Prowl:{cost}
- Rampage:{magnitude}
- Recover:{cost}
- Renown:{N}
- Replicate:{cost}
- Ripple:{magnitude}
- Soulshift:{magnitude}
- Strive:{cost}
- Suspend:{turns}:{cost}
- Transmute:{cost}
- Toxic:{poisonCounters}
- TypeCycling:{Type}:{cost}
- Unearth:{cost}
- UpkeepCost:{cost}
- Vanishing:{TimeCounters}
## Plaintext keywords
These are hardcoded but not truly keywords rules-wise and will eventually be turned into static abilities.
Only listing the most common ones here so you can recognize them.
CARDNAME is replaced by the card's name ingame.
- All creatures able to block CARDNAME do so.
- CARDNAME assigns no combat damage
- CARDNAME attacks each turn if able.
- CARDNAME attacks each combat if able.
- CARDNAME blocks each combat if able.
- CARDNAME blocks each turn if able.
- CARDNAME can attack as though it didn't have defender.
- CARDNAME can attack as though it had haste.
- CARDNAME can block as though it were untapped.
- CARDNAME can block creatures with shadow as though they didn't have shadow.
- CARDNAME can block creatures with landwalk abilities as though they didn't have those abilities.
- CARDNAME can block only creatures with flying.
- CARDNAME can only attack alone.
- CARDNAME can't attack.
- CARDNAME can't attack if you cast a spell this turn.
- CARDNAME can't attack if defending player controls an untapped creature with power {rest of text string}
- CARDNAME can't attack or block.
- CARDNAME can't attack or block alone.
- CARDNAME can't be countered.
- CARDNAME can't be enchanted.
- CARDNAME can't be equipped.
- CARDNAME can't be regenerated.
- CARDNAME can't be the target of Aura spells.
- CARDNAME can't block.
- CARDNAME can't block creatures with power {rest of text string}
- CARDNAME can't block unless a creature with greater power also blocks.
- CARDNAME can't block unless at least two other creatures block.
- CARDNAME can't transform
- CARDNAME doesn't untap during your untap step.
- CARDNAME enters the battlefield tapped.
- CARDNAME is {color}.
- CARDNAME must be blocked if able.
- CARDNAME must be blocked by exactly one creature if able.
- CARDNAME must be blocked by two or more creatures if able.
- CARDNAME can't be blocked unless all creatures defending player controls block it.
- CARDNAME's power and toughness are switched
- CARDNAME untaps during each other player's untap step.
- CARDNAME's activated abilities can't be activated.
- Creatures with power greater than CARDNAME's power can't block it.
- Creatures can't attack unless their controller pays:{params}
- Damage that would be dealt by CARDNAME can't be prevented.
- Damage that would reduce your life total to less than 1 reduces it to 1 instead.
- Enchant artifact
- Enchant creature
- Enchant creature with converted mana cost 2 or less
- Enchant creature without flying
- Enchant red or green creature
- Enchant land
- Enchant land you control
- Enchant tapped creature
- No more than one creature can attack each combat.
- No more than one creature can block each combat.
- No more than two creatures can attack you each combat.
- No more than two creatures can block each combat.
- Play with your hand revealed.
- Prevent all combat damage that would be dealt to and dealt by CARDNAME.
- Prevent all combat damage that would be dealt by CARDNAME.
- Prevent all combat damage that would be dealt to CARDNAME.
- Prevent all damage that would be dealt to and dealt by CARDNAME.
- Prevent all damage that would be dealt by CARDNAME.
- Prevent all damage that would be dealt to CARDNAME.
- Protection from {type}
- Remove CARDNAME from your deck before playing if you're not playing for ante.
- Spells and abilities your opponents control can't cause you to sacrifice permanents.
- You can't pay life to cast spells or activate abilities.
- You can't sacrifice creatures to cast spells or activate abilities.
- You can't draw cards.
- You can't gain life.
- You can't lose the game.
- You can't win the game.
- You don't lose the game for having 0 or less life.
- You may choose not to untap CARDNAME during your untap step.
- You may have CARDNAME assign its combat damage as though it weren't blocked.
- Your life total can't change.
# General SVars
`SVar:SoundEffect:goblinpolkaband.mp3`
The sound system supports a special SVar that defines the sound that should be played when the spell is cast.
`SVar:X:Count$`
Count is our general value computation function. It's quite varied with a lot of different things it can calculate and is often being updated.
# AI specific SVars
`SVar:AIPreference:SacCost$Creature.token,Creature.cmcLE2`
`SVar:AntiBuffedBy:[ValidCards]`
If a permanent with this SVar is on the battlefield under human control
the AI will play the specified cards in Main1. Applicable for cards like
Heart Sliver or Timid Drake.
`SVar:BuffedBy:[ValidCards]`
If a permanent with this SVar is on the battlefield under its control
the AI will play the specified cards in Main1. Applicable for creatures
with a P/T setting static ability (Kithkin Rabble) or additional buffes
(Radiant, Archangel).
`SVar:EnchantMe:[Multiple]/[Once]`
Creatures with "Multiple" in this SVar will always be prefered when the
AI enchants (Rabid Wombat), creatures with "Once" only if they are not
enchanted already (Gate Hound).
`SVar:EquipMe:[Multiple]/[Once]`
Creatures with "Multiple" in this SVar will always be prefered when the
AI equippes (Myr Adapter), creatures with "Once" only if they are not
equipped already (Kor Duelist).
`SVar:AIEvaluationModifier:[ValidAmount]`
`SVar:EndOfTurnLeavePlay:True`
`SVar:maxLevel:`
`SVar:HasCombatEffect:True`
`SVar:HasAttackEffect:True`
`SVar:HasBlockEffect:True`
`SVar:MustAttack:True`
`SVar:MustBeBlocked:True`
`SVar:NeedsToPlayVar:[ValidCards]`
`SVar:ManaNeededToAvoidNegativeEffect:`
`SVar:NonStackingEffect:True`
`SVar:PlayMain1:TRUE/ALWAYS/OPPONENTCREATURES`
The AI will play cards with this SVar in its first main phase. Without other AILogic, it will usually not play any permanents without this in Main1.
`SVar:SacMe:[number]`
The AI will sacrifice these cards to pay costs. The higher the number the higher the priority. Example: Hatching Plans has SVar:SacMe:5.
`SVar:Targeting:Dies`
`SVar:UntapMe:True`
The AI will prioritize untapping of this card.
`SVar:AIUntapPreference:`
`SVar:NoZeroToughnessAI:True`

View File

@@ -0,0 +1,186 @@
Cost is a class that attempts to streamline costs throughout all cards. It requires that each cost is separated by a space. I will use examples that could be found in Ability, although certain Keyworded abilities do use Cost too.
# Common
## Description
Description is an optional last parameter in the cost. This is to allow
for complex Type definitions to have a nice Description that is readable.
## CostDesc / PrecostDesc
## UnlessCost
UnlessCost allows the player specified with UnlessPayer (same as
Defined, defaults to TargetedController) to pay mana to prevent the
resolving of the ability. If the script has the param "UnlessSwitched",
then the player pays mana to resolve the ability (usually used to handle
"any player may pay ..." ).
## XChoice
XChoice is the variable that basically means "You can choose whatever
you want for this variable. But you need to decide what X is before you
start paying." This would commonly appear as an SVar definition of X.
## xPaid
xPaid is the amount of Mana Paid for an X Cost. There are a few cards
that will use the X Payment to determine other costs (like Abandon Hope)
This would commonly appear as an SVar definition of X.
## CARDNAME
For Costs that do something to themselves (ex. Discard Self, Sacrifice
Self)
# Types of Cost
## Discard
Discard has two required parameters and one optional in the form
Discard<Num/Type/Description>
- The first is how many cards are being discarded.
- The second is what card types can be discarded. (Hand for the whole
hand, Random for chosen randomly)
## Draw
## Exert
## Exile
Exile has two required parameters and one option in the form of
Exile<Num/Type/Description>
There are also a few sister abilities that all fit under the Exile
umbrella.
- Exile (for cards on the Battlefield)
- ExileFromGraveyard
- ExileFromHand
- ExileFromTop (for cards on top of your library, this doesn't default
Type to Card, so make sure you add it)
Some Examples
- Exile&lt;1/Creature&gt;
- Exile&lt;1/CARDNAME&gt;
- ExileFromHand&lt;1/CARDNAME&gt;
- ExileFromHand&lt;2/Creature&gt;
- ExileFromGrave&lt;1/CARDNAME&gt;
- ExileFromGrave&lt;1/Treefolk&gt;
- ExileFromTop&lt;10/Card&gt;
## FlipCoin
Only used by "Karplusan Minotaur".
## Mana
- Cost$ 2
- 2 colorless mana
- Cost$ B R
- 1 black and 1 red mana
- Cost$ WG
- Hybrid White/Green mana
- Cost$ S
- Snow Mana
- Cost$ Mana&lt;2\\Creature&gt;
- 2 colorless produced by a source with type 'creature'. Note the
backslash - it was chosen because hybrid costs already use slash
Here's some examples:
- Discard&lt;1/Card&gt;
- "Discard 1 Card"
- Discard&lt;0/Hand&gt; (The number is ignored when Hand is used as a
type.)
- Discard your hand
- Discard&lt;2/Random&gt;
- Discard 2 Cards at Random
- Discard&lt;1/CARDNAME&gt;
- Discard Self (CARDNAME)
- Discard&lt;1/Creature.Black/Black Creature&gt;
- Discard 1 Black Creature
## Mill
## Subtract(Remove) Counter
SubCounter has two required parameters in the form of
SubCounter<Num/CounterName>
- SubCounter&lt;2/P1P1&gt;
- SubCounter&lt;1/CHARGE&gt;
Remember the token name should appear all in caps.
As third parameter you can use a ValidCard.
## Sacrifice
Sacrifice has two required parameters and one optional parameter in the
form of Sac<Num/Type/Description>
- Sac&lt;1/Artifact&gt;
- Sac&lt;1/CARDNAME&gt;
## Tap
- Cost$ T
## Untap
- Cost$ Untap
\- or -
- Cost$ Q
## Unattach
## PayEnergy
## PayLife
PayLife has one required parameter in the form of PayLife<Num>
- PayLife&lt;2&gt;
## GainLife
## TapXType
TapXType has two required parameters and one option in the form of
tapXType<Num/Type/Description>
- tapXType&lt;3/Creature.White&gt;
## Return
Return has two required parameters and one optional in the form of
Return<Num/Type/Description>
- Return&lt;1/Land&gt;
- Return&lt;1/CARDNAME&gt;
## Reveal
# Putting it Together
Putting it together is pretty simple. If a card needs to pay mana and tap, it would look like this:
- Cost$1 W T
For a spell that has an additional cost of sacrificing a land, put the
mana cost and the additional cost in the cost:
- Cost$2 G Sac&lt;1/Land&gt;
One of the features of Cost is you can have more than one of the same Cost type:
- Cost$ Sac&lt;1/Swamp&gt; Sac&lt;1/Creature&gt;
There are many examples, but they mostly fall into those categories.

View File

@@ -0,0 +1,90 @@
Replacement create replacement effects, as you'd expect. Their script
follows the format introduced by AbilityFactory; simply begin a line
with "R:", to indicate that it's for a replacement effect, followed by a
collection of name-value pairs (name and value are separated by $)
separated by pipes (|). All Replacement effects expect an "Event$"
parameter, which declares what event should be replaced. Most replacement effects will also have a "ReplaceWith$" parameter which points to an SVar which contains what should replace the event. They may have a "Prevent$True" parameter, instead though, which means that nothing happens instead of the event.
Similarly to triggers, the replacing code can access special variables
pertaining to the event it replaced (like triggered-variables). These
are specific to each event, and is listed below. Most replacement effects
will also have a "Description$" parameter which is simply the card text
for the ability.
## DamageDone
DamageDone events are checked when damage is about to be assigned to a
card or player. There are 5 special parameters:
- ValidSource - The damage source must match this for the event to be
replaced.
- ValidTarget - The damage target must match this for the event to be
replaced.
- DamageAmount - The amount of damage must match this.
- IsCombat - If true, the damage must be combat damage, if false, it
can't be.
- IsEquipping - If true, the host card must be equipping something.
There are 3 Replaced-variables:
- DamageAmount - The amount of damage to be assigned.
- Target - The target of the damage.
- Source - The source of the damage.
## Discard
Discard events are checked when a player is about to discard a card.
There are 4 special parameters:
- ValidPlayer - The player who would discard must match this.
- ValidCard - The the card that would be discarded must match this.
- ValidSource - The card causing the discard must match this.
- DiscardFromEffect - If true, only discards caused by spells/effects
will be replaced. Cleanup/statebased discards will not.
There are 2 Replaced-variables:
- Card - The card that would be discarded.
- Player - The player that would have discarded
## Draw
Draw events are checked when a player is about to draw a card. There is
1 special parameter:
- ValidPlayer - The player who would draw must match this.
There are no Replaced-variables.
## GainLife
GainLife events are checked when a player would gain life. There is 1
special parameter:
- ValidPlayer - The player who would gain life must match this.
There is 1 Replaced-variable:
- LifeGained - The amount of damage to be gained.
## GameLoss
GameLoss events are checked when a player would lose. There is 1 special
parameter:
- ValidPlayer - The player who would lose must match this.
There are no Replaced-variables.
## Moved
Moved events are checked when a card would be moved between zones. There
are 3 special parameters:
- ValidCard - The moving card must match this.
- Origin - The card must be moving from this zone.
- Destination - The card must be moving to this zone.
There is 1 Replaced-variable:
- Card - The moving card.

View File

@@ -0,0 +1,103 @@
### Activation
Activation$ <Option> can accept several different values:
- Metalcraft
- Threshold
- Hellbent
These basically follow the text of the card.
### ActivationZone
ActivationZone$ <Zone> For cards that have abilities that you can
activate outside of the Battlefield
### Flashback
While Flashback isn't technically an SA\_Restriction it's listed here
because it's handled very similarly in AFs. If sets the ActivationZone
to Graveyard and sets the FlashbackAbility flag of a SpellAbility which
will exile the card as it finishes resolving.
### SorcerySpeed
SorcerySpeed $True For cards that can only activate if you could cast a
sorcery.
### PlayerTurn
PlayerTurn $True For cards that can only be activated during the
activating player's turn.
### OpponentTurn
OpponentTurn $True For cards that can only be activated during the
opponent's turn of the activating player.
### AnyPlayer
AnyPlayer $True For cards that can be activated by any player. Prophecy
has lots of examples of these types of cards.
### ActivationLimit
ActivationLimit$<activationsPerTurn> For cards that have a limited
amount of uses
### ActivationNumberSacrifice
ActivationNumberSacrifice$<activations> For cards that if they you
activate them more than a certain amount per turn are sacrificed at end
of the turn.
### ActivationPhases
ActivationPhases$\<Phases,Seperated,By,Commas\> For Abilities can only
be activated during upkeep then it'll be ActivationPhases$Upkeep if it's
before Declare Attackers than it's
ActivationPhases$Upkeep,Draw,Main1,BeginCombat
This can also be handled in a range. ActivationPhases$
BeginCombat-\>EndCombat for Spells that can only be cast during combat.
### ActivationCardsInHand
ActivationCardsInHand$<CardsInHand> For Abilities with Hellbent (for 0)
or Library of Alexandria (for 7)
### Planeswalker
Planeswalker$ True For Planeswalker Abilities. These can only be
activated at Sorcery Speed, and only if no Planeswalker Abilities
(including this ability) on this card have been activated that turn.
Add Ultimate$ True when applicable for the AI and achievements.
### Present
Present is a Restriction that comes in two parts. IsPresent is required.
And PresentCompare is optional.
#### IsPresent
IsPresent$ <ValidCards> gets all cards on the battlefield that is
considered a ValidCard.
#### PresentCompare
PresentCompare$\<2 Letter Comparison\><Comparator>. The comparisons are
LE,LT,EQ,NE,GE,GT and translated to \<=, \<, ==, \!=, \>=, \>. The
comparator is on the right side of the equation.
If PresentCompare is **missing**, the Restriction defaults to GE1.
### Condition
Condition is similar to a IsPresent restriction, except it's checked on Resolution of the spell and not on Activation.
### CheckSVar
CheckSVar specifies that the results computed from an SVar (Usually via
xCount) must equal a certain value which you can specify in the
accompanying SVarCompare parameter. SVarCompare is the same as
PresentCompare above.

View File

@@ -0,0 +1,219 @@
# Affected
A defined parameter can be either for something that states what is
receiving the action. Remember this is non-targeted!
## Defined Players
Defined Players are for SAs like Draw or Discard. They tell you who is
receiving this action (but not in a targeted way).
### You
The most common of these is Defined$ You. It means exactly what you
think "You draw a card." "You discard a card." Cards that don't seem to
define anything that affect Players should default to "You"
A spell that lets you draw a card is:
SP$ Draw \| Defined$ You
It is important to include this in SAs that have an unclear "Default"
value such as Damage.
### Opponent
Also, fairly common is Defined$ Opponent. It means "Deals damage to each
opponent" "Each Opponent discards a card."
A spell that deals damage to each opponent is:
SP$DealDamage \| Defined$ Opponent \| NumDmg$ 5
### TargetedController
### TargetedOwner
### EnchantedController
It means, "the controller of the enchanted thing." This would be the
"that player" part of things like "At the beginning of enchanted
creature's controller's upkeep, that player loses 1 life."
### EnchantedOwner
### AttackingPlayer
Things like "Whenever Souls of the Faultless is dealt combat damage, you
gain that much life and attacking player loses that much life."
### DefendingPlayer
Things like "Whenever CARDNAME deals combat damage, defending player
discards a card."
### Player
Each player.
## Defined Cards
Defined Cards are for SAs like Pump or Regenerate. They tell you who is
receiving this action (but not in a targeted way).
### Self
The most common of these is Defined$ Self. It means exactly what you
think "I gain Flying" "Regenerate Me." Abilities that don't seem to
define anything should affect Cards default to "Self"
AB$Regenerate\| Defined$ Self
It is important to include this in SAs that have an unclear "Default"
value such as Damage.
### Enchanted
Enchanted is fairly common. It means "do this action to the card I'm
Enchanted to"
A simple example is a card that Pumps the attack of the Enchanted creature
AB$Pump \| Defined$ Enchanted \| NumAtt$ +1
### Equipped
Equipped isn't very common, but is very similar. It means "do this
action to the card I'm Equipped to"
AB$Pump \| Defined$ Equipped \| NumAtt$ +2 \| NumDef$ +2
### Remembered
### ThisTurnEntered
ThisTurnEntered lets you make the ability act on valid cards that were
put in a certain zone,from a certain zone, this turn. The format is
"ThisTurnEntered <Destination> \[from <Origin>\] <ValidExpression>".
For example: No Rest for the Wicked and the like would use:
`AB$ ChangeZone | Cost$ Sac<1/CARDNAME> | Defined$ ThisTurnEntered Graveyard from Battlefield Creature.YouCtrl | SpellDescription$ Return to your hand all creature cards in your graveyard that were put there from the battlefield this turn.`
### Targeted
Targeted will only appear on a [SubAbility][]. It means "Do this action
to whatever a parent Ability targeted"
That may sound confusing so here's an example.
If you had a spell that says "Untap target Creature. It gains +1/+1
until end of turn" it would look like similar to this.
SP$Untap \| ValidTgts$ Creature \| SubAbility$ DBPump
SVar:DBPump:DB$Pump \| Defined$ Targeted \| NumAtt$ +1 \| NumDef$ +1
# Targets
Each element follows the form:
CardType{.restriction}{+furtherRestriction}
The restrictions are optional.
CardType may be any type, generally the supertypes like Creature,
Artifact, Enchantment, Land, etc. However, it could also be Elf or
Goblin... though that would also include Elf Enchantments, for example.
To specify an Elf Creature, then it should be "Creature.Elf".
"Permanent" represents any permanent, "Card" any card....
Restrictions other than type that are interpreted: (case sensitive)
`   named{Name}`
`   notNamed{Name}`
`   sameName`
`   NamedCard`
`   Color, nonColor (White, nonWhite, etc)`
`   Colorless, nonColorless`
`   Multicolor, nonMulticolor`
`   MonoColor, nonMonoColor`
`   ChosenColor`
`   SharesColorWith`
`   YouCtrl, YouDontCtrl`
`   YouOwn, YouDontOwn`
`   EnchantedPlayerCtrl`
`   OwnerDoesntControl`
`   ControllerControls{type}`
`   RememberedPlayerCtrl (use if Remember will be set before resolution)`
`   TargetedPlayerCtrl (only use if restriction is needed wile initial targeting happens)`
`   Other,Self`
`   AttachedBy,Attached`
`   DamagedBy,Damaged`
`   with{Keyword}, without{Keyword}`
`   tapped, untapped`
`   faceDown`
`   enchanted, unenchanted, enchanting, EnchantedBy`
`   equipped, unequipped, equipping, EquippedBy`
`   dealtDamageToYouThisTurn`
`   wasDealtDamageThisTurn`
`   wasDealtDamageByHostThisTurn`
`   wasDealtDamageByEquipeeThisTurn`
`   token, nonToken`
`   kicked, notkicked`
`   enteredBattlefieldThisTurn`
`   power{cmp}{X or #}`
`   toughness{cmp}{X or #}`
`   cmc{cmp}{X or #}`
`   {cmp} is a comparator:`
`       LT - Less Than`
`       LE - Less than or Equal`
`       EQ - EQual`
`       GE - Greater than or Equal`
`       GT - Greater Than`
`   X is parsed from "SVar:X:Count$___"`
`   greatestPower, leastPower`
`   greatestCMC`
`   counters{cmp}{X or #}{Type}`
`   attacking, notattacking`
`   blocking, notblocking`
`   blocked, unblocked, blockedBySource`
`   kicked, notkicked`
`   evoked`
`   hasDevoured, hasNotDevoured`
`   non{Type}`
`   ChosenType{Type} `
`   {Type}`
`   CostsPhyrexianMana`
`   Above, DirectlyAbove`
`   TopGraveyardCreature`
`   TopGraveyard`
`   Cloned`
`   isRemembered`
Examples:
"Artifact or Enchantment" would be represented as 2 elements "Artifact,Enchantment"
"non-black, non-artifact creature" would be represented as "Creature.nonBlack+nonArtifact"
"creature with power 2 or less" would be "Creature.powerLE2"
"nonbasic land" is "Land.nonBasic"
"creature with flying" is "Creature.withFlying"
"creature self with four or more level counters" is
"Creature.countersGE4LEVEL+Self"

View File

@@ -0,0 +1,918 @@
Triggers define when an ability should be automatically added to the
stack. Their syntax in the card files are very similar to that used by
the various AbilityFactorys, that is: every trigger line starts with
"T:" (without the quotes) and is a collection of name-value pairs (name
and value are separated by $) separated by pipes (|). Like with
AbilityFactorys, there are a few that show up almost always if not
always. There are two parameters that are always present on a trigger:
- Mode - Specifies what kind of situation the trigger should wait for.
- TriggerDescription - Describes the trigger, much like AF's
SpellDescription parameter.
- (Execute - Specifies the name of the SVar that holds the ability to
run when the trigger goes off.)
_NOTE: The Execute parameter may be absent, if you are writing a delayed triggered ability. See below._
Depending on which Mode is specified, other parameters may be expected.
Below are the currently available modes.
The script has access to many things that were previously internal to
triggers. These things are accessed via Triggered-variables. Triggered
variables are always of the form "Triggered<Variable Name>\[Controller/Owner\]" and are specific to each trigger mode. You can use Triggered-variables that return a card or a player directly in Defined$ parameters or to grab extra info from (like you use "Targeted" for, for instance "SVar:X:TriggeredCard$CardPower").
You can get the controller or owner of a card returned by a Triggered-variable by appending "Controller" or "Owner" to the variable. Triggered-variables that return an integer can only be accessed from Count$, i.e. "SVar:X:Count$TriggeredLifeAmount".
Other parameters that triggers can use are:
- Secondary - If a trigger has Secondary$ True set, it means that it's
trigger description won't show up in a card's text box. This can be
used if you need to use several triggers to emulate a single effect
on a real card.
- Static - This parameter is mainly used for "As CARDNAME enters the
battlefield..." type things. It causes the triggered ability to
resolve right away, instead of going on the stack.
- ResolvingCheck
- NoResolvingCheck - makes a trigger not recheck its condition to resolve
## Always
Always-triggers represent State triggers, a special kind of triggers. These triggers will not do any checks for intervening if-clauses and will not go on the stack if an instance of it has already been put there. They are checked every time state effects are checked.
Examples: Emperor Crocodile.
There are no special parameters and no triggered-variables.
## Attached
Attached-triggers go off when a card is attached, via enchanting or
equipping, to another card.
Examples: Bramble Elemental, Kithkin Armor.
There are 2 special parameters:
- ValidSource - The card that is being attached to another must match
this for the trigger to go off.
- ValidTarget - The card that is having another card attached to it
must match this.
There are 2 Triggered-variables:
- Source - The card that is being attached.
- Target - The card that is being attached to.
## AttackerBlocked
AttackerBlocked-triggers go off when a creature becomes blocked. It goes
off only once (no matter how many blockers there are) right after the
declare blockers step.
Examples: AEther Membrane, Alley Grifters.
There are 2 special parameters:
- ValidCard - The attacking creature must match this for the trigger
to go off.
- ValidBlocker - The blocking creature must match this for the trigger
to go off.
There are 3 Triggered-variables:
- Attacker - The card of the attacking creature.
- Blocker - The card of the blocking creaure.
- NumBlockers - The number of things blocking the attacker
## AttackerUnblocked
AttackerUnblocked-triggers go off when a creature attacks and is not
blocked, right after the declare blockers step.
Examples: Abyssal Nightstalker, Dauthi Mindripper
There is 1 special parameter:
- ValidCard - The attacking creature must match this for the trigger
to go off.
There is 1 Triggered-variable:
- Attacker - The card of the attacking creature.
## AttackersDeclared
Goes off after attackers are declared, if any attackers were declared,
once a combat only.
Examples: Lightmine Field, Curse of Inertia. There are 2 special
parameters:
- AttackingPlayer - The attacking player must match this.
- AttackedTarget - One of the game entities in TriggeredAttackedTarget
must match this.
There are 3 Triggered-variables:
- Attackers - Collection of attacking creatures.
- AttackingPlayer - The targeted object.
- AttackedTarget - Collection of game entities that each attacker is attacking.
## Attacks
Attacks-triggers go off when a creature attacks. That is, it goes off
once for each creature that attacks during your each combat phase (Right
after the declare attackers step).
Examples: Accorder Paladin, Trepanation Blade.
There are 2 special parameters:
- ValidCard - The attacking creature must match this for the trigger
to go off.
- Alone - If this is True, the trigger will only go off if the
creature attacks alone.
There is 1 Triggered-variable:
- Attacker - The card of the attacking creature.
## BecomeMonstrous
BecomeMonstrous-triggers go off when a creature becomes Monstrous,
naturally.
Examples: Arbor Colossus, Ember Swallower.
There is 1 special parameter:
- ValidCard - The card that becomes monstrous must match this.
There is 1 Triggered-variable:
- Card - The card that became monstrous.
## BecomesTarget
BecomesTarget-triggers go off when a spell or ability (or either) is put
on the stack targeting something that matches a Valid-expression.
Examples: Angelic Protector, Cephalid Illusionist.
There are 3 special parameters:
- SourceType - Can be Spell or Ability.It is optional.
- ValidSource - The card that targets something must match this.
- ValidTarget - The targeted object must match this.
There are 2 Triggered-variables:
- Source - The targeting card.
- Target - The targeted object.
## BlockersDeclared
Goes off after blockers are declared if there are any, once in a combat
only. (unlike Blocks, which goes off once for each creature that blocks.)
Examples: Tide of War
There are no special parameters.
There are 2 Triggered-variables:
- Blockers - Collection of all blockers.
- Attackers - Collection of all attackers.
## Blocks
Blocks-triggers go off when a creature blocks (No surprise there ;) ).
Examples: Amphibious Kavu, Cinder Wall (See below).
There are 2 special parameters:
- ValidCard - The blocking creature must match this.
- ValidBlocked - The creature being blocked must match this.
There are 2 Triggered-variables:
- Attacker - The card of the attacking creature.
- Blocker - The card of the blocking creaure.
## Championed
Goes off when a creature is championed.
Examples: Mistbind Clique.
There are 2 special parameters:
- ValidCard - The card being exiled for championing must match this.
- ValidSource - The champion card that is being played must match
this.
There are 2 Triggered-variables:
- Championed - The champion-exiled card
- Card - The championing card.
## ChangesController
Goes off when a card changes controller.
Examples: Coffin Queen, Duplicity.
There are 2 special parameters:
- ValidCard - The card whose controller changes must match this.
- ValidOriginalController - The player who originally controlled the
card must match this.
There is 1 Triggered-variable:
- Card - The card whose controller changes.
## ChangesZone
ChangesZone-triggers go off whenever, you guessed it, a card changes
zone.
Examples: Contagion Clasp, see below.
There are 3 special parameters:
- ValidCard - The card that was moved must match this for the trigger
to go off.
- Origin - The card must be moved from this zone for the trigger to go
off. (Defaults to "Any")
- Destination - The card must be moved to this zone for the trigger to
go off. (Defaults to "Any")
There is 1 Triggered-variable:
- Card - The card that was moved.
## Clashed
Clashed-triggers go off whenever a player has clashed, regardless of
wether you won or not. They are always run after the clash is through.
Examples: Entangling Trap, Rebellion of the Flamekin.
There are 2 special parameters:
- ValidPlayer - Who clashed.
- Won - True if the player must have won, false otherwise.
There are no Triggered-variables.
## CombatDamageDoneOnce
Goes off once for every game entity that recieves damage in combat.
Examples: Nature's Will, Pyrewild Shaman.
There are 2 special parameters:
- ValidSource - One or more of the game entities that dealt the damage
must match this.
- ValidTarget - The game entity that recieved damage must match this.
There are 2 Triggered-variables:
- Sources - A collection of the game entities that dealt the damage.
- Target - The game entity that recieved damage.
## CounterAdded & CounterRemoved
These triggers go off when a counter is added to / removed from a
card.
Examples: Bloodcrazed Hoplite, Aeon Chronicler.
There are 2 or 3 special parameters:
- ValidCard - The card getting the counter must match this for the
trigger to go off.
- CounterType - The counter must be of this type for the trigger to go
off.
- NewCounterAmount - The counter amount AFTER the trigger fires must
be this. NOTE: only available to CounterRemoved at the moment.
There is 1 Triggered-variable:
- Card - the card the counter was added to
## Countered
Goes off when a spell or ability is countered.
Examples: Lullmage Mentor, Multani's Presence.
There are 3 special parameters:
- ValidCard - The host card of the spell/ability that was countered
must match this.
- ValidPlayer - The player that cast/activated the spell/ability that
was countered must match this.
- ValidCause - The host card of the spell/ability that did the
countering must match this.
There are 3 Triggered-variables:
- Card - The host card of the spell/ability that was countered.
- Player - The player that cast/activated the spell/ability that was
countered.
- Cause - The host card of the spell/ability that did the countering.
## Cycled
Cycled-triggers simply go off whenever you cycle a card.
Examples: Astral Slide, Bant Sojourners.
There is 1 special parameters:
- ValidCard - The card that was cycled must match this.
There is 1 Triggered-variable:
- Card - The card that was cycled.
## DamageDone
DamageDone-triggers go off whenever any source deals damage to any
target.
Examples: Abomination of Gudul, Prophetic Flamespeaker.
There are 4 special parameters:
- ValidSource - The source of the damage must match this.
- ValidTarget - The target of the damage must match this.
- CombatDamage - If set to true, the trigger will only go off if the
damage dealt was combat damage.If set to false, it will only go off
if it wasn't combat damage.. If omitted, it will go off either way.
- DamageAmount - Specifies how much damage must be done for the
trigger to go off. It takes the form "<operator><operand>" where
<operator> can be LT (Less Than),LE (Less than or Equal),EQ
(Equal),GE (Greater than or Equal) or GT (Greater Than) and
<operand> is a positive integer.
There are 3 Triggered-variables:
- Source - The source of the damage.
- Target - The target of the damage.
- DamageAmount - The amount of damage dealt(integer).
<b>BEWARE: Since the Target variable can be either a player or a card,
you must take care to limit this in the ValidTarget parameter\!</b>
## DealtCombatDamageOnce
Goes off \*once\* for each creature that deals damage in combat.
Examples: Arashin War Beast, Five Alarm Fire.
There are 2 special parameters:
- ValidTarget - The game entity that recieves damage must match this.
- ValidSource - The card that dealt damage must match this.
There are 2 Triggered-variables:
- Target - The game entity that recieves damage.
- Source - The card that dealt damage.
## Destroyed
Goes off when a permanent is destroyed. (Not if it it destroyed, but
then regenerated.)
Examples: Cobra Trap, Sacred Ground.
There are 2 special parameters:
- ValidCard - The card that was destroyed must match this.
- ValidCauser - The player that activated the spell/ability that
destroyed the card must match this.
There are 2 Triggered-variables:
- Card - The card that was destroyed.
- Causer - The player that activated the spell/ability that destroyed
the card.
## Devoured
Goes off when a creature is sacrificed for a Devour creature.
Examples: Kresh the Bloodbraided Avatar.
There is 1 special parameter:
- ValidDevoured - The devoured creature must match this.
There is 1 Triggered-variable:
- Devoured - The devoured creature.
## Discarded
Discarded-triggers go off whenever a card is discarded from a players
hand. (side note: ChangesZone-triggers may also go off here because the
card is moved from the hand to the graveyard)
Examples: Abyssal Nocturnus, Confessor.
There are 3 special parameters:
- ValidPlayer - The player who discarded the card must match this.
- ValidCard - The discarded card must match this.
- ValidCause - The card that caused the player to discard must match
this.
There is 1 Triggered-variable:
- Card - The card that was discarded.
## Drawn
Drawn-triggers go off when a player draws a card.
Examples: Booby Trap, Kederekt Parasite.
There is 1 special parameter:
- ValidCard - The drawn card must match this.
There are 2 Triggered-variable:
- Card - The card that was drawn.
- Player - The player that drew the card.
## Evolved
Goes off when a creature gets a +1/+1 counter from evolving.
Examples: Renegade Krasis.
There is 1 special parameter:
- ValidCard - The card that got the counter must match this.
There is 1 Triggered-variable:
- Card - The card that got the counter.
## FlippedCoin
Goes off when a player flips a coin.
Examples: Chance Encounter, Karplusan Minotaur.
There are 2 special parameter:
- ValidPlayer - The player who flipped the coin must match this.
- ValidResult - If this parameter is "Win", the player must win the
flip.
There is 1 Triggered-variable:
- Player - The player who flipped the coin.
## LandPlayed
LandPlayed-triggers of course go off when a land is played.
Examples: Burgeoning, City of Traitors.
There is 1 special parameter:
- ValidCard - The played card must match this.
There is 1 Triggered-variable:
- Card - The card that was played.
## LifeGained & LifeLost
These triggers go off on when a player either gains or loses life, of
course.
Examples: Cradle of Vitality, Exquisite Blood.
There is 1 special parameter:
- ValidPlayer - The player who gained or lost life must match this.
There are 2 Triggered-variables:
- Player - The player that gained/lost life.
- LifeAmount - The amount of life lost/gained. (integer)
## LosesGame
Goes off when a player loses the game.
Examples: Blood Tyrant, Elbrus, the Binding Blade // Withengar Unbound
There is 1 special parameter:
- ValidPlayer - The player who lost the game must match this.
There is 1 Triggered-variable:
- Player - The Player who lost the game.
## NewGame
Goes off once at the start of each game, after mulligans.
Examples: Maralen of the Mornsong Avatar, Worldknit.
There are no special parameters or Triggered-variables.
## PayCumulativeUpkeep
Goes off when a player pays or doesn't pay the cumulative upkeep for a
card.
Examples: Balduvian Fallen, Heart of Bogardan.
There are 2 special parameters:
- Paid - Wether or not the player must have paid the cumulative
upkeep.
- ValidCard - The card that has the cumulative upkeep must match this.
There are 2 Triggered-variables:
- Card - The card that has the cumulative upkeep.
- PayingMana - A string representing the mana spent.
## PayEcho
Goes off when a player pays or doesn't pay the echo cost for a card.
Examples: Shah of Naar Isle.
There are 2 special parameters:
- Paid - Wether or not the player must have paid the echo.
- ValidCard - The card that has the echo must match this.
There is 1 Triggered-variable:
- Card - The card that has the echo.
## Phase
Phase-triggers go off at specific points in the turns.
Examples: AEther Vial, see below.
There are 2 special parameters:
- Phase - The phase during which the trigger should go off.
- ValidPlayer - The player who's turn it should be.
There is 1 Triggered-variable:
- Player - The player whose turn it is.
## PhaseIn & PhaseOut
Goes off when a permanent phases in or out, specifically only while that
permanent is still on the battlefield since triggers don't work on
phased out objects.
Examples: Shimmering Efreet, Ertai's Familiar.
There is 1 special parameter:
- ValidCard - The card phasing in or out must match this.
There is 1 Triggered-variable:
- Card - The card phasing in or out.
## PlanarDice
Goes off when the planar dice is rolled in a Planechase game.
Examples: Panopticon, Orzhova.
There are 2 special parameters:
- ValidPlayer - The player that rolled the dice must match this.
- Result - The dice must roll this. Blank,Chaos or Planeswalk.
There is 1 Triggered-variable:
- Player - The player that rolled the dice.
## PlaneswalkedTo & PlaneswalkedFrom
These triggers go off when a player planeswalks to or away from one or
more planes.
Examples: Panopticon, Orzhova.
There is 1 special parameter:
- ValidCard - One of the planes must match this.
There is 1 Triggered-variable:
- Cards - A collection of all the cards planeswalked to or from.
## Sacrificed
Sacrificed-triggers go off whenever a player sacrifices a permanent.
Examples: Dragon Appeasement, Mortician Beetle.
There are 2 special parameters:
- ValidPlayer - The player who sacrificed the card must match this.
- ValidCard - The sacrificed card must match this.
There is 1 Triggered-variable:
- Card - The card that was Sacrificed.
## Scry
Goes off after a player has scryed and put the card(s) in the proper
place.
Examples: Flamespeaker Adept, Knowledge and Power
There is 1 special parameter:
- ValidPlayer - The player that scryed must match this.
There is 1 Triggered-variable:
- Player - The player that scryed.
## SearchedLibrary
Goes off when a player searches a library.
Examples: Ob Nixilis, Unshackled.
There are 2 special parameters:
- ValidPlayer - The player searching must match this.
- SearchOwnLibrary - If true, the player must be searching his or her
own library (Didn't see that one coming, did ya? :P)
There is 1 Triggered-variable:
- Player - The player searching.
## SetInMotion
Goes off when an Archenemy Scheme is set in motion.
Examples: A Display of My Dark Power, Perhaps You've Met My Cohort.
There is 1 special parameter:
- ValidCard - The scheme card that is set in motion must match this.
There is 1 Triggered-variable:
- Scheme - The scheme card that is set in motion.
## Shuffled
Shuffled-triggers go off whenever a player shuffles his/her library.
Examples: Cosi's Trickster, Psychic Surgery.
There is 1 special parameter:
- ValidPlayer - The player who's turn it should be.
There is 1 Triggered-variable:
- Player - The player whose turn it is.
## SpellCast, AbilityCast & SpellAbilityCast
Triggers go off whenever a spell,ability or either respectively is cast
by either player.
Examples: AEther Barrier, Burning-Tree Shaman, Grip of Chaos.
There are 4 special parameters:
- ValidControllingPlayer - The player who controls the cast spell must
match this.
- ValidActivatingPlayer - The player who activated the ability/spell
must match this. (NOTE: For spells, the activator and controller are
the same. They usually the same for abilities too, with the
exception being abilities that can be activated by any player)
- ValidCard - The card the cast spell or ability originates from must
match this.
- TargetsValid - If this parameter is present, the spell or ability
must be targeted and at least one of it's targets must match this.
There are 4 Triggered-variable:
- Card - The card that the cast spell or ability originates from.
- SpellAbility - The SpellAbility object.
- Player - The player that controls the card that the cast spell or
ability originates from.
- Activator - The player that activated the ability.
## Taps & Untaps
These triggers go off when a permanent taps or untaps.
Examples: Artifact Possession, Frightshroud Courier.
There is 1 special parameter:
- ValidCard - The card that taps or untaps must match this.
There is 1 Triggered-variable:
- Card - The card that was tapped/untapped.
## TapsForMana
This trigger goes off when a land is tapped for a mana ability.
Examples: Bubbling Muck, Market Festival.
There is 1 special parameter:
- ValidCard - The card that taps.
There are 3 Triggered-variable:
- Card - The card that was tapped.
- Player - the payer that did the tapping
- Produced - a String of the Mana produced by this tapping.
## Transformed
Goes off when a card changes state from Original to Transformed or vice
versa. (But not between any other 2 states)
Examples: Afflicted Deserter // Werewolf Ransacker, Huntmaster of the
Fells // Ravager of the Fells.
There is 1 special parameter:
- ValidCard - The card that changes state must match this.
There is 1 Triggered-variable:
- Transformer - The card that changes state.
## TurnFaceUp
Goes off when a card changes state from FaceDown to Original. (But not
between any other 2 states)
Examples: Aphetto Exterminator, Fatal Mutation.
There is 1 special parameter:
- ValidCard - The card that changes state must match this.
There is 1 Triggered-variable:
- Card - The card that changes state.
## Unequip
Goes off when an equipment card is unattached from a creature, wether
it's voluntarily unattached or not.
Examples: Grafted Exoskeleton, Grafted Wargear.
There are 2 special parameters:
- ValidCard - The card that the equipment is unattached from must
match this.
- ValidEquipment - The equipment being unattached must match this.
There are 2 Triggered-variables:
- Card - The card that the equipment is unattached from.
- Equipment - The equipment being unattached.
## Vote
Goes off when a vote is called for, after all votes are cast.
Examples: Grudge Keeper.
There are no special parameters.
There is 1 Triggered-variable:
- OtherVoters - A collection of every player who voted, EXCEPT the
controller of the trigger's host card.
# Restrictions
You can use certain optional parameters to further restrict when a
trigger should go off. These parameters are:
- TriggerZones - This parameter can be used to restrict which zone the
card must be in in order for the trigger to go off. For example, if
the trigger should only go off while the card is in the graveyard
(As in Auntie's Snitch or Bridge from Below) you can use
`TriggerZones$ Graveyard`
- TriggerPhases - This parameter can be used to restrict the phases in
which the trigger can trigger.
- OpponentTurn - This parameter can be used to restrict the trigger to
only trigger on your opponents turn.(True/False)
- PlayerTurn - This parameter can be used to restrict the trigger to
only trigger on your turn.(True/False)
- Metalcraft - If this parameter is set to "True", the controller of
this card must have 3 or more artifacts on the battlefield for the
trigger to go off.
- Threshold - As Metalcraft but requires the controller of the card to
have 7 cards in the graveyard.
- PlayersPoisoned - This parameter specifies that a certain or both
players must have at least 1 poison counter. Valid values are "You",
"Opponent" or "Each".
- IsPresent - This parameter expects a
[ValidCard](Forge_ValidCards "wikilink") formula and only lets the
trigger go off if there is a permanent on the battlefield that
matches it.
- PresentCompare,PresentZone & PresentPlayer - These parameters only
matter if the IsPresent parameter is used. They can be used to
narrow down and how many valid cards must be present and where they
must be.
- IsPresent2,PresentCompare2,PresentZone2 & PresentPlayer2 - Second
requirement (see above).
- CheckSVar - Calculates the named SVar and compares the result
against the accompanying SVarCompare parameter which takes the form
of <operator><operand> where <operator> is in LT,LE,EQ,NE,GE,GT.
# Examples
Learn by example\!
## Contagion Clasp
(When Contagion Clasp enters the battlefield, put a -1/-1 counter on
target creature.) The first thing to do is to identify the WHEN, i.e.
when the trigger should go off so that we can decide on the proper mode.
Here it should go off when a particular card moves from one zone into
another, so ChangesZone is the logical mode here.
`T:Mode$ ChangesZone`
Next we look at which of ChangesZone's 3 special parameters we want to
make use of. Well, we want the trigger to go off when the card enters
one specific zone, so we'll want to use the Destination parameter. Also,
we only care about when it's a specific card being moved so we'll use
ValidCard.
`T:Mode$ ChangesZone | Destination$ Battlefield | ValidCard$
Card.Self`
There, we've defined a trigger that goes off when this card moves from
any zone (remember, Origin and Destination defaults to "Any") to the
battlefield zone. But we still have to use two more parameters. First,
"Execute". Execute should contain the name of the SVar that holds the
Ability you want to be triggered.It can be any valid SVar name. I like
to follow the convention "Trig<name of the abilityfactory used>" but
your mileage may vary.
`T:Mode$ ChangesZone | Destination$ Battlefield | ValidCard$ Card.Self |
Execute$ TrigPutCounter`
Lastly, "TriggerDescription". This is what will be put in the cards text
box, i.e. the rules text. Always try to keep it as close to Oracle
wording as possible. Also, you should use "CARDNAME" instead of the name
of the card for convention.
`T:Mode$ ChangesZone | Destination$ Battlefield | ValidCard$ Card.Self |
Execute$ TrigPutCounter | TriggerDescription$ When CARDNAME enters the
battlefield, put a -1/-1 counter on target creature.`
So we're all done,then?No, it's not a triggered <b>ability</b> until it
actually has an ability. To define the ability we want to be triggered
we simply use an [AbilityFactory](Forge_AbilityFactory "wikilink") but
instead of putting it on it's own line beginning with "A:", we put it in
an SVar named what we put for the Execute parameter.
`T:Mode$ ChangesZone | Destination$ Battlefield | ValidCard$ Card.Self |
Execute$ TrigPutCounter | TriggerDescription$ When CARDNAME enters the
battlefield, put a -1/-1 counter on target creature.`
`SVar:TrigPutCounter:AB$PutCounter | Cost$ 0 | Tgt$ TgtC | CounterType$
M1M1 | CounterNum$ 1`
You may notice some strange things about the ability, namely the Cost
parameter and the lack of a SpellDescription parameter.The reasoning for
these things is that AbilityFactory requires non-drawback abilities to
have a cost and drawback abilities not to have one. But if you want to
do something like "When CARDNAME comes into play, you may pay 1 to...",
that's where you'd use the Cost parameter here. The SpellDescription is
missing because triggers use their own TriggerDescription instead.
## AEther Vial
(At the beginning of your upkeep, you may put a charge counter on AEther
Vial.) Okay let's apply the procedure we learned when doing Contagion
Clasp:
Identify the WHEN - It should go off at the beginning of a specific
PHASE so, well, Phase mode it is\!
`T:Mode$ Phase`
Next,look at Phase modes special parameters: Phase and ValidPlayer. We
can tell right away that Phase should be "Upkeep" and ValidPlayer should
be "You" since it should only trigger on your turn.
`T:Mode$ Phase | Phase$ Upkeep | ValidPlayer$ You`
Next up, we have to make sure that the trigger only goes off when AEther
Vial is in play. If it's not, why would we want to put counters on it?
We can use the TriggerZones parameter to restrict where the card must be
in order for the trigger to go off. It takes a comma-separated list of
zones but since we only want AEther Vial to trigger when it's on the
battlefield, we just give it "Battlefield".
`T:Mode$ Phase | Phase$ Upkeep | ValidPlayer$ You | TriggerZones$
Battlefield`
Now then, there's one word in the rules text that changes things: "may".
To give the player a choice about wether or not to make use of the
triggered ability, we can use the OptionalDecider parameter. It's used
the same way as Defined parameters for AFs and the player it evaluates
to gets to decide if the trigger happens.
`T:Mode$ Phase | Phase$ Upkeep | ValidPlayer$ You | TriggerZones$
Battlefield | OptionalDecider$ You`
Lastly as before, we add the Execute and TriggerDescription
parameters...
`T:Mode$ Phase | Phase$ Upkeep | ValidPlayer$ You | TriggerZones$
Battlefield | OptionalDecider$ You | Execute$ TrigPutCounter |
TriggerDescription$ At the beginning of your upkeep, you may put a
charge counter on CARDNAME.`
...And our mad AbilityFactory-skills to write up the actual ability\!
`T:Mode$ Phase | Phase$ Upkeep | ValidPlayer$ You | TriggerZones$
Battlefield | OptionalDecider$ You | Execute$ TrigPutCounter |
TriggerDescription$ At the beginning of your upkeep, you may put a
charge counter on CARDNAME.`
`SVar:TrigPutCounter:AB$PutCounter | Cost$ 0 | Defined$ Self |
CounterType$ CHARGE | CounterNum$ 1`
DING\! Goblins are up\!
## Cinder Wall
(When Cinder Wall blocks, destroy it at end of combat.) This will be an
example of a delayed trigger. A delayed trigger goes on the stack twice,
once when the conditions are met, and once when the effect should
happen.In Cinder Wall's case, once when it blocks, and once at the
following end of combat step. To start with, we create a Blocks trigger
that looks this.
`T:Mode$ Blocks | ValidCard$ Card.Self`
And this is where delayed triggers differ from ordinary triggers.We do
NOT add an Execute parameter that points to an SVar containing the
trigger's effect as an AF. Instead we add a DelayedTrigger parameter
that points to an SVar containing ANOTHER trigger that specifies when
the delayed effect should occur. This delayed trigger is built like an
ordinary trigger and further points to an ability (Using the Execute
parameter).Don't forget to omit the "T:" from the delayed trigger, for
the same reason you omit "A:" from abilities in SVars\!
`T:Mode$ Blocks | ValidCard$ Card.Self DelayedTrigger$ DelTrig |
TriggerDescription$ When CARDNAME blocks, destroy it at end of
combat.`
`SVar:DelTrig:Mode$ Phase | Phase$ EndCombat | Execute$ TrigDestroy |
TriggerDescription$ Destroy CARDNAME.` `SVar:TrigDestroy:AB$Destroy |
Cost$ 0 | Defined$ Self`
# Test Cards
If you want some test cards for each trigger try these:
Always (Covetous Dragon)
DeclareAttack (Lightmine Field)
Attacks (Battle Cry)
Unblocked (Abyssal Nightstalker)
Blocked (Flanking)
Blocks (Wall of Junk)
Targeted (Tar Pit Warrior)
ChangeZones (Wall of Blossoms, AEther Flash, Valakut)
Phase (Bottomless Pit)
SpellAbilityCast (Dragonlair Spider)
Unqeuip (Grafted Wargear)
Sacrifice (Grave Pact)
Taps (Stonybrook Schoolmaster)
Untaps (Hollowsage)
Championed (Mistbind Clique/delayed due to input issue)
ChangeControllers (?)
CounterAdded (Flourishing Defenses)
CounterRemoved (Fungal Behemoth)
Clashed (Sylvan Echoes)
Cycled (Bant Sojourners)
Damaged (Akki Underminer, Living Artifact)
Discarded (Megrim)
Drawn (Underworld Dreams)
LandPlayed (Horn of Greed)
LifeGained (Ajani's Pridemate)
LifeLost (Mindcrank)
LoseGame
SetInMotion
Shuffled (Cosi's Trickster)
TapsForMana (Mana Flare)
Transformed (Afflicted Deserter)
TurnFaceUp (Bloodstoke Howler)

90
docs/Configure-Planes.md Normal file
View File

@@ -0,0 +1,90 @@
Base settings of a plane is configured in
config.json
Example:
```json
{
"screenWidth": 480,
"screenHeight": 270,
"skin": "skin/ui_skin.json",
"playerBaseSpeed": 32,
"minDeckSize": 40,
"starterDecks": [
"decks/starter/white.json",
"decks/starter/black.json",
"decks/starter/blue.json",
"decks/starter/red.json",
"decks/starter/green.json"
],
"restrictedCards": [
"Black Lotus",
"Ancestral Recall"
],
"restrictedEditions": [],
"legalCards":{
"editions": ["M22","M21"]
},
"difficulties": [
{
"name": "Easy",
"startingLife": 16,
"staringMoney": 500,
"enemyLifeFactor": 0.8,
"spawnRank": 0,
"sellFactor": 0.6,
"startItems": [
"Manasight Amulet",
"Leather Boots"
]
},{
"name": "Normal",
"startingLife": 12,
"staringMoney": 250,
"startingDifficulty": true,
"enemyLifeFactor": 1.0,
"spawnRank": 1,
"sellFactor": 0.5,
"startItems": [
"Leather Boots"
]
},{
"name": "Hard",
"startingLife": 8,
"staringMoney": 125,
"enemyLifeFactor": 1.5,
"spawnRank": 2,
"sellFactor": 0.25
}
]
}
```
# Fields:
## **screenWidth**
## **screenHeight**
Logical screen with/height, changing this would require to change all ui elements and won't increase resolution.
## **skin**
path to the used skin for adventure
## **playerBaseSpeed**
base speed of player character
## **minDeckSize**
minimum deck size for matches, decks with lesser cards will be filled with wastes.
## **starterDecks**
string list of all starter decks
## **restrictedCards**
string list of restricted cards, those cards won't appear in random shops or rewards but it it still possible to get those cards if the plane specifically drops it.
## **restrictedEditions**
string list of restricted editions, behaves the same as restricedCards but with editions.
## **difficulties**
list of DifficultyData
## **legalCards**
RewardData for legal cards, behaves similar as restrictedCards only as white list and not black ist.
Also it is defined as RewardData see [Create-Rewards](https://github.com/Card-Forge/forge/wiki/Create-Rewards) for syntax

23
docs/Configure-Sets.md Normal file
View File

@@ -0,0 +1,23 @@
In order to edit which sets will show up in random rewards and shop you will need to edit the config file. You can find it here "forgefolder"\res\adventure\common\config.json. Add the sets you want to have restricted to the "restricted edition" section
![image](https://github.com/user-attachments/assets/24ad9686-8ec9-453b-a496-03b33c1719f2)
### Funny
PCEL, PAST, UGL, UNH, HHO, DS0, PHTR, UST, PUST, PH17, PH18, CMB1, UND, PH19, PH20, PH21, UNF, DA1, PH22, MB2
### Commander
COM, CM1, C13, C14, C15, C16, C17, CMA, CM2, C18, C19, C20, ZNC, KHC, C21, AFC, MIC, VOC, NEC, NCC, DMC, 40K, BRC, SCD, ONC, MOC, LTC, CMM, WOC, WHO, LCC, MKC, PIP, OTC, M3C, BLC, DSC, PDC
### Starters
CLU, LTR, CLB, CMD, MB1
### Digital
PRM, MBP, MED, ME2, ME3, TD0, TD1, ME4, VMA, TPR, PZ1, PZ2, ANA, PANA, HA1, HA2, HA3, AJMP, AKR, ANB, KLR, HA4, HA5, J21, YMID, YNEO, YSNC, HBG, EA1, HA6, YDMU, YBRO, EA2, YONE, SIS, SIR, EA3, HA7, YWOE, YMKM, YOTJ, YBLB, YDSK
### Promos
DRC94, PHPR, PLGM, PMEI, PARL, PRED, PTMP, JGP, PSTH, PEXO, PALP, PUSG, PAL99, G99, PULG, PUDS, PPTK, PGRU, PWOR, PWOS, PMMQ, PSUS, PAL00, FNM, G00, PELP, PNEM, PPCY, PINV, PAL01, F01, G01, MPR, PPLS, PAPC, PSDG, PODY, PAL02, F02, G02, PTOR, PJUD, PHJ, PAL03, F03, PJJT, G03, P03, OVNT, PLGN, PONS, PSCG, P8ED, PAL04, F04, G04, P04, PDST, P5DN, PMRD, PCHK, PAL05, F05, G05, PJSE, P05, PMPS, PBOK, PSOK, P9ED, PRAV, P2HG, PAL06, DCI, F06, G06, PJAS, P06, PMPS06, PGPT, PCMP, PDIS, PCSP, PTSP, F07, G07, PMPS07, PRES, PPLC, PPRO, PGPX, PFUT, P10E, PLRW, F08, G08, P08, PMPS08, PMOR, P15A, PSHM, PEVE, PALA, PDTP, F09, G09, P09, PMPS09, PBOOK, PCON, PURL, PARB, PM10, PZEN, PDP10, F10, G10, P10, PMPS10, PWWK, PROE, PM11, PSOM, PDP12, F11, G11, OLGC, P11, PMPS11, PW11, PMBS, PNPH, PM12, PISD, PDP13, F12, PIDW, J12, PW12, PDKA, PAVR, PHEL, PM13, PRTR, PDP14, F13, J13, PGTC, WMC, PDGM, PM14, PSDC, PTHS, PDP15, F14, J14, PBNG, PJOU, PCNS, PS14, PPC1, PM15, PKTK, F15, J15, UGF, PFRF, PDTK, PTKDF, PS15, PORI, PSS1, PBFZ, F16, J16, POGW, PSOI, PEMN, PKLD, PS16, F17, J17, PAER, PAKH, PHOU, PS17, PXLN, PSS2, PXTC, J18, PRIX, PNAT, PDOM, PM19, PSS3, PS18, PGRN, PRWK, G18, PF19, PRNA, PRW2, J19, PWAR, PMH1, PM20, PPP1, PS19, PWCS, J20, PF20, PLG20, PL21, PW21, PLG21, Q06, P22, PL22, PW22, GDY, PLG22, SCH, PSVC, P30M, P30A, P30H, PRCQ, BOT, PEWK, P23, PR23, PW23, PL23, SLP, PF23, P30T, PMDA, REX, PF24, PW24, PL24, PSS4, PCBB, PLG24, PLTC, PF25, PSPL, PJSC
### Universes Beyond
40K,SLD,ACR,PCBB,PIP,REX,WHO,LTR,LTC,BOT,HBG,CLB,AFR

View File

@@ -0,0 +1,43 @@
Forge provides an in-game console in adventure mode.
You can access (and close) the console while exploring by pressing F9 (or Fn-F9).
To scroll the console window, click and drag the text box.
## Available commands
| Command Example | Description |
| -- | -- |
| resetMapQuests | Resets the map quests, resulting in all side-quest progress being lost and all side-quest types being re-picked |
| give gold 1000 | Give 1000 gold |
| give shards 1000 | Give 1000 shards |
| give print lea 232 | Add an alpha (LEA set code) black lotus (232 collector number) |
| give item <item name or code?> | Adds an in game item such as leather boots |
| give set sld | Give 4 copies of every card in the Secret Lair Drop (set code SLD), flagged as having no sell value |
| give nosell card forest | Gives a forest with no sell value |
| give boosters leb | Add a booster from beta (LEB set code) |
| give quest 123 | Add the quest by its number ID |
| give life 10 | Add 10 life to yourself |
| give card forest | Adds a forest to your inventory |
| debug collision | Displays bounding boxes around entities |
| debug map | TODO |
| debug off | Turns off previously enable debugging |
| teleport to 6000 5000 | Moves you 6000 tiles east and 5000 tiles north from the left bottom corner |
| fullHeal | Returns your health back to baseline |
| sprint 100 | Increases your speed for 100 seconds |
| setColorId R | Sets the player color identity; Probably used for testing and shops |
| clearnosell | Clears the no sell value flag from all cards you own that are not used in a deck |
| remove enemy abc | Remove the enemy from the map with the map ID abc |
| remove enemy all | Remove all the enemies from the map |
| dumpEnemyDeckList | Print the enemy deck lists to terminal output stream |
| getShards amount 100 | Similar to give shards command; Gives 100 shards to the player |
| resetQuests | Resets the world quests. In progress quests are not abandonned or reset including dungeons. Does not reroll abandoned quests. Not really sure what this does. |
| hide 100 | Enemies do not chase you for 100 seconds |
| fly 100 | You can walk over obstacles for 100 seconds |
| crack | Cracks a random item you are wearing |
| spawn enemy Sliver | Spawns a Sliver on your screen |
| listPOI | Prints all locations in terminal output stream as ID-type pairings |
| leave | Gets you out of the current town/dungeon/cave |
| dumpEnemyColorIdentity | Prints all enemies, their colour affinity and deck name to terminal output |
| heal | Recover your full health |
| dumpEnemyDeckColors | Prints all decks available to enemies and their affinities |

107
docs/Create-Enemies.md Normal file
View File

@@ -0,0 +1,107 @@
All Enemies are stored under `res/<AdventureName>/world/enemies.json`
Enemies spawned on the overworld map or on map stages will use this exact template to define their base behavior. These values can be modified or added to with additional settings on an individual enemy basis, details of which can be found within [map instance](Create-new-Maps).
Some ideas for custom enemy cards:
- basic (CR or at least Alchemy conform) effects for normal mobs to add flavor
- advanced + all UN stuff. but their mechanics could be combined in new ways not seen in print
- boss/rare ones that are balanced around meta mechanics (=quests)
The Json file contains an Array of Objects and each Object is one enemy.
EnemyObject:
```json
{
"name": "Challenger 20",
"nameOverride": "Challenger",
"sprite": "sprites/monsters/doppelganger.atlas",
"deck": [
"decks/challenger/challenger_20_allied_fires.dck",
"decks/challenger/challenger_20_cavalcade_charge.dck",
"decks/challenger/challenger_20_final_adventure.dck",
"decks/challenger/challenger_20_flash_of_ferocity.dck"
],
"ai": "",
"randomizeDeck": true,
"spawnRate": 0.25,
"difficulty": 0.25,
"speed": 28,
"life": 22,
"rewards": [],
"colors": "UBRWG",
"questTags": [
"Challenger",
"IdentityUnknown",
"BiomeGreen",
"BiomeRed",
"BiomeColorless",
"BiomeWhite",
"BiomeBlue",
"BiomeBlack"
]
}
```
# Fields:
## **name**
String - Has to be unique
Name of the enemy, every time an other object will use an enemy, it will refer to this name.
## **nameOverride**
String - If provided, this will be displayed in any references to this enemy in the game. If not provided, Name will be used.
## **sprite**
String - Path to the sprite atlas for the enemy (from `res/<AdventureName>`)
In fights against the enemy, the sprite under "Avatar" will be used as avatar picture.
Every sprite under
"Idle","Walk","Attack","Hit","Death"
will be used as animation for the corresponding action.
direction can be added to alter the animation depending on the direction like "IdleRight"
Supported directions are "Right","Left","Up","Down","RightDown","LeftDown","LeftUp","RightUp"
## **deck**
Array of strings containing paths to the decks used for this enemy (from `res/<AdventureName>`)
If no decks are defined then the enemy will act like a treasure chest and give the rewards without a fight.
(only for enemies in dungeons)
The format for the deck file can be the normal forge *.dck syntax or a json file that will behave like a collection of [rewards](Create-Rewards) to get a random generated deck.
## **randomizeDeck**
Boolean - if true then the enemy deck will be randomly selected from the deck array. If false, an algorithm will select a deck in sequential order based on the player's prior win/loss ratio against that opponent (discouraged and currently unused due to wild swings in ratio at low game count).
## **ai**
String - Currently unused, this appears to be intended to allow different playstyles to be associated with this enemy.
## **boss**
Boolean - Not used to any great extent at this time, but a value of true in this field indicates that this is a boss-level enemy for which the match presentation can be changed if desired. Currently, this causes capable Android devices to vibrate for a longer period on collision with the enemy sprite.
## **flying**
Boolean - If true, this enemy ignores terrain collisions and can travel freely in their intended movement direction.
## **spawnRate**
Decimal - Relative frequency with which this enemy will be picked to spawn in appropriate biomes (which are set in the biome json file). Existing values range from 0 to 1.0.
## **difficulty**
Decimal - Relative estimated difficulty associated with this enemy. Currently unused, but will likely be factored in as a part of filtering enemies into early/late game appropriate opponents. Existing values range from 0 to 1.0.
## **speed**
Integer - Movement speed of this enemy in overworld or on a [map instance](Create-new-Maps). For comparison, the player's base speed is set at a value of 32 (before any equipment / ability modifiers).
## **scale**
Decimal - Default 1.0. For enemies whose sprites are too large or small for their intended usage, this serves as multiplier for the enemy's visual dimensions & collision area. By default, we work with 16x16 pixel sprites for most entities - this can be replicated with a more detailed 32x32 sprite by setting a scale of 0.5 for the enemy entry.
## **life**
Integer - Base starting life total. This is modified universally by a value determined by the player's chosen difficulty, and can be adjusted further at the enemy object level on [map instances](Create-new-Maps).
## **rewards**
Array - A collection of the rewards to be granted for defeating the enemy.
see [Create Rewards](Create-Rewards) for the syntax.
## **equipment**
Array - A collection of strings representing [equipment items](adventure-items) normally intended for player use that this enemy will have. Not used widely, usually when an enemy will drop that [equipment](adventure-items) and it does not use [mana shards](mana-shards).
## **colors**
String - Any combination of "B" (Black), "U" (Blue), "C" (Colorless), "G" (Green), "R" Red, and "W" (White). Used to display color identity alongside the sprite when an active ability allows it.
## **questTags**
Array- A collection of strings associated with this entity for filtering in regards to quests.

178
docs/Create-Rewards.md Normal file
View File

@@ -0,0 +1,178 @@
Rewards represent anything that can be obtained by the player in Adventure Mode. Cards are the most common type of reward, but rewards can also represent a pieces of equipment, gold, mana shards, maximum life increases, keys, or generic items to be interacted with via dialogs and quests.
Rewards are associated with...
* Enemies - The loot they drop when defeated.
* Lootable items - Treasure chests, piles of gold, spellbooks, or mana shards on dungeon maps.
* Shops - The items available for purchase.
* Dialog - Items given to the player during a dialog sequence OR required in order to have access to an option.
* Quests - Rewards for completion of a quest.
* Events - Rewards for completion of an event.
As a multipurpose concept, Reward data has a large number of fields, but almost all are optional and no one reward will use all of the fields.
The expected fields and behavior for the rewards are set based on the reward's `type` value. This is the one field that all reward data must contain, as it tells the game what other fields to expect data in and how to process them.
The simplest types are `gold` (give the player X gold), `shards` (give the player X [mana shards](mana-shards), and `life` (increase the player's current and maximum life total by this amount [given very sparingly]). Beyond their types, these three items only require a `count` field. Optional fields for these types include `probability` and `addMaxCount`, (see full list at bottom). An example of a `gold` reward that will grant the player 50 gold follows:
```json
{
"type": "gold",
"count": 50
}
```
`Item` rewards are slightly more specific, but still relatively simple, requiring `type`, `count`, and EITHER `itemName` or `itemNames`, examples of both follow. Optional parameters again include `probability` and `addMaxCount`. If `itemName` is specified, then `count` copies of the named item will be granted to the player. If `itemNames` is specified, `count` copies of items randomly selected from the list of named items provided will be granted instead.
```json
{
"type": "item",
"count":1,
"itemName": "Mithril Boots"
}
```
```json
{
"type": "item",
"count":1,
"itemNames": ["Mithril Boots", "Mithril Shield", "Mithril Armor"]
}
```
`Card` rewards are potentially the most complex from a definition standpoint, but almost all of the fields are optional. A simple and a complex example follow below.
Granting the player one completely random card that is legal for use in Adventure:
```json
{
"type": "card",
"count":1
}
```
As a contrasting and complicated example that will return no matching results, consider the card reward data below. 80% of the time, this will try to grant the player 1-9 (modified further by difficulty) cards that are rare, multicolor, contain both red and blue in their color identity, are from M21 or M22 editions, are either instants or creatures, have the Elf subtype, contain the word "dragon" in the card name, contain the word "destroy" and/or "exile" in the card text. Details on the individual fields can be found in the reference list at the bottom of this page.
```json
{
"type": "card",
"probability": 0.8,
"count":1,
"addMaxCount":8,
"colors": ["red","blue"],
"rarity": ["rare"],
"editions": ["M22","M21"],
"cardTypes": ["Instant","Creature"],
"colorType": "MultiColor",
"subTypes": ["Elf"],
"superTypes" :["Legendary"]
"cardName": "dragon",
"cardText": "destroy|exile"
}
```
`Union` reward types are a purely structural element. This reward type does nothing on its own, but it is used as wrappers for multiple `card` instances that has distinctly separate parameters. Required elements are `type` (Union), `count`, and `cardUnion` (which contains additional `card` reward definitions). Optional parameters are, once again `addMaxCount` and `probability`. As an example, the following would award the player with a single red dragon from M21 OR a single green sorcery from M22, but never a red sorcery, M22 dragon, or so on. The individual card pools are conjoined, giving an equal chance of all possible cards across the pools.
```json
{
"count":1,
"type":"Union",
"cardUnion": [
{
"count":1,
"editions": ["M21"],
"subTypes": ["Dragon"],
"colors": ["red"]
},
{
"count":1,
"editions": ["M22"],
"cardTypes": ["Sorcery"],
"colors": ["green"]
}
]
}
```
# Fields:
## **type**
Defines the type of reward.
Valid options are:
* `gold` will reward the player with gold.
* `life` will increase the maximum life of the player.
* `shards` will reward the player with [mana shards](mana-shards).
* `item` will give items to be added to the player's inventory.
* `card` will create one or more cards matching a detailed set of filters to follow.
* `union` is a wrapper for multiple `card` instances that can have mutually exclusive filters.
* `deckCard` is only used with rewards from [enemies](Create-Enemies), this functions as a `card` reward that is limited to cards found in that enemy's deck.
`{"type": "card", ...}`
## **probability**
The probability of this reward being given out, on a decimal scale from 0 to 1. (Defaults to 1 if not provided)
`{..., "probability": 0.5, ...}`
## **count**
If given at all (see `probability`, above), get at least this many of the reward.
`{..., "count": 10, ...}`
## **addMaxCount**
If given at all, an additional "addMaxCount" instances of the reward will be added. A pre-set multiplier based on the chosen difficulty is applied to this parameter. On normal difficulty, you will get the reward "count" to "addMaxCount" times, `{"type": gold", "count":10, "addMaxCount":5"}` would give anywhere from 10 to 15 gold. (Defaults to 0 if not provided)
`{..., "addMaxCount": 5, ...}`
## **colors**
An array of the possible colors for `card` and `deckCard`.
`{..., "colors": ["red", "black"], ...}`
## **rarity**
An array of the possible raritys for `card` and `deckCard`.
`{..., "rarity": ["basicland", "common", "uncommon", "rare", "mythicrare"], ...}`
## **editions**
An array of the possible editions for `card` and `deckCard`, referenced by their 3 character set code.
`{..., "editions": ["ONE", "MOM", "MAT"], ...}`
## **cardTypes**
An array of the possible cardTypes for `card` and `deckCard`.
`{..., "cardTypes": ["Creature", "Artifact", "Enchantment", "Instant", "Sorcery", "Planeswalker", "Battle"], ...}`
## **subTypes**
An array of the possible subTypes for `card` and `deckCard`.
Usually used for creature types, but can also denote names of planeswalkers, types of battles, etc.
`{..., "subTypes": ["Elf", "Dragon", "Gideon", "Urza", "Siege", "Tribal"], ...}`
## **superTypes**
An array of the possible superTypes for `card` and `deckCard`.
`{..., "superTypes ": ["Legendary", "Basic", "Snow"], ...}`
## **cardName**
The exact name of a `card` to use.
`{..., "cardName": "Llanowar Elves", ...}`
## **cardText**
A regular expression defining text that must appear on the card. A sequence of plain text alphanumeric (A-Z, 0-9) characters can function here if you are unfamiliar with regular expressions, but many special characters will change the functionality. Useful for denoting keywords or identifying helper cards that are associated with but do not actually have a given type.
`{..., "cardText": "reveal the top card of", ...}`
`{..., "cardText": "cast (an instant|a sorcery) from your hand", ...}`
## **deckNeeds**
This is a functional but partially implemented concept at best, as the result set is currently limited. Card scripts can be tagged as having certain attributes that are used for creating synergies in decks constructed by the game. If/when this feature is expanded to more of our script library, the using those tags will become more and more useful to use for defining rewards so as to allow "concepts" to be awarded as opposed to specific card names or text contents.
`{..., "deckNeeds": ["Ability$Graveyard"], ...}`
## **cardPack**
This element should not be seen or used in JSON definitions of reward data. `cardPack` rewards are a type that represent a collection of cards whose contents have been pre-determined in game logic (such as a drafted deck that can be kept after an event), but that were not pre-determined at the time when the reward data was written. To manually implement granting specific or randomized cards we should use one or more `card` rewards, detailed above. When granted, this will create an item in the player's inventory that can subsequently be opened by the player to award the individual card contents of the associated deck.

42
docs/Create-new-Maps.md Normal file
View File

@@ -0,0 +1,42 @@
Maps in the adventure mode are created with the tool Tiled
[](https://www.mapeditor.org/)
Open the tiled-project under `<adventure>/maps/main.tiled-project`
![Screenshot_2021-09-01_140346](https://user-images.githubusercontent.com/8047400/162841209-c9c7aae3-b21d-47ab-9bd4-c9c79fb511bf.png)
This will allow you to edit the maps and tile sets.
To interact with the player, objects needs to be added to the Objects layer.
Objects templates are stored in the "obj" folder, but are not necessary.
Impotent are the types of the object and his properties.
## Object types
# enemy
will spawn an Enemy on the map. On collide with the player a magic duel will be started.
If the player win, the enemy will be removed from the map and the player will get the reward.
If the player loose, then the player will move 1 step back and receive the standard penalty.
Loot is also defined as enemy without a deck, then the player will receive the reward right away.
Properties:
`enemy` name of the enemies
# shop
Will spawn an shop on the map. On collide the player will enter the shop.
Properties:
`shopList` List of possible shop, leave it empty for all shops.
`signXOffset` x offset for the shop sign.
`signYOffset` y offset for the shop sign.
# inn
Will spawn an inn the map. On collide the player will enter the inn.
Properties:
# entry
Will be used as the map entry and exit. On collide the player will be teleported to an other map or the over world.
Properties:
`direction` the position where to spawn. up means the player will be teleported to the upper edge of the object rectangle.
`teleport` The map where the player gets teleported. If the property is empty, then the player will be teleported to the over world.
`teleportObjectId` the object id where the player will be teleported. If empty then it will search for an entry object, that would teleport the player back to the source map.

View File

@@ -0,0 +1,178 @@
# Guide - Creating a Custom Card
Using the Forge API you can create your own custom cards and sets. This guide will walk you through the process of creating custom cards via the Force Custom Card Script.
The next tutorial will walk you through the process of adding your new cards to a custom set.
## File Locations
### Custom Card Scripts
Windows:
> C:/Users/<your username>/Application Data/Roaming/Forge/custom/cards
Linux:
> ~/.forge/custom/cards
Mac:
> TODO Add filepath
### Custom Tokens
Windows:
> C:/Users/<your username>/Application Data/Roaming/Forge/custom/tokens
Linux:
> ~/.forge/custom/tokens
Mac:
> TODO Add filepath
### Custom Editions
> C:/Users/<your username>/Application Data/Roaming/Forge/custom/editions
Linux:
> ~/.forge/custom/editions
Mac:
> TODO Add filepath
### Card Images
Windows:
> C:/Users/<your username>/Application Data/Local/Forge/Cache/pics/cards
Linux:
> ~/.cache/forge/pics/cards
Mac:
> TODO Add filepath
## Creating a New Card
In this tutorial we'll create a new card called "Goblin Card Guide".
1. Open Script Directory
Navigate to your Custom Card Scripts folder and open (or create) the subfolder for the starting letter of your new card.
In our example:
> C:/Users/<your username>/Application Data/Roaming/Forge/custom/cards/g
2. Add Card Script
Create a new .txt file using all lowercase letters. Spaces are represented with "_" and you can leave out special characters like commas or apostrophes.
> goblin_card_guide.txt
Now we need to define our card. Add the following to your Goblin_Card_Guide text file:
```
Name:Goblin Card Guide
ManaCost:1 R
Types:Creature Goblin
PT:2/2
K:Haste
Oracle:Haste
```
Let's break our card down:
- Name - The name as it appears on the card.
- ManaCost - The card's cost with colorless mana first and spaces between different mana symbols.
- Types - The card's type and then any subtypes seperated by spaces.
- PT - Power and Toughness, which is only used for Creatures (or some cards that turn into creatures like Vehicles)
- K - A Keyword that gives our creature an ability.
- Oracle - The actual text that appears on that card.
For a refrence of possible fields and their descriptions please see the [Card Scripting API](Card-scripting-API) document. Note that maintaining an up to date list of every ability of every Magic Card ever printed is not feasable. The API is meant to serve as a guide and includes most common used information.
3. Add Card to a Set
Now that we have a new card we need to add it to a set so that it will be included in the game. For the purposes of this turorial we'll add out card to an existing set. If you wish to create your own set you can follow this guide: `Guide Coming Soon`
Navigate to your Custom Editions folder and open the text file for the set you would like to add your card to. Let's add our card to the "DCI Promos" set.
In the "CDI Promos.txt" file we can see a list of the cards in the set. Add a new entry at the end of the list for our new card:
```
78 R Circle of Flame @James Paick
79 U Stormblood Berserker @Greg Staples
80 R Dungrove Elder @Scott Chou
81 R Goblin Card Guide @Forge Team
```
The first number is the collector number for the card in the set. This must be unique.
The next field is the card's rarity in the set - we've made our card a rare.
Next is the card's name and finally the name of the artist for the cards artwork.
Speaking of which - our card doesn't have any artwork. Let's fix that.
4. Add Card Image
Open your Card Images folder. Find the code for the set you added your new card to and open the corrosponding subfolder. For us this will be:
> C:/Users/<your username>/Application Data/Local/Forge/Cache/pics/cards/PDCI
Add your card image in the folder. Ther are various online tools to create custom cards. For the purposes of the guide you can use this image:
<img src="https://github.com/user-attachments/assets/55363e68-0232-42e2-a1f7-8971686119e6" width="250"/>
5. Add a Triggered Ability
So we've created a creature card and added it to the game. However our creature is a little... boring, so let's update it to have a triggered ability.
"Whenever Goblin Card Guide deals damage to an opponent, draw a card."
Open the txt file again:
> goblin_card_guide.txt
And update the contents to the following:
```
Name:Goblin Card Guide
ManaCost:1 R
Types:Creature Goblin
PT:2/2
K:Haste
T:Mode$ DamageDone | ValidSource$ Card.Self | ValidTarget$ Opponent | TriggerZones$ Battlefield | Execute$ TrigDraw | TriggerDescription$ Whenever CARDNAME deals damage to an opponent, draw a card.
SVar:TrigDraw:DB$ Draw | Defined$ You | NumCards$ 1
Oracle:Haste
\nWhenever Goblin Card Guide deals damage to an opponent, draw a card.
```
Let's take a look at our changes:
- T:Mode$ DamageDone - Trigger when Damage is Done.
- ValidSource$ Card.Self - The source of the trigger. "Self" means our our card must be the source of the damage for the trigger to occur.
- ValidTarget$ Opponent - The target of the trigger. "Oppenent" means our oppenent must receive damage for the trigger to occur.
- TriggerZones$ Battlefield - Means the card must be on the battlefield for the trigger to occur.
- Execute$ TrigDraw - What happens then the trigger occurs - in this case trigger a Draw effect.
- SVar:TrigDraw:DB$ Draw - A String Variable used by the script. This one takes the Triggered Draw (TrigDraw) and tells the script to draw a card. "DB$ Draw" means "Drawback" "Draw".*
- Defined$ You - Who is drawing the card(s), in this case the controller of the card.
- NumCards$ 1 - Draw 1 card. This could be changed to any number to trigger drawing that many card.
- TriggerDescription$ - The description of the trigger.
*"Drawback" is a connotation that has since been replaced with "SubAbility".
The original connotation differentiated between AB (Ability), SP (Spell) and DB (Drawback).
AP and SP require costs, whereas Drawback do not. The card scripts still use the "DB$" connotation.
6. Updating our Image
Finally since we createda new effect on our card, we need to update the image. Card images are simply .jpg files and don't update or read from any scripts or gamefiles.
I used the same online card creator to make the change to our card:
<img src="https://github.com/user-attachments/assets/9c1df095-7d94-4a1a-a30f-9d0f64f6da38" width="250"/>
Simply save and rename the image to "Goblin Card Guide.fullborder.jpg" then overwrite the previous file we used in:
> C:/Users/<your username>/Application Data/Roaming/Forge/custom/cards/g
7. Next Steps
You can check the [Abilities](AbilityFactory) and [Triggers](Triggers) documentation for more information on this topic. These documents are meant as a guide and are unlikely to contain information about every ability in the game.
The sinplest method for creating an effect on your card is to find another card that does the same thing and copying the ability. These can be found in your Forge folder:
>./Forge/res/cardsfolder/cardsfolder.zip
Unzipping this file will sllow you to search for any card in the containing subfolders.

View File

@@ -0,0 +1,258 @@
# Creating a custom set
This is a tutorial to start creating your own custom set, or implementing an existing one. We'll take you step by step into implementing a few cards from [MSEM Champions](https://msem-instigator.herokuapp.com/set/MPS_MSE). This is a basic guide to help you get started.
**Note:** This tutorial is currently for **Windows only**.
## Where do the files go?
### Non-image files
Everything but your cards images go into `%appdata%/Forge/custom`. You will need to put the files in the correct directories in order for the game to load them correctly.
The important folders are the following (you can create them if they don't exist):
* **cards**: Your card rules (logic) go inside this folder (.txt). I suggest you create subfolders inside it to keep everything clean.
* **editions**: Your editions (sets) definition files (.txt) go inside this folder.
* **tokens**: Your tokens definition files (.txt) go inside this folder.
### Image files
Your card and token images go into `%localappdata%/Forge/Cache/pics`.
The important folders are the following:
* **cards**: This is where you will put your card images. You'll want to create a folder with the Code of your edition. The images are named using this convention `Card Name.full.jpg`. If you have multiple art for the same card (something like basic lands, or maybe alternate art of the same card), then you can name them `Card Name1.full.jpg`, `Card Name2.full.jpg`, and so forth.
* **tokens**: Same as the cards folder, your tokens will go inside this folder. The naming convention is `token_script_name.jpg`. So if your token script name is `b_5_5_golem_trample`, then you can put your token image inside your edition folder named `b_5_5_golem_trample.jpg`. If there is a collector number, append it at the beginning, such as `1_b_5_5_golem_trample.jpg`
## Creating your edition definition file
As mentioned in the opening section, we'll be partially implementing the **MSEM Champions** set. Let's create a new text file (.txt) inside `%appdata%/Forge/custom/editions`. Let's name it `MSEM Champions.txt`.
> Note: The file's name don't matter, but it'll be easier to find it if you ever need to edit anything.
Let's paste the following inside it:
```
[metadata]
Code=MSEM_CHAMPIONS
Name=MSEM Champions
Date=2017-10-01
Type=Custom
[cards]
7 M Master Chef
33 M Golden Touch
34 M Avatar of Basat
35 M Exeunt
62 M Unearth
78 M Fox of the Orange Orchard
78★ S Fox of the Orange Orchard
107 M Inked Summoner
107★ S Inked Summoner
130 M Plains
131 M Island
132 M Swamp
133 M Mountain
134 M Forest
[tokens]
b_1_1_bird_flying
b_3_3_cat_deathtouch
b_5_5_golem_trample
[CreatureTypes]
Artist:Artists
```
Let's break it down.
```
[metadata]
Code=MSEM_CHAMPIONS
Name=MSEM Champions
Date=2017-10-01
Type=Custom
```
The **[metadata]** section contains the information about your edition.
* **Code** is an **unique** identifier for your edition.
* **Name** is the name of your edition.
* **Date** is the date the set was first released/created.
* **Type** should be `Custom` as Forge do things differently for them, including but not limited to skipping the automatic download of the images.
```
[cards]
7 M Master Chef
34 M Avatar of Basat
35 M Exeunt
62 M Unearth
78 M Fox of the Orange Orchard
78★ S Fox of the Orange Orchard
107 M Inked Summoner
107★ S Inked Summoner
130 L Plains
131 L Island
132 L Swamp
133 L Mountain
134 L Forest
```
The **[cards]** section contains the cards of your edition. Any card appearing under this section has a chance to appear as a reward and in shops.
Each line is as follow: `CollectorNumber Rarity CardName @ArtistName`.
* The collector number should be unique in a given set. You can see some numbers have a ★ next to their name. In this case it denotes an alternate art of a card, but it could also have been a different number altogether.
> Note: While it generally doesn't matter what collector number you use, avoid using the collector number F followed by only digits (ie. `F001`) as it represents a "Funny" card inside a normal edition. (Think of Funny cards as Un- sets cards)
* The rarity is a one letter representation. It can be L (Basic Land), C (Common), U (Uncommon), R (Rare), M (Mythic Rare), S (Special).
* The card name is self-explanatory. It should match the name of the corresponding card rule. (More of that later)
* The artist is optional, but it should be `@Artist Name` if present. We'll omit it in this tutorial.
> Note: You can put the cards in the list even if they aren't scripted yet. Forge will skip over them.
```
[tokens]
b_1_1_bird_flying
b_3_3_cat_deathtouch
b_5_5_golem_trample
```
The **[tokens]** section is optional, and only needed if you want to use specific token images in this set. They should be named using the name of their token script. `b_1_1_bird_flying` means it is a black 1/1 bird with flying. More on that later.
If you load the game with just file, you'll be able to see that Master Chef, Unearth and the basic lands can already be found in game. That's because they share a name with existing Magic the Gathering cards. **However**, [Master Chef](https://msem-instigator.herokuapp.com/card?q=Master+Chef) from MSEM and [Master Chef](https://scryfall.com/card/clb/241/master-chef) from MTG are two different cards! You must ensure that your custom cards do not have the same name as an existing one, unless you just want it to be another print, just like [Unearth](https://msem-instigator.herokuapp.com/card/CHAMPIONS/62/Unearth) and the basic lands in this example.
Let's comment out Master Chef to avoid a name conflict with an existing MTG card:
```
[cards]
#7 M Master Chef
33 M Golden Touch
...
```
Save your file, and let's move onto another step.
## Scripting your first cards
As mentioned earlier, your custom card rules need to be located inside `%appdata%/Forge/custom/cards`. I recommend creating subfolders for each starting letter (`Forge/custom/cards/a`, `Forge/custom/cards/b`, etc.) to quickly find if a card has a duplicate name.
Now, you might remember than Unearth was an existing MTG card so we do not need to create a custom card rule for it. Let's create a few others.
> This tutorial will not teach you to script your cards, and they might not be perfect. Please check out [Creating a Custom Card](https://github.com/Card-Forge/forge/wiki/Creating-a-Custom-Card) if you want more info, or look at the existing cards to learn more complex scripting.
Let's create the following files:
avatar_of_basat.txt
```
Name:Avatar of Basat
ManaCost:R
Types:Creature Avatar
PT:2/1
S:Mode$ CantBlock | ValidCard$ Card.Self | Description$ CARDNAME can't block.
K:Menace
Oracle:Menace\nAvatar of Basat can't block.
```
exhunt.txt
```
Name:Exeunt
ManaCost:B
Types:Instant
A:SP$ Sacrifice | SacValid$ Creature | Defined$ Player | SpellDescription$ Each player sacrifices a creature.
AI:RemoveDeck:All
Oracle:Each player sacrifices a creature.
```
fox_of_the_orange_orchard.txt
```
Name:Fox of the Orange Orchard
ManaCost:1 W
Types:Creature Fox Spirit
PT:3/1
Oracle:
```
inked_summoner.txt
```
Name:Inked Summoner
ManaCost:1 B
Types:Creature Human Warlock Artist
PT:1/2
T:Mode$ Phase | Phase$ End of Turn | ValidPlayer$ You | TriggerZones$ Battlefield | Execute$ TrigBranch | CheckSVar$ X | SVarCompare$ GE2 | TriggerDescription$ At the beginning of your end step, if you lost 2 or more life this turn, create a 1/1 black Bird creature token with flying. If you lost 4 or more life this turn, instead create a 3/3 black Cat creature token with deathtouch. If you lost 6 or more life this turn, instead create a 5/5 black Golem creature token with trample.
SVar:TrigBranch:DB$ Branch | BranchConditionSVar$ Y | TrueSubAbility$ TrigBranch2 | FalseSubAbility$ DBBird
SVar:TrigBranch2:DB$ Branch | BranchConditionSVar$ Z | TrueSubAbility$ DBGolem | FalseSubAbility$ DBCat
SVar:DBBird:DB$ Token | TokenScript$ b_1_1_bird_flying | TokenAmount$ 1
SVar:DBCat:DB$ Token | TokenScript$ b_3_3_cat_deathtouch | TokenAmount$ 1
SVar:DBGolem:DB$ Token | TokenScript$ b_5_5_golem_trample | TokenAmount$ 1
SVar:X:PlayerCountPropertyYou$LifeLostThisTurn
SVar:Y:Count$Compare X GE4.1.0
SVar:Z:Count$Compare X GE6.1.0
Oracle:At the beginning of your end step, if you lost 2 or more life this turn, create a 1/1 black Bird creature token with flying.\nIf you lost 4 or more life this turn, instead create a 3/3 black Cat creature token with deathtouch.\nIf you lost 6 or more life this turn, instead create a 5/5 black Golem creature token with trample.
```
If you load your game now, you should be able to find these cards you just scripted! You'll also notice that Inked Summoner is only listed as a Human Warlock, missing the Artist subtype. That's because Artist is not a real MTG subtype. You can add custom types directing inside the set definition file by following the sections found inside the `res/lists/TypeLists.txt` file. Duplicates will be ignored.
```
[CreatureTypes]
Artist:Artists
```
Oh no! If you play with Inked Summoner now, you will crash when summoning a token. That's because they don't exist in MTG and we need to define them! Let's go onto the next step!
## Scripting custom tokens
The token scripts are located at `%appdata%/Forge/custom/tokens`.
Let's add the new tokens we need to make Inked Summoner work!
> Just like for card scripting, this tutorial will not teach you about scripting them.
b_1_1_bird.flying.txt
```
Name:Bird Token
ManaCost:no cost
Colors:black
Types:Creature Bird
PT:1/1
K:Flying
Oracle:Flying
```
b_3_3_cat_deathtouch.txt
```
Name:Cat Token
ManaCost:no cost
Colors:black
Types:Creature Cat
PT:3/3
K:Deathtouch
Oracle:Deathtouch
```
b_5_5_golem_trample.txt
```
Name:Golem Token
ManaCost:no cost
Colors:black
Types:Creature Golem
PT:5/5
K:Trample
Oracle:Trample
```
Great! Now Inked Summoner no longer make the game crash! Now let's add some images to spice it all up.
## Adding card and token images
You can find the card images for the MSEM Champions edition [here](https://msem-instigator.herokuapp.com/set/CHAMPIONS). Find the ones you need and save them inside `%appdata%/../Local/Forge/Cache/pics/cards/MSEM_CHAMPIONS` Remember the filename format should be something like `Swamp.full.jpg` if you only have one variant in your edition. If you have multiples, then it should be something like `Fox of the Orange Orchard1.full.jpg`, `Fox of the Orange Orchard2.full.jpg`, etc. You can find the alternate images from [here](https://msem-instigator.herokuapp.com/set/MPS_MSE) if you want.
For the tokens, we can deposit them inside `%localappdata%/Forge/Cache/pics/tokens/MSEM_CHAMPIONS`. They should be named the same as their token script so `b_1_1_bird_flying.jpg` and so forth.
![b_1_1_bird_flying](https://github.com/user-attachments/assets/531583c1-3985-4744-858a-3a49fd12740a)
![b_3_3_cat_deathtouch](https://github.com/user-attachments/assets/15a24e62-be43-4c0c-aeac-0ddb38fca97a)
![b_5_5_golem_trample](https://github.com/user-attachments/assets/7ff44dc7-0284-48bd-9233-785ac79106f3)
You can now start your game again, and see that the art loads correctly now.
## 🎉 Congratulations!
Youve just added your first custom set in Forge! There's still much more to explore — scripting advanced abilities, custom mechanics, and set structures — but you now have a solid foundation to build from.

34
docs/Credit-and-Thanks.md Normal file
View File

@@ -0,0 +1,34 @@
## Special Thanks
1. Quest icons created by Teekatas, from his Legendora set - [Link](http://raindropmemory.deviantart.com/)
1. Thanks to the XMage team for permission to use their targeting arrows.
1. Thanks to http://www.freesound.org/browse/ for providing some sound files.
1. Credit to Kevin Macleod for the royalty free music that is used.
1. Credit to Juhani Junkala for the royalty free music for boss battles - [Link](https://opengameart.org/content/boss-battle-music)
## Adventure Mode Sprites and tiles.
Some of the sprites and tiles that are used in Adventure mode come from external artists. These fall under the ownership of their respective artists and may be used only under the conditions laid out in their respective licence.
1. Credit to Reddit user [wampastompah](https://www.reddit.com/user/wampastompah) for the sprites of iconic MTG characters that are used in Adventure mode
1. Credit to [Aleksandr Makarov's](https://itch.io/profile/iknowkingrabbit) pixelart (tiles and sprites) that are used in Adventure mode.
1. Credit to [Elthen](https://linktr.ee/elthen) for his sprites that are used in adventure mode.
1. Credit to [DeepDiveGameStudio](https://deepdivegamestudio.itch.io) for some of the sprites that are used in adventure mode.
1. Credit to [Krishna Palacio](https://itch.io/profile/krishna-palacio) for some of the sprites and tiles that are used in adventure mode.
1. Credit to https://opengameart.org/ for some of the tiles. More in dept creditation of the tiles used can be found [Here](https://docs.google.com/spreadsheets/d/e/2PACX-1vTD0L8yDltZnn4025CZ9exhziCj0rbpd2aKE-0qeHikVBz51OKaAHLsgFuaDuIWrkrqIJicxzdn3SG1/pubhtml)
## Soundtrack
### Adventure
1. Battle = Rising Legion - Derek Fiechter//Assyrian Fortress - Derek Fiechter//Goblin Raid - Brandon Fiechter// As we Marched - Vindsvept // Mecha Dwarves - Derek Fiechter
1. Boss =
1. Inn= Wild Boar's Inn - Brandon Fiechter// Black Rock - Logan Epic Canto //The Land of Gnomes - Logan Epic Canto//Dance of the Red Lights- Logan Epic Canto // Poland - Brandon Fiechter // Tir Nan Og - Logan Epic Canto // Village Consort -Kevin Macleod
1. Dungeon = Swamp Witch - Derek Fiechter // Giant Mushrooms - Derek Fiechter// Cobweb Fairies - Derek Fiechter
1. Menus = Vindsvept - Wanderer // Vindsvept - Lake of Light
1. Waste biome = Vindsvept - Through the Woods we Ran // Vindsvept - Adventure
1. Swamp biome = Merky Swamp - Brandon Fiechter // Masquerade of the Ghosts - Brandon Fiechter
1. Island biome = Pirates of the Coast - Brandon Fiechter & Derek Fiechter//Buried Treasure - Brandon Fiechter & Derek Fiechter
1. Forest biome = Enchanted Forest - Logan Epic Canto // The Celtic King
1. Plains biome = Cobblestone Village - Brandon Fiechter // Camelot - Brandon Fiechter
1. Mountain biome = Goblin Tinker - Brandon Fiechter // Goblin King's Tavern - Brandon Fiechter
1. Castle = Horus - Brandon Fiechter & Derek Fiechter

46
docs/Currency.md Normal file
View File

@@ -0,0 +1,46 @@
There are many currencies in the game, and most of them can be interchanged.
# Cards
Acquired by:
- World drops
- Match reward
- Draft wins
- Shop purchases
- Quests
Spent on:
- Selling to shops
# Gold
Acquired by:
- World drop
- Match reward
- Draft reward
- Quests
Spent on:
- Cards and items from shops
- Drafts games
- Crafting cards
- Shards
# Shards
Acquired by
- World drop
- Quest reward
Spent on
- Crafting cards
- Shop Re-rolls
- Gold exchange
# Challenge Coins
Acquired by
- At the start of the game
Spent on
- Drafts

35
docs/Custom-Music.md Normal file
View File

@@ -0,0 +1,35 @@
# Custom music for adventure mode
In the `res/adventure/common/music` folder resides all the music that is played in various parts of adventure mode:
* `black` - Tracks that are played in the black magic biome in the overworld
* `blue` - Tracks that are played in the blue magic biome in the overworld
* `boss` - Tracks that are played in a boss battle
* `castle` - Tracks that are played inside biome boss dungeons
* `cave` - Tracks that are played in any dungeon that is not a biome boss dungeon
* `colorless` - Tracks that are played in the colorless magic (wastes) biome in the overworld
* `green` - Tracks that are played in the green magic biome in the overworld
* `match` - Tracks that are played during a non-boss battle
* `menus` - Tracks that are played in the opening menu of adventure mode
* `red` - Tracks that are played in the red magic biome in the overworld
* `town` - Tracks that are played when you are in any town
* `white` - Tracks that are played in the white magic biome in the overworld
The game will play a track from any of the above folders at random. The tracks can be any
file name with a `.mp3`, `.wav` or `.m4a` extension.
NOTE: On Steam Deck, if you added Forge Adventure mode to Steam Deck gaming mode, the game may
have issues playing tracks that have non-ascii characters in its name. A current
workaround is to rename such tracks with accented characters to their ascii equivalents (eg. `é` to `e`)
and such tracks will play again. Reference: https://github.com/Card-Forge/forge/issues/8290
To customize the music in adventure mode, simply [add to -OR- replace] the existing music track files in the folders referenced above.
# Custom music for regular Forge
In the `res/music` folder resides all the music that is played in regular Forge if you have music enabled.
* `match` - Tracks that are played inside a game
* `menus` - Tracks that are played outside of any game (ie. menus)
All the same playback rules apply. The process for customizing the music here is the same as adventure mode.

View File

@@ -0,0 +1,28 @@
# Adding basic lands and special arts
You can add lands by clicking the triple dots icon in the right top of the deck building interface.
Initially you only have access to jumpstart basic land arts - to get more, you need to purchase the landscape sketch books from the basic land shop (The Cartographers Guild).
# 40-card deck recommendation
40-card decks give you a much more predictable curve.
In a 40-card deck, each individual card has a 2.5% chance of being drawn.
In a 60-card deck, each individual card has a 1.6% chance of being drawn.
When you use a smaller deck, the significance of each individual card is much higher and will give you more predictable performance.
# Autosell
When you click a card that is not part of any decks, you get the option to move it to auto-sell.
The numbers in the interface indicate how many copies you have.
To sell the cards you have marked, go to any town and enter the Inn.
In the Inn, the middle icon of the coin called Sell (E) will sell all your cards you have marked to sell.
Individual card values vary by rarity and reputation with the town you sell them in.
Since dying will cause you to lose a percentage of your gold, you may want to not sell all your cards immediately.

View File

@@ -0,0 +1,46 @@
In order to build and sign the android release, you will need the `forge.keystore` file (which is not present in the repository). This file will need to be placed in the `forge-gui-android` folder. This file should **never** be committed to the repository.
In preparation for the android release, update the version recorded in the following files:
```
forge-gui-android/pom.xml
forge-gui-ios/pom.xml
forge-gui-mobile/src/forge/Forge.java
```
In the first two, you're looking for `alpha-version` (~line 10 in both files) and setting the string accordingly.
In the last one, you're looking for the declaration of `CURRENT_VERSION` (~line 37) and setting it to the same value as the previous two files.
Commit the changes to these three files to the repository with an appropriately descriptive commit message.
A script such as the following will compile and sign the android build:
```
export ANDROID_HOME=/opt/android-sdk/
export _JAVA_OPTIONS="-Xmx2g"
mvn -U -B clean \\
-P android-release-build,android-release-sign \\
install \\
-Dsign.keystore=forge.keystore \\
-Dsign.alias=Forge \\
-Dsign.storepass=${FORGE_STOREPASS} \\
-Dsign.keypass=${FORGE_KEYPASS}
```
Once the above build has successfully completed and passed any desired testing, the following will build, sign, and publish the build:
```
export ANDROID_HOME=/opt/android-sdk/
export _JAVA_OPTIONS="-Xmx2g"
mvn -U -B clean \\
-P android-release-build,android-release-sign,android-release-upload \\
install \\
-Dsign.keystore=forge.keystore \\
-Dsign.alias=Forge \\
-Dsign.storepass=${FORGE_STOREPASS} \\
-Dsign.keypass=${FORGE_KEYPASS} \\
-Dcardforge.user=${FORGE_FTP_USER} \\
-Dcardforge.pass=${FORGE_FTP_PASS}
```
After this, the appropriate forum posts will need to be made announcing the new release.

View File

@@ -0,0 +1,139 @@
1. Setup IntelliJ with Android (plugin, SDKs etc).
2. Get the Android 13 image for the emulator (important: Android 13), then run the emulator. *Skip this step if you use a physical device.*
3. Make sure you can build the APK.
a. `mvn clean verify -P android-debug` using the working directory forge-gui-android/
4. Use `android-debug` profile for creating the debug version from below in the forge-gui-android/pom.xml
5. Use this maven command: `mvn android:deploy-apk android:run`
6. Look at the emulator (or device), it should say "Waiting for debugger to connect".
7. CRTL+SHIFT+A in IntelliJ and type in `attach android` and click on "Attach Debugger to Android Process".
8. Tick "Show all processes" and you should be able to pick `forge.app` from the list and click "Okay".
9. Ready to debug
Profile XML for debugging:
```
<profile>
<id>android-debug</id>
<properties>
<android.debug>true</android.debug>
<android.run.debug>true</android.run.debug>
<android.deployapk.filename>target\forge-android-${snapshot-version}-aligned-debugSigned.apk</android.deployapk.filename>
<packaging.type>apk</packaging.type>
</properties>
<build>
<plugins>
<plugin>
<artifactId>exec-maven-plugin</artifactId>
<version>3.4.1</version>
<groupId>org.codehaus.mojo</groupId>
<executions>
<execution>
<id>SignV2</id>
<phase>verify</phase>
<goals>
<goal>exec</goal>
</goals>
</execution>
</executions>
<configuration>
<workingDirectory>${pom.basedir}</workingDirectory>
<executable>java</executable>
<arguments>
<argument>-jar</argument>
<argument>${pom.basedir}/tools/uber-apk-signer.jar</argument>
<argument>-a</argument>
<argument>${pom.basedir}/target/</argument>
<argument>--debug</argument>
</arguments>
</configuration>
</plugin>
<plugin>
<groupId>com.github.cardforge.maven.plugins</groupId>
<artifactId>android-maven-plugin</artifactId>
<dependencies>
<dependency>
<groupId>javax.xml.bind</groupId>
<artifactId>jaxb-api</artifactId>
<version>2.3.1</version>
</dependency>
<dependency>
<groupId>com.sun.xml.bind</groupId>
<artifactId>jaxb-impl</artifactId>
<version>2.3.4</version>
</dependency>
<dependency>
<groupId>sun</groupId>
<artifactId>misc</artifactId>
<version>1</version>
<scope>system</scope>
<systemPath>${pom.basedir}/libs/sun-misc.jar</systemPath>
</dependency>
</dependencies>
<version>4.6.2</version>
<extensions>true</extensions>
<configuration>
<sign>
<debug>false</debug>
</sign>
<sdk>
<platform>${androidPlatform}</platform>
<buildTools>${androidBuildTools}</buildTools>
</sdk>
<dexForceJumbo>true</dexForceJumbo>
<assetsDirectory>${project.basedir}/assets</assetsDirectory>
<resourceDirectory>${project.basedir}/res</resourceDirectory>
<nativeLibrariesDirectory>${project.basedir}/libs</nativeLibrariesDirectory>
<extractDuplicates>true</extractDuplicates>
<proguard>
<skip>false</skip>
<config>${project.basedir}/proguard.cfg</config>
</proguard>
<proguardProguardJarPath>${pom.basedir}/tools/proguard.jar</proguardProguardJarPath>
<release>false</release>
<dexCompiler>d8</dexCompiler>
<d8>
<minApi>26</minApi>
<jvmArguments>
<argument>${build.min.memory}</argument>
<argument>${build.max.memory}</argument>
</jvmArguments>
</d8>
<dex>
<multi-dex>true</multi-dex>
<jvmArguments>
<argument>${build.min.memory}</argument>
<argument>${build.max.memory}</argument>
</jvmArguments>
<dexArguments>--min-sdk-version=26</dexArguments>
</dex>
</configuration>
<executions>
<execution>
<id>update-manifest</id>
<goals>
<goal>manifest-merger</goal>
</goals>
</execution>
</executions>
</plugin>
<plugin>
<groupId>se.bjurr.gitchangelog</groupId>
<artifactId>git-changelog-maven-plugin</artifactId>
<version>2.2.0</version>
<inherited>false</inherited>
<executions>
<execution>
<id>GenerateGitChangelog</id>
<phase>generate-sources</phase>
<goals>
<goal>git-changelog</goal>
</goals>
<configuration>
<skip>true</skip>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
</build>
</profile>
```

View File

@@ -0,0 +1,8 @@
This is based on Latent Dirichlet allocation:
1) use Agetian's getmtgdecks.sh scripts to download recent decks from mtgdecks.net and convert them to forge format and separate into Standard/Modern/Pioneer using his python tools (deck2forge_3.5.py and deckSorter_1.4a)
2) copy the new decks into forge-gui/res/deckgendecks/$format for each format and remove the $format.lda.dat and $format.raw.dat files from that folder
3) check out the Austin/ldastream branch and merge it with the latest
4) run the forge.deck.generate.LDAModelGenerator class in the forge-gui-desktop module
this will generate updated .raw.dat and .lda.dat files that can then be checked in
probably need to do step 3 before 2 actually

183
docs/Development/DevMode.md Normal file
View File

@@ -0,0 +1,183 @@
Developer Mode is a Mode that allows Developers to try out different
things and gain different shortcuts during play. In a Normal program,
this Mode would be available in a Debug build, but removed from the code
during the Retail build. Since Forge is in constant Beta, this Mode is
available during our Beta releases. On the NewGame Screen, just make
sure it's checked and you'll be able to edit the options at any point
during the game.
## Lose By Decking
This one is a simple Checkbox. If your Library is Empty and you try to
try a card, you normally lose the game. This checkbox should be on by
Default (meaning you lose) but if you are running a deck without many
cards, uncheck this box so you don't lose when failing to draw a card
when you need to.
\[THIS OPTION NOT READILY VISIBLE IN VERSIONS 1.6.23\]
## View Zone
There are a few View Zone menu item which help to make sure your Library
has what you think or the AI isn't being too overly foolish. They do
exactly what you might think. Click on the menu item, and all Cards in
that Zone are revealed to you.
## Generate Mana
Useful for not needing Land in your Deck while you are just trying to
test something out, by selecting Generate Mana, 7 of each color and 7
colorless is generated and put into your Mana Pool.
## Setup Game State
The Setup Game State is a Command that lets you open an external file to
Add things into the Game State. Currently the command uses an external
text file that is opened through a file open dialog when you click on
the Setup Game State menu item. The file structure is simple. It must
contain any of the following lines defining what needs to be changed in
the current game state:
### HumanLife
Defines the value to set the human's current life to. Example:
HumanLife=6
### AILife
Defines the value to set the computer opponent's life to. Example:
AILife=14
### HumanCardsInPlay
Defines the cards that are to be placed under Human's control on the
battlefield. Can be just one card name or a list of card names separated
with semicolons. Example: HumanCardsInPlay=Swamp; Swamp; Drudge
Skeletons
### AICardsInPlay
Defines the cards that are to be placed under Computer's control on the
battlefield. Can be just one card name or a list of card names separated
with semicolons. Example: AICardsInPlay=Island
### HumanCardsInHand
Defines the cards that are to replace the Human's current hand. Old
cards in the Human's card will be removed. Can be just one card name or
a list of card names separated with semicolons, see HumanCardsInPlay or
AICardsInPlay above for examples.
### AICardsInHand
Defines the cards that are to replace the Computer's current hand. Old
cards in the Computer's card will be removed. Can be just one card name
or a list of card names separated with semicolons, see HumanCardsInPlay
or AICardsInPlay above for examples.
### HumanCardsInGraveyard
Defines the cards that are to replace the Human's current graveyard. Old
cards in the Human's graveyard will be removed. Can be just one card
name or a list of card names separated with semicolons, see
HumanCardsInPlay or AICardsInPlay above for examples.
### AICardsInGraveyard
Defines the cards that are to replace the Computer's current graveyard.
Old cards in the Computer's graveyard will be removed. Can be just one
card name or a list of card names separated with semicolons, see
HumanCardsInPlay or AICardsInPlay above for examples.
### HumanCardsInLibrary
Defines the cards that are to replace the Human's current library. Old
cards in the Human's library will be removed. Can be just one card name
or a list of card names separated with semicolons, see HumanCardsInPlay
or AICardsInPlay above for examples.
### AICardsInLibrary
Defines the cards that are to replace the Computer's current library.
Old cards in the Computer's library will be removed. Can be just one
card name or a list of card names separated with semicolons, see
HumanCardsInPlay or AICardsInPlay above for examples.
### HumanCardsInExile
Defines the cards that are to replace the Human's current exile area.
Old cards in the Human's exile area will be removed. Can be just one
card name or a list of card names separated with semicolons, see
HumanCardsInPlay or AICardsInPlay above for examples.
### AICardsInExile
Defines the cards that are to replace the Computer's current exile area.
Old cards in the Computer's exile area will be removed. Can be just one
card name or a list of card names separated with semicolons, see
HumanCardsInPlay or AICardsInPlay above for examples.
### ActivePlayer
Defines the active player that must be given priority when the game
state is set up. If this line is absent, the current player is not
changed. There are two valid values for this option: Human and AI. Note
that this option does not change the current phase, only the current
player. Example: ActivePlayer=AI
### ActivePhase
Changes the current phase of the game to the one specified. The valid
values are Untap, Upkeep, Draw, Main1, Declare Attackers, Declare
Blockers, Main2, End of Turn, and Cleanup. Note that the phase names are
case-sensitive.
### Comments
Game state files are allowed to have comments - any line that is
prefixed with a pound sign (\#) is not parsed and is considered to be a
text fragment. Also, empty lines are ignored. Example: <b>\# This is a
comment.</b>
### Specifying a Set for Spawned Cards
When specifying card names, you can optionally add the set code by
appending the pipe sign (|) and the three-letter set code to the card
name you are spawning. That will allow you to spawn cards from specific
sets. For example, <b>HumanCardsInPlay=Mountain; Mountain</b> will just
spawn two Mountains on the human battlefield, using the latest possible
set for them, while <b>HumanCardsInPlay=Mountain|4ED; Mountain|4ED</b>
will spawn two Mountains from the 4th Edition on the human battlefield.
### Samples
Here are two examples of valid state configuration files:
HumanLife=5
AILife=6
HumanCardsInPlay=Forest; Forest; Forest; Llanowar Elves
AICardsInPlay=Mountain; Mountain; Mountain
HumanCardsInHand=Island; Raging Goblin
AICardsInHand=Swamp; Swamp; Forest
Sets human's life to 5, AI life to 6, puts 3 Forests and Llanowar Elves
on the human battlefield, puts 3 Mountains on the computer battlefield,
replaces the human hand with Island and Raging Goblin, replaces the AI
hand with 2 Swamps and a Forest. Does not add any cards to either
graveyard and does not replace either library.
HumanCardsInPlay=Plains|10E
AICardsInPlay=Mountain; Raging Goblin
AICardsInGraveyard=Force of Nature; Raging Goblin; Amulet of Kroog
ActivePlayer=Human
ActivePhase=Main1
Does not change the human's life and the AI life, puts a Plains from the
10th Edition on the human battlefield, puts a Mountain and a Raging
Goblin on the opponent's battlefield, does not replace the human and the
AI hands and leaves them intact, and adds Force of Nature, Raging
Goblin, and Amulet of Kroog to the computer's graveyard. Does not
replace either library. Sets the current player to Human and the current
phase to Main 1.
It's important to note you won't get achievements in a game once you started cheating.

Binary file not shown.

After

Width:  |  Height:  |  Size: 10 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 82 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 28 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 16 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 11 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 24 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 35 KiB

Some files were not shown because too many files have changed in this diff Show More