diff --git a/Mage.Client/src/main/java/mage/client/cards/CardsList.java b/Mage.Client/src/main/java/mage/client/cards/CardsList.java
index c930ec76c3..ba565a752d 100644
--- a/Mage.Client/src/main/java/mage/client/cards/CardsList.java
+++ b/Mage.Client/src/main/java/mage/client/cards/CardsList.java
@@ -34,8 +34,21 @@
 
 package mage.client.cards;
 
-import java.awt.Dimension;
-import java.awt.Rectangle;
+import mage.Constants.CardType;
+import mage.cards.MageCard;
+import mage.client.constants.Constants;
+import mage.client.constants.Constants.SortBy;
+import mage.client.deckeditor.table.TableModel;
+import mage.client.plugins.impl.Plugins;
+import mage.client.util.*;
+import mage.client.util.Event;
+import mage.view.CardView;
+import mage.view.CardsView;
+
+import javax.swing.*;
+import javax.swing.table.DefaultTableCellRenderer;
+import java.awt.*;
+import java.awt.event.MouseAdapter;
 import java.awt.event.MouseEvent;
 import java.awt.event.MouseListener;
 import java.beans.Beans;
@@ -43,27 +56,12 @@ import java.util.ArrayList;
 import java.util.Collections;
 import java.util.List;
 import java.util.UUID;
-import javax.swing.DefaultComboBoxModel;
-import mage.Constants.CardType;
-
-import mage.cards.MageCard;
-import mage.client.constants.Constants.SortBy;
-import mage.client.plugins.impl.Plugins;
-import mage.client.util.CardViewColorComparator;
-import mage.client.util.CardViewCostComparator;
-import mage.client.util.CardViewNameComparator;
-import mage.client.util.CardViewRarityComparator;
-import mage.client.util.Config;
-import mage.client.util.Event;
-import mage.client.util.Listener;
-import mage.view.CardView;
-import mage.view.CardsView;
 
 /**
  *
  * @author BetaSteward_at_googlemail.com
  */
