mirror of
https://github.com/correl/mage.git
synced 2024-11-16 11:09:29 +00:00
Merge pull request #58 from magefree/master
Merge https://github.com/magefree/mage
This commit is contained in:
commit
b368d3f832
18239 changed files with 52051 additions and 39322 deletions
6
.gitignore
vendored
6
.gitignore
vendored
|
@ -89,6 +89,8 @@ Mage.Verify/target
|
||||||
Mage.Verify/mageclient.log
|
Mage.Verify/mageclient.log
|
||||||
Mage.Verify/AllCards.json.zip
|
Mage.Verify/AllCards.json.zip
|
||||||
Mage.Verify/AllSets.json.zip
|
Mage.Verify/AllSets.json.zip
|
||||||
|
Mage.Verify/AllCards.json
|
||||||
|
Mage.Verify/AllSets.json
|
||||||
|
|
||||||
releases
|
releases
|
||||||
Utils/author.txt
|
Utils/author.txt
|
||||||
|
@ -140,3 +142,7 @@ client_secrets.json
|
||||||
dependency-reduced-pom.xml
|
dependency-reduced-pom.xml
|
||||||
mage-bundle
|
mage-bundle
|
||||||
/Mage.Client/game-*.json
|
/Mage.Client/game-*.json
|
||||||
|
|
||||||
|
# build-tools config and log files when building client/server with Atom
|
||||||
|
.build-tools.cson
|
||||||
|
build-output.log
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.mage</groupId>
|
<groupId>org.mage</groupId>
|
||||||
<artifactId>mage-root</artifactId>
|
<artifactId>mage-root</artifactId>
|
||||||
<version>1.4.29</version>
|
<version>1.4.30</version>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<groupId>org.mage</groupId>
|
<groupId>org.mage</groupId>
|
||||||
|
|
|
@ -105,6 +105,10 @@ public class MageFrame extends javax.swing.JFrame implements MageClient {
|
||||||
private static final String GRAY_MODE_ARG = "-gray";
|
private static final String GRAY_MODE_ARG = "-gray";
|
||||||
private static final String FILL_SCREEN_ARG = "-fullscreen";
|
private static final String FILL_SCREEN_ARG = "-fullscreen";
|
||||||
private static final String SKIP_DONE_SYMBOLS = "-skipDoneSymbols";
|
private static final String SKIP_DONE_SYMBOLS = "-skipDoneSymbols";
|
||||||
|
private static final String USER_ARG = "-user";
|
||||||
|
private static final String PASSWORD_ARG = "-pw";
|
||||||
|
private static final String SERVER_ARG = "-server";
|
||||||
|
private static final String PORT_ARG = "-port";
|
||||||
|
|
||||||
private static final String NOT_CONNECTED_TEXT = "<not connected>";
|
private static final String NOT_CONNECTED_TEXT = "<not connected>";
|
||||||
private static MageFrame instance;
|
private static MageFrame instance;
|
||||||
|
@ -123,6 +127,10 @@ public class MageFrame extends javax.swing.JFrame implements MageClient {
|
||||||
private static boolean grayMode = false;
|
private static boolean grayMode = false;
|
||||||
private static boolean fullscreenMode = false;
|
private static boolean fullscreenMode = false;
|
||||||
private static boolean skipSmallSymbolGenerationForExisting = false;
|
private static boolean skipSmallSymbolGenerationForExisting = false;
|
||||||
|
private static String startUser = null;
|
||||||
|
private static String startPassword = "";
|
||||||
|
private static String startServer = "localhost";
|
||||||
|
private static int startPort = -1;
|
||||||
|
|
||||||
private static final Map<UUID, ChatPanelBasic> CHATS = new HashMap<>();
|
private static final Map<UUID, ChatPanelBasic> CHATS = new HashMap<>();
|
||||||
private static final Map<UUID, GamePanel> GAMES = new HashMap<>();
|
private static final Map<UUID, GamePanel> GAMES = new HashMap<>();
|
||||||
|
@ -732,7 +740,7 @@ public class MageFrame extends javax.swing.JFrame implements MageClient {
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean autoConnect() {
|
public boolean autoConnect() {
|
||||||
boolean autoConnectParamValue = Boolean.parseBoolean(PREFS.get("autoConnect", "false"));
|
boolean autoConnectParamValue = startUser != null || Boolean.parseBoolean(PREFS.get("autoConnect", "false"));
|
||||||
boolean status = false;
|
boolean status = false;
|
||||||
if (autoConnectParamValue) {
|
if (autoConnectParamValue) {
|
||||||
status = performConnect(false);
|
status = performConnect(false);
|
||||||
|
@ -1186,8 +1194,10 @@ public class MageFrame extends javax.swing.JFrame implements MageClient {
|
||||||
|
|
||||||
startTime = System.currentTimeMillis();
|
startTime = System.currentTimeMillis();
|
||||||
Thread.setDefaultUncaughtExceptionHandler((t, e) -> LOGGER.fatal(null, e));
|
Thread.setDefaultUncaughtExceptionHandler((t, e) -> LOGGER.fatal(null, e));
|
||||||
|
|
||||||
SwingUtilities.invokeLater(() -> {
|
SwingUtilities.invokeLater(() -> {
|
||||||
for (String arg : args) {
|
for (int i = 0; i < args.length; i++) {
|
||||||
|
String arg = args[i];
|
||||||
if (arg.startsWith(LITE_MODE_ARG)) {
|
if (arg.startsWith(LITE_MODE_ARG)) {
|
||||||
liteMode = true;
|
liteMode = true;
|
||||||
}
|
}
|
||||||
|
@ -1200,6 +1210,22 @@ public class MageFrame extends javax.swing.JFrame implements MageClient {
|
||||||
if (arg.startsWith(SKIP_DONE_SYMBOLS)) {
|
if (arg.startsWith(SKIP_DONE_SYMBOLS)) {
|
||||||
skipSmallSymbolGenerationForExisting = true;
|
skipSmallSymbolGenerationForExisting = true;
|
||||||
}
|
}
|
||||||
|
if (arg.startsWith(USER_ARG)){
|
||||||
|
startUser = args[i+1];
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
if (arg.startsWith(PASSWORD_ARG)){
|
||||||
|
startPassword = args[i+1];
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
if (arg.startsWith(SERVER_ARG)){
|
||||||
|
startServer = args[i+1];
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
if (arg.startsWith(PORT_ARG)){
|
||||||
|
startPort = Integer.valueOf(args[i+1]);
|
||||||
|
i++;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if (!liteMode) {
|
if (!liteMode) {
|
||||||
final SplashScreen splash = SplashScreen.getSplashScreen();
|
final SplashScreen splash = SplashScreen.getSplashScreen();
|
||||||
|
@ -1212,6 +1238,19 @@ public class MageFrame extends javax.swing.JFrame implements MageClient {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
instance = new MageFrame();
|
instance = new MageFrame();
|
||||||
|
|
||||||
|
if( startUser != null){
|
||||||
|
instance.currentConnection = new Connection();
|
||||||
|
instance.currentConnection.setUsername(startUser);
|
||||||
|
instance.currentConnection.setHost(startServer);
|
||||||
|
if (startPort > 0){
|
||||||
|
instance.currentConnection.setPort(startPort);
|
||||||
|
}else {
|
||||||
|
instance.currentConnection.setPort(MagePreferences.getServerPortWithDefault(Config.port));
|
||||||
|
}
|
||||||
|
PreferencesDialog.setProxyInformation(instance.currentConnection);
|
||||||
|
instance.currentConnection.setPassword(startPassword);
|
||||||
|
}
|
||||||
instance.setVisible(true);
|
instance.setVisible(true);
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
|
@ -851,7 +851,6 @@
|
||||||
</Component>
|
</Component>
|
||||||
<Component class="javax.swing.JCheckBox" name="chkUnique">
|
<Component class="javax.swing.JCheckBox" name="chkUnique">
|
||||||
<Properties>
|
<Properties>
|
||||||
<Property name="selected" type="boolean" value="false"/>
|
|
||||||
<Property name="text" type="java.lang.String" value="Unique"/>
|
<Property name="text" type="java.lang.String" value="Unique"/>
|
||||||
<Property name="toolTipText" type="java.lang.String" value="Show only the first found card of every card name."/>
|
<Property name="toolTipText" type="java.lang.String" value="Show only the first found card of every card name."/>
|
||||||
<Property name="focusable" type="boolean" value="false"/>
|
<Property name="focusable" type="boolean" value="false"/>
|
||||||
|
|
|
@ -51,13 +51,13 @@ import mage.client.MageFrame;
|
||||||
import mage.client.cards.*;
|
import mage.client.cards.*;
|
||||||
import mage.client.constants.Constants.SortBy;
|
import mage.client.constants.Constants.SortBy;
|
||||||
import mage.client.deckeditor.table.TableModel;
|
import mage.client.deckeditor.table.TableModel;
|
||||||
|
import mage.client.dialog.CheckBoxList;
|
||||||
import static mage.client.dialog.PreferencesDialog.KEY_DECK_EDITOR_SEARCH_NAMES;
|
import static mage.client.dialog.PreferencesDialog.KEY_DECK_EDITOR_SEARCH_NAMES;
|
||||||
import static mage.client.dialog.PreferencesDialog.KEY_DECK_EDITOR_SEARCH_RULES;
|
import static mage.client.dialog.PreferencesDialog.KEY_DECK_EDITOR_SEARCH_RULES;
|
||||||
import static mage.client.dialog.PreferencesDialog.KEY_DECK_EDITOR_SEARCH_TYPES;
|
import static mage.client.dialog.PreferencesDialog.KEY_DECK_EDITOR_SEARCH_TYPES;
|
||||||
import static mage.client.dialog.PreferencesDialog.KEY_DECK_EDITOR_SEARCH_UNIQUE;
|
import static mage.client.dialog.PreferencesDialog.KEY_DECK_EDITOR_SEARCH_UNIQUE;
|
||||||
import mage.client.util.GUISizeHelper;
|
import mage.client.util.GUISizeHelper;
|
||||||
import mage.client.util.gui.FastSearchUtil;
|
import mage.client.util.gui.FastSearchUtil;
|
||||||
import mage.client.dialog.CheckBoxList;
|
|
||||||
import mage.client.util.sets.ConstructedFormats;
|
import mage.client.util.sets.ConstructedFormats;
|
||||||
import mage.constants.CardType;
|
import mage.constants.CardType;
|
||||||
import mage.constants.Rarity;
|
import mage.constants.Rarity;
|
||||||
|
@ -85,7 +85,7 @@ public class CardSelector extends javax.swing.JPanel implements ComponentListene
|
||||||
private final SortSetting sortSetting;
|
private final SortSetting sortSetting;
|
||||||
private static final Map<String, Integer> pdAllowed = new HashMap<>();
|
private static final Map<String, Integer> pdAllowed = new HashMap<>();
|
||||||
|
|
||||||
private final String TEST_MULTI_SET="Multiple Sets selected";
|
private final String TEST_MULTI_SET = "Multiple Sets selected";
|
||||||
|
|
||||||
private final ActionListener searchAction = evt -> jButtonSearchActionPerformed(evt);
|
private final ActionListener searchAction = evt -> jButtonSearchActionPerformed(evt);
|
||||||
|
|
||||||
|
@ -101,18 +101,16 @@ public class CardSelector extends javax.swing.JPanel implements ComponentListene
|
||||||
setGUISize();
|
setGUISize();
|
||||||
currentView = mainModel; // by default we use List View
|
currentView = mainModel; // by default we use List View
|
||||||
|
|
||||||
listCodeSelected = new CheckBoxList();
|
listCodeSelected = new CheckBoxList();
|
||||||
// remove the all option
|
// remove the all option
|
||||||
boolean is_removeFinish=false;
|
boolean is_removeFinish = false;
|
||||||
|
|
||||||
String[] setCodes = ConstructedFormats.getTypes();
|
String[] setCodes = ConstructedFormats.getTypes();
|
||||||
java.util.List<String> result = new ArrayList<>();
|
java.util.List<String> result = new ArrayList<>();
|
||||||
|
|
||||||
for(int i=0; (i<setCodes.length)&&(!is_removeFinish);i++)
|
for (int i = 0; (i < setCodes.length) && (!is_removeFinish); i++) {
|
||||||
{
|
|
||||||
String item = setCodes[i];
|
String item = setCodes[i];
|
||||||
if(!item.equals(ConstructedFormats.ALL))
|
if (!item.equals(ConstructedFormats.ALL)) {
|
||||||
{
|
|
||||||
result.add(item);
|
result.add(item);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -377,33 +375,29 @@ public class CardSelector extends javax.swing.JPanel implements ComponentListene
|
||||||
criteria.rarities(Rarity.BONUS);
|
criteria.rarities(Rarity.BONUS);
|
||||||
}
|
}
|
||||||
if (this.cbExpansionSet.isVisible()) {
|
if (this.cbExpansionSet.isVisible()) {
|
||||||
if(listCodeSelected.getCheckedIndices().length <= 1)
|
if (listCodeSelected.getCheckedIndices().length <= 1) {
|
||||||
{
|
String expansionSelection = this.cbExpansionSet.getSelectedItem().toString();
|
||||||
String expansionSelection = this.cbExpansionSet.getSelectedItem().toString();
|
if (!expansionSelection.equals("- All Sets")) {
|
||||||
if (!expansionSelection.equals("- All Sets")) {
|
java.util.List<String> setCodes = ConstructedFormats.getSetsByFormat(expansionSelection);
|
||||||
java.util.List<String> setCodes = ConstructedFormats.getSetsByFormat(expansionSelection);
|
criteria.setCodes(setCodes.toArray(new String[0]));
|
||||||
criteria.setCodes(setCodes.toArray(new String[0]));
|
}
|
||||||
}
|
} else {
|
||||||
}
|
java.util.List<String> setCodes = new ArrayList<>();
|
||||||
else
|
//java.util.List<String> listReceived=new ArrayList<>() ;
|
||||||
{
|
|
||||||
java.util.List<String> setCodes = new ArrayList<>() ;
|
|
||||||
//java.util.List<String> listReceived=new ArrayList<>() ;
|
|
||||||
|
|
||||||
int[] choiseValue=listCodeSelected.getCheckedIndices();
|
int[] choiseValue = listCodeSelected.getCheckedIndices();
|
||||||
ListModel x= listCodeSelected.getModel();
|
ListModel x = listCodeSelected.getModel();
|
||||||
|
|
||||||
for(int itemIndex: choiseValue){
|
for (int itemIndex : choiseValue) {
|
||||||
|
|
||||||
java.util.List<String> listReceived=ConstructedFormats.getSetsByFormat(x.getElementAt(itemIndex).toString());
|
|
||||||
listReceived.stream().filter((item) -> (setCodes.contains(item)==false)).forEachOrdered((item) -> {
|
|
||||||
setCodes.add(item);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
criteria.setCodes(setCodes.toArray(new String[0]));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
java.util.List<String> listReceived = ConstructedFormats.getSetsByFormat(x.getElementAt(itemIndex).toString());
|
||||||
|
listReceived.stream().filter((item) -> (setCodes.contains(item) == false)).forEachOrdered((item) -> {
|
||||||
|
setCodes.add(item);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
criteria.setCodes(setCodes.toArray(new String[0]));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return criteria;
|
return criteria;
|
||||||
}
|
}
|
||||||
|
@ -1234,19 +1228,16 @@ public class CardSelector extends javax.swing.JPanel implements ComponentListene
|
||||||
}// </editor-fold>//GEN-END:initComponents
|
}// </editor-fold>//GEN-END:initComponents
|
||||||
|
|
||||||
private void cbExpansionSetActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_cbExpansionSetActionPerformed
|
private void cbExpansionSetActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_cbExpansionSetActionPerformed
|
||||||
if(!cbExpansionSet.getSelectedItem().toString().contains(TEST_MULTI_SET))
|
if (!cbExpansionSet.getSelectedItem().toString().contains(TEST_MULTI_SET)) {
|
||||||
{
|
int index = cbExpansionSet.getSelectedIndex();
|
||||||
int index=cbExpansionSet.getSelectedIndex();
|
if (cbExpansionSet.getItemAt(0).contains(TEST_MULTI_SET)) {
|
||||||
if(cbExpansionSet.getItemAt(0).contains(TEST_MULTI_SET))
|
|
||||||
{
|
|
||||||
cbExpansionSet.removeItemAt(0);
|
cbExpansionSet.removeItemAt(0);
|
||||||
index--;
|
index--;
|
||||||
}
|
}
|
||||||
listCodeSelected.uncheckAll();
|
listCodeSelected.uncheckAll();
|
||||||
if(index > 0)
|
if (index > 0) {
|
||||||
{
|
|
||||||
//ofset because all sets is removed from the list
|
//ofset because all sets is removed from the list
|
||||||
listCodeSelected.setChecked(index-1, true);
|
listCodeSelected.setChecked(index - 1, true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1431,53 +1422,44 @@ public class CardSelector extends javax.swing.JPanel implements ComponentListene
|
||||||
}//GEN-LAST:event_chkRulesActionPerformed
|
}//GEN-LAST:event_chkRulesActionPerformed
|
||||||
|
|
||||||
private void btnExpansionSearchActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_btnExpansionSearchActionPerformed
|
private void btnExpansionSearchActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_btnExpansionSearchActionPerformed
|
||||||
FastSearchUtil.showFastSearchForStringComboBox(listCodeSelected, FastSearchUtil.DEFAULT_EXPANSION_SEARCH_MESSAGE);
|
FastSearchUtil.showFastSearchForStringComboBox(listCodeSelected, FastSearchUtil.DEFAULT_EXPANSION_SEARCH_MESSAGE);
|
||||||
//
|
//
|
||||||
int[] choiseValue=listCodeSelected.getCheckedIndices();
|
int[] choiseValue = listCodeSelected.getCheckedIndices();
|
||||||
ListModel x= listCodeSelected.getModel();
|
ListModel x = listCodeSelected.getModel();
|
||||||
|
|
||||||
if(choiseValue.length==0)//none
|
if (choiseValue.length == 0)//none
|
||||||
{
|
{
|
||||||
cbExpansionSet.setSelectedIndex(0);
|
cbExpansionSet.setSelectedIndex(0);
|
||||||
}
|
} else if (choiseValue.length == 1)//one
|
||||||
else if(choiseValue.length==1)//one
|
|
||||||
{
|
{
|
||||||
String itemSelected=listCodeSelected.getModel().getElementAt(choiseValue[0]).toString();
|
String itemSelected = listCodeSelected.getModel().getElementAt(choiseValue[0]).toString();
|
||||||
for(int index=0;index < cbExpansionSet.getItemCount();index++)
|
for (int index = 0; index < cbExpansionSet.getItemCount(); index++) {
|
||||||
{
|
if (cbExpansionSet.getItemAt(index).equals(itemSelected)) {
|
||||||
if(cbExpansionSet.getItemAt(index).equals(itemSelected))
|
|
||||||
{
|
|
||||||
cbExpansionSet.setSelectedIndex(index);
|
cbExpansionSet.setSelectedIndex(index);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
} else//many
|
||||||
else//many
|
|
||||||
{
|
{
|
||||||
String message=String.format("%s:%d",TEST_MULTI_SET,choiseValue.length);
|
String message = String.format("%s:%d", TEST_MULTI_SET, choiseValue.length);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
cbExpansionSet.insertItemAt(message, 0);
|
cbExpansionSet.insertItemAt(message, 0);
|
||||||
cbExpansionSet.setSelectedIndex(0);
|
cbExpansionSet.setSelectedIndex(0);
|
||||||
|
|
||||||
if(cbExpansionSet.getItemAt(1).contains(TEST_MULTI_SET))
|
if (cbExpansionSet.getItemAt(1).contains(TEST_MULTI_SET)) {
|
||||||
{
|
cbExpansionSet.removeItemAt(1);
|
||||||
cbExpansionSet.removeItemAt(1);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
//listCodeSelected.setChecked(index-1, true);
|
//listCodeSelected.setChecked(index-1, true);
|
||||||
//cbExpansionSet.
|
//cbExpansionSet.
|
||||||
}
|
}
|
||||||
|
|
||||||
/*for(int itemIndex: choiseValue){
|
/*for(int itemIndex: choiseValue){
|
||||||
// LogLog.warn(String.format("%d:%s",itemIndex,x.getElementAt(itemIndex).toString()));
|
// LogLog.warn(String.format("%d:%s",itemIndex,x.getElementAt(itemIndex).toString()));
|
||||||
}
|
}
|
||||||
*/
|
*/
|
||||||
//
|
//
|
||||||
|
filterCards();
|
||||||
filterCards();
|
|
||||||
}//GEN-LAST:event_btnExpansionSearchActionPerformed
|
}//GEN-LAST:event_btnExpansionSearchActionPerformed
|
||||||
|
|
||||||
private void tbCommonActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_tbCommonActionPerformed
|
private void tbCommonActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_tbCommonActionPerformed
|
||||||
|
@ -1538,7 +1520,7 @@ public class CardSelector extends javax.swing.JPanel implements ComponentListene
|
||||||
private JTable mainTable;
|
private JTable mainTable;
|
||||||
private ICardGrid currentView;
|
private ICardGrid currentView;
|
||||||
|
|
||||||
private CheckBoxList listCodeSelected;
|
private final CheckBoxList listCodeSelected;
|
||||||
|
|
||||||
// Variables declaration - do not modify//GEN-BEGIN:variables
|
// Variables declaration - do not modify//GEN-BEGIN:variables
|
||||||
private javax.swing.ButtonGroup bgView;
|
private javax.swing.ButtonGroup bgView;
|
||||||
|
|
|
@ -26,11 +26,10 @@
|
||||||
*/
|
*/
|
||||||
package mage.client.deckeditor.table;
|
package mage.client.deckeditor.table;
|
||||||
|
|
||||||
|
import java.util.Comparator;
|
||||||
import mage.cards.MageCard;
|
import mage.cards.MageCard;
|
||||||
import mage.view.CardView;
|
import mage.view.CardView;
|
||||||
|
|
||||||
import java.util.Comparator;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* {@link MageCard} comparator. Used to sort cards in Deck Editor Table View
|
* {@link MageCard} comparator. Used to sort cards in Deck Editor Table View
|
||||||
* pane.
|
* pane.
|
||||||
|
@ -75,7 +74,7 @@ public class MageCardComparator implements Comparator<CardView> {
|
||||||
// Color
|
// Color
|
||||||
case 3:
|
case 3:
|
||||||
aCom = a.getColorText();
|
aCom = a.getColorText();
|
||||||
bCom = a.getColorText();
|
bCom = b.getColorText();
|
||||||
break;
|
break;
|
||||||
// Type
|
// Type
|
||||||
case 4:
|
case 4:
|
||||||
|
|
|
@ -203,6 +203,7 @@ public class PreferencesDialog extends javax.swing.JDialog {
|
||||||
public static final String KEY_TABLES_DIVIDER_LOCATION_1 = "tablePanelDividerLocation1";
|
public static final String KEY_TABLES_DIVIDER_LOCATION_1 = "tablePanelDividerLocation1";
|
||||||
public static final String KEY_TABLES_DIVIDER_LOCATION_2 = "tablePanelDividerLocation2";
|
public static final String KEY_TABLES_DIVIDER_LOCATION_2 = "tablePanelDividerLocation2";
|
||||||
public static final String KEY_TABLES_DIVIDER_LOCATION_3 = "tablePanelDividerLocation3";
|
public static final String KEY_TABLES_DIVIDER_LOCATION_3 = "tablePanelDividerLocation3";
|
||||||
|
public static final String KEY_TABLES_DIVIDER_LOCATION_4 = "tablePanelDividerLocation4";
|
||||||
|
|
||||||
// Positions of deck editor divider bars
|
// Positions of deck editor divider bars
|
||||||
public static final String KEY_EDITOR_HORIZONTAL_DIVIDER_LOCATION = "editorHorizontalDividerLocation";
|
public static final String KEY_EDITOR_HORIZONTAL_DIVIDER_LOCATION = "editorHorizontalDividerLocation";
|
||||||
|
|
|
@ -111,7 +111,7 @@
|
||||||
|
|
||||||
<Layout class="org.netbeans.modules.form.compat2.layouts.support.JScrollPaneSupportLayout"/>
|
<Layout class="org.netbeans.modules.form.compat2.layouts.support.JScrollPaneSupportLayout"/>
|
||||||
<SubComponents>
|
<SubComponents>
|
||||||
<Component class="javax.swing.JTable" name="tableSeats">
|
<Component class="javax.swing.JTable" name="jTableSeats">
|
||||||
<Properties>
|
<Properties>
|
||||||
<Property name="model" type="javax.swing.table.TableModel" editor="org.netbeans.modules.form.RADConnectionPropertyEditor">
|
<Property name="model" type="javax.swing.table.TableModel" editor="org.netbeans.modules.form.RADConnectionPropertyEditor">
|
||||||
<Connection code="tableWaitModel" type="code"/>
|
<Connection code="tableWaitModel" type="code"/>
|
||||||
|
|
|
@ -34,6 +34,7 @@
|
||||||
package mage.client.dialog;
|
package mage.client.dialog;
|
||||||
|
|
||||||
import java.awt.Dimension;
|
import java.awt.Dimension;
|
||||||
|
import java.awt.Rectangle;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
@ -43,22 +44,26 @@ import java.util.concurrent.TimeUnit;
|
||||||
import javax.swing.Icon;
|
import javax.swing.Icon;
|
||||||
import javax.swing.SwingWorker;
|
import javax.swing.SwingWorker;
|
||||||
import javax.swing.table.AbstractTableModel;
|
import javax.swing.table.AbstractTableModel;
|
||||||
|
import org.apache.log4j.Logger;
|
||||||
|
|
||||||
import mage.client.MageFrame;
|
import mage.client.MageFrame;
|
||||||
import mage.client.SessionHandler;
|
import mage.client.SessionHandler;
|
||||||
import mage.client.chat.ChatPanelBasic;
|
import mage.client.chat.ChatPanelBasic;
|
||||||
import mage.client.components.MageComponents;
|
import mage.client.components.MageComponents;
|
||||||
import mage.client.components.tray.MageTray;
|
import mage.client.components.tray.MageTray;
|
||||||
import static mage.client.dialog.PreferencesDialog.KEY_TABLE_WAITING_COLUMNS_ORDER;
|
|
||||||
import static mage.client.dialog.PreferencesDialog.KEY_TABLE_WAITING_COLUMNS_WIDTH;
|
|
||||||
import mage.client.util.GUISizeHelper;
|
import mage.client.util.GUISizeHelper;
|
||||||
import mage.client.util.audio.AudioManager;
|
import mage.client.util.audio.AudioManager;
|
||||||
import mage.client.util.gui.TableUtil;
|
import mage.client.util.gui.TableUtil;
|
||||||
import mage.client.util.gui.countryBox.CountryCellRenderer;
|
import mage.client.util.gui.countryBox.CountryCellRenderer;
|
||||||
|
import mage.client.util.gui.GuiDisplayUtil;
|
||||||
import mage.players.PlayerType;
|
import mage.players.PlayerType;
|
||||||
import mage.remote.Session;
|
import mage.remote.Session;
|
||||||
import mage.view.SeatView;
|
import mage.view.SeatView;
|
||||||
import mage.view.TableView;
|
import mage.view.TableView;
|
||||||
import org.apache.log4j.Logger;
|
|
||||||
|
import static mage.client.dialog.PreferencesDialog.KEY_TABLE_WAITING_COLUMNS_ORDER;
|
||||||
|
import static mage.client.dialog.PreferencesDialog.KEY_TABLE_WAITING_COLUMNS_WIDTH;
|
||||||
|
import static mage.client.dialog.PreferencesDialog.KEY_TABLES_DIVIDER_LOCATION_4;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author BetaSteward_at_googlemail.com
|
* @author BetaSteward_at_googlemail.com
|
||||||
|
@ -66,7 +71,7 @@ import org.apache.log4j.Logger;
|
||||||
public class TableWaitingDialog extends MageDialog {
|
public class TableWaitingDialog extends MageDialog {
|
||||||
|
|
||||||
private static final Logger LOGGER = Logger.getLogger(TableWaitingDialog.class);
|
private static final Logger LOGGER = Logger.getLogger(TableWaitingDialog.class);
|
||||||
private static final int[] DEFAULT_COLUMS_WIDTH = {20, 50, 100, 100, 100};
|
private static final int[] DEFAULT_COLUMNS_WIDTH = {20, 50, 100, 100, 100, 100};
|
||||||
|
|
||||||
private UUID tableId;
|
private UUID tableId;
|
||||||
private UUID roomId;
|
private UUID roomId;
|
||||||
|
@ -89,12 +94,11 @@ public class TableWaitingDialog extends MageDialog {
|
||||||
this.setSize(prefWidth, prefHeight);
|
this.setSize(prefWidth, prefHeight);
|
||||||
}
|
}
|
||||||
|
|
||||||
chatPanel.useExtendedView(ChatPanelBasic.VIEW_MODE.NONE);
|
|
||||||
tableSeats.createDefaultColumnsFromModel();
|
|
||||||
TableUtil.setColumnWidthAndOrder(tableSeats, DEFAULT_COLUMS_WIDTH, KEY_TABLE_WAITING_COLUMNS_WIDTH, KEY_TABLE_WAITING_COLUMNS_ORDER);
|
|
||||||
tableSeats.setDefaultRenderer(Icon.class, new CountryCellRenderer());
|
|
||||||
setGUISize();
|
setGUISize();
|
||||||
|
jTableSeats.createDefaultColumnsFromModel();
|
||||||
|
jTableSeats.setDefaultRenderer(Icon.class, new CountryCellRenderer());
|
||||||
|
TableUtil.setColumnWidthAndOrder(jTableSeats, DEFAULT_COLUMNS_WIDTH, KEY_TABLE_WAITING_COLUMNS_WIDTH, KEY_TABLE_WAITING_COLUMNS_ORDER);
|
||||||
|
chatPanel.useExtendedView(ChatPanelBasic.VIEW_MODE.NONE);
|
||||||
MageFrame.getUI().addButton(MageComponents.TABLE_WAITING_START_BUTTON, btnStart);
|
MageFrame.getUI().addButton(MageComponents.TABLE_WAITING_START_BUTTON, btnStart);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -104,9 +108,9 @@ public class TableWaitingDialog extends MageDialog {
|
||||||
}
|
}
|
||||||
|
|
||||||
private void setGUISize() {
|
private void setGUISize() {
|
||||||
tableSeats.getTableHeader().setFont(GUISizeHelper.tableFont);
|
jTableSeats.getTableHeader().setFont(GUISizeHelper.tableFont);
|
||||||
tableSeats.setFont(GUISizeHelper.tableFont);
|
jTableSeats.setFont(GUISizeHelper.tableFont);
|
||||||
tableSeats.setRowHeight(GUISizeHelper.getTableRowHeight());
|
jTableSeats.setRowHeight(GUISizeHelper.getTableRowHeight());
|
||||||
|
|
||||||
jSplitPane1.setDividerSize(GUISizeHelper.dividerBarSize);
|
jSplitPane1.setDividerSize(GUISizeHelper.dividerBarSize);
|
||||||
jScrollPane1.getVerticalScrollBar().setPreferredSize(new Dimension(GUISizeHelper.scrollBarSize, 0));
|
jScrollPane1.getVerticalScrollBar().setPreferredSize(new Dimension(GUISizeHelper.scrollBarSize, 0));
|
||||||
|
@ -131,14 +135,14 @@ public class TableWaitingDialog extends MageDialog {
|
||||||
closeDialog();
|
closeDialog();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
int row = this.tableSeats.getSelectedRow();
|
int row = this.jTableSeats.getSelectedRow();
|
||||||
if (getTitle().equals("Waiting for players")) {
|
if (getTitle().equals("Waiting for players")) {
|
||||||
this.title = getTitle() + " - " + table.getDeckType() + " / " + table.getGameType();
|
this.title = getTitle() + " - " + table.getDeckType() + " / " + table.getGameType();
|
||||||
this.repaint();
|
this.repaint();
|
||||||
}
|
}
|
||||||
tableWaitModel.loadData(table);
|
tableWaitModel.loadData(table);
|
||||||
this.tableSeats.repaint();
|
this.jTableSeats.repaint();
|
||||||
this.tableSeats.getSelectionModel().setSelectionInterval(row, row);
|
this.jTableSeats.getSelectionModel().setSelectionInterval(row, row);
|
||||||
} else {
|
} else {
|
||||||
closeDialog();
|
closeDialog();
|
||||||
}
|
}
|
||||||
|
@ -148,10 +152,15 @@ public class TableWaitingDialog extends MageDialog {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void showDialog(UUID roomId, UUID tableId, boolean isTournament) {
|
public void showDialog(UUID roomId, UUID tableId, boolean isTournament) {
|
||||||
|
Rectangle currentBounds = MageFrame.getDesktop().getBounds();
|
||||||
|
Optional<UUID> chatId = SessionHandler.getTableChatId(tableId);
|
||||||
|
String tournamentChatDivider = PreferencesDialog.getCachedValue(KEY_TABLES_DIVIDER_LOCATION_4, null);
|
||||||
|
updateTask = new UpdateSeatsTask(SessionHandler.getSession(), roomId, tableId, this);
|
||||||
|
|
||||||
this.roomId = roomId;
|
this.roomId = roomId;
|
||||||
this.tableId = tableId;
|
this.tableId = tableId;
|
||||||
this.isTournament = isTournament;
|
this.isTournament = isTournament;
|
||||||
updateTask = new UpdateSeatsTask(SessionHandler.getSession(), roomId, tableId, this);
|
|
||||||
if (SessionHandler.isTableOwner(roomId, tableId)) {
|
if (SessionHandler.isTableOwner(roomId, tableId)) {
|
||||||
this.btnStart.setVisible(true);
|
this.btnStart.setVisible(true);
|
||||||
this.btnMoveDown.setVisible(true);
|
this.btnMoveDown.setVisible(true);
|
||||||
|
@ -161,13 +170,15 @@ public class TableWaitingDialog extends MageDialog {
|
||||||
this.btnMoveDown.setVisible(false);
|
this.btnMoveDown.setVisible(false);
|
||||||
this.btnMoveUp.setVisible(false);
|
this.btnMoveUp.setVisible(false);
|
||||||
}
|
}
|
||||||
Optional<UUID> chatId = SessionHandler.getTableChatId(tableId);
|
|
||||||
if (chatId.isPresent()) {
|
if (chatId.isPresent()) {
|
||||||
this.chatPanel.connect(chatId.get());
|
this.chatPanel.connect(chatId.get());
|
||||||
updateTask.execute();
|
updateTask.execute();
|
||||||
this.setModal(false);
|
this.setModal(false);
|
||||||
this.setLocation(100, 100);
|
this.setLocation(100, 100);
|
||||||
this.setVisible(true);
|
this.setVisible(true);
|
||||||
|
|
||||||
|
GuiDisplayUtil.restoreDividerLocations(currentBounds, tournamentChatDivider, jSplitPane1);
|
||||||
} else {
|
} else {
|
||||||
closeDialog();
|
closeDialog();
|
||||||
}
|
}
|
||||||
|
@ -177,12 +188,13 @@ public class TableWaitingDialog extends MageDialog {
|
||||||
if (updateTask != null) {
|
if (updateTask != null) {
|
||||||
updateTask.cancel(true);
|
updateTask.cancel(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
this.chatPanel.disconnect();
|
this.chatPanel.disconnect();
|
||||||
MageFrame.getUI().removeButton(MageComponents.TABLE_WAITING_START_BUTTON);
|
MageFrame.getUI().removeButton(MageComponents.TABLE_WAITING_START_BUTTON);
|
||||||
this.removeDialog();
|
this.removeDialog();
|
||||||
TableUtil.saveColumnWidthAndOrderToPrefs(tableSeats, KEY_TABLE_WAITING_COLUMNS_WIDTH, KEY_TABLE_WAITING_COLUMNS_ORDER);
|
TableUtil.saveColumnWidthAndOrderToPrefs(jTableSeats, KEY_TABLE_WAITING_COLUMNS_WIDTH, KEY_TABLE_WAITING_COLUMNS_ORDER);
|
||||||
PreferencesDialog.saveValue(PreferencesDialog.KEY_TABLE_WAITING_WIDTH, Integer.toString(getWidth()));
|
GuiDisplayUtil.saveCurrentBoundsToPrefs();
|
||||||
PreferencesDialog.saveValue(PreferencesDialog.KEY_TABLE_WAITING_HEIGHT, Integer.toString(getHeight()));
|
GuiDisplayUtil.saveDividerLocationToPrefs(KEY_TABLES_DIVIDER_LOCATION_4, this.jSplitPane1.getDividerLocation());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -200,7 +212,7 @@ public class TableWaitingDialog extends MageDialog {
|
||||||
btnStart = new javax.swing.JButton();
|
btnStart = new javax.swing.JButton();
|
||||||
jSplitPane1 = new javax.swing.JSplitPane();
|
jSplitPane1 = new javax.swing.JSplitPane();
|
||||||
jScrollPane1 = new javax.swing.JScrollPane();
|
jScrollPane1 = new javax.swing.JScrollPane();
|
||||||
tableSeats = new javax.swing.JTable();
|
jTableSeats = new javax.swing.JTable();
|
||||||
chatPanel = new mage.client.chat.ChatPanelBasic();
|
chatPanel = new mage.client.chat.ChatPanelBasic();
|
||||||
|
|
||||||
setResizable(true);
|
setResizable(true);
|
||||||
|
@ -226,9 +238,9 @@ public class TableWaitingDialog extends MageDialog {
|
||||||
jSplitPane1.setResizeWeight(1.0);
|
jSplitPane1.setResizeWeight(1.0);
|
||||||
jSplitPane1.setToolTipText("");
|
jSplitPane1.setToolTipText("");
|
||||||
|
|
||||||
tableSeats.setModel(tableWaitModel);
|
jTableSeats.setModel(tableWaitModel);
|
||||||
tableSeats.setSelectionMode(javax.swing.ListSelectionModel.SINGLE_SELECTION);
|
jTableSeats.setSelectionMode(javax.swing.ListSelectionModel.SINGLE_SELECTION);
|
||||||
jScrollPane1.setViewportView(tableSeats);
|
jScrollPane1.setViewportView(jTableSeats);
|
||||||
|
|
||||||
jSplitPane1.setLeftComponent(jScrollPane1);
|
jSplitPane1.setLeftComponent(jScrollPane1);
|
||||||
jSplitPane1.setRightComponent(chatPanel);
|
jSplitPane1.setRightComponent(chatPanel);
|
||||||
|
@ -288,19 +300,19 @@ public class TableWaitingDialog extends MageDialog {
|
||||||
}//GEN-LAST:event_btnCancelActionPerformed
|
}//GEN-LAST:event_btnCancelActionPerformed
|
||||||
|
|
||||||
private void btnMoveDownActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_btnMoveDownActionPerformed
|
private void btnMoveDownActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_btnMoveDownActionPerformed
|
||||||
int row = this.tableSeats.getSelectedRow();
|
int row = this.jTableSeats.getSelectedRow();
|
||||||
if (row < this.tableSeats.getRowCount() - 1) {
|
if (row < this.jTableSeats.getRowCount() - 1) {
|
||||||
SessionHandler.swapSeats(roomId, tableId, row, row + 1);
|
SessionHandler.swapSeats(roomId, tableId, row, row + 1);
|
||||||
this.tableSeats.getSelectionModel().setSelectionInterval(row + 1, row + 1);
|
this.jTableSeats.getSelectionModel().setSelectionInterval(row + 1, row + 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
}//GEN-LAST:event_btnMoveDownActionPerformed
|
}//GEN-LAST:event_btnMoveDownActionPerformed
|
||||||
|
|
||||||
private void btnMoveUpActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_btnMoveUpActionPerformed
|
private void btnMoveUpActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_btnMoveUpActionPerformed
|
||||||
int row = this.tableSeats.getSelectedRow();
|
int row = this.jTableSeats.getSelectedRow();
|
||||||
if (row > 0) {
|
if (row > 0) {
|
||||||
SessionHandler.swapSeats(roomId, tableId, row, row - 1);
|
SessionHandler.swapSeats(roomId, tableId, row, row - 1);
|
||||||
this.tableSeats.getSelectionModel().setSelectionInterval(row - 1, row - 1);
|
this.jTableSeats.getSelectionModel().setSelectionInterval(row - 1, row - 1);
|
||||||
}
|
}
|
||||||
}//GEN-LAST:event_btnMoveUpActionPerformed
|
}//GEN-LAST:event_btnMoveUpActionPerformed
|
||||||
|
|
||||||
|
@ -312,14 +324,14 @@ public class TableWaitingDialog extends MageDialog {
|
||||||
private mage.client.chat.ChatPanelBasic chatPanel;
|
private mage.client.chat.ChatPanelBasic chatPanel;
|
||||||
private javax.swing.JScrollPane jScrollPane1;
|
private javax.swing.JScrollPane jScrollPane1;
|
||||||
private javax.swing.JSplitPane jSplitPane1;
|
private javax.swing.JSplitPane jSplitPane1;
|
||||||
private javax.swing.JTable tableSeats;
|
private javax.swing.JTable jTableSeats;
|
||||||
// End of variables declaration//GEN-END:variables
|
// End of variables declaration//GEN-END:variables
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
class TableWaitModel extends AbstractTableModel {
|
class TableWaitModel extends AbstractTableModel {
|
||||||
|
|
||||||
private final String[] columnNames = new String[]{"Seat", "Loc", "Player Name", "Constructed Rating", "Player Type", "History"};
|
private final String[] columnNames = new String[]{"Seat", "Loc", "Player Name", "Rating", "Player Type", "History"};
|
||||||
private SeatView[] seats = new SeatView[0];
|
private SeatView[] seats = new SeatView[0];
|
||||||
private boolean limited;
|
private boolean limited;
|
||||||
|
|
||||||
|
@ -327,8 +339,6 @@ class TableWaitModel extends AbstractTableModel {
|
||||||
seats = table.getSeats().toArray(new SeatView[0]);
|
seats = table.getSeats().toArray(new SeatView[0]);
|
||||||
if (limited != table.isLimited()) {
|
if (limited != table.isLimited()) {
|
||||||
limited = table.isLimited();
|
limited = table.isLimited();
|
||||||
columnNames[3] = limited ? "Limited Rating" : "Constructed Rating";
|
|
||||||
this.fireTableStructureChanged();
|
|
||||||
}
|
}
|
||||||
this.fireTableDataChanged();
|
this.fireTableDataChanged();
|
||||||
}
|
}
|
||||||
|
|
|
@ -56,6 +56,10 @@ import mage.client.components.MageComponents;
|
||||||
import mage.client.dialog.*;
|
import mage.client.dialog.*;
|
||||||
import static mage.client.dialog.PreferencesDialog.KEY_TABLES_COLUMNS_ORDER;
|
import static mage.client.dialog.PreferencesDialog.KEY_TABLES_COLUMNS_ORDER;
|
||||||
import static mage.client.dialog.PreferencesDialog.KEY_TABLES_COLUMNS_WIDTH;
|
import static mage.client.dialog.PreferencesDialog.KEY_TABLES_COLUMNS_WIDTH;
|
||||||
|
import static mage.client.dialog.PreferencesDialog.KEY_TABLES_FILTER_SETTINGS;
|
||||||
|
import static mage.client.dialog.PreferencesDialog.KEY_TABLES_DIVIDER_LOCATION_1;
|
||||||
|
import static mage.client.dialog.PreferencesDialog.KEY_TABLES_DIVIDER_LOCATION_2;
|
||||||
|
import static mage.client.dialog.PreferencesDialog.KEY_TABLES_DIVIDER_LOCATION_3;
|
||||||
import mage.client.util.ButtonColumn;
|
import mage.client.util.ButtonColumn;
|
||||||
import mage.client.util.GUISizeHelper;
|
import mage.client.util.GUISizeHelper;
|
||||||
import mage.client.util.IgnoreList;
|
import mage.client.util.IgnoreList;
|
||||||
|
@ -191,8 +195,7 @@ public class TablesPanel extends javax.swing.JPanel {
|
||||||
list.add(new RowSorter.SortKey(TableTableModel.COLUMN_CREATED, SortOrder.DESCENDING));
|
list.add(new RowSorter.SortKey(TableTableModel.COLUMN_CREATED, SortOrder.DESCENDING));
|
||||||
activeTablesSorter.setSortKeys(list);
|
activeTablesSorter.setSortKeys(list);
|
||||||
|
|
||||||
TableUtil.setColumnWidthAndOrder(tableTables, DEFAULT_COLUMNS_WIDTH,
|
TableUtil.setColumnWidthAndOrder(tableTables, DEFAULT_COLUMNS_WIDTH, KEY_TABLES_COLUMNS_WIDTH, KEY_TABLES_COLUMNS_ORDER);
|
||||||
PreferencesDialog.KEY_TABLES_COLUMNS_WIDTH, PreferencesDialog.KEY_TABLES_COLUMNS_ORDER); // TODO: is sort order save and restore after app restart/window open?
|
|
||||||
|
|
||||||
// 2. TABLE COMPLETED
|
// 2. TABLE COMPLETED
|
||||||
completedTablesSorter = new MageTableRowSorter(matchesModel);
|
completedTablesSorter = new MageTableRowSorter(matchesModel);
|
||||||
|
@ -227,8 +230,7 @@ public class TablesPanel extends javax.swing.JPanel {
|
||||||
jScrollPaneTablesActive.getViewport().setBackground(new Color(255, 255, 255, 50));
|
jScrollPaneTablesActive.getViewport().setBackground(new Color(255, 255, 255, 50));
|
||||||
jScrollPaneTablesFinished.getViewport().setBackground(new Color(255, 255, 255, 50));
|
jScrollPaneTablesFinished.getViewport().setBackground(new Color(255, 255, 255, 50));
|
||||||
|
|
||||||
restoreSettings();
|
restoreFilters();
|
||||||
|
|
||||||
setGUISize();
|
setGUISize();
|
||||||
|
|
||||||
Action openTableAction;
|
Action openTableAction;
|
||||||
|
@ -343,7 +345,7 @@ public class TablesPanel extends javax.swing.JPanel {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void cleanUp() {
|
public void cleanUp() {
|
||||||
saveSettings();
|
saveGuiSettings();
|
||||||
chatPanelMain.cleanUp();
|
chatPanelMain.cleanUp();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -406,65 +408,32 @@ public class TablesPanel extends javax.swing.JPanel {
|
||||||
}
|
}
|
||||||
|
|
||||||
private void saveDividerLocations() {
|
private void saveDividerLocations() {
|
||||||
// save panel sizes and divider locations.
|
// save divider locations and divider saveDividerLocations
|
||||||
Rectangle rec = MageFrame.getDesktop().getBounds();
|
GuiDisplayUtil.saveCurrentBoundsToPrefs();
|
||||||
String sb = Double.toString(rec.getWidth()) + 'x' + Double.toString(rec.getHeight());
|
GuiDisplayUtil.saveDividerLocationToPrefs(KEY_TABLES_DIVIDER_LOCATION_1, this.jSplitPane1.getDividerLocation());
|
||||||
PreferencesDialog.saveValue(PreferencesDialog.KEY_MAGE_PANEL_LAST_SIZE, sb);
|
GuiDisplayUtil.saveDividerLocationToPrefs(KEY_TABLES_DIVIDER_LOCATION_2, this.jSplitPaneTables.getDividerLocation());
|
||||||
PreferencesDialog.saveValue(PreferencesDialog.KEY_TABLES_DIVIDER_LOCATION_1, Integer.toString(this.jSplitPane1.getDividerLocation()));
|
GuiDisplayUtil.saveDividerLocationToPrefs(KEY_TABLES_DIVIDER_LOCATION_3, chatPanelMain.getSplitDividerLocation());
|
||||||
PreferencesDialog.saveValue(PreferencesDialog.KEY_TABLES_DIVIDER_LOCATION_2, Integer.toString(this.jSplitPaneTables.getDividerLocation()));
|
|
||||||
PreferencesDialog.saveValue(PreferencesDialog.KEY_TABLES_DIVIDER_LOCATION_3, Integer.toString(chatPanelMain.getSplitDividerLocation()));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void restoreSettings() {
|
private void restoreFilters() {
|
||||||
// filter settings
|
TableUtil.setActiveFilters(KEY_TABLES_FILTER_SETTINGS, filterButtons);
|
||||||
String formatSettings = PreferencesDialog.getCachedValue(PreferencesDialog.KEY_TABLES_FILTER_SETTINGS, "");
|
|
||||||
int i = 0;
|
|
||||||
for (JToggleButton component : filterButtons) {
|
|
||||||
if (formatSettings.length() > i) {
|
|
||||||
component.setSelected(formatSettings.substring(i, i + 1).equals("x"));
|
|
||||||
} else {
|
|
||||||
component.setSelected(true);
|
|
||||||
}
|
|
||||||
i++;
|
|
||||||
}
|
|
||||||
setTableFilter();
|
setTableFilter();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void saveSettings() {
|
private void saveGuiSettings() {
|
||||||
// Filters
|
TableUtil.saveActiveFiltersToPrefs(KEY_TABLES_FILTER_SETTINGS, filterButtons);
|
||||||
StringBuilder formatSettings = new StringBuilder();
|
|
||||||
for (JToggleButton component : filterButtons) {
|
|
||||||
formatSettings.append(component.isSelected() ? "x" : "-");
|
|
||||||
}
|
|
||||||
PreferencesDialog.saveValue(PreferencesDialog.KEY_TABLES_FILTER_SETTINGS, formatSettings.toString());
|
|
||||||
|
|
||||||
TableUtil.saveColumnWidthAndOrderToPrefs(tableTables, KEY_TABLES_COLUMNS_WIDTH, KEY_TABLES_COLUMNS_ORDER);
|
TableUtil.saveColumnWidthAndOrderToPrefs(tableTables, KEY_TABLES_COLUMNS_WIDTH, KEY_TABLES_COLUMNS_ORDER);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void restoreDividerLocations() {
|
private void restoreDividers() {
|
||||||
Rectangle rec = MageFrame.getDesktop().getBounds();
|
Rectangle currentBounds = MageFrame.getDesktop().getBounds();
|
||||||
if (rec != null) {
|
if (currentBounds != null) {
|
||||||
String size = PreferencesDialog.getCachedValue(PreferencesDialog.KEY_MAGE_PANEL_LAST_SIZE, null);
|
String firstDivider = PreferencesDialog.getCachedValue(KEY_TABLES_DIVIDER_LOCATION_1, null);
|
||||||
String sb = Double.toString(rec.getWidth()) + 'x' + Double.toString(rec.getHeight());
|
String tableDivider = PreferencesDialog.getCachedValue(KEY_TABLES_DIVIDER_LOCATION_2, null);
|
||||||
// use divider positions only if screen size is the same as it was the time the settings were saved
|
String chatDivider = PreferencesDialog.getCachedValue(KEY_TABLES_DIVIDER_LOCATION_3, null);
|
||||||
if (size != null && size.equals(sb)) {
|
GuiDisplayUtil.restoreDividerLocations(currentBounds, firstDivider, jSplitPane1);
|
||||||
String location = PreferencesDialog.getCachedValue(PreferencesDialog.KEY_TABLES_DIVIDER_LOCATION_1, null);
|
GuiDisplayUtil.restoreDividerLocations(currentBounds, tableDivider, jSplitPaneTables);
|
||||||
if (location != null && jSplitPane1 != null) {
|
GuiDisplayUtil.restoreDividerLocations(currentBounds, chatDivider, chatPanelMain);
|
||||||
jSplitPane1.setDividerLocation(Integer.parseInt(location));
|
|
||||||
}
|
|
||||||
if (this.btnStateFinished.isSelected()) {
|
|
||||||
this.jSplitPaneTables.setDividerLocation(-1);
|
|
||||||
} else {
|
|
||||||
location = PreferencesDialog.getCachedValue(PreferencesDialog.KEY_TABLES_DIVIDER_LOCATION_2, null);
|
|
||||||
if (location != null && jSplitPaneTables != null) {
|
|
||||||
jSplitPaneTables.setDividerLocation(Integer.parseInt(location));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
location = PreferencesDialog.getCachedValue(PreferencesDialog.KEY_TABLES_DIVIDER_LOCATION_3, null);
|
|
||||||
if (location != null && chatPanelMain != null) {
|
|
||||||
chatPanelMain.setSplitDividerLocation(Integer.parseInt(location));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -565,7 +534,7 @@ public class TablesPanel extends javax.swing.JPanel {
|
||||||
MageFrame.getUI().addButton(MageComponents.NEW_GAME_BUTTON, btnNewTable);
|
MageFrame.getUI().addButton(MageComponents.NEW_GAME_BUTTON, btnNewTable);
|
||||||
|
|
||||||
// divider locations have to be set with delay else values set are overwritten with system defaults
|
// divider locations have to be set with delay else values set are overwritten with system defaults
|
||||||
Executors.newSingleThreadScheduledExecutor().schedule(() -> restoreDividerLocations(), 300, TimeUnit.MILLISECONDS);
|
Executors.newSingleThreadScheduledExecutor().schedule(() -> restoreDividers(), 300, TimeUnit.MILLISECONDS);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -580,6 +549,7 @@ public class TablesPanel extends javax.swing.JPanel {
|
||||||
this.jPanelBottom.setVisible(false);
|
this.jPanelBottom.setVisible(false);
|
||||||
} else {
|
} else {
|
||||||
this.jPanelBottom.setVisible(true);
|
this.jPanelBottom.setVisible(true);
|
||||||
|
URLHandler.RemoveMouseAdapter(jLabelFooterText);
|
||||||
URLHandler.handleMessage(serverMessages.get(0), this.jLabelFooterText);
|
URLHandler.handleMessage(serverMessages.get(0), this.jLabelFooterText);
|
||||||
this.jButtonFooterNext.setVisible(serverMessages.size() > 1);
|
this.jButtonFooterNext.setVisible(serverMessages.size() > 1);
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,10 +9,10 @@ import java.awt.Desktop;
|
||||||
import java.awt.event.MouseAdapter;
|
import java.awt.event.MouseAdapter;
|
||||||
import java.awt.event.MouseEvent;
|
import java.awt.event.MouseEvent;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.net.URL;
|
|
||||||
import java.net.MalformedURLException;
|
import java.net.MalformedURLException;
|
||||||
import java.net.URI;
|
import java.net.URI;
|
||||||
import java.net.URISyntaxException;
|
import java.net.URISyntaxException;
|
||||||
|
import java.net.URL;
|
||||||
import javax.swing.JLabel;
|
import javax.swing.JLabel;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -47,6 +47,7 @@ public class URLHandler {
|
||||||
|
|
||||||
private static MouseAdapter createMouseAdapter(String url) {
|
private static MouseAdapter createMouseAdapter(String url) {
|
||||||
currentMouseAdapter = new MouseAdapter() {
|
currentMouseAdapter = new MouseAdapter() {
|
||||||
|
@Override
|
||||||
public void mouseClicked(MouseEvent e) {
|
public void mouseClicked(MouseEvent e) {
|
||||||
if (e.getClickCount() > 0) {
|
if (e.getClickCount() > 0) {
|
||||||
if (Desktop.isDesktopSupported()) {
|
if (Desktop.isDesktopSupported()) {
|
||||||
|
|
|
@ -4,8 +4,11 @@ import java.awt.*;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
import javax.swing.*;
|
import javax.swing.*;
|
||||||
|
import mage.client.dialog.PreferencesDialog;
|
||||||
|
import static mage.client.dialog.PreferencesDialog.KEY_MAGE_PANEL_LAST_SIZE;
|
||||||
import mage.client.MageFrame;
|
import mage.client.MageFrame;
|
||||||
import mage.client.util.GUISizeHelper;
|
import mage.client.util.GUISizeHelper;
|
||||||
|
import mage.client.table.*;
|
||||||
import mage.constants.*;
|
import mage.constants.*;
|
||||||
import mage.view.CardView;
|
import mage.view.CardView;
|
||||||
import mage.view.CounterView;
|
import mage.view.CounterView;
|
||||||
|
@ -26,6 +29,35 @@ public final class GuiDisplayUtil {
|
||||||
public ArrayList<String> lines;
|
public ArrayList<String> lines;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static void restoreDividerLocations(Rectangle bounds, String lastDividerLocation, JComponent component) {
|
||||||
|
String currentBounds = Double.toString(bounds.getWidth()) + 'x' + Double.toString(bounds.getHeight());
|
||||||
|
String savedBounds = PreferencesDialog.getCachedValue(KEY_MAGE_PANEL_LAST_SIZE, null);
|
||||||
|
// use divider positions only if screen size is the same as it was the time the settings were saved
|
||||||
|
if (savedBounds != null && savedBounds.equals(currentBounds)) {
|
||||||
|
if (lastDividerLocation != null && component != null) {
|
||||||
|
if (component instanceof JSplitPane) {
|
||||||
|
JSplitPane jSplitPane = (JSplitPane) component;
|
||||||
|
jSplitPane.setDividerLocation(Integer.parseInt(lastDividerLocation));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (component instanceof PlayersChatPanel) {
|
||||||
|
PlayersChatPanel playerChatPanel = (PlayersChatPanel) component;
|
||||||
|
playerChatPanel.setSplitDividerLocation(Integer.parseInt(lastDividerLocation));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void saveCurrentBoundsToPrefs() {
|
||||||
|
Rectangle rec = MageFrame.getDesktop().getBounds();
|
||||||
|
String currentBounds = Double.toString(rec.getWidth()) + 'x' + Double.toString(rec.getHeight());
|
||||||
|
PreferencesDialog.saveValue(KEY_MAGE_PANEL_LAST_SIZE, currentBounds);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void saveDividerLocationToPrefs(String dividerPrefKey, int position) {
|
||||||
|
PreferencesDialog.saveValue(dividerPrefKey, Integer.toString(position));
|
||||||
|
}
|
||||||
|
|
||||||
public static JXPanel getDescription(CardView card, int width, int height) {
|
public static JXPanel getDescription(CardView card, int width, int height) {
|
||||||
JXPanel descriptionPanel = new JXPanel();
|
JXPanel descriptionPanel = new JXPanel();
|
||||||
|
|
||||||
|
|
|
@ -5,8 +5,11 @@
|
||||||
*/
|
*/
|
||||||
package mage.client.util.gui;
|
package mage.client.util.gui;
|
||||||
|
|
||||||
|
import java.util.Arrays;
|
||||||
import javax.swing.JTable;
|
import javax.swing.JTable;
|
||||||
|
import javax.swing.JToggleButton;
|
||||||
import javax.swing.table.TableColumn;
|
import javax.swing.table.TableColumn;
|
||||||
|
import org.apache.log4j.Logger;
|
||||||
import mage.client.dialog.PreferencesDialog;
|
import mage.client.dialog.PreferencesDialog;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -22,7 +25,32 @@ public final class TableUtil {
|
||||||
* @param widthPrefKey
|
* @param widthPrefKey
|
||||||
* @param orderPrefKey
|
* @param orderPrefKey
|
||||||
*/
|
*/
|
||||||
static public void setColumnWidthAndOrder(JTable table, int[] defaultColumnsWidth, String widthPrefKey, String orderPrefKey) {
|
|
||||||
|
private static final Logger LOGGER = Logger.getLogger(TableUtil.class);
|
||||||
|
|
||||||
|
public static void saveActiveFiltersToPrefs(String filterPrefKey, JToggleButton[] buttons) {
|
||||||
|
StringBuilder currentFilters = new StringBuilder();
|
||||||
|
for (JToggleButton component : buttons) {
|
||||||
|
currentFilters.append(component.isSelected() ? "x" : "-");
|
||||||
|
}
|
||||||
|
|
||||||
|
PreferencesDialog.saveValue(filterPrefKey, currentFilters.toString());
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void setActiveFilters(String filterPrefKey, JToggleButton[] buttons) {
|
||||||
|
String formatSettings = PreferencesDialog.getCachedValue(filterPrefKey, "");
|
||||||
|
int i = 0;
|
||||||
|
for (JToggleButton component : buttons) {
|
||||||
|
if (formatSettings.length() > i) {
|
||||||
|
component.setSelected(formatSettings.substring(i, i + 1).equals("x"));
|
||||||
|
} else {
|
||||||
|
component.setSelected(true);
|
||||||
|
}
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void setColumnWidthAndOrder(JTable table, int[] defaultColumnsWidth, String widthPrefKey, String orderPrefKey) {
|
||||||
table.setAutoResizeMode(JTable.AUTO_RESIZE_OFF);
|
table.setAutoResizeMode(JTable.AUTO_RESIZE_OFF);
|
||||||
|
|
||||||
// set the column width from saved value or defaults
|
// set the column width from saved value or defaults
|
||||||
|
@ -51,11 +79,11 @@ public final class TableUtil {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static public void saveColumnWidthAndOrderToPrefs(JTable table, String widthPrefKey, String orderPrefKey) {
|
public static void saveColumnWidthAndOrderToPrefs(JTable table, String widthPrefKey, String orderPrefKey) {
|
||||||
// Column width
|
|
||||||
StringBuilder columnWidthSettings = new StringBuilder();
|
StringBuilder columnWidthSettings = new StringBuilder();
|
||||||
StringBuilder columnOrderSettings = new StringBuilder();
|
StringBuilder columnOrderSettings = new StringBuilder();
|
||||||
boolean firstValue = true;
|
boolean firstValue = true;
|
||||||
|
|
||||||
for (int i = 0; i < table.getColumnModel().getColumnCount(); i++) {
|
for (int i = 0; i < table.getColumnModel().getColumnCount(); i++) {
|
||||||
TableColumn column = table.getColumnModel().getColumn(table.convertColumnIndexToView(i));
|
TableColumn column = table.getColumnModel().getColumn(table.convertColumnIndexToView(i));
|
||||||
if (!firstValue) {
|
if (!firstValue) {
|
||||||
|
@ -67,12 +95,12 @@ public final class TableUtil {
|
||||||
columnWidthSettings.append(column.getWidth());
|
columnWidthSettings.append(column.getWidth());
|
||||||
columnOrderSettings.append(table.convertColumnIndexToModel(i));
|
columnOrderSettings.append(table.convertColumnIndexToModel(i));
|
||||||
}
|
}
|
||||||
|
|
||||||
PreferencesDialog.saveValue(widthPrefKey, columnWidthSettings.toString());
|
PreferencesDialog.saveValue(widthPrefKey, columnWidthSettings.toString());
|
||||||
PreferencesDialog.saveValue(orderPrefKey, columnOrderSettings.toString());
|
PreferencesDialog.saveValue(orderPrefKey, columnOrderSettings.toString());
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static int[] getIntArrayFromString(String stringData) {
|
private static int[] getIntArrayFromString(String stringData) {
|
||||||
int[] intArray = null;
|
int[] intArray = null;
|
||||||
if (stringData != null && !stringData.isEmpty()) {
|
if (stringData != null && !stringData.isEmpty()) {
|
||||||
String[] items = stringData.split(",");
|
String[] items = stringData.split(",");
|
||||||
|
|
|
@ -55,7 +55,7 @@ public class EventListenerList extends javax.swing.event.EventListenerList {
|
||||||
* @param listenerClass
|
* @param listenerClass
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
public <T extends EventListener> Iterator<T> getIterator(Class<? extends T>... listenerClass) {
|
public <T extends EventListener> Iterator<T> getIterator(Class<T>... listenerClass) {
|
||||||
return getIterable(listenerClass).iterator();
|
return getIterable(listenerClass).iterator();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -257,6 +257,7 @@ public enum MythicspoilerComSource implements CardImageSource {
|
||||||
supportedSets.add("UST");
|
supportedSets.add("UST");
|
||||||
supportedSets.add("RIX");
|
supportedSets.add("RIX");
|
||||||
supportedSets.add("DOM");
|
supportedSets.add("DOM");
|
||||||
|
supportedSets.add("BBD");
|
||||||
|
|
||||||
sets = new LinkedHashMap<>();
|
sets = new LinkedHashMap<>();
|
||||||
setsAliases = new HashMap<>();
|
setsAliases = new HashMap<>();
|
||||||
|
|
|
@ -210,6 +210,7 @@ public enum ScryfallImageSource implements CardImageSource {
|
||||||
supportedSets.add("PPRO");
|
supportedSets.add("PPRO");
|
||||||
supportedSets.add("A25");
|
supportedSets.add("A25");
|
||||||
supportedSets.add("DOM");
|
supportedSets.add("DOM");
|
||||||
|
supportedSets.add("BBD");
|
||||||
// supportedSets.add("M19");
|
// supportedSets.add("M19");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -97,6 +97,7 @@
|
||||||
|Generate|PLANE:PCA|Plane - Hedron Fields of Agadeem|||HedronFieldsOfAgadeemPlane|
|
|Generate|PLANE:PCA|Plane - Hedron Fields of Agadeem|||HedronFieldsOfAgadeemPlane|
|
||||||
|Generate|PLANE:PCA|Plane - Lethe Lake|||LetheLakePlane|
|
|Generate|PLANE:PCA|Plane - Lethe Lake|||LetheLakePlane|
|
||||||
|Generate|PLANE:PCA|Plane - Naya|||NayaPlane|
|
|Generate|PLANE:PCA|Plane - Naya|||NayaPlane|
|
||||||
|
|Generate|PLANE:PCA|Plane - Panopticon|||PanopticonPlane|
|
||||||
|Generate|PLANE:PCA|Plane - Tazeem|||TazeemPlane|
|
|Generate|PLANE:PCA|Plane - Tazeem|||TazeemPlane|
|
||||||
|Generate|PLANE:PCA|Plane - The Dark Barony|||TheDarkBaronyPlane|
|
|Generate|PLANE:PCA|Plane - The Dark Barony|||TheDarkBaronyPlane|
|
||||||
|Generate|PLANE:PCA|Plane - The Eon Fog|||TheEonFogPlane|
|
|Generate|PLANE:PCA|Plane - The Eon Fog|||TheEonFogPlane|
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.mage</groupId>
|
<groupId>org.mage</groupId>
|
||||||
<artifactId>mage-root</artifactId>
|
<artifactId>mage-root</artifactId>
|
||||||
<version>1.4.29</version>
|
<version>1.4.30</version>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<artifactId>mage-common</artifactId>
|
<artifactId>mage-common</artifactId>
|
||||||
|
|
|
@ -40,8 +40,8 @@ public class MageVersion implements Serializable, Comparable<MageVersion> {
|
||||||
*/
|
*/
|
||||||
public final static int MAGE_VERSION_MAJOR = 1;
|
public final static int MAGE_VERSION_MAJOR = 1;
|
||||||
public final static int MAGE_VERSION_MINOR = 4;
|
public final static int MAGE_VERSION_MINOR = 4;
|
||||||
public final static int MAGE_VERSION_PATCH = 29;
|
public final static int MAGE_VERSION_PATCH = 30;
|
||||||
public final static String MAGE_VERSION_MINOR_PATCH = "V4";
|
public final static String MAGE_VERSION_MINOR_PATCH = "V2";
|
||||||
public final static String MAGE_VERSION_INFO = "";
|
public final static String MAGE_VERSION_INFO = "";
|
||||||
|
|
||||||
private final int major;
|
private final int major;
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.mage</groupId>
|
<groupId>org.mage</groupId>
|
||||||
<artifactId>mage-plugins</artifactId>
|
<artifactId>mage-plugins</artifactId>
|
||||||
<version>1.4.29</version>
|
<version>1.4.30</version>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<artifactId>mage-counter-plugin</artifactId>
|
<artifactId>mage-counter-plugin</artifactId>
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.mage</groupId>
|
<groupId>org.mage</groupId>
|
||||||
<artifactId>mage-root</artifactId>
|
<artifactId>mage-root</artifactId>
|
||||||
<version>1.4.29</version>
|
<version>1.4.30</version>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<artifactId>mage-plugins</artifactId>
|
<artifactId>mage-plugins</artifactId>
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.mage</groupId>
|
<groupId>org.mage</groupId>
|
||||||
<artifactId>mage-root</artifactId>
|
<artifactId>mage-root</artifactId>
|
||||||
<version>1.4.29</version>
|
<version>1.4.30</version>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<groupId>org.mage</groupId>
|
<groupId>org.mage</groupId>
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.mage</groupId>
|
<groupId>org.mage</groupId>
|
||||||
<artifactId>mage-server-plugins</artifactId>
|
<artifactId>mage-server-plugins</artifactId>
|
||||||
<version>1.4.29</version>
|
<version>1.4.30</version>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<artifactId>mage-deck-constructed</artifactId>
|
<artifactId>mage-deck-constructed</artifactId>
|
||||||
|
|
|
@ -149,10 +149,12 @@ public class Brawl extends Constructed {
|
||||||
if (commanderColor.isGreen()) {
|
if (commanderColor.isGreen()) {
|
||||||
colorIdentity.setGreen(true);
|
colorIdentity.setGreen(true);
|
||||||
}
|
}
|
||||||
|
if (commanderColor.isColorless()) {
|
||||||
|
colorIdentity.setColorless(true);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Set<String> basicsInDeck = new HashSet<>();
|
||||||
List<String> basicsInDeck = new ArrayList<>();
|
|
||||||
if (colorIdentity.isColorless()) {
|
if (colorIdentity.isColorless()) {
|
||||||
for (Card card : deck.getCards()) {
|
for (Card card : deck.getCards()) {
|
||||||
if (basicLandNames.contains(card.getName())) {
|
if (basicLandNames.contains(card.getName())) {
|
||||||
|
|
|
@ -33,6 +33,7 @@ import mage.abilities.Ability;
|
||||||
import mage.abilities.common.CanBeYourCommanderAbility;
|
import mage.abilities.common.CanBeYourCommanderAbility;
|
||||||
import mage.abilities.costs.mana.ManaCost;
|
import mage.abilities.costs.mana.ManaCost;
|
||||||
import mage.abilities.keyword.PartnerAbility;
|
import mage.abilities.keyword.PartnerAbility;
|
||||||
|
import mage.abilities.keyword.PartnerWithAbility;
|
||||||
import mage.cards.Card;
|
import mage.cards.Card;
|
||||||
import mage.cards.ExpansionSet;
|
import mage.cards.ExpansionSet;
|
||||||
import mage.cards.Sets;
|
import mage.cards.Sets;
|
||||||
|
@ -133,6 +134,10 @@ public class Commander extends Constructed {
|
||||||
invalid.put("Commander", "Sideboard must contain only the commander(s)");
|
invalid.put("Commander", "Sideboard must contain only the commander(s)");
|
||||||
valid = false;
|
valid = false;
|
||||||
} else {
|
} else {
|
||||||
|
Set<String> commanderNames = new HashSet<>();
|
||||||
|
for (Card commander : deck.getSideboard()) {
|
||||||
|
commanderNames.add(commander.getName());
|
||||||
|
}
|
||||||
for (Card commander : deck.getSideboard()) {
|
for (Card commander : deck.getSideboard()) {
|
||||||
if (bannedCommander.contains(commander.getName())) {
|
if (bannedCommander.contains(commander.getName())) {
|
||||||
invalid.put("Commander", "Commander banned (" + commander.getName() + ')');
|
invalid.put("Commander", "Commander banned (" + commander.getName() + ')');
|
||||||
|
@ -144,8 +149,18 @@ public class Commander extends Constructed {
|
||||||
valid = false;
|
valid = false;
|
||||||
}
|
}
|
||||||
if (deck.getSideboard().size() == 2 && !commander.getAbilities().contains(PartnerAbility.getInstance())) {
|
if (deck.getSideboard().size() == 2 && !commander.getAbilities().contains(PartnerAbility.getInstance())) {
|
||||||
invalid.put("Commander", "Commander without Partner (" + commander.getName() + ')');
|
boolean partnersWith = false;
|
||||||
valid = false;
|
for (Ability ability : commander.getAbilities()) {
|
||||||
|
if (ability instanceof PartnerWithAbility
|
||||||
|
&& commanderNames.contains(((PartnerWithAbility) ability).getPartnerName())) {
|
||||||
|
partnersWith = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!partnersWith) {
|
||||||
|
invalid.put("Commander", "Commander without Partner (" + commander.getName() + ')');
|
||||||
|
valid = false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
FilterMana commanderColor = commander.getColorIdentity();
|
FilterMana commanderColor = commander.getColorIdentity();
|
||||||
if (commanderColor.isWhite()) {
|
if (commanderColor.isWhite()) {
|
||||||
|
|
|
@ -100,6 +100,7 @@ public class DuelCommander extends Commander {
|
||||||
bannedCommander.add("Tasigur, the Golden Fang");
|
bannedCommander.add("Tasigur, the Golden Fang");
|
||||||
bannedCommander.add("Vial Smasher the Fierce");
|
bannedCommander.add("Vial Smasher the Fierce");
|
||||||
bannedCommander.add("Zur the Enchanter");
|
bannedCommander.add("Zur the Enchanter");
|
||||||
|
bannedCommander.add("Zurgo Bellstriker");
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -28,15 +28,14 @@
|
||||||
package mage.deck;
|
package mage.deck;
|
||||||
|
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
import java.util.Map.Entry;
|
import mage.abilities.Ability;
|
||||||
import mage.abilities.common.CanBeYourCommanderAbility;
|
|
||||||
import mage.abilities.keyword.PartnerAbility;
|
import mage.abilities.keyword.PartnerAbility;
|
||||||
|
import mage.abilities.keyword.PartnerWithAbility;
|
||||||
import mage.cards.Card;
|
import mage.cards.Card;
|
||||||
import mage.cards.ExpansionSet;
|
import mage.cards.ExpansionSet;
|
||||||
import mage.cards.Sets;
|
import mage.cards.Sets;
|
||||||
import mage.cards.decks.Constructed;
|
import mage.cards.decks.Constructed;
|
||||||
import mage.cards.decks.Deck;
|
import mage.cards.decks.Deck;
|
||||||
import mage.constants.SetType;
|
|
||||||
import mage.filter.FilterMana;
|
import mage.filter.FilterMana;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -90,15 +89,29 @@ public class FreeformCommander extends Constructed {
|
||||||
invalid.put("Commander", "Sideboard must contain only the commander(s)");
|
invalid.put("Commander", "Sideboard must contain only the commander(s)");
|
||||||
valid = false;
|
valid = false;
|
||||||
} else {
|
} else {
|
||||||
|
Set<String> commanderNames = new HashSet<>();
|
||||||
for (Card commander : deck.getSideboard()) {
|
for (Card commander : deck.getSideboard()) {
|
||||||
if (!(commander.isCreature() ||
|
commanderNames.add(commander.getName());
|
||||||
commander.isLegendary())) {
|
}
|
||||||
|
for (Card commander : deck.getSideboard()) {
|
||||||
|
if (!(commander.isCreature()
|
||||||
|
|| commander.isLegendary())) {
|
||||||
invalid.put("Commander", "For Freeform Commander, the commander must be a creature or be legendary. Yours was: " + commander.getName());
|
invalid.put("Commander", "For Freeform Commander, the commander must be a creature or be legendary. Yours was: " + commander.getName());
|
||||||
valid = false;
|
valid = false;
|
||||||
}
|
}
|
||||||
if (deck.getSideboard().size() == 2 && !commander.getAbilities().contains(PartnerAbility.getInstance())) {
|
if (deck.getSideboard().size() == 2 && !commander.getAbilities().contains(PartnerAbility.getInstance())) {
|
||||||
invalid.put("Commander", "Commander without Partner (" + commander.getName() + ')');
|
boolean partnersWith = false;
|
||||||
valid = false;
|
for (Ability ability : commander.getAbilities()) {
|
||||||
|
if (ability instanceof PartnerWithAbility
|
||||||
|
&& commanderNames.contains(((PartnerWithAbility) ability).getPartnerName())) {
|
||||||
|
partnersWith = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!partnersWith) {
|
||||||
|
invalid.put("Commander", "Commander without Partner (" + commander.getName() + ')');
|
||||||
|
valid = false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
FilterMana commanderColor = commander.getColorIdentity();
|
FilterMana commanderColor = commander.getColorIdentity();
|
||||||
if (commanderColor.isWhite()) {
|
if (commanderColor.isWhite()) {
|
||||||
|
|
|
@ -29,8 +29,10 @@ package mage.deck;
|
||||||
|
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
import java.util.Map.Entry;
|
import java.util.Map.Entry;
|
||||||
|
import mage.abilities.Ability;
|
||||||
import mage.abilities.common.CanBeYourCommanderAbility;
|
import mage.abilities.common.CanBeYourCommanderAbility;
|
||||||
import mage.abilities.keyword.PartnerAbility;
|
import mage.abilities.keyword.PartnerAbility;
|
||||||
|
import mage.abilities.keyword.PartnerWithAbility;
|
||||||
import mage.cards.Card;
|
import mage.cards.Card;
|
||||||
import mage.cards.ExpansionSet;
|
import mage.cards.ExpansionSet;
|
||||||
import mage.cards.Sets;
|
import mage.cards.Sets;
|
||||||
|
@ -98,6 +100,10 @@ public class PennyDreadfulCommander extends Constructed {
|
||||||
invalid.put("Commander", "Sideboard must contain only the commander(s)");
|
invalid.put("Commander", "Sideboard must contain only the commander(s)");
|
||||||
valid = false;
|
valid = false;
|
||||||
} else {
|
} else {
|
||||||
|
Set<String> commanderNames = new HashSet<>();
|
||||||
|
for (Card commander : deck.getSideboard()) {
|
||||||
|
commanderNames.add(commander.getName());
|
||||||
|
}
|
||||||
for (Card commander : deck.getSideboard()) {
|
for (Card commander : deck.getSideboard()) {
|
||||||
if ((!commander.isCreature() || !commander.isLegendary())
|
if ((!commander.isCreature() || !commander.isLegendary())
|
||||||
&& (!commander.isPlaneswalker() || !commander.getAbilities().contains(CanBeYourCommanderAbility.getInstance()))) {
|
&& (!commander.isPlaneswalker() || !commander.getAbilities().contains(CanBeYourCommanderAbility.getInstance()))) {
|
||||||
|
@ -105,8 +111,18 @@ public class PennyDreadfulCommander extends Constructed {
|
||||||
valid = false;
|
valid = false;
|
||||||
}
|
}
|
||||||
if (deck.getSideboard().size() == 2 && !commander.getAbilities().contains(PartnerAbility.getInstance())) {
|
if (deck.getSideboard().size() == 2 && !commander.getAbilities().contains(PartnerAbility.getInstance())) {
|
||||||
invalid.put("Commander", "Commander without Partner (" + commander.getName() + ')');
|
boolean partnersWith = false;
|
||||||
valid = false;
|
for (Ability ability : commander.getAbilities()) {
|
||||||
|
if (ability instanceof PartnerWithAbility
|
||||||
|
&& commanderNames.contains(((PartnerWithAbility) ability).getPartnerName())) {
|
||||||
|
partnersWith = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!partnersWith) {
|
||||||
|
invalid.put("Commander", "Commander without Partner (" + commander.getName() + ')');
|
||||||
|
valid = false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
FilterMana commanderColor = commander.getColorIdentity();
|
FilterMana commanderColor = commander.getColorIdentity();
|
||||||
if (commanderColor.isWhite()) {
|
if (commanderColor.isWhite()) {
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.mage</groupId>
|
<groupId>org.mage</groupId>
|
||||||
<artifactId>mage-server-plugins</artifactId>
|
<artifactId>mage-server-plugins</artifactId>
|
||||||
<version>1.4.29</version>
|
<version>1.4.30</version>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<artifactId>mage-deck-limited</artifactId>
|
<artifactId>mage-deck-limited</artifactId>
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.mage</groupId>
|
<groupId>org.mage</groupId>
|
||||||
<artifactId>mage-server-plugins</artifactId>
|
<artifactId>mage-server-plugins</artifactId>
|
||||||
<version>1.4.29</version>
|
<version>1.4.30</version>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<artifactId>mage-game-brawlduel</artifactId>
|
<artifactId>mage-game-brawlduel</artifactId>
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.mage</groupId>
|
<groupId>org.mage</groupId>
|
||||||
<artifactId>mage-server-plugins</artifactId>
|
<artifactId>mage-server-plugins</artifactId>
|
||||||
<version>1.4.29</version>
|
<version>1.4.30</version>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<artifactId>mage-game-brawlfreeforall</artifactId>
|
<artifactId>mage-game-brawlfreeforall</artifactId>
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.mage</groupId>
|
<groupId>org.mage</groupId>
|
||||||
<artifactId>mage-server-plugins</artifactId>
|
<artifactId>mage-server-plugins</artifactId>
|
||||||
<version>1.4.29</version>
|
<version>1.4.30</version>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<artifactId>mage-game-canadianhighlanderduel</artifactId>
|
<artifactId>mage-game-canadianhighlanderduel</artifactId>
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.mage</groupId>
|
<groupId>org.mage</groupId>
|
||||||
<artifactId>mage-server-plugins</artifactId>
|
<artifactId>mage-server-plugins</artifactId>
|
||||||
<version>1.4.29</version>
|
<version>1.4.30</version>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<artifactId>mage-game-commanderduel</artifactId>
|
<artifactId>mage-game-commanderduel</artifactId>
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.mage</groupId>
|
<groupId>org.mage</groupId>
|
||||||
<artifactId>mage-server-plugins</artifactId>
|
<artifactId>mage-server-plugins</artifactId>
|
||||||
<version>1.4.29</version>
|
<version>1.4.30</version>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<artifactId>mage-game-commanderfreeforall</artifactId>
|
<artifactId>mage-game-commanderfreeforall</artifactId>
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.mage</groupId>
|
<groupId>org.mage</groupId>
|
||||||
<artifactId>mage-server-plugins</artifactId>
|
<artifactId>mage-server-plugins</artifactId>
|
||||||
<version>1.4.29</version>
|
<version>1.4.30</version>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<artifactId>mage-game-freeforall</artifactId>
|
<artifactId>mage-game-freeforall</artifactId>
|
||||||
|
|
|
@ -25,16 +25,11 @@
|
||||||
* authors and should not be interpreted as representing official policies, either expressed
|
* authors and should not be interpreted as representing official policies, either expressed
|
||||||
* or implied, of BetaSteward_at_googlemail.com.
|
* or implied, of BetaSteward_at_googlemail.com.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package mage.game;
|
package mage.game;
|
||||||
|
|
||||||
import java.util.HashSet;
|
|
||||||
import java.util.Set;
|
|
||||||
import java.util.UUID;
|
|
||||||
import mage.constants.MultiplayerAttackOption;
|
import mage.constants.MultiplayerAttackOption;
|
||||||
import mage.constants.RangeOfInfluence;
|
import mage.constants.RangeOfInfluence;
|
||||||
import mage.game.match.MatchType;
|
import mage.game.match.MatchType;
|
||||||
import mage.players.Player;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@ -67,22 +62,6 @@ public class FreeForAll extends GameImpl {
|
||||||
this.numPlayers = numPlayers;
|
this.numPlayers = numPlayers;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public Set<UUID> getOpponents(UUID playerId) {
|
|
||||||
Set<UUID> opponents = new HashSet<>();
|
|
||||||
for (UUID opponentId: this.getPlayer(playerId).getInRange()) {
|
|
||||||
if (!opponentId.equals(playerId)) {
|
|
||||||
opponents.add(opponentId);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return opponents;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean isOpponent(Player player, UUID playerToCheck) {
|
|
||||||
return !player.getId().equals(playerToCheck) && player.getInRange().contains(playerToCheck);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public FreeForAll copy() {
|
public FreeForAll copy() {
|
||||||
return new FreeForAll(this);
|
return new FreeForAll(this);
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.mage</groupId>
|
<groupId>org.mage</groupId>
|
||||||
<artifactId>mage-server-plugins</artifactId>
|
<artifactId>mage-server-plugins</artifactId>
|
||||||
<version>1.4.29</version>
|
<version>1.4.30</version>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<artifactId>mage-game-freeformcommanderfreeforall</artifactId>
|
<artifactId>mage-game-freeformcommanderfreeforall</artifactId>
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.mage</groupId>
|
<groupId>org.mage</groupId>
|
||||||
<artifactId>mage-server-plugins</artifactId>
|
<artifactId>mage-server-plugins</artifactId>
|
||||||
<version>1.4.29</version>
|
<version>1.4.30</version>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<artifactId>mage-game-momirduel</artifactId>
|
<artifactId>mage-game-momirduel</artifactId>
|
||||||
|
|
|
@ -27,8 +27,6 @@
|
||||||
*/
|
*/
|
||||||
package mage.game;
|
package mage.game;
|
||||||
|
|
||||||
import java.util.HashSet;
|
|
||||||
import java.util.Set;
|
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
import mage.abilities.Ability;
|
import mage.abilities.Ability;
|
||||||
import mage.abilities.common.SimpleStaticAbility;
|
import mage.abilities.common.SimpleStaticAbility;
|
||||||
|
@ -83,22 +81,6 @@ public class MomirDuel extends GameImpl {
|
||||||
state.getTurnMods().add(new TurnMod(startingPlayerId, PhaseStep.DRAW));
|
state.getTurnMods().add(new TurnMod(startingPlayerId, PhaseStep.DRAW));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public Set<UUID> getOpponents(UUID playerId) {
|
|
||||||
Set<UUID> opponents = new HashSet<>();
|
|
||||||
for (UUID opponentId : this.getPlayer(playerId).getInRange()) {
|
|
||||||
if (!opponentId.equals(playerId)) {
|
|
||||||
opponents.add(opponentId);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return opponents;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean isOpponent(Player player, UUID playerToCheck) {
|
|
||||||
return !player.getId().equals(playerToCheck);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public MomirDuel copy() {
|
public MomirDuel copy() {
|
||||||
return new MomirDuel(this);
|
return new MomirDuel(this);
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.mage</groupId>
|
<groupId>org.mage</groupId>
|
||||||
<artifactId>mage-server-plugins</artifactId>
|
<artifactId>mage-server-plugins</artifactId>
|
||||||
<version>1.4.29</version>
|
<version>1.4.30</version>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<artifactId>mage-game-momirfreeforall</artifactId>
|
<artifactId>mage-game-momirfreeforall</artifactId>
|
||||||
|
|
|
@ -27,8 +27,6 @@
|
||||||
*/
|
*/
|
||||||
package mage.game;
|
package mage.game;
|
||||||
|
|
||||||
import java.util.HashSet;
|
|
||||||
import java.util.Set;
|
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
import mage.abilities.Ability;
|
import mage.abilities.Ability;
|
||||||
import mage.abilities.common.SimpleStaticAbility;
|
import mage.abilities.common.SimpleStaticAbility;
|
||||||
|
@ -44,7 +42,6 @@ import mage.game.match.MatchType;
|
||||||
import mage.game.turn.TurnMod;
|
import mage.game.turn.TurnMod;
|
||||||
import mage.players.Player;
|
import mage.players.Player;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
* @author nigelzor
|
* @author nigelzor
|
||||||
|
@ -86,22 +83,6 @@ public class MomirGame extends GameImpl {
|
||||||
state.getTurnMods().add(new TurnMod(startingPlayerId, PhaseStep.DRAW));
|
state.getTurnMods().add(new TurnMod(startingPlayerId, PhaseStep.DRAW));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public Set<UUID> getOpponents(UUID playerId) {
|
|
||||||
Set<UUID> opponents = new HashSet<>();
|
|
||||||
for (UUID opponentId : this.getPlayer(playerId).getInRange()) {
|
|
||||||
if (!opponentId.equals(playerId)) {
|
|
||||||
opponents.add(opponentId);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return opponents;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean isOpponent(Player player, UUID playerToCheck) {
|
|
||||||
return !player.getId().equals(playerToCheck) && player.getInRange().contains(playerToCheck);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public MomirGame copy() {
|
public MomirGame copy() {
|
||||||
return new MomirGame(this);
|
return new MomirGame(this);
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.mage</groupId>
|
<groupId>org.mage</groupId>
|
||||||
<artifactId>mage-server-plugins</artifactId>
|
<artifactId>mage-server-plugins</artifactId>
|
||||||
<version>1.4.29</version>
|
<version>1.4.30</version>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<artifactId>mage-game-pennydreadfulcommanderfreeforall</artifactId>
|
<artifactId>mage-game-pennydreadfulcommanderfreeforall</artifactId>
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.mage</groupId>
|
<groupId>org.mage</groupId>
|
||||||
<artifactId>mage-server-plugins</artifactId>
|
<artifactId>mage-server-plugins</artifactId>
|
||||||
<version>1.4.29</version>
|
<version>1.4.30</version>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<artifactId>mage-game-tinyleadersduel</artifactId>
|
<artifactId>mage-game-tinyleadersduel</artifactId>
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.mage</groupId>
|
<groupId>org.mage</groupId>
|
||||||
<artifactId>mage-server-plugins</artifactId>
|
<artifactId>mage-server-plugins</artifactId>
|
||||||
<version>1.4.29</version>
|
<version>1.4.30</version>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<artifactId>mage-game-twoplayerduel</artifactId>
|
<artifactId>mage-game-twoplayerduel</artifactId>
|
||||||
|
|
|
@ -24,19 +24,15 @@
|
||||||
* The views and conclusions contained in the software and documentation are those of the
|
* The views and conclusions contained in the software and documentation are those of the
|
||||||
* authors and should not be interpreted as representing official policies, either expressed
|
* authors and should not be interpreted as representing official policies, either expressed
|
||||||
* or implied, of BetaSteward_at_googlemail.com.
|
* or implied, of BetaSteward_at_googlemail.com.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package mage.game;
|
package mage.game;
|
||||||
|
|
||||||
import java.util.HashSet;
|
|
||||||
import java.util.Set;
|
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
import mage.constants.MultiplayerAttackOption;
|
import mage.constants.MultiplayerAttackOption;
|
||||||
import mage.constants.PhaseStep;
|
import mage.constants.PhaseStep;
|
||||||
import mage.constants.RangeOfInfluence;
|
import mage.constants.RangeOfInfluence;
|
||||||
import mage.game.match.MatchType;
|
import mage.game.match.MatchType;
|
||||||
import mage.game.turn.TurnMod;
|
import mage.game.turn.TurnMod;
|
||||||
import mage.players.Player;
|
|
||||||
|
|
||||||
public class TwoPlayerDuel extends GameImpl {
|
public class TwoPlayerDuel extends GameImpl {
|
||||||
|
|
||||||
|
@ -64,22 +60,6 @@ public class TwoPlayerDuel extends GameImpl {
|
||||||
state.getTurnMods().add(new TurnMod(startingPlayerId, PhaseStep.DRAW));
|
state.getTurnMods().add(new TurnMod(startingPlayerId, PhaseStep.DRAW));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public Set<UUID> getOpponents(UUID playerId) {
|
|
||||||
Set<UUID> opponents = new HashSet<>();
|
|
||||||
for (UUID opponentId: this.getPlayer(playerId).getInRange()) {
|
|
||||||
if (!opponentId.equals(playerId)) {
|
|
||||||
opponents.add(opponentId);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return opponents;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean isOpponent(Player player, UUID playerToCheck) {
|
|
||||||
return !player.getId().equals(playerToCheck);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public TwoPlayerDuel copy() {
|
public TwoPlayerDuel copy() {
|
||||||
return new TwoPlayerDuel(this);
|
return new TwoPlayerDuel(this);
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.mage</groupId>
|
<groupId>org.mage</groupId>
|
||||||
<artifactId>mage-server-plugins</artifactId>
|
<artifactId>mage-server-plugins</artifactId>
|
||||||
<version>1.4.29</version>
|
<version>1.4.30</version>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<artifactId>mage-player-ai-draftbot</artifactId>
|
<artifactId>mage-player-ai-draftbot</artifactId>
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.mage</groupId>
|
<groupId>org.mage</groupId>
|
||||||
<artifactId>mage-server-plugins</artifactId>
|
<artifactId>mage-server-plugins</artifactId>
|
||||||
<version>1.4.29</version>
|
<version>1.4.30</version>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<artifactId>mage-player-ai-ma</artifactId>
|
<artifactId>mage-player-ai-ma</artifactId>
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.mage</groupId>
|
<groupId>org.mage</groupId>
|
||||||
<artifactId>mage-server-plugins</artifactId>
|
<artifactId>mage-server-plugins</artifactId>
|
||||||
<version>1.4.29</version>
|
<version>1.4.30</version>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<artifactId>mage-player-ai</artifactId>
|
<artifactId>mage-player-ai</artifactId>
|
||||||
|
|
|
@ -31,7 +31,9 @@ import java.io.IOException;
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
import java.util.Map.Entry;
|
import java.util.Map.Entry;
|
||||||
|
import mage.ConditionalMana;
|
||||||
import mage.MageObject;
|
import mage.MageObject;
|
||||||
|
import mage.MageObjectReference;
|
||||||
import mage.Mana;
|
import mage.Mana;
|
||||||
import mage.abilities.*;
|
import mage.abilities.*;
|
||||||
import mage.abilities.costs.VariableCost;
|
import mage.abilities.costs.VariableCost;
|
||||||
|
@ -1026,7 +1028,7 @@ public class ComputerPlayer extends PlayerImpl implements Player {
|
||||||
findPlayables(game);
|
findPlayables(game);
|
||||||
if (!playableAbilities.isEmpty()) {
|
if (!playableAbilities.isEmpty()) {
|
||||||
for (ActivatedAbility ability : playableAbilities) {
|
for (ActivatedAbility ability : playableAbilities) {
|
||||||
if (ability.canActivate(playerId, game)) {
|
if (ability.canActivate(playerId, game).canActivate()) {
|
||||||
if (ability.getEffects().hasOutcome(Outcome.PutLandInPlay)) {
|
if (ability.getEffects().hasOutcome(Outcome.PutLandInPlay)) {
|
||||||
if (this.activateAbility(ability, game)) {
|
if (this.activateAbility(ability, game)) {
|
||||||
return true;
|
return true;
|
||||||
|
@ -1057,7 +1059,7 @@ public class ComputerPlayer extends PlayerImpl implements Player {
|
||||||
if (game.getStack().isEmpty()) {
|
if (game.getStack().isEmpty()) {
|
||||||
if (!playableNonInstant.isEmpty()) {
|
if (!playableNonInstant.isEmpty()) {
|
||||||
for (Card card : playableNonInstant) {
|
for (Card card : playableNonInstant) {
|
||||||
if (card.getSpellAbility().canActivate(playerId, game)) {
|
if (card.getSpellAbility().canActivate(playerId, game).canActivate()) {
|
||||||
if (this.activateAbility(card.getSpellAbility(), game)) {
|
if (this.activateAbility(card.getSpellAbility(), game)) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -1066,7 +1068,7 @@ public class ComputerPlayer extends PlayerImpl implements Player {
|
||||||
}
|
}
|
||||||
if (!playableAbilities.isEmpty()) {
|
if (!playableAbilities.isEmpty()) {
|
||||||
for (ActivatedAbility ability : playableAbilities) {
|
for (ActivatedAbility ability : playableAbilities) {
|
||||||
if (ability.canActivate(playerId, game)) {
|
if (ability.canActivate(playerId, game).canActivate()) {
|
||||||
if (!(ability.getEffects().get(0) instanceof BecomesCreatureSourceEffect)) {
|
if (!(ability.getEffects().get(0) instanceof BecomesCreatureSourceEffect)) {
|
||||||
if (this.activateAbility(ability, game)) {
|
if (this.activateAbility(ability, game)) {
|
||||||
return true;
|
return true;
|
||||||
|
@ -1186,7 +1188,7 @@ public class ComputerPlayer extends PlayerImpl implements Player {
|
||||||
for (Mana avail : available) {
|
for (Mana avail : available) {
|
||||||
if (mana.enough(avail)) {
|
if (mana.enough(avail)) {
|
||||||
SpellAbility ability = card.getSpellAbility();
|
SpellAbility ability = card.getSpellAbility();
|
||||||
if (ability != null && ability.canActivate(playerId, game)
|
if (ability != null && ability.canActivate(playerId, game).canActivate()
|
||||||
&& game.getContinuousEffects().preventedByRuleModification(GameEvent.getEvent(GameEvent.EventType.CAST_SPELL, ability.getSourceId(), ability.getSourceId(), playerId), ability, game, true)) {
|
&& game.getContinuousEffects().preventedByRuleModification(GameEvent.getEvent(GameEvent.EventType.CAST_SPELL, ability.getSourceId(), ability.getSourceId(), playerId), ability, game, true)) {
|
||||||
if (card.getCardType().contains(CardType.INSTANT)
|
if (card.getCardType().contains(CardType.INSTANT)
|
||||||
|| card.hasAbility(FlashAbility.getInstance().getId(), game)) {
|
|| card.hasAbility(FlashAbility.getInstance().getId(), game)) {
|
||||||
|
@ -1203,7 +1205,7 @@ public class ComputerPlayer extends PlayerImpl implements Player {
|
||||||
}
|
}
|
||||||
for (Permanent permanent : game.getBattlefield().getAllActivePermanents(playerId)) {
|
for (Permanent permanent : game.getBattlefield().getAllActivePermanents(playerId)) {
|
||||||
for (ActivatedAbility ability : permanent.getAbilities().getActivatedAbilities(Zone.BATTLEFIELD)) {
|
for (ActivatedAbility ability : permanent.getAbilities().getActivatedAbilities(Zone.BATTLEFIELD)) {
|
||||||
if (!(ability instanceof ActivatedManaAbilityImpl) && ability.canActivate(playerId, game)) {
|
if (!(ability instanceof ActivatedManaAbilityImpl) && ability.canActivate(playerId, game).canActivate()) {
|
||||||
if (ability instanceof EquipAbility && permanent.getAttachedTo() != null) {
|
if (ability instanceof EquipAbility && permanent.getAttachedTo() != null) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
@ -1230,7 +1232,7 @@ public class ComputerPlayer extends PlayerImpl implements Player {
|
||||||
}
|
}
|
||||||
for (Card card : graveyard.getCards(game)) {
|
for (Card card : graveyard.getCards(game)) {
|
||||||
for (ActivatedAbility ability : card.getAbilities().getActivatedAbilities(Zone.GRAVEYARD)) {
|
for (ActivatedAbility ability : card.getAbilities().getActivatedAbilities(Zone.GRAVEYARD)) {
|
||||||
if (ability.canActivate(playerId, game)) {
|
if (ability.canActivate(playerId, game).canActivate()) {
|
||||||
ManaOptions abilityOptions = ability.getManaCosts().getOptions();
|
ManaOptions abilityOptions = ability.getManaCosts().getOptions();
|
||||||
if (abilityOptions.isEmpty()) {
|
if (abilityOptions.isEmpty()) {
|
||||||
playableAbilities.add(ability);
|
playableAbilities.add(ability);
|
||||||
|
@ -1261,9 +1263,9 @@ public class ComputerPlayer extends PlayerImpl implements Player {
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected boolean playManaHandling(Ability ability, ManaCost unpaid, Game game) {
|
protected boolean playManaHandling(Ability ability, ManaCost unpaid, final Game game) {
|
||||||
// log.info("paying for " + unpaid.getText());
|
// log.info("paying for " + unpaid.getText());
|
||||||
UUID spendAnyManaId = game.getContinuousEffects().asThough(ability.getSourceId(), AsThoughEffectType.SPEND_OTHER_MANA, ability, ability.getControllerId(), game);
|
MageObjectReference permittingObject = game.getContinuousEffects().asThough(ability.getSourceId(), AsThoughEffectType.SPEND_OTHER_MANA, ability, ability.getControllerId(), game);
|
||||||
ManaCost cost;
|
ManaCost cost;
|
||||||
List<MageObject> producers;
|
List<MageObject> producers;
|
||||||
if (unpaid instanceof ManaCosts) {
|
if (unpaid instanceof ManaCosts) {
|
||||||
|
@ -1279,7 +1281,7 @@ public class ComputerPlayer extends PlayerImpl implements Player {
|
||||||
// use color producing mana abilities with costs first that produce all color manas that are needed to pay
|
// use color producing mana abilities with costs first that produce all color manas that are needed to pay
|
||||||
// otherwise the computer may not be able to pay the cost for that source
|
// otherwise the computer may not be able to pay the cost for that source
|
||||||
ManaAbility:
|
ManaAbility:
|
||||||
for (ActivatedManaAbilityImpl manaAbility : mageObject.getAbilities().getAvailableActivatedManaAbilities(Zone.BATTLEFIELD, game)) {
|
for (ActivatedManaAbilityImpl manaAbility : getManaAbilitiesSortedByManaCount(mageObject, game)) {
|
||||||
int colored = 0;
|
int colored = 0;
|
||||||
for (Mana mana : manaAbility.getNetMana(game)) {
|
for (Mana mana : manaAbility.getNetMana(game)) {
|
||||||
if (!unpaid.getMana().includesMana(mana)) {
|
if (!unpaid.getMana().includesMana(mana)) {
|
||||||
|
@ -1288,9 +1290,11 @@ public class ComputerPlayer extends PlayerImpl implements Player {
|
||||||
colored += mana.countColored();
|
colored += mana.countColored();
|
||||||
}
|
}
|
||||||
if (colored > 1 && (cost instanceof ColoredManaCost)) {
|
if (colored > 1 && (cost instanceof ColoredManaCost)) {
|
||||||
|
|
||||||
for (Mana netMana : manaAbility.getNetMana(game)) {
|
for (Mana netMana : manaAbility.getNetMana(game)) {
|
||||||
if (cost.testPay(netMana)) {
|
if (cost.testPay(netMana)) {
|
||||||
|
if (netMana instanceof ConditionalMana && !((ConditionalMana) netMana).apply(ability, game, getId(), cost)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
if (activateAbility(manaAbility, game)) {
|
if (activateAbility(manaAbility, game)) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -1302,10 +1306,13 @@ public class ComputerPlayer extends PlayerImpl implements Player {
|
||||||
|
|
||||||
for (MageObject mageObject : producers) {
|
for (MageObject mageObject : producers) {
|
||||||
// pay all colored costs first
|
// pay all colored costs first
|
||||||
for (ActivatedManaAbilityImpl manaAbility : mageObject.getAbilities().getAvailableActivatedManaAbilities(Zone.BATTLEFIELD, game)) {
|
for (ActivatedManaAbilityImpl manaAbility : getManaAbilitiesSortedByManaCount(mageObject, game)) {
|
||||||
if (cost instanceof ColoredManaCost) {
|
if (cost instanceof ColoredManaCost) {
|
||||||
for (Mana netMana : manaAbility.getNetMana(game)) {
|
for (Mana netMana : manaAbility.getNetMana(game)) {
|
||||||
if (cost.testPay(netMana) || spendAnyManaId != null) {
|
if (cost.testPay(netMana) || permittingObject != null) {
|
||||||
|
if (netMana instanceof ConditionalMana && !((ConditionalMana) netMana).apply(ability, game, getId(), cost)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
if (activateAbility(manaAbility, game)) {
|
if (activateAbility(manaAbility, game)) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -1314,10 +1321,13 @@ public class ComputerPlayer extends PlayerImpl implements Player {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// pay snow covered mana
|
// pay snow covered mana
|
||||||
for (ActivatedManaAbilityImpl manaAbility : mageObject.getAbilities().getAvailableActivatedManaAbilities(Zone.BATTLEFIELD, game)) {
|
for (ActivatedManaAbilityImpl manaAbility : getManaAbilitiesSortedByManaCount(mageObject, game)) {
|
||||||
if (cost instanceof SnowManaCost) {
|
if (cost instanceof SnowManaCost) {
|
||||||
for (Mana netMana : manaAbility.getNetMana(game)) {
|
for (Mana netMana : manaAbility.getNetMana(game)) {
|
||||||
if (cost.testPay(netMana) || spendAnyManaId != null) {
|
if (cost.testPay(netMana) || permittingObject != null) {
|
||||||
|
if (netMana instanceof ConditionalMana && !((ConditionalMana) netMana).apply(ability, game, getId(), cost)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
if (activateAbility(manaAbility, game)) {
|
if (activateAbility(manaAbility, game)) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -1326,10 +1336,13 @@ public class ComputerPlayer extends PlayerImpl implements Player {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// then pay hybrid
|
// then pay hybrid
|
||||||
for (ActivatedManaAbilityImpl manaAbility : mageObject.getAbilities().getAvailableActivatedManaAbilities(Zone.BATTLEFIELD, game)) {
|
for (ActivatedManaAbilityImpl manaAbility : getManaAbilitiesSortedByManaCount(mageObject, game)) {
|
||||||
if (cost instanceof HybridManaCost) {
|
if (cost instanceof HybridManaCost) {
|
||||||
for (Mana netMana : manaAbility.getNetMana(game)) {
|
for (Mana netMana : manaAbility.getNetMana(game)) {
|
||||||
if (cost.testPay(netMana) || spendAnyManaId != null) {
|
if (cost.testPay(netMana) || permittingObject != null) {
|
||||||
|
if (netMana instanceof ConditionalMana && !((ConditionalMana) netMana).apply(ability, game, getId(), cost)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
if (activateAbility(manaAbility, game)) {
|
if (activateAbility(manaAbility, game)) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -1338,10 +1351,13 @@ public class ComputerPlayer extends PlayerImpl implements Player {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// then pay mono hybrid
|
// then pay mono hybrid
|
||||||
for (ActivatedManaAbilityImpl manaAbility : mageObject.getAbilities().getAvailableActivatedManaAbilities(Zone.BATTLEFIELD, game)) {
|
for (ActivatedManaAbilityImpl manaAbility : getManaAbilitiesSortedByManaCount(mageObject, game)) {
|
||||||
if (cost instanceof MonoHybridManaCost) {
|
if (cost instanceof MonoHybridManaCost) {
|
||||||
for (Mana netMana : manaAbility.getNetMana(game)) {
|
for (Mana netMana : manaAbility.getNetMana(game)) {
|
||||||
if (cost.testPay(netMana) || spendAnyManaId != null) {
|
if (cost.testPay(netMana) || permittingObject != null) {
|
||||||
|
if (netMana instanceof ConditionalMana && !((ConditionalMana) netMana).apply(ability, game, getId(), cost)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
if (activateAbility(manaAbility, game)) {
|
if (activateAbility(manaAbility, game)) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -1350,10 +1366,13 @@ public class ComputerPlayer extends PlayerImpl implements Player {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// pay colorless
|
// pay colorless
|
||||||
for (ActivatedManaAbilityImpl manaAbility : mageObject.getAbilities().getAvailableActivatedManaAbilities(Zone.BATTLEFIELD, game)) {
|
for (ActivatedManaAbilityImpl manaAbility : getManaAbilitiesSortedByManaCount(mageObject, game)) {
|
||||||
if (cost instanceof ColorlessManaCost) {
|
if (cost instanceof ColorlessManaCost) {
|
||||||
for (Mana netMana : manaAbility.getNetMana(game)) {
|
for (Mana netMana : manaAbility.getNetMana(game)) {
|
||||||
if (cost.testPay(netMana) || spendAnyManaId != null) {
|
if (cost.testPay(netMana) || permittingObject != null) {
|
||||||
|
if (netMana instanceof ConditionalMana && !((ConditionalMana) netMana).apply(ability, game, getId(), cost)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
if (activateAbility(manaAbility, game)) {
|
if (activateAbility(manaAbility, game)) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -1362,10 +1381,13 @@ public class ComputerPlayer extends PlayerImpl implements Player {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// finally pay generic
|
// finally pay generic
|
||||||
for (ActivatedManaAbilityImpl manaAbility : mageObject.getAbilities().getAvailableActivatedManaAbilities(Zone.BATTLEFIELD, game)) {
|
for (ActivatedManaAbilityImpl manaAbility : getManaAbilitiesSortedByManaCount(mageObject, game)) {
|
||||||
if (cost instanceof GenericManaCost) {
|
if (cost instanceof GenericManaCost) {
|
||||||
for (Mana netMana : manaAbility.getNetMana(game)) {
|
for (Mana netMana : manaAbility.getNetMana(game)) {
|
||||||
if (cost.testPay(netMana) || spendAnyManaId != null) {
|
if (cost.testPay(netMana) || permittingObject != null) {
|
||||||
|
if (netMana instanceof ConditionalMana && !((ConditionalMana) netMana).apply(ability, game, getId(), cost)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
if (activateAbility(manaAbility, game)) {
|
if (activateAbility(manaAbility, game)) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -1376,13 +1398,39 @@ public class ComputerPlayer extends PlayerImpl implements Player {
|
||||||
}
|
}
|
||||||
// pay phyrexian life costs
|
// pay phyrexian life costs
|
||||||
if (cost instanceof PhyrexianManaCost) {
|
if (cost instanceof PhyrexianManaCost) {
|
||||||
if (cost.pay(null, game, null, playerId, false, null) || spendAnyManaId != null) {
|
if (cost.pay(null, game, null, playerId, false, null) || permittingObject != null) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private Abilities<ActivatedManaAbilityImpl> getManaAbilitiesSortedByManaCount(MageObject mageObject, final Game game) {
|
||||||
|
Abilities<ActivatedManaAbilityImpl> manaAbilities = mageObject.getAbilities().getAvailableActivatedManaAbilities(Zone.BATTLEFIELD, game);
|
||||||
|
if (manaAbilities.size() > 1) {
|
||||||
|
// Sort mana abilities by numbver of produced manas, to use ability first that produces most mana (maybe also conditional if possible)
|
||||||
|
Collections.sort(manaAbilities, new Comparator<ActivatedManaAbilityImpl>() {
|
||||||
|
@Override
|
||||||
|
public int compare(ActivatedManaAbilityImpl a1, ActivatedManaAbilityImpl a2) {
|
||||||
|
int a1Max = 0;
|
||||||
|
for (Mana netMana : a1.getNetMana(game)) {
|
||||||
|
if (netMana.count() > a1Max) {
|
||||||
|
a1Max = netMana.count();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
int a2Max = 0;
|
||||||
|
for (Mana netMana : a2.getNetMana(game)) {
|
||||||
|
if (netMana.count() > a2Max) {
|
||||||
|
a2Max = netMana.count();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return a2Max - a1Max;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
return manaAbilities;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
* returns a list of Permanents that produce mana sorted by the number of
|
* returns a list of Permanents that produce mana sorted by the number of
|
||||||
|
@ -2339,7 +2387,7 @@ public class ComputerPlayer extends PlayerImpl implements Player {
|
||||||
private void playRemoval(List<UUID> creatures, Game game) {
|
private void playRemoval(List<UUID> creatures, Game game) {
|
||||||
for (UUID creatureId : creatures) {
|
for (UUID creatureId : creatures) {
|
||||||
for (Card card : this.playableInstant) {
|
for (Card card : this.playableInstant) {
|
||||||
if (card.getSpellAbility().canActivate(playerId, game)) {
|
if (card.getSpellAbility().canActivate(playerId, game).canActivate()) {
|
||||||
for (Effect effect : card.getSpellAbility().getEffects()) {
|
for (Effect effect : card.getSpellAbility().getEffects()) {
|
||||||
if (effect.getOutcome() == Outcome.DestroyPermanent || effect.getOutcome() == Outcome.ReturnToHand) {
|
if (effect.getOutcome() == Outcome.DestroyPermanent || effect.getOutcome() == Outcome.ReturnToHand) {
|
||||||
if (card.getSpellAbility().getTargets().get(0).canTarget(creatureId, card.getSpellAbility(), game)) {
|
if (card.getSpellAbility().getTargets().get(0).canTarget(creatureId, card.getSpellAbility(), game)) {
|
||||||
|
@ -2358,7 +2406,7 @@ public class ComputerPlayer extends PlayerImpl implements Player {
|
||||||
for (UUID creatureId : creatures) {
|
for (UUID creatureId : creatures) {
|
||||||
Permanent creature = game.getPermanent(creatureId);
|
Permanent creature = game.getPermanent(creatureId);
|
||||||
for (Card card : this.playableInstant) {
|
for (Card card : this.playableInstant) {
|
||||||
if (card.getSpellAbility().canActivate(playerId, game)) {
|
if (card.getSpellAbility().canActivate(playerId, game).canActivate()) {
|
||||||
for (Effect effect : card.getSpellAbility().getEffects()) {
|
for (Effect effect : card.getSpellAbility().getEffects()) {
|
||||||
if (effect instanceof DamageTargetEffect) {
|
if (effect instanceof DamageTargetEffect) {
|
||||||
if (card.getSpellAbility().getTargets().get(0).canTarget(creatureId, card.getSpellAbility(), game)) {
|
if (card.getSpellAbility().getTargets().get(0).canTarget(creatureId, card.getSpellAbility(), game)) {
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.mage</groupId>
|
<groupId>org.mage</groupId>
|
||||||
<artifactId>mage-server-plugins</artifactId>
|
<artifactId>mage-server-plugins</artifactId>
|
||||||
<version>1.4.29</version>
|
<version>1.4.30</version>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<artifactId>mage-player-ai-mcts</artifactId>
|
<artifactId>mage-player-ai-mcts</artifactId>
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.mage</groupId>
|
<groupId>org.mage</groupId>
|
||||||
<artifactId>mage-server-plugins</artifactId>
|
<artifactId>mage-server-plugins</artifactId>
|
||||||
<version>1.4.29</version>
|
<version>1.4.30</version>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<artifactId>mage-player-aiminimax</artifactId>
|
<artifactId>mage-player-aiminimax</artifactId>
|
||||||
|
|
|
@ -25,17 +25,16 @@
|
||||||
* authors and should not be interpreted as representing official policies, either expressed
|
* authors and should not be interpreted as representing official policies, either expressed
|
||||||
* or implied, of BetaSteward_at_googlemail.com.
|
* or implied, of BetaSteward_at_googlemail.com.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package mage.player.ai;
|
package mage.player.ai;
|
||||||
|
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
import mage.constants.CardType;
|
|
||||||
import mage.constants.Zone;
|
|
||||||
import mage.abilities.ActivatedAbility;
|
import mage.abilities.ActivatedAbility;
|
||||||
import mage.abilities.keyword.DoubleStrikeAbility;
|
import mage.abilities.keyword.DoubleStrikeAbility;
|
||||||
import mage.abilities.keyword.FirstStrikeAbility;
|
import mage.abilities.keyword.FirstStrikeAbility;
|
||||||
import mage.abilities.keyword.TrampleAbility;
|
import mage.abilities.keyword.TrampleAbility;
|
||||||
import mage.abilities.mana.ActivatedManaAbilityImpl;
|
import mage.abilities.mana.ActivatedManaAbilityImpl;
|
||||||
|
import mage.constants.CardType;
|
||||||
|
import mage.constants.Zone;
|
||||||
import mage.counters.BoostCounter;
|
import mage.counters.BoostCounter;
|
||||||
import mage.counters.Counter;
|
import mage.counters.Counter;
|
||||||
import mage.counters.CounterType;
|
import mage.counters.CounterType;
|
||||||
|
@ -71,18 +70,20 @@ public final class GameStateEvaluator {
|
||||||
Player player = game.getPlayer(playerId);
|
Player player = game.getPlayer(playerId);
|
||||||
Player opponent = game.getPlayer(game.getOpponents(playerId).iterator().next());
|
Player opponent = game.getPlayer(game.getOpponents(playerId).iterator().next());
|
||||||
if (game.checkIfGameIsOver()) {
|
if (game.checkIfGameIsOver()) {
|
||||||
if (player.hasLost() || opponent.hasWon())
|
if (player.hasLost() || opponent.hasWon()) {
|
||||||
return LOSE_SCORE;
|
return LOSE_SCORE;
|
||||||
if (opponent.hasLost() || player.hasWon())
|
}
|
||||||
|
if (opponent.hasLost() || player.hasWon()) {
|
||||||
return WIN_SCORE;
|
return WIN_SCORE;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
int lifeScore = (player.getLife() - opponent.getLife()) * LIFE_FACTOR;
|
int lifeScore = (player.getLife() - opponent.getLife()) * LIFE_FACTOR;
|
||||||
int poisonScore = (opponent.getCounters().getCount(CounterType.POISON) - player.getCounters().getCount(CounterType.POISON)) * LIFE_FACTOR * 2;
|
int poisonScore = (opponent.getCounters().getCount(CounterType.POISON) - player.getCounters().getCount(CounterType.POISON)) * LIFE_FACTOR * 2;
|
||||||
int permanentScore = 0;
|
int permanentScore = 0;
|
||||||
for (Permanent permanent: game.getBattlefield().getAllActivePermanents(playerId)) {
|
for (Permanent permanent : game.getBattlefield().getAllActivePermanents(playerId)) {
|
||||||
permanentScore += evaluatePermanent(permanent, game, ignoreTapped);
|
permanentScore += evaluatePermanent(permanent, game, ignoreTapped);
|
||||||
}
|
}
|
||||||
for (Permanent permanent: game.getBattlefield().getAllActivePermanents(opponent.getId())) {
|
for (Permanent permanent : game.getBattlefield().getAllActivePermanents(opponent.getId())) {
|
||||||
permanentScore -= evaluatePermanent(permanent, game, ignoreTapped);
|
permanentScore -= evaluatePermanent(permanent, game, ignoreTapped);
|
||||||
}
|
}
|
||||||
permanentScore *= PERMANENT_FACTOR;
|
permanentScore *= PERMANENT_FACTOR;
|
||||||
|
@ -92,26 +93,29 @@ public final class GameStateEvaluator {
|
||||||
handScore *= HAND_FACTOR;
|
handScore *= HAND_FACTOR;
|
||||||
|
|
||||||
int score = lifeScore + poisonScore + permanentScore + handScore;
|
int score = lifeScore + poisonScore + permanentScore + handScore;
|
||||||
if (logger.isDebugEnabled())
|
if (logger.isDebugEnabled()) {
|
||||||
logger.debug("game state for player " + player.getName() + " evaluated to- lifeScore:" + lifeScore + " permanentScore:" + permanentScore + " handScore:" + handScore + " total:" + score);
|
logger.debug("game state for player " + player.getName() + " evaluated to- lifeScore:" + lifeScore + " permanentScore:" + permanentScore + " handScore:" + handScore + " total:" + score);
|
||||||
|
}
|
||||||
return score;
|
return score;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static int evaluatePermanent(Permanent permanent, Game game, boolean ignoreTapped) {
|
public static int evaluatePermanent(Permanent permanent, Game game, boolean ignoreTapped) {
|
||||||
int value = 0;
|
int value = 0;
|
||||||
if (ignoreTapped)
|
if (ignoreTapped) {
|
||||||
value = 5;
|
value = 5;
|
||||||
else
|
} else {
|
||||||
value = permanent.isTapped()?4:5;
|
value = permanent.isTapped() ? 4 : 5;
|
||||||
|
}
|
||||||
if (permanent.getCardType().contains(CardType.CREATURE)) {
|
if (permanent.getCardType().contains(CardType.CREATURE)) {
|
||||||
value += evaluateCreature(permanent, game) * CREATURE_FACTOR;
|
value += evaluateCreature(permanent, game) * CREATURE_FACTOR;
|
||||||
}
|
}
|
||||||
value += permanent.getAbilities().getActivatedManaAbilities(Zone.BATTLEFIELD).size();
|
value += permanent.getAbilities().getActivatedManaAbilities(Zone.BATTLEFIELD).size();
|
||||||
for (ActivatedAbility ability: permanent.getAbilities().getActivatedAbilities(Zone.BATTLEFIELD)) {
|
for (ActivatedAbility ability : permanent.getAbilities().getActivatedAbilities(Zone.BATTLEFIELD)) {
|
||||||
if (!(ability instanceof ActivatedManaAbilityImpl) && ability.canActivate(ability.getControllerId(), game))
|
if (!(ability instanceof ActivatedManaAbilityImpl) && ability.canActivate(ability.getControllerId(), game).canActivate()) {
|
||||||
value += ability.getEffects().size();
|
value += ability.getEffects().size();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
for (Counter counter: permanent.getCounters(game).values()) {
|
for (Counter counter : permanent.getCounters(game).values()) {
|
||||||
if (!(counter instanceof BoostCounter)) {
|
if (!(counter instanceof BoostCounter)) {
|
||||||
value += counter.getCount();
|
value += counter.getCount();
|
||||||
}
|
}
|
||||||
|
@ -133,9 +137,9 @@ public final class GameStateEvaluator {
|
||||||
// value += 2;
|
// value += 2;
|
||||||
value += creature.getAbilities().getEvasionAbilities().size();
|
value += creature.getAbilities().getEvasionAbilities().size();
|
||||||
value += creature.getAbilities().getProtectionAbilities().size();
|
value += creature.getAbilities().getProtectionAbilities().size();
|
||||||
value += creature.getAbilities().containsKey(FirstStrikeAbility.getInstance().getId())?1:0;
|
value += creature.getAbilities().containsKey(FirstStrikeAbility.getInstance().getId()) ? 1 : 0;
|
||||||
value += creature.getAbilities().containsKey(DoubleStrikeAbility.getInstance().getId())?2:0;
|
value += creature.getAbilities().containsKey(DoubleStrikeAbility.getInstance().getId()) ? 2 : 0;
|
||||||
value += creature.getAbilities().containsKey(TrampleAbility.getInstance().getId())?1:0;
|
value += creature.getAbilities().containsKey(TrampleAbility.getInstance().getId()) ? 1 : 0;
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.mage</groupId>
|
<groupId>org.mage</groupId>
|
||||||
<artifactId>mage-server-plugins</artifactId>
|
<artifactId>mage-server-plugins</artifactId>
|
||||||
<version>1.4.29</version>
|
<version>1.4.30</version>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<artifactId>mage-player-human</artifactId>
|
<artifactId>mage-player-human</artifactId>
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.mage</groupId>
|
<groupId>org.mage</groupId>
|
||||||
<artifactId>mage-server-plugins</artifactId>
|
<artifactId>mage-server-plugins</artifactId>
|
||||||
<version>1.4.29</version>
|
<version>1.4.30</version>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<artifactId>mage-tournament-boosterdraft</artifactId>
|
<artifactId>mage-tournament-boosterdraft</artifactId>
|
||||||
|
|
|
@ -37,15 +37,15 @@ public class AdamStyborskisPauperCube extends DraftCube {
|
||||||
|
|
||||||
public AdamStyborskisPauperCube() {
|
public AdamStyborskisPauperCube() {
|
||||||
super("Adam Styborkski's Pauper Cube"); // https://docs.google.com/spreadsheets/d/12iQhC4bHqFW7hEWxPBjyC8yBDehFZ0_4DkqzyA8EL3o/edit#gid=0
|
super("Adam Styborkski's Pauper Cube"); // https://docs.google.com/spreadsheets/d/12iQhC4bHqFW7hEWxPBjyC8yBDehFZ0_4DkqzyA8EL3o/edit#gid=0
|
||||||
// last updated with Hour of Devastation, Iconic Masters and Ixalan 10/18/17
|
// last updated with Dominaria 5/1/18
|
||||||
|
cubeCards.add(new CardIdentity("Academy Journeymage", ""));
|
||||||
cubeCards.add(new CardIdentity("Act of Treason", ""));
|
cubeCards.add(new CardIdentity("Act of Treason", ""));
|
||||||
cubeCards.add(new CardIdentity("Adventuring Gear", ""));
|
cubeCards.add(new CardIdentity("Adventuring Gear", ""));
|
||||||
|
cubeCards.add(new CardIdentity("Aerie Bowmasters", ""));
|
||||||
cubeCards.add(new CardIdentity("Aerie Ouphes", ""));
|
cubeCards.add(new CardIdentity("Aerie Ouphes", ""));
|
||||||
cubeCards.add(new CardIdentity("Aether Adept", ""));
|
cubeCards.add(new CardIdentity("Aether Adept", ""));
|
||||||
cubeCards.add(new CardIdentity("Aethersnipe", ""));
|
cubeCards.add(new CardIdentity("Aethersnipe", ""));
|
||||||
cubeCards.add(new CardIdentity("Agony Warp", ""));
|
cubeCards.add(new CardIdentity("Agony Warp", ""));
|
||||||
cubeCards.add(new CardIdentity("Aim High", ""));
|
|
||||||
cubeCards.add(new CardIdentity("Ambuscade", ""));
|
|
||||||
cubeCards.add(new CardIdentity("Ambush Viper", ""));
|
cubeCards.add(new CardIdentity("Ambush Viper", ""));
|
||||||
cubeCards.add(new CardIdentity("Angelic Purge", ""));
|
cubeCards.add(new CardIdentity("Angelic Purge", ""));
|
||||||
cubeCards.add(new CardIdentity("Arachnus Web", ""));
|
cubeCards.add(new CardIdentity("Arachnus Web", ""));
|
||||||
|
@ -61,7 +61,7 @@ public class AdamStyborskisPauperCube extends DraftCube {
|
||||||
cubeCards.add(new CardIdentity("Aven Riftwatcher", ""));
|
cubeCards.add(new CardIdentity("Aven Riftwatcher", ""));
|
||||||
cubeCards.add(new CardIdentity("Aven Surveyor", ""));
|
cubeCards.add(new CardIdentity("Aven Surveyor", ""));
|
||||||
cubeCards.add(new CardIdentity("Azorius Guildgate", ""));
|
cubeCards.add(new CardIdentity("Azorius Guildgate", ""));
|
||||||
cubeCards.add(new CardIdentity("Baleful Eidolon", ""));
|
cubeCards.add(new CardIdentity("Baloth Gorger", ""));
|
||||||
cubeCards.add(new CardIdentity("Barbed Lightning", ""));
|
cubeCards.add(new CardIdentity("Barbed Lightning", ""));
|
||||||
cubeCards.add(new CardIdentity("Basking Rootwalla", ""));
|
cubeCards.add(new CardIdentity("Basking Rootwalla", ""));
|
||||||
cubeCards.add(new CardIdentity("Battle Screech", ""));
|
cubeCards.add(new CardIdentity("Battle Screech", ""));
|
||||||
|
@ -72,33 +72,31 @@ public class AdamStyborskisPauperCube extends DraftCube {
|
||||||
cubeCards.add(new CardIdentity("Blazing Torch", ""));
|
cubeCards.add(new CardIdentity("Blazing Torch", ""));
|
||||||
cubeCards.add(new CardIdentity("Blightning", ""));
|
cubeCards.add(new CardIdentity("Blightning", ""));
|
||||||
cubeCards.add(new CardIdentity("Blinding Beam", ""));
|
cubeCards.add(new CardIdentity("Blinding Beam", ""));
|
||||||
|
cubeCards.add(new CardIdentity("Blink of an Eye", ""));
|
||||||
cubeCards.add(new CardIdentity("Bloodfell Caves", ""));
|
cubeCards.add(new CardIdentity("Bloodfell Caves", ""));
|
||||||
cubeCards.add(new CardIdentity("Blossoming Sands", ""));
|
cubeCards.add(new CardIdentity("Blossoming Sands", ""));
|
||||||
cubeCards.add(new CardIdentity("Bonded Construct", ""));
|
cubeCards.add(new CardIdentity("Bonded Construct", ""));
|
||||||
cubeCards.add(new CardIdentity("Bonds of Faith", ""));
|
cubeCards.add(new CardIdentity("Bonds of Faith", ""));
|
||||||
cubeCards.add(new CardIdentity("Bonesplitter", ""));
|
cubeCards.add(new CardIdentity("Bonesplitter", ""));
|
||||||
cubeCards.add(new CardIdentity("Borderland Marauder", ""));
|
|
||||||
cubeCards.add(new CardIdentity("Boros Guildgate", ""));
|
cubeCards.add(new CardIdentity("Boros Guildgate", ""));
|
||||||
cubeCards.add(new CardIdentity("Borrowed Grace", ""));
|
cubeCards.add(new CardIdentity("Borrowed Grace", ""));
|
||||||
cubeCards.add(new CardIdentity("Branching Bolt", ""));
|
cubeCards.add(new CardIdentity("Branching Bolt", ""));
|
||||||
cubeCards.add(new CardIdentity("Brazen Buccaneers", ""));
|
|
||||||
cubeCards.add(new CardIdentity("Brazen Wolves", ""));
|
cubeCards.add(new CardIdentity("Brazen Wolves", ""));
|
||||||
cubeCards.add(new CardIdentity("Burning-Tree Emissary", ""));
|
cubeCards.add(new CardIdentity("Burning-Tree Emissary", ""));
|
||||||
cubeCards.add(new CardIdentity("Burst Lightning", ""));
|
cubeCards.add(new CardIdentity("Burst Lightning", ""));
|
||||||
cubeCards.add(new CardIdentity("Butcher Ghoul", ""));
|
cubeCards.add(new CardIdentity("Butcher Ghoul", ""));
|
||||||
cubeCards.add(new CardIdentity("Byway Courier", ""));
|
|
||||||
cubeCards.add(new CardIdentity("Cage of Hands", ""));
|
cubeCards.add(new CardIdentity("Cage of Hands", ""));
|
||||||
cubeCards.add(new CardIdentity("Calcite Snapper", ""));
|
cubeCards.add(new CardIdentity("Calcite Snapper", ""));
|
||||||
cubeCards.add(new CardIdentity("Call of the Conclave", ""));
|
cubeCards.add(new CardIdentity("Call of the Conclave", ""));
|
||||||
|
cubeCards.add(new CardIdentity("Call the Cavalry", ""));
|
||||||
cubeCards.add(new CardIdentity("Capsize", ""));
|
cubeCards.add(new CardIdentity("Capsize", ""));
|
||||||
cubeCards.add(new CardIdentity("Carnivorous Death-Parrot", ""));
|
cubeCards.add(new CardIdentity("Carnivorous Death-Parrot", ""));
|
||||||
cubeCards.add(new CardIdentity("Cartouche of Strength", ""));
|
cubeCards.add(new CardIdentity("Cartouche of Strength", ""));
|
||||||
cubeCards.add(new CardIdentity("Cathodion", ""));
|
|
||||||
cubeCards.add(new CardIdentity("Cavern Harpy", ""));
|
cubeCards.add(new CardIdentity("Cavern Harpy", ""));
|
||||||
cubeCards.add(new CardIdentity("Centaur Healer", ""));
|
cubeCards.add(new CardIdentity("Centaur Healer", ""));
|
||||||
cubeCards.add(new CardIdentity("Chain Lightning", ""));
|
cubeCards.add(new CardIdentity("Chain Lightning", ""));
|
||||||
cubeCards.add(new CardIdentity("Chainer's Edict", ""));
|
cubeCards.add(new CardIdentity("Chainer's Edict", ""));
|
||||||
cubeCards.add(new CardIdentity("Chatter of the Squirrel", ""));
|
cubeCards.add(new CardIdentity("Chivalrous Chevalier", ""));
|
||||||
cubeCards.add(new CardIdentity("Cinder Barrens", ""));
|
cubeCards.add(new CardIdentity("Cinder Barrens", ""));
|
||||||
cubeCards.add(new CardIdentity("Citanul Woodreaders", ""));
|
cubeCards.add(new CardIdentity("Citanul Woodreaders", ""));
|
||||||
cubeCards.add(new CardIdentity("Claustrophobia", ""));
|
cubeCards.add(new CardIdentity("Claustrophobia", ""));
|
||||||
|
@ -108,13 +106,14 @@ public class AdamStyborskisPauperCube extends DraftCube {
|
||||||
cubeCards.add(new CardIdentity("Coalition Honor Guard", ""));
|
cubeCards.add(new CardIdentity("Coalition Honor Guard", ""));
|
||||||
cubeCards.add(new CardIdentity("Cogwork Librarian", ""));
|
cubeCards.add(new CardIdentity("Cogwork Librarian", ""));
|
||||||
cubeCards.add(new CardIdentity("Colossal Might", ""));
|
cubeCards.add(new CardIdentity("Colossal Might", ""));
|
||||||
|
cubeCards.add(new CardIdentity("Common Iguana", ""));
|
||||||
cubeCards.add(new CardIdentity("Compulsive Research", ""));
|
cubeCards.add(new CardIdentity("Compulsive Research", ""));
|
||||||
cubeCards.add(new CardIdentity("Compulsory Rest", ""));
|
cubeCards.add(new CardIdentity("Compulsory Rest", ""));
|
||||||
cubeCards.add(new CardIdentity("Consume Strength", ""));
|
cubeCards.add(new CardIdentity("Consume Strength", ""));
|
||||||
cubeCards.add(new CardIdentity("Corrupted Zendikon", ""));
|
cubeCards.add(new CardIdentity("Corrupted Zendikon", ""));
|
||||||
cubeCards.add(new CardIdentity("Counterspell", ""));
|
cubeCards.add(new CardIdentity("Counterspell", ""));
|
||||||
|
cubeCards.add(new CardIdentity("Court Hussar", ""));
|
||||||
cubeCards.add(new CardIdentity("Crippling Fatigue", ""));
|
cubeCards.add(new CardIdentity("Crippling Fatigue", ""));
|
||||||
cubeCards.add(new CardIdentity("Crow of Dark Tidings", ""));
|
|
||||||
cubeCards.add(new CardIdentity("Crypt Rats", ""));
|
cubeCards.add(new CardIdentity("Crypt Rats", ""));
|
||||||
cubeCards.add(new CardIdentity("Crystallization", ""));
|
cubeCards.add(new CardIdentity("Crystallization", ""));
|
||||||
cubeCards.add(new CardIdentity("Cunning Strike", ""));
|
cubeCards.add(new CardIdentity("Cunning Strike", ""));
|
||||||
|
@ -126,24 +125,23 @@ public class AdamStyborskisPauperCube extends DraftCube {
|
||||||
cubeCards.add(new CardIdentity("Dead Weight", ""));
|
cubeCards.add(new CardIdentity("Dead Weight", ""));
|
||||||
cubeCards.add(new CardIdentity("Deadeye Tormentor", ""));
|
cubeCards.add(new CardIdentity("Deadeye Tormentor", ""));
|
||||||
cubeCards.add(new CardIdentity("Death Denied", ""));
|
cubeCards.add(new CardIdentity("Death Denied", ""));
|
||||||
|
cubeCards.add(new CardIdentity("Deathbloom Thallid", ""));
|
||||||
cubeCards.add(new CardIdentity("Deep Analysis", ""));
|
cubeCards.add(new CardIdentity("Deep Analysis", ""));
|
||||||
cubeCards.add(new CardIdentity("Deprive", ""));
|
cubeCards.add(new CardIdentity("Deprive", ""));
|
||||||
cubeCards.add(new CardIdentity("Depths of Desire", ""));
|
cubeCards.add(new CardIdentity("Depths of Desire", ""));
|
||||||
cubeCards.add(new CardIdentity("Deputy of Acquittals", ""));
|
cubeCards.add(new CardIdentity("Deputy of Acquittals", ""));
|
||||||
cubeCards.add(new CardIdentity("Desert", ""));
|
cubeCards.add(new CardIdentity("Desert", ""));
|
||||||
cubeCards.add(new CardIdentity("Desperate Sentry", ""));
|
|
||||||
cubeCards.add(new CardIdentity("Devour Flesh", ""));
|
cubeCards.add(new CardIdentity("Devour Flesh", ""));
|
||||||
cubeCards.add(new CardIdentity("Diabolic Edict", ""));
|
cubeCards.add(new CardIdentity("Diabolic Edict", ""));
|
||||||
cubeCards.add(new CardIdentity("Dimir Guildgate", ""));
|
cubeCards.add(new CardIdentity("Dimir Guildgate", ""));
|
||||||
cubeCards.add(new CardIdentity("Dinrova Horror", ""));
|
cubeCards.add(new CardIdentity("Dinrova Horror", ""));
|
||||||
cubeCards.add(new CardIdentity("Dire Fleet Hoarder", ""));
|
|
||||||
cubeCards.add(new CardIdentity("Disfigure", ""));
|
cubeCards.add(new CardIdentity("Disfigure", ""));
|
||||||
cubeCards.add(new CardIdentity("Dismal Backwater", ""));
|
cubeCards.add(new CardIdentity("Dismal Backwater", ""));
|
||||||
cubeCards.add(new CardIdentity("Disowned Ancestor", ""));
|
cubeCards.add(new CardIdentity("Disowned Ancestor", ""));
|
||||||
cubeCards.add(new CardIdentity("Doom Blade", ""));
|
cubeCards.add(new CardIdentity("Doom Blade", ""));
|
||||||
cubeCards.add(new CardIdentity("Doomed Traveler", ""));
|
cubeCards.add(new CardIdentity("Doomed Traveler", ""));
|
||||||
cubeCards.add(new CardIdentity("Drag Under", ""));
|
|
||||||
cubeCards.add(new CardIdentity("Dragon Fodder", ""));
|
cubeCards.add(new CardIdentity("Dragon Fodder", ""));
|
||||||
|
cubeCards.add(new CardIdentity("Dusk Legion Zealot", ""));
|
||||||
cubeCards.add(new CardIdentity("Dynacharge", ""));
|
cubeCards.add(new CardIdentity("Dynacharge", ""));
|
||||||
cubeCards.add(new CardIdentity("Eager Construct", ""));
|
cubeCards.add(new CardIdentity("Eager Construct", ""));
|
||||||
cubeCards.add(new CardIdentity("Eldrazi Devastator", ""));
|
cubeCards.add(new CardIdentity("Eldrazi Devastator", ""));
|
||||||
|
@ -154,12 +152,13 @@ public class AdamStyborskisPauperCube extends DraftCube {
|
||||||
cubeCards.add(new CardIdentity("Emperor Crocodile", ""));
|
cubeCards.add(new CardIdentity("Emperor Crocodile", ""));
|
||||||
cubeCards.add(new CardIdentity("Epic Confrontation", ""));
|
cubeCards.add(new CardIdentity("Epic Confrontation", ""));
|
||||||
cubeCards.add(new CardIdentity("Errant Ephemeron", ""));
|
cubeCards.add(new CardIdentity("Errant Ephemeron", ""));
|
||||||
cubeCards.add(new CardIdentity("Esper Cormorants", ""));
|
|
||||||
cubeCards.add(new CardIdentity("Evincar's Justice", ""));
|
cubeCards.add(new CardIdentity("Evincar's Justice", ""));
|
||||||
cubeCards.add(new CardIdentity("Evolving Wilds", ""));
|
cubeCards.add(new CardIdentity("Evolving Wilds", ""));
|
||||||
|
cubeCards.add(new CardIdentity("Extremely Slow Zombie (C)", ""));
|
||||||
cubeCards.add(new CardIdentity("Faceless Butcher", ""));
|
cubeCards.add(new CardIdentity("Faceless Butcher", ""));
|
||||||
cubeCards.add(new CardIdentity("Faith's Fetters", ""));
|
cubeCards.add(new CardIdentity("Faith's Fetters", ""));
|
||||||
cubeCards.add(new CardIdentity("Falkenrath Noble", ""));
|
cubeCards.add(new CardIdentity("Falkenrath Noble", ""));
|
||||||
|
cubeCards.add(new CardIdentity("Fanatical Firebrand", ""));
|
||||||
cubeCards.add(new CardIdentity("Feeling of Dread", ""));
|
cubeCards.add(new CardIdentity("Feeling of Dread", ""));
|
||||||
cubeCards.add(new CardIdentity("Fervent Cathar", ""));
|
cubeCards.add(new CardIdentity("Fervent Cathar", ""));
|
||||||
cubeCards.add(new CardIdentity("Firebolt", ""));
|
cubeCards.add(new CardIdentity("Firebolt", ""));
|
||||||
|
@ -170,25 +169,27 @@ public class AdamStyborskisPauperCube extends DraftCube {
|
||||||
cubeCards.add(new CardIdentity("Forsaken Sanctuary", ""));
|
cubeCards.add(new CardIdentity("Forsaken Sanctuary", ""));
|
||||||
cubeCards.add(new CardIdentity("Fortify", ""));
|
cubeCards.add(new CardIdentity("Fortify", ""));
|
||||||
cubeCards.add(new CardIdentity("Foul Orchard", ""));
|
cubeCards.add(new CardIdentity("Foul Orchard", ""));
|
||||||
|
cubeCards.add(new CardIdentity("Frenzied Goblin", ""));
|
||||||
|
cubeCards.add(new CardIdentity("Frilled Deathspitter", ""));
|
||||||
cubeCards.add(new CardIdentity("Frilled Oculus", ""));
|
cubeCards.add(new CardIdentity("Frilled Oculus", ""));
|
||||||
cubeCards.add(new CardIdentity("Frostburn Weird", ""));
|
cubeCards.add(new CardIdentity("Frostburn Weird", ""));
|
||||||
|
cubeCards.add(new CardIdentity("Fungal Infection", ""));
|
||||||
|
cubeCards.add(new CardIdentity("GO TO JAIL", ""));
|
||||||
cubeCards.add(new CardIdentity("Gathan Raiders", ""));
|
cubeCards.add(new CardIdentity("Gathan Raiders", ""));
|
||||||
cubeCards.add(new CardIdentity("Gather the Townsfolk", ""));
|
cubeCards.add(new CardIdentity("Gather the Townsfolk", ""));
|
||||||
cubeCards.add(new CardIdentity("Ghastly Demise", ""));
|
|
||||||
cubeCards.add(new CardIdentity("Ghirapur Gearcrafter", ""));
|
cubeCards.add(new CardIdentity("Ghirapur Gearcrafter", ""));
|
||||||
cubeCards.add(new CardIdentity("Ghitu Slinger", ""));
|
|
||||||
cubeCards.add(new CardIdentity("Giant Growth", ""));
|
cubeCards.add(new CardIdentity("Giant Growth", ""));
|
||||||
cubeCards.add(new CardIdentity("Gideon's Lawkeeper", ""));
|
cubeCards.add(new CardIdentity("Gideon's Lawkeeper", ""));
|
||||||
cubeCards.add(new CardIdentity("Glint-Sleeve Artisan", ""));
|
cubeCards.add(new CardIdentity("Glint-Sleeve Artisan", ""));
|
||||||
cubeCards.add(new CardIdentity("Gnawing Zombie", ""));
|
cubeCards.add(new CardIdentity("Gnawing Zombie", ""));
|
||||||
cubeCards.add(new CardIdentity("Goblin Freerunner", ""));
|
cubeCards.add(new CardIdentity("Goblin Freerunner", ""));
|
||||||
cubeCards.add(new CardIdentity("Goblin Heelcutter", ""));
|
cubeCards.add(new CardIdentity("Goblin Heelcutter", ""));
|
||||||
|
cubeCards.add(new CardIdentity("Goblin Trailblazer", ""));
|
||||||
cubeCards.add(new CardIdentity("Gods Willing", ""));
|
cubeCards.add(new CardIdentity("Gods Willing", ""));
|
||||||
cubeCards.add(new CardIdentity("Goldmeadow Harrier", ""));
|
cubeCards.add(new CardIdentity("Goldmeadow Harrier", ""));
|
||||||
cubeCards.add(new CardIdentity("Golgari Guildgate", ""));
|
cubeCards.add(new CardIdentity("Golgari Guildgate", ""));
|
||||||
cubeCards.add(new CardIdentity("Gravedigger", ""));
|
cubeCards.add(new CardIdentity("Gravedigger", ""));
|
||||||
cubeCards.add(new CardIdentity("Gray Merchant of Asphodel", ""));
|
cubeCards.add(new CardIdentity("Gray Merchant of Asphodel", ""));
|
||||||
cubeCards.add(new CardIdentity("Grazing Whiptail", ""));
|
|
||||||
cubeCards.add(new CardIdentity("Grim Contest", ""));
|
cubeCards.add(new CardIdentity("Grim Contest", ""));
|
||||||
cubeCards.add(new CardIdentity("Grisly Salvage", ""));
|
cubeCards.add(new CardIdentity("Grisly Salvage", ""));
|
||||||
cubeCards.add(new CardIdentity("Grixis Slavedriver", ""));
|
cubeCards.add(new CardIdentity("Grixis Slavedriver", ""));
|
||||||
|
@ -204,9 +205,8 @@ public class AdamStyborskisPauperCube extends DraftCube {
|
||||||
cubeCards.add(new CardIdentity("Highland Lake", ""));
|
cubeCards.add(new CardIdentity("Highland Lake", ""));
|
||||||
cubeCards.add(new CardIdentity("Hissing Iguanar", ""));
|
cubeCards.add(new CardIdentity("Hissing Iguanar", ""));
|
||||||
cubeCards.add(new CardIdentity("Hooting Mandrills", ""));
|
cubeCards.add(new CardIdentity("Hooting Mandrills", ""));
|
||||||
cubeCards.add(new CardIdentity("Humble", ""));
|
cubeCards.add(new CardIdentity("Hordeling Outburst", ""));
|
||||||
cubeCards.add(new CardIdentity("Imperiosaur", ""));
|
cubeCards.add(new CardIdentity("Imperiosaur", ""));
|
||||||
cubeCards.add(new CardIdentity("Incinerate", ""));
|
|
||||||
cubeCards.add(new CardIdentity("Inner-Flame Acolyte", ""));
|
cubeCards.add(new CardIdentity("Inner-Flame Acolyte", ""));
|
||||||
cubeCards.add(new CardIdentity("Insolent Neonate", ""));
|
cubeCards.add(new CardIdentity("Insolent Neonate", ""));
|
||||||
cubeCards.add(new CardIdentity("Into the Roil", ""));
|
cubeCards.add(new CardIdentity("Into the Roil", ""));
|
||||||
|
@ -214,17 +214,20 @@ public class AdamStyborskisPauperCube extends DraftCube {
|
||||||
cubeCards.add(new CardIdentity("Ivy Elemental", ""));
|
cubeCards.add(new CardIdentity("Ivy Elemental", ""));
|
||||||
cubeCards.add(new CardIdentity("Izzet Chronarch", ""));
|
cubeCards.add(new CardIdentity("Izzet Chronarch", ""));
|
||||||
cubeCards.add(new CardIdentity("Izzet Guildgate", ""));
|
cubeCards.add(new CardIdentity("Izzet Guildgate", ""));
|
||||||
|
cubeCards.add(new CardIdentity("Jackal Pup", ""));
|
||||||
cubeCards.add(new CardIdentity("Jilt", ""));
|
cubeCards.add(new CardIdentity("Jilt", ""));
|
||||||
cubeCards.add(new CardIdentity("Journey to Nowhere", ""));
|
cubeCards.add(new CardIdentity("Journey to Nowhere", ""));
|
||||||
cubeCards.add(new CardIdentity("Jungle Hollow", ""));
|
cubeCards.add(new CardIdentity("Jungle Hollow", ""));
|
||||||
cubeCards.add(new CardIdentity("Kabuto Moth", ""));
|
cubeCards.add(new CardIdentity("Jungleborn Pioneer", ""));
|
||||||
cubeCards.add(new CardIdentity("Keldon Marauders", ""));
|
cubeCards.add(new CardIdentity("Keldon Marauders", ""));
|
||||||
|
cubeCards.add(new CardIdentity("Keldon Overseer", ""));
|
||||||
|
cubeCards.add(new CardIdentity("Keldon Raider", ""));
|
||||||
cubeCards.add(new CardIdentity("Kingpin's Pet", ""));
|
cubeCards.add(new CardIdentity("Kingpin's Pet", ""));
|
||||||
|
cubeCards.add(new CardIdentity("Kitesail Corsair", ""));
|
||||||
cubeCards.add(new CardIdentity("Kor Skyfisher", ""));
|
cubeCards.add(new CardIdentity("Kor Skyfisher", ""));
|
||||||
cubeCards.add(new CardIdentity("Kozilek's Channeler", ""));
|
cubeCards.add(new CardIdentity("Kozilek's Channeler", ""));
|
||||||
cubeCards.add(new CardIdentity("Krenko's Command", ""));
|
cubeCards.add(new CardIdentity("Krenko's Command", ""));
|
||||||
cubeCards.add(new CardIdentity("Krosan Tusker", ""));
|
cubeCards.add(new CardIdentity("Krosan Tusker", ""));
|
||||||
cubeCards.add(new CardIdentity("Kruin Striker", ""));
|
|
||||||
cubeCards.add(new CardIdentity("Lash Out", ""));
|
cubeCards.add(new CardIdentity("Lash Out", ""));
|
||||||
cubeCards.add(new CardIdentity("Last Gasp", ""));
|
cubeCards.add(new CardIdentity("Last Gasp", ""));
|
||||||
cubeCards.add(new CardIdentity("Leave in the Dust", ""));
|
cubeCards.add(new CardIdentity("Leave in the Dust", ""));
|
||||||
|
@ -232,16 +235,15 @@ public class AdamStyborskisPauperCube extends DraftCube {
|
||||||
cubeCards.add(new CardIdentity("Lifecraft Cavalry", ""));
|
cubeCards.add(new CardIdentity("Lifecraft Cavalry", ""));
|
||||||
cubeCards.add(new CardIdentity("Lightning Bolt", ""));
|
cubeCards.add(new CardIdentity("Lightning Bolt", ""));
|
||||||
cubeCards.add(new CardIdentity("Liliana's Specter", ""));
|
cubeCards.add(new CardIdentity("Liliana's Specter", ""));
|
||||||
cubeCards.add(new CardIdentity("Lotus Path Djinn", ""));
|
|
||||||
cubeCards.add(new CardIdentity("Loyal Pegasus", ""));
|
cubeCards.add(new CardIdentity("Loyal Pegasus", ""));
|
||||||
cubeCards.add(new CardIdentity("Lurking Automaton", ""));
|
cubeCards.add(new CardIdentity("Lurking Automaton", ""));
|
||||||
cubeCards.add(new CardIdentity("Magma Jet", ""));
|
cubeCards.add(new CardIdentity("Magma Jet", ""));
|
||||||
cubeCards.add(new CardIdentity("Makeshift Mauler", ""));
|
cubeCards.add(new CardIdentity("Makeshift Mauler", ""));
|
||||||
cubeCards.add(new CardIdentity("Man-o'-War", ""));
|
cubeCards.add(new CardIdentity("Man-o'-War", ""));
|
||||||
cubeCards.add(new CardIdentity("Mana Leak", ""));
|
cubeCards.add(new CardIdentity("Mana Leak", ""));
|
||||||
cubeCards.add(new CardIdentity("Manticore of the Gauntlet", ""));
|
|
||||||
cubeCards.add(new CardIdentity("Mardu Hordechief", ""));
|
cubeCards.add(new CardIdentity("Mardu Hordechief", ""));
|
||||||
cubeCards.add(new CardIdentity("Mardu Skullhunter", ""));
|
cubeCards.add(new CardIdentity("Mardu Skullhunter", ""));
|
||||||
|
cubeCards.add(new CardIdentity("Martyr of Dusk", ""));
|
||||||
cubeCards.add(new CardIdentity("Maul Splicer", ""));
|
cubeCards.add(new CardIdentity("Maul Splicer", ""));
|
||||||
cubeCards.add(new CardIdentity("Maze of Ith", ""));
|
cubeCards.add(new CardIdentity("Maze of Ith", ""));
|
||||||
cubeCards.add(new CardIdentity("Meandering River", ""));
|
cubeCards.add(new CardIdentity("Meandering River", ""));
|
||||||
|
@ -263,7 +265,6 @@ public class AdamStyborskisPauperCube extends DraftCube {
|
||||||
cubeCards.add(new CardIdentity("Mulldrifter", ""));
|
cubeCards.add(new CardIdentity("Mulldrifter", ""));
|
||||||
cubeCards.add(new CardIdentity("Nameless Inversion", ""));
|
cubeCards.add(new CardIdentity("Nameless Inversion", ""));
|
||||||
cubeCards.add(new CardIdentity("Narcolepsy", ""));
|
cubeCards.add(new CardIdentity("Narcolepsy", ""));
|
||||||
cubeCards.add(new CardIdentity("Necromancer's Assistant", ""));
|
|
||||||
cubeCards.add(new CardIdentity("Nessian Asp", ""));
|
cubeCards.add(new CardIdentity("Nessian Asp", ""));
|
||||||
cubeCards.add(new CardIdentity("Nest Robber", ""));
|
cubeCards.add(new CardIdentity("Nest Robber", ""));
|
||||||
cubeCards.add(new CardIdentity("Nezumi Cutthroat", ""));
|
cubeCards.add(new CardIdentity("Nezumi Cutthroat", ""));
|
||||||
|
@ -272,25 +273,22 @@ public class AdamStyborskisPauperCube extends DraftCube {
|
||||||
cubeCards.add(new CardIdentity("Ninja of the Deep Hours", ""));
|
cubeCards.add(new CardIdentity("Ninja of the Deep Hours", ""));
|
||||||
cubeCards.add(new CardIdentity("Oblivion Ring", ""));
|
cubeCards.add(new CardIdentity("Oblivion Ring", ""));
|
||||||
cubeCards.add(new CardIdentity("Oona's Grace", ""));
|
cubeCards.add(new CardIdentity("Oona's Grace", ""));
|
||||||
|
cubeCards.add(new CardIdentity("Ordinary Pony", ""));
|
||||||
cubeCards.add(new CardIdentity("Orzhov Guildgate", ""));
|
cubeCards.add(new CardIdentity("Orzhov Guildgate", ""));
|
||||||
cubeCards.add(new CardIdentity("Otherworldly Journey", ""));
|
cubeCards.add(new CardIdentity("Otherworldly Journey", ""));
|
||||||
|
cubeCards.add(new CardIdentity("Overgrown Armasaur", ""));
|
||||||
cubeCards.add(new CardIdentity("Pacifism", ""));
|
cubeCards.add(new CardIdentity("Pacifism", ""));
|
||||||
cubeCards.add(new CardIdentity("Paladin of the Bloodstained", ""));
|
cubeCards.add(new CardIdentity("Paladin of the Bloodstained", ""));
|
||||||
cubeCards.add(new CardIdentity("Peema Outrider", ""));
|
cubeCards.add(new CardIdentity("Peema Outrider", ""));
|
||||||
cubeCards.add(new CardIdentity("Penumbra Spider", ""));
|
cubeCards.add(new CardIdentity("Penumbra Spider", ""));
|
||||||
cubeCards.add(new CardIdentity("Peregrine Drake", ""));
|
|
||||||
cubeCards.add(new CardIdentity("Perilous Myr", ""));
|
cubeCards.add(new CardIdentity("Perilous Myr", ""));
|
||||||
cubeCards.add(new CardIdentity("Pestermite", ""));
|
cubeCards.add(new CardIdentity("Pestermite", ""));
|
||||||
cubeCards.add(new CardIdentity("Pestilence", ""));
|
cubeCards.add(new CardIdentity("Pestilence", ""));
|
||||||
cubeCards.add(new CardIdentity("Phantom Nomad", ""));
|
|
||||||
cubeCards.add(new CardIdentity("Phantom Tiger", ""));
|
|
||||||
cubeCards.add(new CardIdentity("Pharika's Chosen", ""));
|
|
||||||
cubeCards.add(new CardIdentity("Phyrexian Rager", ""));
|
cubeCards.add(new CardIdentity("Phyrexian Rager", ""));
|
||||||
cubeCards.add(new CardIdentity("Pillory of the Sleepless", ""));
|
cubeCards.add(new CardIdentity("Pillory of the Sleepless", ""));
|
||||||
cubeCards.add(new CardIdentity("Pit Fight", ""));
|
cubeCards.add(new CardIdentity("Pit Fight", ""));
|
||||||
cubeCards.add(new CardIdentity("Pit Keeper", ""));
|
cubeCards.add(new CardIdentity("Pit Keeper", ""));
|
||||||
cubeCards.add(new CardIdentity("Plated Geopede", ""));
|
cubeCards.add(new CardIdentity("Plated Geopede", ""));
|
||||||
cubeCards.add(new CardIdentity("Plover Knights", ""));
|
|
||||||
cubeCards.add(new CardIdentity("Porcelain Legionnaire", ""));
|
cubeCards.add(new CardIdentity("Porcelain Legionnaire", ""));
|
||||||
cubeCards.add(new CardIdentity("Pounce", ""));
|
cubeCards.add(new CardIdentity("Pounce", ""));
|
||||||
cubeCards.add(new CardIdentity("Predatory Nightstalker", ""));
|
cubeCards.add(new CardIdentity("Predatory Nightstalker", ""));
|
||||||
|
@ -321,16 +319,18 @@ public class AdamStyborskisPauperCube extends DraftCube {
|
||||||
cubeCards.add(new CardIdentity("Renegade Freighter", ""));
|
cubeCards.add(new CardIdentity("Renegade Freighter", ""));
|
||||||
cubeCards.add(new CardIdentity("Rift Bolt", ""));
|
cubeCards.add(new CardIdentity("Rift Bolt", ""));
|
||||||
cubeCards.add(new CardIdentity("Rishadan Airship", ""));
|
cubeCards.add(new CardIdentity("Rishadan Airship", ""));
|
||||||
cubeCards.add(new CardIdentity("Ronin Houndmaster", ""));
|
|
||||||
cubeCards.add(new CardIdentity("Rugged Highlands", ""));
|
cubeCards.add(new CardIdentity("Rugged Highlands", ""));
|
||||||
cubeCards.add(new CardIdentity("Runed Servitor", ""));
|
cubeCards.add(new CardIdentity("Runed Servitor", ""));
|
||||||
cubeCards.add(new CardIdentity("Rushing River", ""));
|
cubeCards.add(new CardIdentity("Rushing River", ""));
|
||||||
|
cubeCards.add(new CardIdentity("Ruthless Ripper", ""));
|
||||||
cubeCards.add(new CardIdentity("Sailor of Means", ""));
|
cubeCards.add(new CardIdentity("Sailor of Means", ""));
|
||||||
cubeCards.add(new CardIdentity("Sakura-Tribe Elder", ""));
|
cubeCards.add(new CardIdentity("Sakura-Tribe Elder", ""));
|
||||||
cubeCards.add(new CardIdentity("Sandsteppe Outcast", ""));
|
cubeCards.add(new CardIdentity("Sandsteppe Outcast", ""));
|
||||||
cubeCards.add(new CardIdentity("Sangrite Backlash", ""));
|
cubeCards.add(new CardIdentity("Sangrite Backlash", ""));
|
||||||
|
cubeCards.add(new CardIdentity("Saproling Migration", ""));
|
||||||
cubeCards.add(new CardIdentity("Sarkhan's Rage", ""));
|
cubeCards.add(new CardIdentity("Sarkhan's Rage", ""));
|
||||||
cubeCards.add(new CardIdentity("Savage Punch", ""));
|
cubeCards.add(new CardIdentity("Savage Punch", ""));
|
||||||
|
cubeCards.add(new CardIdentity("Savannah Lions", ""));
|
||||||
cubeCards.add(new CardIdentity("Scatter the Seeds", ""));
|
cubeCards.add(new CardIdentity("Scatter the Seeds", ""));
|
||||||
cubeCards.add(new CardIdentity("Scion Summoner", ""));
|
cubeCards.add(new CardIdentity("Scion Summoner", ""));
|
||||||
cubeCards.add(new CardIdentity("Scion of the Wild", ""));
|
cubeCards.add(new CardIdentity("Scion of the Wild", ""));
|
||||||
|
@ -343,9 +343,10 @@ public class AdamStyborskisPauperCube extends DraftCube {
|
||||||
cubeCards.add(new CardIdentity("Seeker of Insight", ""));
|
cubeCards.add(new CardIdentity("Seeker of Insight", ""));
|
||||||
cubeCards.add(new CardIdentity("Seeker of the Way", ""));
|
cubeCards.add(new CardIdentity("Seeker of the Way", ""));
|
||||||
cubeCards.add(new CardIdentity("Selesnya Guildgate", ""));
|
cubeCards.add(new CardIdentity("Selesnya Guildgate", ""));
|
||||||
cubeCards.add(new CardIdentity("Sentinel Spider", ""));
|
cubeCards.add(new CardIdentity("Selfie Preservation", ""));
|
||||||
cubeCards.add(new CardIdentity("Separatist Voidmage", ""));
|
cubeCards.add(new CardIdentity("Separatist Voidmage", ""));
|
||||||
cubeCards.add(new CardIdentity("Seraph of Dawn", ""));
|
cubeCards.add(new CardIdentity("Seraph of Dawn", ""));
|
||||||
|
cubeCards.add(new CardIdentity("Sergeant-at-Arms", ""));
|
||||||
cubeCards.add(new CardIdentity("Serrated Arrows", ""));
|
cubeCards.add(new CardIdentity("Serrated Arrows", ""));
|
||||||
cubeCards.add(new CardIdentity("Shaper Parasite", ""));
|
cubeCards.add(new CardIdentity("Shaper Parasite", ""));
|
||||||
cubeCards.add(new CardIdentity("Sheer Drop", ""));
|
cubeCards.add(new CardIdentity("Sheer Drop", ""));
|
||||||
|
@ -360,11 +361,12 @@ public class AdamStyborskisPauperCube extends DraftCube {
|
||||||
cubeCards.add(new CardIdentity("Snakeform", ""));
|
cubeCards.add(new CardIdentity("Snakeform", ""));
|
||||||
cubeCards.add(new CardIdentity("Snap", ""));
|
cubeCards.add(new CardIdentity("Snap", ""));
|
||||||
cubeCards.add(new CardIdentity("Soul Manipulation", ""));
|
cubeCards.add(new CardIdentity("Soul Manipulation", ""));
|
||||||
|
cubeCards.add(new CardIdentity("Soul of the Rapids", ""));
|
||||||
cubeCards.add(new CardIdentity("Soulstinger", ""));
|
cubeCards.add(new CardIdentity("Soulstinger", ""));
|
||||||
|
cubeCards.add(new CardIdentity("Sparring Construct", ""));
|
||||||
cubeCards.add(new CardIdentity("Sphere of the Suns", ""));
|
cubeCards.add(new CardIdentity("Sphere of the Suns", ""));
|
||||||
cubeCards.add(new CardIdentity("Spike Jester", ""));
|
cubeCards.add(new CardIdentity("Spike Jester", ""));
|
||||||
cubeCards.add(new CardIdentity("Spined Thopter", ""));
|
cubeCards.add(new CardIdentity("Squirrel Dealer", ""));
|
||||||
cubeCards.add(new CardIdentity("Splatter Thug", ""));
|
|
||||||
cubeCards.add(new CardIdentity("Staggershock", ""));
|
cubeCards.add(new CardIdentity("Staggershock", ""));
|
||||||
cubeCards.add(new CardIdentity("Star Compass", ""));
|
cubeCards.add(new CardIdentity("Star Compass", ""));
|
||||||
cubeCards.add(new CardIdentity("Stitched Drake", ""));
|
cubeCards.add(new CardIdentity("Stitched Drake", ""));
|
||||||
|
@ -372,20 +374,19 @@ public class AdamStyborskisPauperCube extends DraftCube {
|
||||||
cubeCards.add(new CardIdentity("Storm Fleet Pyromancer", ""));
|
cubeCards.add(new CardIdentity("Storm Fleet Pyromancer", ""));
|
||||||
cubeCards.add(new CardIdentity("Stormfront Pegasus", ""));
|
cubeCards.add(new CardIdentity("Stormfront Pegasus", ""));
|
||||||
cubeCards.add(new CardIdentity("Stormscape Apprentice", ""));
|
cubeCards.add(new CardIdentity("Stormscape Apprentice", ""));
|
||||||
cubeCards.add(new CardIdentity("Strip Mine", ""));
|
cubeCards.add(new CardIdentity("Strip Min", ""));
|
||||||
cubeCards.add(new CardIdentity("Striped Riverwinder", ""));
|
cubeCards.add(new CardIdentity("Striped Riverwinder", ""));
|
||||||
|
cubeCards.add(new CardIdentity("Stronghold Confessor", ""));
|
||||||
cubeCards.add(new CardIdentity("Submerged Boneyard", ""));
|
cubeCards.add(new CardIdentity("Submerged Boneyard", ""));
|
||||||
cubeCards.add(new CardIdentity("Sultai Scavenger", ""));
|
cubeCards.add(new CardIdentity("Sultai Scavenger", ""));
|
||||||
cubeCards.add(new CardIdentity("Suppression Bonds", ""));
|
cubeCards.add(new CardIdentity("Suppression Bonds", ""));
|
||||||
cubeCards.add(new CardIdentity("Swiftwater Cliffs", ""));
|
cubeCards.add(new CardIdentity("Swiftwater Cliffs", ""));
|
||||||
cubeCards.add(new CardIdentity("Sylvan Might", ""));
|
cubeCards.add(new CardIdentity("Sylvan Might", ""));
|
||||||
cubeCards.add(new CardIdentity("Sylvok Lifestaff", ""));
|
cubeCards.add(new CardIdentity("Sylvok Lifestaff", ""));
|
||||||
cubeCards.add(new CardIdentity("Tah-Crop Elite", ""));
|
|
||||||
cubeCards.add(new CardIdentity("Temporal Isolation", ""));
|
cubeCards.add(new CardIdentity("Temporal Isolation", ""));
|
||||||
cubeCards.add(new CardIdentity("Tenement Crasher", ""));
|
cubeCards.add(new CardIdentity("Tenement Crasher", ""));
|
||||||
cubeCards.add(new CardIdentity("Terminate", ""));
|
cubeCards.add(new CardIdentity("Terminate", ""));
|
||||||
cubeCards.add(new CardIdentity("Terramorphic Expanse", ""));
|
cubeCards.add(new CardIdentity("Terramorphic Expanse", ""));
|
||||||
cubeCards.add(new CardIdentity("Test of Faith", ""));
|
|
||||||
cubeCards.add(new CardIdentity("Thorn of the Black Rose", ""));
|
cubeCards.add(new CardIdentity("Thorn of the Black Rose", ""));
|
||||||
cubeCards.add(new CardIdentity("Thornweald Archer", ""));
|
cubeCards.add(new CardIdentity("Thornweald Archer", ""));
|
||||||
cubeCards.add(new CardIdentity("Thornwood Falls", ""));
|
cubeCards.add(new CardIdentity("Thornwood Falls", ""));
|
||||||
|
@ -393,7 +394,6 @@ public class AdamStyborskisPauperCube extends DraftCube {
|
||||||
cubeCards.add(new CardIdentity("Thraben Inspector", ""));
|
cubeCards.add(new CardIdentity("Thraben Inspector", ""));
|
||||||
cubeCards.add(new CardIdentity("Thrill-Kill Assassin", ""));
|
cubeCards.add(new CardIdentity("Thrill-Kill Assassin", ""));
|
||||||
cubeCards.add(new CardIdentity("Thundering Giant", ""));
|
cubeCards.add(new CardIdentity("Thundering Giant", ""));
|
||||||
cubeCards.add(new CardIdentity("Thundering Tanadon", ""));
|
|
||||||
cubeCards.add(new CardIdentity("Thunderous Wrath", ""));
|
cubeCards.add(new CardIdentity("Thunderous Wrath", ""));
|
||||||
cubeCards.add(new CardIdentity("Timber Gorge", ""));
|
cubeCards.add(new CardIdentity("Timber Gorge", ""));
|
||||||
cubeCards.add(new CardIdentity("Time to Feed", ""));
|
cubeCards.add(new CardIdentity("Time to Feed", ""));
|
||||||
|
@ -408,7 +408,6 @@ public class AdamStyborskisPauperCube extends DraftCube {
|
||||||
cubeCards.add(new CardIdentity("Typhoid Rats", ""));
|
cubeCards.add(new CardIdentity("Typhoid Rats", ""));
|
||||||
cubeCards.add(new CardIdentity("Ulamog's Crusher", ""));
|
cubeCards.add(new CardIdentity("Ulamog's Crusher", ""));
|
||||||
cubeCards.add(new CardIdentity("Ulvenwald Captive", ""));
|
cubeCards.add(new CardIdentity("Ulvenwald Captive", ""));
|
||||||
cubeCards.add(new CardIdentity("Undying Rage", ""));
|
|
||||||
cubeCards.add(new CardIdentity("Unearth", ""));
|
cubeCards.add(new CardIdentity("Unearth", ""));
|
||||||
cubeCards.add(new CardIdentity("Unmake", ""));
|
cubeCards.add(new CardIdentity("Unmake", ""));
|
||||||
cubeCards.add(new CardIdentity("Vampire Interloper", ""));
|
cubeCards.add(new CardIdentity("Vampire Interloper", ""));
|
||||||
|
@ -427,6 +426,7 @@ public class AdamStyborskisPauperCube extends DraftCube {
|
||||||
cubeCards.add(new CardIdentity("Warped Landscape", ""));
|
cubeCards.add(new CardIdentity("Warped Landscape", ""));
|
||||||
cubeCards.add(new CardIdentity("Warren Pilferers", ""));
|
cubeCards.add(new CardIdentity("Warren Pilferers", ""));
|
||||||
cubeCards.add(new CardIdentity("Wasteland Scorpion", ""));
|
cubeCards.add(new CardIdentity("Wasteland Scorpion", ""));
|
||||||
|
cubeCards.add(new CardIdentity("Waterknot", ""));
|
||||||
cubeCards.add(new CardIdentity("Wayfarer's Bauble", ""));
|
cubeCards.add(new CardIdentity("Wayfarer's Bauble", ""));
|
||||||
cubeCards.add(new CardIdentity("Werebear", ""));
|
cubeCards.add(new CardIdentity("Werebear", ""));
|
||||||
cubeCards.add(new CardIdentity("Whitemane Lion", ""));
|
cubeCards.add(new CardIdentity("Whitemane Lion", ""));
|
||||||
|
@ -436,13 +436,13 @@ public class AdamStyborskisPauperCube extends DraftCube {
|
||||||
cubeCards.add(new CardIdentity("Wildsize", ""));
|
cubeCards.add(new CardIdentity("Wildsize", ""));
|
||||||
cubeCards.add(new CardIdentity("Will-Forged Golem", ""));
|
cubeCards.add(new CardIdentity("Will-Forged Golem", ""));
|
||||||
cubeCards.add(new CardIdentity("Wind-Scarred Crag", ""));
|
cubeCards.add(new CardIdentity("Wind-Scarred Crag", ""));
|
||||||
cubeCards.add(new CardIdentity("Winds of Rebuke", ""));
|
|
||||||
cubeCards.add(new CardIdentity("Winged Coatl", ""));
|
cubeCards.add(new CardIdentity("Winged Coatl", ""));
|
||||||
cubeCards.add(new CardIdentity("Wojek Halberdiers", ""));
|
cubeCards.add(new CardIdentity("Wojek Halberdiers", ""));
|
||||||
cubeCards.add(new CardIdentity("Woodland Stream", ""));
|
cubeCards.add(new CardIdentity("Woodland Stream", ""));
|
||||||
cubeCards.add(new CardIdentity("Wrecking Ball", ""));
|
cubeCards.add(new CardIdentity("Wrecking Ball", ""));
|
||||||
cubeCards.add(new CardIdentity("Wretched Gryff", ""));
|
cubeCards.add(new CardIdentity("Wretched Gryff", ""));
|
||||||
cubeCards.add(new CardIdentity("Yavimaya Elder", ""));
|
cubeCards.add(new CardIdentity("Yavimaya Elder", ""));
|
||||||
|
cubeCards.add(new CardIdentity("Yavimaya Sapherd", ""));
|
||||||
cubeCards.add(new CardIdentity("Yotian Soldier", ""));
|
cubeCards.add(new CardIdentity("Yotian Soldier", ""));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.mage</groupId>
|
<groupId>org.mage</groupId>
|
||||||
<artifactId>mage-server-plugins</artifactId>
|
<artifactId>mage-server-plugins</artifactId>
|
||||||
<version>1.4.29</version>
|
<version>1.4.30</version>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<artifactId>mage-tournament-constructed</artifactId>
|
<artifactId>mage-tournament-constructed</artifactId>
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.mage</groupId>
|
<groupId>org.mage</groupId>
|
||||||
<artifactId>mage-server-plugins</artifactId>
|
<artifactId>mage-server-plugins</artifactId>
|
||||||
<version>1.4.29</version>
|
<version>1.4.30</version>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<artifactId>mage-tournament-sealed</artifactId>
|
<artifactId>mage-tournament-sealed</artifactId>
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.mage</groupId>
|
<groupId>org.mage</groupId>
|
||||||
<artifactId>mage-root</artifactId>
|
<artifactId>mage-root</artifactId>
|
||||||
<version>1.4.29</version>
|
<version>1.4.30</version>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<artifactId>mage-server-plugins</artifactId>
|
<artifactId>mage-server-plugins</artifactId>
|
||||||
|
|
|
@ -149,14 +149,13 @@
|
||||||
<deckType name="Constructed - Pauper" jar="mage-deck-constructed.jar" className="mage.deck.Pauper"/>
|
<deckType name="Constructed - Pauper" jar="mage-deck-constructed.jar" className="mage.deck.Pauper"/>
|
||||||
<deckType name="Constructed - Historical Type 2" jar="mage-deck-constructed.jar" className="mage.deck.HistoricalType2"/>
|
<deckType name="Constructed - Historical Type 2" jar="mage-deck-constructed.jar" className="mage.deck.HistoricalType2"/>
|
||||||
<deckType name="Constructed - Super Type 2" jar="mage-deck-constructed.jar" className="mage.deck.SuperType2"/>
|
<deckType name="Constructed - Super Type 2" jar="mage-deck-constructed.jar" className="mage.deck.SuperType2"/>
|
||||||
<deckType name="Constructed - Freeform" jar="mage-deck-constructed.jar" className="mage.deck.Freeform"/>
|
|
||||||
<deckType name="Constructed - Old School 93/94" jar="mage-deck-constructed.jar" className="mage.deck.OldSchool9394"/>
|
|
||||||
<deckType name="Constructed - Old School 93/94 - Italian Rules" jar="mage-deck-constructed.jar" className="mage.deck.OldSchool9394Italian"/>
|
|
||||||
<deckType name="Constructed - Old School 93/94 - Channel Fireball Rules" jar="mage-deck-constructed.jar" className="mage.deck.OldSchool9394CFB"/>
|
|
||||||
<deckType name="Constructed - Old School 93/94 - EudoGames Rules" jar="mage-deck-constructed.jar" className="mage.deck.OldSchool9394EG"/>
|
|
||||||
<deckType name="Constructed - Old School 93/94 - EC Rules" jar="mage-deck-constructed.jar" className="mage.deck.OldSchool9394EC"/>
|
|
||||||
<deckType name="Constructed - Australian Highlander" jar="mage-deck-constructed.jar" className="mage.deck.AusHighlander"/>
|
<deckType name="Constructed - Australian Highlander" jar="mage-deck-constructed.jar" className="mage.deck.AusHighlander"/>
|
||||||
<deckType name="Constructed - Canadian Highlander" jar="mage-deck-constructed.jar" className="mage.deck.CanadianHighlander"/>
|
<deckType name="Constructed - Canadian Highlander" jar="mage-deck-constructed.jar" className="mage.deck.CanadianHighlander"/>
|
||||||
|
<deckType name="Constructed - Old School 93/94" jar="mage-deck-constructed.jar" className="mage.deck.OldSchool9394"/>
|
||||||
|
<deckType name="Constructed - Old School 93/94 - Italian Rules" jar="mage-deck-constructed.jar" className="mage.deck.OldSchool9394Italian"/>
|
||||||
|
<deckType name="Constructed - Old School 93/94 - Channel Fireball Rules" jar="mage-deck-constructed.jar" className="mage.deck.OldSchool9394CFB"/>
|
||||||
|
<deckType name="Constructed - Old School 93/94 - EudoGames Rules" jar="mage-deck-constructed.jar" className="mage.deck.OldSchool9394EG"/>
|
||||||
|
<deckType name="Constructed - Old School 93/94 - EC Rules" jar="mage-deck-constructed.jar" className="mage.deck.OldSchool9394EC"/>
|
||||||
<deckType name="Constructed - Freeform" jar="mage-deck-constructed.jar" className="mage.deck.Freeform"/>
|
<deckType name="Constructed - Freeform" jar="mage-deck-constructed.jar" className="mage.deck.Freeform"/>
|
||||||
<deckType name="Variant Magic - Commander" jar="mage-deck-constructed.jar" className="mage.deck.Commander"/>
|
<deckType name="Variant Magic - Commander" jar="mage-deck-constructed.jar" className="mage.deck.Commander"/>
|
||||||
<deckType name="Variant Magic - Duel Commander" jar="mage-deck-constructed.jar" className="mage.deck.DuelCommander"/>
|
<deckType name="Variant Magic - Duel Commander" jar="mage-deck-constructed.jar" className="mage.deck.DuelCommander"/>
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.mage</groupId>
|
<groupId>org.mage</groupId>
|
||||||
<artifactId>mage-root</artifactId>
|
<artifactId>mage-root</artifactId>
|
||||||
<version>1.4.29</version>
|
<version>1.4.30</version>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<artifactId>mage-server</artifactId>
|
<artifactId>mage-server</artifactId>
|
||||||
|
|
|
@ -142,10 +142,13 @@
|
||||||
<deckType name="Constructed - Pauper" jar="mage-deck-constructed-${project.version}.jar" className="mage.deck.Pauper"/>
|
<deckType name="Constructed - Pauper" jar="mage-deck-constructed-${project.version}.jar" className="mage.deck.Pauper"/>
|
||||||
<deckType name="Constructed - Historical Type 2" jar="mage-deck-constructed-${project.version}.jar" className="mage.deck.HistoricalType2"/>
|
<deckType name="Constructed - Historical Type 2" jar="mage-deck-constructed-${project.version}.jar" className="mage.deck.HistoricalType2"/>
|
||||||
<deckType name="Constructed - Super Type 2" jar="mage-deck-constructed-${project.version}.jar" className="mage.deck.SuperType2"/>
|
<deckType name="Constructed - Super Type 2" jar="mage-deck-constructed-${project.version}.jar" className="mage.deck.SuperType2"/>
|
||||||
<deckType name="Constructed - Freeform" jar="mage-deck-constructed-${project.version}.jar" className="mage.deck.Freeform"/>
|
|
||||||
<deckType name="Constructed - Old School 93/94" jar="mage-deck-constructed-${project.version}.jar" className="mage.deck.OldSchool9394"/>
|
|
||||||
<deckType name="Constructed - Australian Highlander" jar="mage-deck-constructed-${project.version}.jar" className="mage.deck.AusHighlander"/>
|
<deckType name="Constructed - Australian Highlander" jar="mage-deck-constructed-${project.version}.jar" className="mage.deck.AusHighlander"/>
|
||||||
<deckType name="Constructed - Canadian Highlander" jar="mage-deck-constructed-${project.version}.jar" className="mage.deck.CanadianHighlander"/>
|
<deckType name="Constructed - Canadian Highlander" jar="mage-deck-constructed-${project.version}.jar" className="mage.deck.CanadianHighlander"/>
|
||||||
|
<deckType name="Constructed - Old School 93/94" jar="mage-deck-constructed-${project.version}.jar" className="mage.deck.OldSchool9394"/>
|
||||||
|
<deckType name="Constructed - Old School 93/94 - Italian Rules" jar="mage-deck-constructed-${project.version}.jar" className="mage.deck.OldSchool9394Italian"/>
|
||||||
|
<deckType name="Constructed - Old School 93/94 - Channel Fireball Rules" jar="mage-deck-constructed-${project.version}.jar" className="mage.deck.OldSchool9394CFB"/>
|
||||||
|
<deckType name="Constructed - Old School 93/94 - EudoGames Rules" jar="mage-deck-constructed-${project.version}.jar" className="mage.deck.OldSchool9394EG"/>
|
||||||
|
<deckType name="Constructed - Old School 93/94 - EC Rules" jar="mage-deck-constructed-${project.version}.jar" className="mage.deck.OldSchool9394EC"/>
|
||||||
<deckType name="Constructed - Freeform" jar="mage-deck-constructed-${project.version}.jar" className="mage.deck.Freeform"/>
|
<deckType name="Constructed - Freeform" jar="mage-deck-constructed-${project.version}.jar" className="mage.deck.Freeform"/>
|
||||||
<deckType name="Variant Magic - Commander" jar="mage-deck-constructed-${project.version}.jar" className="mage.deck.Commander"/>
|
<deckType name="Variant Magic - Commander" jar="mage-deck-constructed-${project.version}.jar" className="mage.deck.Commander"/>
|
||||||
<deckType name="Variant Magic - Duel Commander" jar="mage-deck-constructed-${project.version}.jar" className="mage.deck.DuelCommander"/>
|
<deckType name="Variant Magic - Duel Commander" jar="mage-deck-constructed-${project.version}.jar" className="mage.deck.DuelCommander"/>
|
||||||
|
|
|
@ -486,7 +486,11 @@ public class TableController {
|
||||||
if (userPlayerMap.get(userId) != null) {
|
if (userPlayerMap.get(userId) != null) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return UserManager.instance.getUser(userId).get().ccWatchGame(match.getGame().getId());
|
Optional<User> _user = UserManager.instance.getUser(userId);
|
||||||
|
if (!_user.isPresent()) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return _user.get().ccWatchGame(match.getGame().getId());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.mage</groupId>
|
<groupId>org.mage</groupId>
|
||||||
<artifactId>mage-root</artifactId>
|
<artifactId>mage-root</artifactId>
|
||||||
<version>1.4.29</version>
|
<version>1.4.30</version>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<groupId>org.mage</groupId>
|
<groupId>org.mage</groupId>
|
||||||
|
|
|
@ -51,7 +51,7 @@ import mage.target.TargetPlayer;
|
||||||
*
|
*
|
||||||
* @author Styxo
|
* @author Styxo
|
||||||
*/
|
*/
|
||||||
public class AAT1 extends CardImpl {
|
public final class AAT1 extends CardImpl {
|
||||||
|
|
||||||
public AAT1(UUID ownerId, CardSetInfo setInfo) {
|
public AAT1(UUID ownerId, CardSetInfo setInfo) {
|
||||||
super(ownerId, setInfo, new CardType[]{CardType.ARTIFACT, CardType.CREATURE}, "{1}{W}{U}{B}");
|
super(ownerId, setInfo, new CardType[]{CardType.ARTIFACT, CardType.CREATURE}, "{1}{W}{U}{B}");
|
||||||
|
|
|
@ -44,7 +44,7 @@ import mage.filter.predicate.mageobject.SubtypePredicate;
|
||||||
*
|
*
|
||||||
* @author Styxo
|
* @author Styxo
|
||||||
*/
|
*/
|
||||||
public class ATST extends CardImpl {
|
public final class ATST extends CardImpl {
|
||||||
|
|
||||||
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("Trooper creatures");
|
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("Trooper creatures");
|
||||||
|
|
||||||
|
|
|
@ -49,7 +49,7 @@ import mage.game.permanent.Permanent;
|
||||||
*
|
*
|
||||||
* @author Styxo
|
* @author Styxo
|
||||||
*/
|
*/
|
||||||
public class AWing extends CardImpl {
|
public final class AWing extends CardImpl {
|
||||||
|
|
||||||
public AWing(UUID ownerId, CardSetInfo setInfo) {
|
public AWing(UUID ownerId, CardSetInfo setInfo) {
|
||||||
super(ownerId,setInfo,new CardType[]{CardType.ARTIFACT,CardType.CREATURE},"{2}{R}");
|
super(ownerId,setInfo,new CardType[]{CardType.ARTIFACT,CardType.CREATURE},"{2}{R}");
|
||||||
|
|
|
@ -49,7 +49,7 @@ import mage.target.common.TargetCardInHand;
|
||||||
*
|
*
|
||||||
* @author fireshoes
|
* @author fireshoes
|
||||||
*/
|
*/
|
||||||
public class AbandonHope extends CardImpl {
|
public final class AbandonHope extends CardImpl {
|
||||||
|
|
||||||
public AbandonHope(UUID ownerId, CardSetInfo setInfo) {
|
public AbandonHope(UUID ownerId, CardSetInfo setInfo) {
|
||||||
super(ownerId, setInfo, new CardType[]{CardType.SORCERY}, "{X}{1}{B}");
|
super(ownerId, setInfo, new CardType[]{CardType.SORCERY}, "{X}{1}{B}");
|
||||||
|
|
|
@ -44,7 +44,7 @@ import mage.target.common.TargetCreaturePermanent;
|
||||||
*
|
*
|
||||||
* @author LevelX2
|
* @author LevelX2
|
||||||
*/
|
*/
|
||||||
public class AbandonReason extends CardImpl {
|
public final class AbandonReason extends CardImpl {
|
||||||
|
|
||||||
public AbandonReason(UUID ownerId, CardSetInfo setInfo) {
|
public AbandonReason(UUID ownerId, CardSetInfo setInfo) {
|
||||||
super(ownerId,setInfo,new CardType[]{CardType.INSTANT},"{2}{R}");
|
super(ownerId,setInfo,new CardType[]{CardType.INSTANT},"{2}{R}");
|
||||||
|
|
|
@ -43,7 +43,7 @@ import mage.constants.CardType;
|
||||||
* @author cbt33
|
* @author cbt33
|
||||||
*/
|
*/
|
||||||
|
|
||||||
public class AbandonedOutpost extends CardImpl {
|
public final class AbandonedOutpost extends CardImpl {
|
||||||
|
|
||||||
public AbandonedOutpost(UUID ownerId, CardSetInfo setInfo){
|
public AbandonedOutpost(UUID ownerId, CardSetInfo setInfo){
|
||||||
super(ownerId,setInfo,new CardType[]{CardType.LAND},"");
|
super(ownerId,setInfo,new CardType[]{CardType.LAND},"");
|
||||||
|
|
|
@ -62,7 +62,7 @@ import mage.watchers.Watcher;
|
||||||
*
|
*
|
||||||
* @author jeffwadsworth
|
* @author jeffwadsworth
|
||||||
*/
|
*/
|
||||||
public class AbandonedSarcophagus extends CardImpl {
|
public final class AbandonedSarcophagus extends CardImpl {
|
||||||
|
|
||||||
public AbandonedSarcophagus(UUID ownerId, CardSetInfo setInfo) {
|
public AbandonedSarcophagus(UUID ownerId, CardSetInfo setInfo) {
|
||||||
super(ownerId, setInfo, new CardType[]{CardType.ARTIFACT}, "{3}");
|
super(ownerId, setInfo, new CardType[]{CardType.ARTIFACT}, "{3}");
|
||||||
|
|
|
@ -48,7 +48,7 @@ import mage.players.Player;
|
||||||
*
|
*
|
||||||
* @author Alvin
|
* @author Alvin
|
||||||
*/
|
*/
|
||||||
public class AbattoirGhoul extends CardImpl {
|
public final class AbattoirGhoul extends CardImpl {
|
||||||
|
|
||||||
public AbattoirGhoul(UUID ownerId, CardSetInfo setInfo) {
|
public AbattoirGhoul(UUID ownerId, CardSetInfo setInfo) {
|
||||||
super(ownerId,setInfo,new CardType[]{CardType.CREATURE},"{3}{B}");
|
super(ownerId,setInfo,new CardType[]{CardType.CREATURE},"{3}{B}");
|
||||||
|
|
|
@ -41,7 +41,7 @@ import mage.constants.SubType;
|
||||||
*
|
*
|
||||||
* @author Sir-Speshkitty
|
* @author Sir-Speshkitty
|
||||||
*/
|
*/
|
||||||
public class AbbeyGargoyles extends CardImpl {
|
public final class AbbeyGargoyles extends CardImpl {
|
||||||
|
|
||||||
public AbbeyGargoyles(UUID ownerId, CardSetInfo setInfo) {
|
public AbbeyGargoyles(UUID ownerId, CardSetInfo setInfo) {
|
||||||
super(ownerId,setInfo,new CardType[]{CardType.CREATURE},"{2}{W}{W}{W}");
|
super(ownerId,setInfo,new CardType[]{CardType.CREATURE},"{2}{W}{W}{W}");
|
||||||
|
|
|
@ -41,7 +41,7 @@ import mage.constants.SubType;
|
||||||
*
|
*
|
||||||
* @author BetaSteward_at_googlemail.com
|
* @author BetaSteward_at_googlemail.com
|
||||||
*/
|
*/
|
||||||
public class AbbeyGriffin extends CardImpl {
|
public final class AbbeyGriffin extends CardImpl {
|
||||||
|
|
||||||
public AbbeyGriffin(UUID ownerId, CardSetInfo setInfo) {
|
public AbbeyGriffin(UUID ownerId, CardSetInfo setInfo) {
|
||||||
super(ownerId,setInfo,new CardType[]{CardType.CREATURE},"{3}{W}");
|
super(ownerId,setInfo,new CardType[]{CardType.CREATURE},"{3}{W}");
|
||||||
|
|
|
@ -45,7 +45,7 @@ import mage.constants.Zone;
|
||||||
*
|
*
|
||||||
* @author Sir-Speshkitty
|
* @author Sir-Speshkitty
|
||||||
*/
|
*/
|
||||||
public class AbbeyMatron extends CardImpl {
|
public final class AbbeyMatron extends CardImpl {
|
||||||
|
|
||||||
public AbbeyMatron(UUID ownerId, CardSetInfo setInfo) {
|
public AbbeyMatron(UUID ownerId, CardSetInfo setInfo) {
|
||||||
super(ownerId,setInfo,new CardType[]{CardType.CREATURE},"{2}{W}");
|
super(ownerId,setInfo,new CardType[]{CardType.CREATURE},"{2}{W}");
|
||||||
|
|
|
@ -49,7 +49,7 @@ import mage.target.targetpointer.FixedTarget;
|
||||||
*
|
*
|
||||||
* @author fireshoes
|
* @author fireshoes
|
||||||
*/
|
*/
|
||||||
public class AbbotOfKeralKeep extends CardImpl {
|
public final class AbbotOfKeralKeep extends CardImpl {
|
||||||
|
|
||||||
public AbbotOfKeralKeep(UUID ownerId, CardSetInfo setInfo) {
|
public AbbotOfKeralKeep(UUID ownerId, CardSetInfo setInfo) {
|
||||||
super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{1}{R}");
|
super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{1}{R}");
|
||||||
|
|
|
@ -49,7 +49,7 @@ import mage.target.common.TargetCreaturePermanent;
|
||||||
*
|
*
|
||||||
* @author Quercitron
|
* @author Quercitron
|
||||||
*/
|
*/
|
||||||
public class Abduction extends CardImpl {
|
public final class Abduction extends CardImpl {
|
||||||
|
|
||||||
public Abduction(UUID ownerId, CardSetInfo setInfo) {
|
public Abduction(UUID ownerId, CardSetInfo setInfo) {
|
||||||
super(ownerId,setInfo,new CardType[]{CardType.ENCHANTMENT},"{2}{U}{U}");
|
super(ownerId,setInfo,new CardType[]{CardType.ENCHANTMENT},"{2}{U}{U}");
|
||||||
|
|
|
@ -47,7 +47,7 @@ import mage.players.Player;
|
||||||
*
|
*
|
||||||
* @author fireshoes
|
* @author fireshoes
|
||||||
*/
|
*/
|
||||||
public class AberrantResearcher extends CardImpl {
|
public final class AberrantResearcher extends CardImpl {
|
||||||
|
|
||||||
public AberrantResearcher(UUID ownerId, CardSetInfo setInfo) {
|
public AberrantResearcher(UUID ownerId, CardSetInfo setInfo) {
|
||||||
super(ownerId,setInfo,new CardType[]{CardType.CREATURE},"{3}{U}");
|
super(ownerId,setInfo,new CardType[]{CardType.CREATURE},"{3}{U}");
|
||||||
|
|
|
@ -47,7 +47,7 @@ import mage.target.TargetPlayer;
|
||||||
*
|
*
|
||||||
* @author fireshoes
|
* @author fireshoes
|
||||||
*/
|
*/
|
||||||
public class Abeyance extends CardImpl {
|
public final class Abeyance extends CardImpl {
|
||||||
|
|
||||||
public Abeyance(UUID ownerId, CardSetInfo setInfo) {
|
public Abeyance(UUID ownerId, CardSetInfo setInfo) {
|
||||||
super(ownerId, setInfo, new CardType[]{CardType.INSTANT}, "{1}{W}");
|
super(ownerId, setInfo, new CardType[]{CardType.INSTANT}, "{1}{W}");
|
||||||
|
|
|
@ -50,7 +50,7 @@ import mage.game.permanent.token.Token;
|
||||||
*
|
*
|
||||||
* @author LevelX2
|
* @author LevelX2
|
||||||
*/
|
*/
|
||||||
public class AbhorrentOverlord extends CardImpl {
|
public final class AbhorrentOverlord extends CardImpl {
|
||||||
|
|
||||||
public AbhorrentOverlord(UUID ownerId, CardSetInfo setInfo) {
|
public AbhorrentOverlord(UUID ownerId, CardSetInfo setInfo) {
|
||||||
super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{5}{B}{B}");
|
super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{5}{B}{B}");
|
||||||
|
|
|
@ -43,7 +43,7 @@ import mage.target.common.TargetControlledPermanent;
|
||||||
*
|
*
|
||||||
* @author djbrez
|
* @author djbrez
|
||||||
*/
|
*/
|
||||||
public class Abjure extends CardImpl {
|
public final class Abjure extends CardImpl {
|
||||||
|
|
||||||
private static final FilterControlledPermanent filter = new FilterControlledPermanent("a blue permanent");
|
private static final FilterControlledPermanent filter = new FilterControlledPermanent("a blue permanent");
|
||||||
|
|
||||||
|
|
|
@ -46,7 +46,7 @@ import java.util.UUID;
|
||||||
*
|
*
|
||||||
* @author Backfir3
|
* @author Backfir3
|
||||||
*/
|
*/
|
||||||
public class Abolish extends CardImpl {
|
public final class Abolish extends CardImpl {
|
||||||
|
|
||||||
private static final FilterCard filterCost = new FilterCard("Plains card");
|
private static final FilterCard filterCost = new FilterCard("Plains card");
|
||||||
|
|
||||||
|
|
|
@ -49,7 +49,7 @@ import mage.target.common.TargetOpponent;
|
||||||
*
|
*
|
||||||
* @author fireshoes
|
* @author fireshoes
|
||||||
*/
|
*/
|
||||||
public class AbolisherOfBloodlines extends CardImpl {
|
public final class AbolisherOfBloodlines extends CardImpl {
|
||||||
|
|
||||||
public AbolisherOfBloodlines(UUID ownerId, CardSetInfo setInfo) {
|
public AbolisherOfBloodlines(UUID ownerId, CardSetInfo setInfo) {
|
||||||
super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "");
|
super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "");
|
||||||
|
|
|
@ -47,7 +47,7 @@ import mage.filter.predicate.mageobject.ColorPredicate;
|
||||||
*
|
*
|
||||||
* @author jeffwadsworth
|
* @author jeffwadsworth
|
||||||
*/
|
*/
|
||||||
public class Abomination extends CardImpl {
|
public final class Abomination extends CardImpl {
|
||||||
|
|
||||||
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("green or white creature");
|
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("green or white creature");
|
||||||
|
|
||||||
|
|
|
@ -44,7 +44,7 @@ import mage.constants.SubType;
|
||||||
*
|
*
|
||||||
* @author LevelX2
|
* @author LevelX2
|
||||||
*/
|
*/
|
||||||
public class AbominationOfGudul extends CardImpl {
|
public final class AbominationOfGudul extends CardImpl {
|
||||||
|
|
||||||
public AbominationOfGudul(UUID ownerId, CardSetInfo setInfo) {
|
public AbominationOfGudul(UUID ownerId, CardSetInfo setInfo) {
|
||||||
super(ownerId,setInfo,new CardType[]{CardType.CREATURE},"{3}{B}{G}{U}");
|
super(ownerId,setInfo,new CardType[]{CardType.CREATURE},"{3}{B}{G}{U}");
|
||||||
|
|
|
@ -45,7 +45,7 @@ import mage.game.permanent.Permanent;
|
||||||
*
|
*
|
||||||
* @author Styxo
|
* @author Styxo
|
||||||
*/
|
*/
|
||||||
public class Aboroth extends CardImpl {
|
public final class Aboroth extends CardImpl {
|
||||||
|
|
||||||
public Aboroth(UUID ownerId, CardSetInfo setInfo) {
|
public Aboroth(UUID ownerId, CardSetInfo setInfo) {
|
||||||
super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{4}{G}{G}");
|
super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{4}{G}{G}");
|
||||||
|
|
|
@ -54,7 +54,7 @@ import mage.target.common.TargetControlledCreaturePermanent;
|
||||||
*
|
*
|
||||||
* @author cbt33
|
* @author cbt33
|
||||||
*/
|
*/
|
||||||
public class AboshanCephalidEmperor extends CardImpl {
|
public final class AboshanCephalidEmperor extends CardImpl {
|
||||||
|
|
||||||
static final FilterControlledCreaturePermanent filter1 = new FilterControlledCreaturePermanent("untapped Cephalid you control");
|
static final FilterControlledCreaturePermanent filter1 = new FilterControlledCreaturePermanent("untapped Cephalid you control");
|
||||||
static final FilterCreaturePermanent filter2 = new FilterCreaturePermanent("creatures without flying");
|
static final FilterCreaturePermanent filter2 = new FilterCreaturePermanent("creatures without flying");
|
||||||
|
|
|
@ -47,7 +47,7 @@ import mage.target.common.TargetCreaturePermanent;
|
||||||
*
|
*
|
||||||
* @author cbt33
|
* @author cbt33
|
||||||
*/
|
*/
|
||||||
public class AboshansDesire extends CardImpl {
|
public final class AboshansDesire extends CardImpl {
|
||||||
|
|
||||||
public AboshansDesire(UUID ownerId, CardSetInfo setInfo) {
|
public AboshansDesire(UUID ownerId, CardSetInfo setInfo) {
|
||||||
super(ownerId,setInfo,new CardType[]{CardType.ENCHANTMENT},"{U}");
|
super(ownerId,setInfo,new CardType[]{CardType.ENCHANTMENT},"{U}");
|
||||||
|
|
|
@ -39,7 +39,7 @@ import mage.target.common.TargetCreaturePermanent;
|
||||||
*
|
*
|
||||||
* @author Backfir3
|
* @author Backfir3
|
||||||
*/
|
*/
|
||||||
public class AboutFace extends CardImpl {
|
public final class AboutFace extends CardImpl {
|
||||||
|
|
||||||
public AboutFace(UUID ownerId, CardSetInfo setInfo) {
|
public AboutFace(UUID ownerId, CardSetInfo setInfo) {
|
||||||
super(ownerId,setInfo,new CardType[]{CardType.INSTANT},"{R}");
|
super(ownerId,setInfo,new CardType[]{CardType.INSTANT},"{R}");
|
||||||
|
|
|
@ -41,7 +41,7 @@ import mage.target.common.TargetCreaturePermanent;
|
||||||
*
|
*
|
||||||
* @author fireshoes
|
* @author fireshoes
|
||||||
*/
|
*/
|
||||||
public class Abrade extends CardImpl {
|
public final class Abrade extends CardImpl {
|
||||||
|
|
||||||
public Abrade(UUID ownerId, CardSetInfo setInfo) {
|
public Abrade(UUID ownerId, CardSetInfo setInfo) {
|
||||||
super(ownerId, setInfo, new CardType[]{CardType.INSTANT}, "{1}{R}");
|
super(ownerId, setInfo, new CardType[]{CardType.INSTANT}, "{1}{R}");
|
||||||
|
|
|
@ -46,7 +46,7 @@ import mage.target.common.TargetNonlandPermanent;
|
||||||
*
|
*
|
||||||
* @author LevelX2
|
* @author LevelX2
|
||||||
*/
|
*/
|
||||||
public class AbruptDecay extends CardImpl {
|
public final class AbruptDecay extends CardImpl {
|
||||||
|
|
||||||
private static final FilterNonlandPermanent filter = new FilterNonlandPermanent("nonland permanent with converted mana cost 3 or less");
|
private static final FilterNonlandPermanent filter = new FilterNonlandPermanent("nonland permanent with converted mana cost 3 or less");
|
||||||
|
|
||||||
|
|
|
@ -44,7 +44,7 @@ import static mage.filter.StaticFilters.FILTER_PERMANENT_CREATURES;
|
||||||
*
|
*
|
||||||
* @author Backfir3
|
* @author Backfir3
|
||||||
*/
|
*/
|
||||||
public class AbsoluteGrace extends CardImpl {
|
public final class AbsoluteGrace extends CardImpl {
|
||||||
|
|
||||||
public AbsoluteGrace(UUID ownerId, CardSetInfo setInfo) {
|
public AbsoluteGrace(UUID ownerId, CardSetInfo setInfo) {
|
||||||
super(ownerId, setInfo, new CardType[]{CardType.ENCHANTMENT}, "{1}{W}");
|
super(ownerId, setInfo, new CardType[]{CardType.ENCHANTMENT}, "{1}{W}");
|
||||||
|
|
|
@ -44,7 +44,7 @@ import static mage.filter.StaticFilters.FILTER_PERMANENT_CREATURES;
|
||||||
*
|
*
|
||||||
* @author Backfir3
|
* @author Backfir3
|
||||||
*/
|
*/
|
||||||
public class AbsoluteLaw extends CardImpl {
|
public final class AbsoluteLaw extends CardImpl {
|
||||||
|
|
||||||
public AbsoluteLaw(UUID ownerId, CardSetInfo setInfo) {
|
public AbsoluteLaw(UUID ownerId, CardSetInfo setInfo) {
|
||||||
super(ownerId, setInfo, new CardType[]{CardType.ENCHANTMENT}, "{1}{W}");
|
super(ownerId, setInfo, new CardType[]{CardType.ENCHANTMENT}, "{1}{W}");
|
||||||
|
|
|
@ -42,7 +42,7 @@ import mage.target.common.TargetEnchantmentPermanent;
|
||||||
*
|
*
|
||||||
* @author LevelX2
|
* @author LevelX2
|
||||||
*/
|
*/
|
||||||
public class AbsolverThrull extends CardImpl {
|
public final class AbsolverThrull extends CardImpl {
|
||||||
|
|
||||||
public AbsolverThrull(UUID ownerId, CardSetInfo setInfo) {
|
public AbsolverThrull(UUID ownerId, CardSetInfo setInfo) {
|
||||||
super(ownerId,setInfo,new CardType[]{CardType.CREATURE},"{3}{W}");
|
super(ownerId,setInfo,new CardType[]{CardType.CREATURE},"{3}{W}");
|
||||||
|
|
|
@ -39,7 +39,7 @@ import mage.target.TargetSpell;
|
||||||
*
|
*
|
||||||
* @author Loki
|
* @author Loki
|
||||||
*/
|
*/
|
||||||
public class Absorb extends CardImpl {
|
public final class Absorb extends CardImpl {
|
||||||
|
|
||||||
public Absorb(UUID ownerId, CardSetInfo setInfo) {
|
public Absorb(UUID ownerId, CardSetInfo setInfo) {
|
||||||
super(ownerId,setInfo,new CardType[]{CardType.INSTANT},"{W}{U}{U}");
|
super(ownerId,setInfo,new CardType[]{CardType.INSTANT},"{W}{U}{U}");
|
||||||
|
|
|
@ -42,7 +42,7 @@ import mage.target.TargetPlayer;
|
||||||
*
|
*
|
||||||
* @author Loki
|
* @author Loki
|
||||||
*/
|
*/
|
||||||
public class AbsorbVis extends CardImpl {
|
public final class AbsorbVis extends CardImpl {
|
||||||
|
|
||||||
public AbsorbVis (UUID ownerId, CardSetInfo setInfo) {
|
public AbsorbVis (UUID ownerId, CardSetInfo setInfo) {
|
||||||
super(ownerId,setInfo,new CardType[]{CardType.SORCERY},"{6}{B}");
|
super(ownerId,setInfo,new CardType[]{CardType.SORCERY},"{6}{B}");
|
||||||
|
|
|
@ -43,7 +43,7 @@ import mage.target.TargetSpell;
|
||||||
*
|
*
|
||||||
* @author fireshoes
|
* @author fireshoes
|
||||||
*/
|
*/
|
||||||
public class AbstruseInterference extends CardImpl {
|
public final class AbstruseInterference extends CardImpl {
|
||||||
|
|
||||||
public AbstruseInterference(UUID ownerId, CardSetInfo setInfo) {
|
public AbstruseInterference(UUID ownerId, CardSetInfo setInfo) {
|
||||||
super(ownerId, setInfo, new CardType[]{CardType.INSTANT}, "{2}{U}");
|
super(ownerId, setInfo, new CardType[]{CardType.INSTANT}, "{2}{U}");
|
||||||
|
|
|
@ -44,7 +44,7 @@ import mage.filter.predicate.permanent.BlockingAttackerIdPredicate;
|
||||||
*
|
*
|
||||||
* @author MarcoMarin
|
* @author MarcoMarin
|
||||||
*/
|
*/
|
||||||
public class AbuJafar extends CardImpl {
|
public final class AbuJafar extends CardImpl {
|
||||||
|
|
||||||
public AbuJafar(UUID ownerId, CardSetInfo setInfo) {
|
public AbuJafar(UUID ownerId, CardSetInfo setInfo) {
|
||||||
super(ownerId,setInfo,new CardType[]{CardType.CREATURE},"{W}");
|
super(ownerId,setInfo,new CardType[]{CardType.CREATURE},"{W}");
|
||||||
|
|
|
@ -48,7 +48,7 @@ import mage.target.common.TargetCreaturePermanent;
|
||||||
*
|
*
|
||||||
* @author Martin Sagastume msr986@gmail.com
|
* @author Martin Sagastume msr986@gmail.com
|
||||||
*/
|
*/
|
||||||
public class AbunaAcolyte extends CardImpl {
|
public final class AbunaAcolyte extends CardImpl {
|
||||||
|
|
||||||
final static FilterCreaturePermanent filter = new FilterCreaturePermanent("artifact creature");
|
final static FilterCreaturePermanent filter = new FilterCreaturePermanent("artifact creature");
|
||||||
|
|
||||||
|
|
|
@ -42,7 +42,7 @@ import mage.target.common.TargetCreaturePermanent;
|
||||||
*
|
*
|
||||||
* @author Plopman
|
* @author Plopman
|
||||||
*/
|
*/
|
||||||
public class AbunasChant extends CardImpl {
|
public final class AbunasChant extends CardImpl {
|
||||||
|
|
||||||
public AbunasChant(UUID ownerId, CardSetInfo setInfo) {
|
public AbunasChant(UUID ownerId, CardSetInfo setInfo) {
|
||||||
super(ownerId,setInfo,new CardType[]{CardType.INSTANT},"{3}{W}");
|
super(ownerId,setInfo,new CardType[]{CardType.INSTANT},"{3}{W}");
|
||||||
|
|
|
@ -48,7 +48,7 @@ import mage.players.Player;
|
||||||
*
|
*
|
||||||
* @author emerald000
|
* @author emerald000
|
||||||
*/
|
*/
|
||||||
public class Abundance extends CardImpl {
|
public final class Abundance extends CardImpl {
|
||||||
|
|
||||||
public Abundance(UUID ownerId, CardSetInfo setInfo) {
|
public Abundance(UUID ownerId, CardSetInfo setInfo) {
|
||||||
super(ownerId, setInfo, new CardType[]{CardType.ENCHANTMENT}, "{2}{G}{G}");
|
super(ownerId, setInfo, new CardType[]{CardType.ENCHANTMENT}, "{2}{G}{G}");
|
||||||
|
|
Some files were not shown because too many files have changed in this diff Show more
Loading…
Reference in a new issue