From f8faae4bb38894f733c1f0576761b80d7b0d6ef6 Mon Sep 17 00:00:00 2001
From: Evan Kranzler <theelk801@gmail.com>
Date: Sun, 24 Sep 2017 10:35:12 -0400
Subject: [PATCH] Implemented Security Detail

---
 .../src/mage/cards/s/SecurityDetail.java      | 69 +++++++++++++++++++
 Mage.Sets/src/mage/sets/MercadianMasques.java |  1 +
 .../common/CreatureCountCondition.java        | 12 +++-
 3 files changed, 79 insertions(+), 3 deletions(-)
 create mode 100644 Mage.Sets/src/mage/cards/s/SecurityDetail.java

diff --git a/Mage.Sets/src/mage/cards/s/SecurityDetail.java b/Mage.Sets/src/mage/cards/s/SecurityDetail.java
new file mode 100644
index 0000000000..8002d6ed5c
--- /dev/null
+++ b/Mage.Sets/src/mage/cards/s/SecurityDetail.java
@@ -0,0 +1,69 @@
+/*
+ *  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.cards.s;
+
+import java.util.UUID;
+import mage.abilities.common.LimitedTimesPerTurnActivatedAbility;
+import mage.abilities.condition.common.CreatureCountCondition;
+import mage.abilities.costs.mana.ManaCostsImpl;
+import mage.abilities.effects.common.CreateTokenEffect;
+import mage.cards.CardImpl;
+import mage.cards.CardSetInfo;
+import mage.constants.CardType;
+import mage.constants.TargetController;
+import mage.constants.Zone;
+import mage.game.permanent.token.SoldierToken;
+
+/**
+ *
+ * @author TheElk801
+ */
+public class SecurityDetail extends CardImpl {
+
+    public SecurityDetail(UUID ownerId, CardSetInfo setInfo) {
+        super(ownerId, setInfo, new CardType[]{CardType.ENCHANTMENT}, "{3}{W}");
+
+        // {W}{W}: Put a 1/1 white Soldier creature token onto the battlefield. Activate this ability only if you control no creatures and only once each turn.
+        this.addAbility(new LimitedTimesPerTurnActivatedAbility(
+                Zone.BATTLEFIELD,
+                new CreateTokenEffect(new SoldierToken()),
+                new ManaCostsImpl("{W}{W}"),
+                1,
+                new CreatureCountCondition(0, TargetController.YOU)
+        ));
+    }
+
+    public SecurityDetail(final SecurityDetail card) {
+        super(card);
+    }
+
+    @Override
+    public SecurityDetail copy() {
+        return new SecurityDetail(this);
+    }
+}
diff --git a/Mage.Sets/src/mage/sets/MercadianMasques.java b/Mage.Sets/src/mage/sets/MercadianMasques.java
index ad45df77e8..a9de3c9c57 100644
--- a/Mage.Sets/src/mage/sets/MercadianMasques.java
+++ b/Mage.Sets/src/mage/sets/MercadianMasques.java
@@ -270,6 +270,7 @@ public class MercadianMasques extends ExpansionSet {
         cards.add(new SetCardInfo("Saprazzan Legate", 100, Rarity.UNCOMMON, mage.cards.s.SaprazzanLegate.class));
         cards.add(new SetCardInfo("Saprazzan Raider", 102, Rarity.COMMON, mage.cards.s.SaprazzanRaider.class));
         cards.add(new SetCardInfo("Saprazzan Skerry", 328, Rarity.COMMON, mage.cards.s.SaprazzanSkerry.class));
+        cards.add(new SetCardInfo("Security Detail", 47, Rarity.RARE, mage.cards.s.SecurityDetail.class));
         cards.add(new SetCardInfo("Seismic Mage", 211, Rarity.RARE, mage.cards.s.SeismicMage.class));
         cards.add(new SetCardInfo("Sever Soul", 159, Rarity.COMMON, mage.cards.s.SeverSoul.class));
         cards.add(new SetCardInfo("Shock Troops", 212, Rarity.COMMON, mage.cards.s.ShockTroops.class));
diff --git a/Mage/src/main/java/mage/abilities/condition/common/CreatureCountCondition.java b/Mage/src/main/java/mage/abilities/condition/common/CreatureCountCondition.java
index 89705f8e40..6b2686030d 100644
--- a/Mage/src/main/java/mage/abilities/condition/common/CreatureCountCondition.java
+++ b/Mage/src/main/java/mage/abilities/condition/common/CreatureCountCondition.java
@@ -72,10 +72,16 @@ public class CreatureCountCondition implements Condition {
                 sb.append(" are on the battlefield");
                 return sb.toString();
         }
-        sb.append(" control exactly ");
-        sb.append(creatureCount);
-        sb.append(' ');
+        sb.append(" control");
+        if (creatureCount == 0) {
+            sb.append(" no ");
+        } else {
+            sb.append(" exactly ");
+            sb.append(creatureCount);
+            sb.append(' ');
+        }
         sb.append(filter.getMessage());
+        sb.append(creatureCount != 1 ? "s" : "");
 
         return sb.toString();
     }