-public class CardsList extends javax.swing.JPanel implements MouseListener {
+public class CardsList extends javax.swing.JPanel implements MouseListener, ICardGrid {
 
 	protected CardEventSource cardEventSource = new CardEventSource();
     private Dimension cardDimension;
@@ -71,24 +69,82 @@ public class CardsList extends javax.swing.JPanel implements MouseListener {
 	protected BigCard bigCard;
 	protected UUID gameId;
 
+	private TableModel mainModel;
+	private JTable mainTable;
+	private ICardGrid currentView;
+
     /** Creates new form Cards */
     public CardsList() {
         initComponents();
-        jScrollPane1.setOpaque(false);
+        makeTransparent();
+		//initListViewComponents();
+		//currentView = mainModel; // by default we have List (table) view
+		currentView = this;
+    }
+
+	public void makeTransparent() {
+		jScrollPane1.setOpaque(false);
         cardArea.setOpaque(false);
         jScrollPane1.getViewport().setOpaque(false);
 		cbSortBy.setModel(new DefaultComboBoxModel(SortBy.values()));
+	}
+
+	public void initListViewComponents() {
+		mainTable = new JTable();
+
+		mainModel = new TableModel();
+		mainModel.addListeners(mainTable);
+
+        mainTable.setModel(mainModel);
+		mainTable.setForeground(Color.white);
+		DefaultTableCellRenderer myRenderer = (DefaultTableCellRenderer) mainTable.getDefaultRenderer(String.class);
+		myRenderer.setBackground(new Color(0, 0, 0, 100));
+		mainTable.getColumnModel().getColumn(0).setMaxWidth(0);
+		mainTable.getColumnModel().getColumn(0).setPreferredWidth(10);
+		mainTable.getColumnModel().getColumn(1).setPreferredWidth(110);
+		mainTable.getColumnModel().getColumn(2).setPreferredWidth(90);
+		mainTable.getColumnModel().getColumn(3).setPreferredWidth(50);
+		mainTable.getColumnModel().getColumn(4).setPreferredWidth(170);
+		mainTable.getColumnModel().getColumn(5).setPreferredWidth(30);
+		mainTable.getColumnModel().getColumn(6).setPreferredWidth(15);
+		mainTable.getColumnModel().getColumn(7).setPreferredWidth(15);
+
+		//jScrollPane1.setViewportView(mainTable);
+
+		mainTable.setOpaque(false);
+
+		//cbSortBy.setEnabled(false);
+	    //chkPiles.setEnabled(false);
+
+		mainTable.addMouseListener(new MouseAdapter() {
+			public void mousePressed(MouseEvent e) {
+				if (e.getClickCount() == 2 && !e.isConsumed()) {
+					e.consume();
+					if (mainTable.getSelectedRowCount() > 0) {
+						int[] n = mainTable.getSelectedRows();
+						List<Integer> indexes = asList(n);
+						Collections.reverse(indexes);
+						for (Integer index : indexes) {
+							mainModel.doubleClick(index);
+						}
+					}
+				}
+			}
+		});
+	}
+
+	public List<Integer> asList(final int[] is) {
+        List<Integer> list = new ArrayList<Integer>();
+		for (int i : is) list.add(i);
+		return list;
     }
 
 	public void loadCards(CardsView showCards, BigCard bigCard, UUID gameId) {
-		//FIXME: why we remove all cards? for performance it's better to merge changes
-		cards = showCards;
-		this.bigCard = bigCard;
-		this.gameId = gameId;
-		drawCards((SortBy) cbSortBy.getSelectedItem());
+		currentView.loadCards(showCards, null, false, bigCard, gameId);
+		//loadCards(showCards, null, false, bigCard, gameId);
 	}
 
-	private void drawCards(SortBy sortBy) {
+	public void drawCards(SortBy sortBy, boolean piles) {
 		int maxWidth = this.getParent().getWidth();
 		int numColumns = maxWidth / Config.dimensions.frameWidth;
 		int curColumn = 0;
@@ -194,6 +250,20 @@ public class CardsList extends javax.swing.JPanel implements MouseListener {
 	
 	public void addCardEventListener(Listener<Event> listener) {
 		cardEventSource.addListener(listener);
+		//mainModel.addCardEventListener(listener);
+	}
+
+	public void drawCards(SortBy sortBy) {
+		drawCards(sortBy, false);
+	}
+
+	@Override
+	public void loadCards(CardsView showCards, SortBy sortBy, boolean piles, BigCard bigCard, UUID gameId) {
+		//FIXME: why we remove all cards? for performance it's better to merge changes
+		cards = showCards;
+		this.bigCard = bigCard;
+		this.gameId = gameId;
+		drawCards((SortBy) cbSortBy.getSelectedItem());
 	}
 
 	public void clearCardEventListeners() {
@@ -292,8 +362,7 @@ public class CardsList extends javax.swing.JPanel implements MouseListener {
 		drawCards((SortBy) cbSortBy.getSelectedItem());
 	}//GEN-LAST:event_chkPilesActionPerformed
 
-
-    // Variables declaration - do not modify//GEN-BEGIN:variables
+	// Variables declaration - do not modify//GEN-BEGIN:variables
     private javax.swing.JLayeredPane cardArea;
     private javax.swing.JComboBox cbSortBy;
     private javax.swing.JCheckBox chkPiles;
diff --git a/Mage.Client/src/main/java/mage/client/deckeditor/CardSelector.java b/Mage.Client/src/main/java/mage/client/deckeditor/CardSelector.java
index 418310ebac..80412b870e 100644
--- a/Mage.Client/src/main/java/mage/client/deckeditor/CardSelector.java
+++ b/Mage.Client/src/main/java/mage/client/deckeditor/CardSelector.java
@@ -115,7 +115,7 @@ public class CardSelector extends javax.swing.JPanel implements ComponentListene
 			public void mousePressed(MouseEvent e) {
 				if (e.getClickCount() == 2 && !e.isConsumed()) {
 					e.consume();
-					//TODO: jButtonAddToMainActionPerformed(null);
+					jButtonAddToMainActionPerformed(null);
 				}
 			}
 		});
@@ -210,6 +210,7 @@ public class CardSelector extends javax.swing.JPanel implements ComponentListene
 	}
 
 	public void removeCard(UUID cardId) {
+		this.mainModel.removeCard(cardId);
 		this.cardGrid.removeCard(cardId);
 		for (Card card: cards) {
 			if (card.getId().equals(cardId)) {
diff --git a/Mage.Client/src/main/java/mage/client/deckeditor/DeckEditorPanel.java b/Mage.Client/src/main/java/mage/client/deckeditor/DeckEditorPanel.java
index 954dd9f48e..3ae8a937e2 100644
--- a/Mage.Client/src/main/java/mage/client/deckeditor/DeckEditorPanel.java
+++ b/Mage.Client/src/main/java/mage/client/deckeditor/DeckEditorPanel.java
@@ -169,7 +169,6 @@ public class DeckEditorPanel extends javax.swing.JPanel {
 								if (mode == DeckEditorMode.Sideboard || mode == DeckEditorMode.Limited) {
 									deck.getSideboard().remove(card);
 									cardSelector.removeCard(card.getId());
-									//cardTableSelector.removeCard(card.getId());
 								}
 								if (cardInfoPane instanceof  CardInfoPane)  {
 									((CardInfoPane)cardInfoPane).setCard(new CardView(card));
@@ -188,35 +187,6 @@ public class DeckEditorPanel extends javax.swing.JPanel {
 				}
 			);
 		}
-		/*this.cardTableSelector.getCardsList().clearCardEventListeners();
-		this.cardTableSelector.getCardsList().addCardEventListener(
-			new Listener<Event> () {
-				@Override
-				public void event(Event event) {
-					if (event.getEventName().equals("double-click")) {
-						Card card = cardTableSelector.getCard((UUID) event.getSource());
-						if (card != null) {
-							deck.getCards().add(Sets.createCard(card.getClass()));
-							if (mode == DeckEditorMode.Sideboard || mode == DeckEditorMode.Limited) {
-								deck.getSideboard().remove(card);
-								cardSelector.removeCard(card.getId());
-								cardTableSelector.removeCard(card.getId());
-							}
-							if (cardInfoPane instanceof  CardInfoPane)  {
-								((CardInfoPane)cardInfoPane).setCard(new CardView(card));
-							}
-						}
-					} else if (event.getEventName().equals("shift-double-click") && mode == DeckEditorMode.Constructed) {
-						Card card = cardTableSelector.getCard((UUID) event.getSource());
-						deck.getSideboard().add(Sets.createCard(card.getClass()));
-						if (cardInfoPane instanceof  CardInfoPane)  {
-							((CardInfoPane)cardInfoPane).setCard(new CardView(card));
-						}
-					}
-					refreshDeck();
-				}
-			}
-		);*/
 		this.deckArea.clearDeckEventListeners();
 		this.deckArea.addDeckEventListener(
 			new Listener<Event> () {
diff --git a/Mage.Sets/src/mage/sets/alarareborn/NemesisofReason.java b/Mage.Sets/src/mage/sets/alarareborn/NemesisofReason.java
new file mode 100644
index 0000000000..6cdab0064c
--- /dev/null
+++ b/Mage.Sets/src/mage/sets/alarareborn/NemesisofReason.java
@@ -0,0 +1,103 @@
+/*
+ *  Copyright 2010 BetaSteward_at_googlemail.com. All rights reserved.
+ *
+ *  Redistribution and use in source and binary forms, with or without modification, are
+ *  permitted provided that the following conditions are met:
+ *
+ *     1. Redistributions of source code must retain the above copyright notice, this list of
+ *        conditions and the following disclaimer.
+ *
+ *     2. Redistributions in binary form must reproduce the above copyright notice, this list
+ *        of conditions and the following disclaimer in the documentation and/or other materials
+ *        provided with the distribution.
+ *
+ *  THIS SOFTWARE IS PROVIDED BY BetaSteward_at_googlemail.com ``AS IS'' AND ANY EXPRESS OR IMPLIED
+ *  WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
+ *  FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL BetaSteward_at_googlemail.com OR
+ *  CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ *  CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
+ *  SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
+ *  ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
+ *  NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
+ *  ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ *  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
+ *  or implied, of BetaSteward_at_googlemail.com.
+ */
+
+package mage.sets.alarareborn;
+
+import java.util.UUID;
+
+import mage.Constants;
+import mage.Constants.CardType;
+import mage.Constants.Rarity;
+import mage.MageInt;
+import mage.abilities.TriggeredAbilityImpl;
+import mage.abilities.common.AttacksTriggeredAbility;
+import mage.abilities.effects.Effect;
+import mage.abilities.effects.common.PutLibraryIntoGraveTargetEffect;
+import mage.cards.CardImpl;
+import mage.game.Game;
+import mage.game.events.GameEvent;
+import mage.target.targetpointer.FixedTarget;
+
+/**
+ *
+ * @author Loki
+ */
+public class NemesisofReason extends CardImpl<NemesisofReason> {
+
+    public NemesisofReason (UUID ownerId) {
+        super(ownerId, 28, "Nemesis of Reason", Rarity.RARE, new CardType[]{CardType.CREATURE}, "{3}{U}{B}");
+        this.expansionSetCode = "ARB";
+        this.subtype.add("Leviathan");
+        this.subtype.add("Horror");
+		this.color.setBlue(true);
+		this.color.setBlack(true);
+        this.power = new MageInt(3);
+        this.toughness = new MageInt(7);
+        this.addAbility(new NemesisofReasonTriggeredAbility());
+    }
+
+    public NemesisofReason (final NemesisofReason card) {
+        super(card);
+    }
+
+    @Override
+    public NemesisofReason copy() {
+        return new NemesisofReason(this);
+    }
+}
+
+class NemesisofReasonTriggeredAbility extends TriggeredAbilityImpl<NemesisofReasonTriggeredAbility> {
+    NemesisofReasonTriggeredAbility() {
+        super(Constants.Zone.BATTLEFIELD, new PutLibraryIntoGraveTargetEffect(10));
+    }
+
+    NemesisofReasonTriggeredAbility(final NemesisofReasonTriggeredAbility ability) {
+        super(ability);
+    }
+
+    @Override
+    public NemesisofReasonTriggeredAbility copy() {
+        return new NemesisofReasonTriggeredAbility(this);
+    }
+
+    @Override
+    public boolean checkTrigger(GameEvent event, Game game) {
+        if (event.getType() == GameEvent.EventType.ATTACKER_DECLARED && event.getSourceId().equals(this.getSourceId()) ) {
+            for (Effect effect : this.getEffects()) {
+                effect.setTargetPointer(new FixedTarget(event.getTargetId()));
+            }
+			return true;
+		}
+		return false;
+    }
+
+    @Override
+    public String getRule() {
+        return "Whenever Nemesis of Reason attacks, defending player puts the top ten cards of his or her library into his or her graveyard.";
+    }
+}
\ No newline at end of file
diff --git a/Mage.Sets/src/mage/sets/mirrodinbesieged/TurntheTide.java b/Mage.Sets/src/mage/sets/mirrodinbesieged/TurntheTide.java
new file mode 100644
index 0000000000..ffa0a8cde5
--- /dev/null
+++ b/Mage.Sets/src/mage/sets/mirrodinbesieged/TurntheTide.java
@@ -0,0 +1,61 @@
+/*
+ *  Copyright 2010 BetaSteward_at_googlemail.com. All rights reserved.
+ *
+ *  Redistribution and use in source and binary forms, with or without modification, are
+ *  permitted provided that the following conditions are met:
+ *
+ *     1. Redistributions of source code must retain the above copyright notice, this list of
+ *        conditions and the following disclaimer.
+ *
+ *     2. Redistributions in binary form must reproduce the above copyright notice, this list
+ *        of conditions and the following disclaimer in the documentation and/or other materials
+ *        provided with the distribution.
+ *
+ *  THIS SOFTWARE IS PROVIDED BY BetaSteward_at_googlemail.com ``AS IS'' AND ANY EXPRESS OR IMPLIED
+ *  WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
+ *  FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL BetaSteward_at_googlemail.com OR
+ *  CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ *  CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
+ *  SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
+ *  ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
+ *  NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
+ *  ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ *  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
+ *  or implied, of BetaSteward_at_googlemail.com.
+ */
+
+package mage.sets.mirrodinbesieged;
+
+import java.util.UUID;
+
+import mage.Constants;
+import mage.Constants.CardType;
+import mage.Constants.Rarity;
+import mage.abilities.effects.common.continious.BoostOpponentsEffect;
+import mage.cards.CardImpl;
+
+/**
+ *
+ * @author Loki
+ */
+public class TurntheTide extends CardImpl<TurntheTide> {
+
+    public TurntheTide (UUID ownerId) {
+        super(ownerId, 35, "Turn the Tide", Rarity.COMMON, new CardType[]{CardType.INSTANT}, "{1}{U}");
+        this.expansionSetCode = "MBS";
+		this.color.setBlue(true);
+        this.getSpellAbility().addEffect(new BoostOpponentsEffect(-2, 0, Constants.Duration.EndOfTurn));
+    }
+
+    public TurntheTide (final TurntheTide card) {
+        super(card);
+    }
+
+    @Override
+    public TurntheTide copy() {
+        return new TurntheTide(this);
+    }
+
+}
diff --git a/Mage.Sets/src/mage/sets/newphyrexia/GethsVerdict.java b/Mage.Sets/src/mage/sets/newphyrexia/GethsVerdict.java
new file mode 100644
index 0000000000..c70811e7ba
--- /dev/null
+++ b/Mage.Sets/src/mage/sets/newphyrexia/GethsVerdict.java
@@ -0,0 +1,65 @@
+/*
+ *  Copyright 2010 BetaSteward_at_googlemail.com. All rights reserved.
+ *
+ *  Redistribution and use in source and binary forms, with or without modification, are
+ *  permitted provided that the following conditions are met:
+ *
+ *     1. Redistributions of source code must retain the above copyright notice, this list of
+ *        conditions and the following disclaimer.
+ *
+ *     2. Redistributions in binary form must reproduce the above copyright notice, this list
+ *        of conditions and the following disclaimer in the documentation and/or other materials
+ *        provided with the distribution.
+ *
+ *  THIS SOFTWARE IS PROVIDED BY BetaSteward_at_googlemail.com ``AS IS'' AND ANY EXPRESS OR IMPLIED
+ *  WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
+ *  FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL BetaSteward_at_googlemail.com OR
+ *  CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ *  CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
+ *  SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
+ *  ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
+ *  NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
+ *  ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ *  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
+ *  or implied, of BetaSteward_at_googlemail.com.
+ */
+
+package mage.sets.newphyrexia;
+
+import java.util.UUID;
+import mage.Constants.CardType;
+import mage.Constants.Rarity;
+import mage.abilities.effects.common.LoseLifeTargetEffect;
+import mage.abilities.effects.common.SacrificeEffect;
+import mage.abilities.effects.common.SacrificeTargetEffect;
+import mage.cards.CardImpl;
+import mage.filter.common.FilterCreaturePermanent;
+import mage.target.TargetPlayer;
+
+/**
+ *
+ * @author Loki
+ */
+public class GethsVerdict extends CardImpl<GethsVerdict> {
+
+    public GethsVerdict (UUID ownerId) {
+        super(ownerId, 61, "Geth's Verdict", Rarity.COMMON, new CardType[]{CardType.INSTANT}, "{B}{B}");
+        this.expansionSetCode = "NPH";
+		this.color.setBlack(true);
+        this.getSpellAbility().addEffect(new SacrificeEffect(new FilterCreaturePermanent(), 1, "Target player"));
+        this.getSpellAbility().addEffect(new LoseLifeTargetEffect(1));
+        this.getSpellAbility().addTarget(new TargetPlayer());
+    }
+
+    public GethsVerdict (final GethsVerdict card) {
+        super(card);
+    }
+
+    @Override
+    public GethsVerdict copy() {
+        return new GethsVerdict(this);
+    }
+
+}
diff --git a/Mage.Sets/src/mage/sets/newphyrexia/GitaxianProbe.java b/Mage.Sets/src/mage/sets/newphyrexia/GitaxianProbe.java
new file mode 100644
index 0000000000..4757c38642
--- /dev/null
+++ b/Mage.Sets/src/mage/sets/newphyrexia/GitaxianProbe.java
@@ -0,0 +1,98 @@
+/*
+ *  Copyright 2010 BetaSteward_at_googlemail.com. All rights reserved.
+ *
+ *  Redistribution and use in source and binary forms, with or without modification, are
+ *  permitted provided that the following conditions are met:
+ *
+ *     1. Redistributions of source code must retain the above copyright notice, this list of
+ *        conditions and the following disclaimer.
+ *
+ *     2. Redistributions in binary form must reproduce the above copyright notice, this list
+ *        of conditions and the following disclaimer in the documentation and/or other materials
+ *        provided with the distribution.
+ *
+ *  THIS SOFTWARE IS PROVIDED BY BetaSteward_at_googlemail.com ``AS IS'' AND ANY EXPRESS OR IMPLIED
+ *  WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
+ *  FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL BetaSteward_at_googlemail.com OR
+ *  CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ *  CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
+ *  SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
+ *  ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
+ *  NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
+ *  ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ *  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
+ *  or implied, of BetaSteward_at_googlemail.com.
+ */
+
+package mage.sets.newphyrexia;
+
+import java.util.UUID;
+
+import mage.Constants;
+import mage.Constants.CardType;
+import mage.Constants.Rarity;
+import mage.abilities.Ability;
+import mage.abilities.effects.OneShotEffect;
+import mage.abilities.effects.common.DrawCardControllerEffect;
+import mage.cards.CardImpl;
+import mage.game.Game;
+import mage.players.Player;
+import mage.target.TargetPlayer;
+
+/**
+ *
+ * @author Loki
+ */
+public class GitaxianProbe extends CardImpl<GitaxianProbe> {
+
+    public GitaxianProbe (UUID ownerId) {
+        super(ownerId, 35, "Gitaxian Probe", Rarity.COMMON, new CardType[]{CardType.SORCERY}, "{UP}");
+        this.expansionSetCode = "NPH";
+		this.color.setBlue(true);
+        this.getSpellAbility().addEffect(new GitaxianProbeEffect());
+        this.getSpellAbility().addEffect(new DrawCardControllerEffect(1));
+        this.getSpellAbility().addTarget(new TargetPlayer());
+    }
+
+    public GitaxianProbe (final GitaxianProbe card) {
+        super(card);
+    }
+
+    @Override
+    public GitaxianProbe copy() {
+        return new GitaxianProbe(this);
+    }
+
+}
+
+class GitaxianProbeEffect extends OneShotEffect<GitaxianProbeEffect> {
+    GitaxianProbeEffect() {
+        super(Constants.Outcome.Detriment);
+    }
+
+    GitaxianProbeEffect(final GitaxianProbeEffect effect) {
+        super(effect);
+    }
+
+    @Override
+    public boolean apply(Game game, Ability source) {
+        Player controller = game.getPlayer(source.getControllerId());
+        Player player = game.getPlayer(targetPointer.getFirst(source));
+        if (player != null && controller != null) {
+            controller.lookAtCards("Gitaxian Probe", player.getHand(), game);
+        }
+        return true;
+    }
+
+    @Override
+    public GitaxianProbeEffect copy() {
+        return new GitaxianProbeEffect(this);
+    }
+
+    @Override
+    public String getText(Ability source) {
+        return "Look at target player's hand";
+    }
+}
\ No newline at end of file
diff --git a/Mage.Sets/src/mage/sets/newphyrexia/NoxiousRevival.java b/Mage.Sets/src/mage/sets/newphyrexia/NoxiousRevival.java
new file mode 100644
index 0000000000..afb001eb9b
--- /dev/null
+++ b/Mage.Sets/src/mage/sets/newphyrexia/NoxiousRevival.java
@@ -0,0 +1,61 @@
+/*
+ *  Copyright 2010 BetaSteward_at_googlemail.com. All rights reserved.
+ *
+ *  Redistribution and use in source and binary forms, with or without modification, are
+ *  permitted provided that the following conditions are met:
+ *
+ *     1. Redistributions of source code must retain the above copyright notice, this list of
+ *        conditions and the following disclaimer.
+ *
+ *     2. Redistributions in binary form must reproduce the above copyright notice, this list
+ *        of conditions and the following disclaimer in the documentation and/or other materials
+ *        provided with the distribution.
+ *
+ *  THIS SOFTWARE IS PROVIDED BY BetaSteward_at_googlemail.com ``AS IS'' AND ANY EXPRESS OR IMPLIED
+ *  WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
+ *  FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL BetaSteward_at_googlemail.com OR
+ *  CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ *  CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
+ *  SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
+ *  ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
+ *  NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
+ *  ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ *  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
+ *  or implied, of BetaSteward_at_googlemail.com.
+ */
+
+package mage.sets.newphyrexia;
+
+import java.util.UUID;
+import mage.Constants.CardType;
+import mage.Constants.Rarity;
+import mage.abilities.effects.common.PutOnLibraryTargetEffect;
+import mage.cards.CardImpl;
+import mage.target.common.TargetCardInGraveyard;
+
+/**
+ *
+ * @author Loki
+ */
+public class NoxiousRevival extends CardImpl<NoxiousRevival> {
+
+    public NoxiousRevival (UUID ownerId) {
+        super(ownerId, 118, "Noxious Revival", Rarity.UNCOMMON, new CardType[]{CardType.INSTANT}, "{GP}");
+        this.expansionSetCode = "NPH";
+		this.color.setGreen(true);
+        this.getSpellAbility().addEffect(new PutOnLibraryTargetEffect(true));
+        this.getSpellAbility().addTarget(new TargetCardInGraveyard());
+    }
+
+    public NoxiousRevival (final NoxiousRevival card) {
+        super(card);
+    }
+
+    @Override
+    public NoxiousRevival copy() {
+        return new NoxiousRevival(this);
+    }
+
+}
diff --git a/Mage.Sets/src/mage/sets/scarsofmirrodin/GlintHawkIdol.java b/Mage.Sets/src/mage/sets/scarsofmirrodin/GlintHawkIdol.java
new file mode 100644
index 0000000000..4e5a3df049
--- /dev/null
+++ b/Mage.Sets/src/mage/sets/scarsofmirrodin/GlintHawkIdol.java
@@ -0,0 +1,119 @@
+/*
+ *  Copyright 2010 BetaSteward_at_googlemail.com. All rights reserved.
+ *
+ *  Redistribution and use in source and binary forms, with or without modification, are
+ *  permitted provided that the following conditions are met:
+ *
+ *     1. Redistributions of source code must retain the above copyright notice, this list of
+ *        conditions and the following disclaimer.
+ *
+ *     2. Redistributions in binary form must reproduce the above copyright notice, this list
+ *        of conditions and the following disclaimer in the documentation and/or other materials
+ *        provided with the distribution.
+ *
+ *  THIS SOFTWARE IS PROVIDED BY BetaSteward_at_googlemail.com ``AS IS'' AND ANY EXPRESS OR IMPLIED
+ *  WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
+ *  FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL BetaSteward_at_googlemail.com OR
+ *  CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ *  CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
+ *  SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
+ *  ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
+ *  NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
+ *  ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ *  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
+ *  or implied, of BetaSteward_at_googlemail.com.
+ */
+
+package mage.sets.scarsofmirrodin;
+
+import java.util.UUID;
+
+import mage.Constants;
+import mage.Constants.CardType;
+import mage.Constants.Rarity;
+import mage.MageInt;
+import mage.abilities.Abilities;
+import mage.abilities.TriggeredAbilityImpl;
+import mage.abilities.common.SimpleActivatedAbility;
+import mage.abilities.costs.mana.ColoredManaCost;
+import mage.abilities.effects.common.continious.BecomesCreatureSourceEOTEffect;
+import mage.abilities.keyword.FlyingAbility;
+import mage.cards.CardImpl;
+import mage.game.Game;
+import mage.game.events.GameEvent;
+import mage.game.events.ZoneChangeEvent;
+import mage.game.permanent.Permanent;
+import mage.game.permanent.token.Token;
+
+/**
+ *
+ * @author Loki
+ */
+public class GlintHawkIdol extends CardImpl<GlintHawkIdol> {
+
+    public GlintHawkIdol (UUID ownerId) {
+        super(ownerId, 156, "Glint Hawk Idol", Rarity.COMMON, new CardType[]{CardType.ARTIFACT}, "{2}");
+        this.expansionSetCode = "SOM";
+        this.addAbility(new GlintHawkIdolTriggeredAbility());
+        this.addAbility(new SimpleActivatedAbility(Constants.Zone.BATTLEFIELD, new BecomesCreatureSourceEOTEffect(new GlintHawkIdolToken(), ""), new ColoredManaCost(Constants.ColoredManaSymbol.W)));
+        
+    }
+
+    public GlintHawkIdol (final GlintHawkIdol card) {
+        super(card);
+    }
+
+    @Override
+    public GlintHawkIdol copy() {
+        return new GlintHawkIdol(this);
+    }
+
+}
+
+class GlintHawkIdolTriggeredAbility extends TriggeredAbilityImpl<GlintHawkIdolTriggeredAbility> {
+    GlintHawkIdolTriggeredAbility() {
+        super(Constants.Zone.BATTLEFIELD, new BecomesCreatureSourceEOTEffect(new GlintHawkIdolToken(), ""), true);
+    }
+
+    GlintHawkIdolTriggeredAbility(final GlintHawkIdolTriggeredAbility ability) {
+        super(ability);
+    }
+
+    @Override
+    public GlintHawkIdolTriggeredAbility copy() {
+        return new GlintHawkIdolTriggeredAbility(this);
+    }
+
+    @Override
+    public boolean checkTrigger(GameEvent event, Game game) {
+        if (event.getType() == GameEvent.EventType.ZONE_CHANGE && !event.getTargetId().equals(this.getSourceId())) {
+			ZoneChangeEvent zEvent = (ZoneChangeEvent)event;
+			if (zEvent.getToZone() == Constants.Zone.BATTLEFIELD) {
+				Permanent permanent = game.getPermanent(event.getTargetId());
+				if (permanent != null && permanent.getCardType().contains(CardType.ARTIFACT)) {
+					return true;
+				}
+			}
+		}
+		return false;
+    }
+
+    @Override
+    public String getRule() {
+        return "Whenever another artifact enters the battlefield under your control, you may have Glint Hawk Idol become a 2/2 Bird artifact creature with flying until end of turn.";
+    }
+}
+
+class GlintHawkIdolToken extends Token {
+    GlintHawkIdolToken() {
+        super("", "a 2/2 Bird artifact creature with flying");
+        cardType.add(CardType.ARTIFACT);
+        cardType.add(CardType.CREATURE);
+        subtype.add("Bird");
+        power = new MageInt(2);
+		toughness = new MageInt(2);
+        addAbility(FlyingAbility.getInstance());
+    }
+}
\ No newline at end of file
diff --git a/Mage/src/mage/abilities/effects/common/PutLibraryIntoGraveTargetEffect.java b/Mage/src/mage/abilities/effects/common/PutLibraryIntoGraveTargetEffect.java
index 18dd1bb495..ae5ac8d3ea 100644
--- a/Mage/src/mage/abilities/effects/common/PutLibraryIntoGraveTargetEffect.java
+++ b/Mage/src/mage/abilities/effects/common/PutLibraryIntoGraveTargetEffect.java
@@ -67,7 +67,7 @@ public class PutLibraryIntoGraveTargetEffect extends OneShotEffect<PutLibraryInt
 
 	@Override
 	public boolean apply(Game game, Ability source) {
-		Player player = game.getPlayer(source.getFirstTarget());
+		Player player = game.getPlayer(targetPointer.getFirst(source));
 		if (player != null) {
 			// putting cards to grave shouldn't end the game, so getting minimun available
 			int cardsCount = Math.min(amount.calculate(game, source), player.getLibrary().size());
diff --git a/Mage/src/mage/abilities/effects/common/continious/BecomesCreatureSourceEOTEffect.java b/Mage/src/mage/abilities/effects/common/continious/BecomesCreatureSourceEOTEffect.java
index 88213a6a4f..4973fe978a 100644
--- a/Mage/src/mage/abilities/effects/common/continious/BecomesCreatureSourceEOTEffect.java
+++ b/Mage/src/mage/abilities/effects/common/continious/BecomesCreatureSourceEOTEffect.java
@@ -113,7 +113,10 @@ public class BecomesCreatureSourceEOTEffect extends ContinuousEffectImpl<Becomes
 
 	@Override
 	public String getText(Ability source) {
-		return "Until end of turn {this} becomes a " + token.getDescription() + " that's still a " + this.type;
+        if (type.length() > 0)
+		    return "Until end of turn {this} becomes a " + token.getDescription() + " that's still a " + this.type;
+        else
+            return "Until end of turn {this} becomes a " + token.getDescription();
 	}
 
 	@Override
diff --git a/Mage/src/mage/cards/decks/Deck.java b/Mage/src/mage/cards/decks/Deck.java
index d7234af042..ea15831cc2 100644
--- a/Mage/src/mage/cards/decks/Deck.java
+++ b/Mage/src/mage/cards/decks/Deck.java
@@ -105,30 +105,11 @@ public class Deck implements Serializable {
 		return cards;
 	}
 
-//	/**
-//	 * @param cards the cards to set
-//	 */
-//	public void setCards(List<Card> cards) {
-//		this.cards = cards;
-//	}
-
 	/**
 	 * @return the sideboard
 	 */
 	public Set<Card> getSideboard() {
 		return sideboard;
 	}
-
-//	/**
-//	 * @param sideboard the sideboard to set
-//	 */
-//	public void setSideboard(Cards sideboard) {
-//		this.sideboard = sideboard;
-//	}
-
-//	public void setOwnerId(UUID playerId) {
-//		cards.setOwner(playerId);
-//		sideboard.setOwner(playerId);
-//	}
 	
 }