-
Notifications
You must be signed in to change notification settings - Fork 582
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Migrate Guava Predicates and Functions to Java implementations #6047
Conversation
@Hanmac is this PR good, I think java is more performant than guava, also do we need guava (I don't know if java covers all other collections guava have) |
@kevlahnota i will look over this MR, but i think it should be good enough? we can't really drop guava fully, i would miss my Table support |
I looked at cutting out more of Guava and recreating the functionality within other util classes, but the scope of that started expanding too quickly for this PR at least. They have a huge number of helper methods that we use, and many of those are implemented through internal helper classes which would either need to be reproduced as well or replaced with inline logic. If we want to further lessen the dependency on Guava, I think a good direction would be expanding the functionality of For performance improvements, as mentioned above, I think |
# 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
…mpound predicates.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
the toList method directly from stream are missing on older Android (12 and below tested, not sure on 13 and above), so this will break mobile builds.
#4bbc165460cbe87a32eb4227f5b4fda26959d9f9
Gah. I was excited when I saw we'd moved up to Java 17. Should I just treat the language level as though it were 11, then? |
Hmm I just discovered it when I update the auditer. Don't know which Java api are excluded on android. |
Android 12 and 13 reportedly support up to Java 11, and Android 14 partially supports Java 17. From what I can tell, the D8 compiler has support for backporting newer Java API members via desugaring, but it sounds like that's only being used to enable stuff from the Java 11 API on Android <= 11. If the project is gonna be set to Java 17, though, It would probably be a good idea to add a github workflow to test the android build, or otherwise report unsupported API members. It seems like an easy thing to overlook. Worth keeping an eye on this in case desugaring support for 17 gets added someday - https://github.com/google/desugar_jdk_libs/blob/master/CHANGELOG.md |
# Conflicts: # forge-core/src/main/java/forge/StaticData.java
# 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
# 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
# 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
Looks like this broke entering the Inn/Drafting in Adventure mode. |
Per #5717.
Not complete yet but wouldn't hurt to get some eyes on it while it's easier to revise things.
The switch-over of the implementation is done, but still need to finish cleaning up the helper methods. Many can be simplified through method references (e.g.
::equals
and::contains
), but others don't have a good equivalent.The dependency on Guava's
Iterables
is one point of uncertainty at the moment. It's too convenient to get rid of, but a handful of the filter methods still want Guava predicates. Could reimplement these manually in anIterableUtils
class, or could just use thepredicate::test
hack to keep using the original library.