diff --git a/src/main/java/forge/card/abilityfactory/AbilityFactory.java b/src/main/java/forge/card/abilityfactory/AbilityFactory.java index 49646cb43e5..3f4804ce9dd 100644 --- a/src/main/java/forge/card/abilityfactory/AbilityFactory.java +++ b/src/main/java/forge/card/abilityfactory/AbilityFactory.java @@ -813,6 +813,16 @@ public class AbilityFactory { } } + else if (this.api.equals("GenericChoice")) { + if (this.isAb) { + spellAbility = AbilityFactoryChoose.createAbilityChooseGeneric(this); + } else if (this.isSp) { + spellAbility = AbilityFactoryChoose.createSpellChooseGeneric(this); + } else if (this.isDb) { + spellAbility = AbilityFactoryChoose.createDrawbackChooseGeneric(this); + } + } + else if (this.api.equals("LoseLife")) { if (this.isAb) { spellAbility = AbilityFactoryAlterLife.createAbilityLoseLife(this); diff --git a/src/main/java/forge/card/abilityfactory/AbilityFactoryChoose.java b/src/main/java/forge/card/abilityfactory/AbilityFactoryChoose.java index 72505dbe0fd..9a7f368a4ba 100644 --- a/src/main/java/forge/card/abilityfactory/AbilityFactoryChoose.java +++ b/src/main/java/forge/card/abilityfactory/AbilityFactoryChoose.java @@ -26,6 +26,9 @@ import java.util.Random; import javax.swing.JOptionPane; +import com.google.common.collect.BiMap; +import com.google.common.collect.HashBiMap; + import forge.AllZone; import forge.AllZoneUtil; import forge.Card; @@ -1739,4 +1742,214 @@ public final class AbilityFactoryChoose { } } + // ************************************************************************* + // ************************* ChooseGeneric ********************************* + // ************************************************************************* + + /** + *
+ * createAbilityChooseGeneric. + *
+ * + * @param af + * a {@link forge.card.abilityfactory.AbilityFactory} object. + * @return a {@link forge.card.spellability.SpellAbility} object. + * + * @since 1.2.4 + */ + public static SpellAbility createAbilityChooseGeneric(final AbilityFactory af) { + + final SpellAbility abChooseGeneric = new AbilityActivated(af.getHostCard(), af.getAbCost(), af.getAbTgt()) { + private static final long serialVersionUID = -459173435583208151L; + + @Override + public String getStackDescription() { + return AbilityFactoryChoose.chooseGenericStackDescription(af, this); + } + + @Override + public boolean canPlayAI() { + return AbilityFactoryChoose.chooseGenericCanPlayAI(af, this); + } + + @Override + public void resolve() { + AbilityFactoryChoose.chooseGenericResolve(af, this); + } + + @Override + public boolean doTrigger(final boolean mandatory) { + return AbilityFactoryChoose.chooseGenericTriggerAI(af, this, mandatory); + } + + }; + return abChooseGeneric; + } + + /** + *+ * createSpellChooseGeneric. + *
+ * + * @param af + * a {@link forge.card.abilityfactory.AbilityFactory} object. + * @return a {@link forge.card.spellability.SpellAbility} object. + * + * @since 1.2.4 + */ + public static SpellAbility createSpellChooseGeneric(final AbilityFactory af) { + final SpellAbility spChooseGeneric = new Spell(af.getHostCard(), af.getAbCost(), af.getAbTgt()) { + private static final long serialVersionUID = 4187094641157371974L; + + @Override + public String getStackDescription() { + return AbilityFactoryChoose.chooseGenericStackDescription(af, this); + } + + @Override + public boolean canPlayAI() { + return AbilityFactoryChoose.chooseGenericCanPlayAI(af, this); + } + + @Override + public void resolve() { + AbilityFactoryChoose.chooseGenericResolve(af, this); + } + + }; + return spChooseGeneric; + } + + /** + *+ * createDrawbackChooseGeneric. + *
+ * + * @param af + * a {@link forge.card.abilityfactory.AbilityFactory} object. + * @return a {@link forge.card.spellability.SpellAbility} object. + * + * @since 1.2.4 + */ + public static SpellAbility createDrawbackChooseGeneric(final AbilityFactory af) { + final SpellAbility dbChooseGeneric = new AbilitySub(af.getHostCard(), af.getAbTgt()) { + private static final long serialVersionUID = 1586980855969921641L; + + @Override + public String getStackDescription() { + return AbilityFactoryChoose.chooseGenericStackDescription(af, this); + } + + @Override + public void resolve() { + AbilityFactoryChoose.chooseGenericResolve(af, this); + } + + @Override + public boolean chkAIDrawback() { + return true; + } + + @Override + public boolean doTrigger(final boolean mandatory) { + return AbilityFactoryChoose.chooseGenericTriggerAI(af, this, mandatory); + } + + }; + return dbChooseGeneric; + } + + private static String chooseGenericStackDescription(final AbilityFactory af, final SpellAbility sa) { + final HashMap+ * chooseTypeTriggerAI. + *
+ * + * @param af + * a {@link forge.card.abilityfactory.AbilityFactory} object. + * @param sa + * a {@link forge.card.spellability.SpellAbility} object. + * @param mandatory + * a boolean. + * @return a boolean. + */ + private static boolean chooseGenericTriggerAI(final AbilityFactory af, final SpellAbility sa, final boolean mandatory) { + if (!ComputerUtil.canPayCost(sa)) { + return false; + } + + return false; + } + + private static void chooseGenericResolve(final AbilityFactory af, final SpellAbility sa) { + final HashMap