diff options
Diffstat (limited to 'src/eu/equalparts/cardbase/cardstorage')
-rw-r--r-- | src/eu/equalparts/cardbase/cardstorage/ReferenceCardContainer.java | 137 | ||||
-rw-r--r-- | src/eu/equalparts/cardbase/cardstorage/StandaloneCardContainer.java | 66 |
2 files changed, 0 insertions, 203 deletions
diff --git a/src/eu/equalparts/cardbase/cardstorage/ReferenceCardContainer.java b/src/eu/equalparts/cardbase/cardstorage/ReferenceCardContainer.java deleted file mode 100644 index f43b76b..0000000 --- a/src/eu/equalparts/cardbase/cardstorage/ReferenceCardContainer.java +++ /dev/null @@ -1,137 +0,0 @@ -package eu.equalparts.cardbase.cardstorage; - -import java.util.HashMap; -import java.util.Map; - -import com.fasterxml.jackson.annotation.JsonProperty; - -import eu.equalparts.cardbase.cards.Card; - -/** - * A class which contains card quantities with absolutely no other - * information about the cards themselves. - * - * @author Eduardo Pedroni - * - */ -public class ReferenceCardContainer { - - /** - * Land field initialised to 0, accessed with getter and updated with setter. - */ - private int plains = 0, islands = 0, swamps = 0, forests = 0, mountains = 0; - /** - * A map with card hashes as entry keys (calculated used {@code Card.hashCode()}) - * and card amounts as entry values. - */ - @JsonProperty private Map<Integer, Integer> cardReferences = new HashMap<>(); - - /** - * Returns the amount of the specified card. If the card is not present at all, return 0. - * - * @param cardToCount a card whose count is to be returned. - * @return the count of the returned card in the container. - */ - public int getCount(Card cardToCount){ - int cardHash = cardToCount.hashCode(); - return cardReferences.containsKey(cardHash) ? cardReferences.get(cardHash) : 0; - } - - /** - * @param cardToAdd the card to add the container. - * @param count the amount to add. - */ - public void addCard(Card cardToAdd, int count) { - cardReferences.put(cardToAdd.hashCode(), getCount(cardToAdd) + count); - } - - /** - * @param cardToRemove the card to remove from the container. - * @param count the amount to remove. - * @return the amount that was effectively removed. Could be less than {@code count} - * depending on how many of the card were present. - */ - public int removeCard(Card cardToRemove, int count) { - int cardHash = cardToRemove.hashCode(); - if (count <= 0 || !cardReferences.containsKey(cardHash)) { - return 0; - } - - if (count >= cardReferences.get(cardHash)) { - return cardReferences.remove(cardHash); - } else { - cardReferences.put(cardHash, cardReferences.get(cardHash) - count); - return count; - } - } - - /** - * @return the plains - */ - public int getPlains() { - return plains; - } - - /** - * @return the islands - */ - public int getIslands() { - return islands; - } - - /** - * @return the swamps - */ - public int getSwamps() { - return swamps; - } - - /** - * @return the forests - */ - public int getForests() { - return forests; - } - - /** - * @return the mountains - */ - public int getMountains() { - return mountains; - } - - /** - * @param plains the plains to set - */ - public void setPlains(int plains) { - this.plains = plains; - } - - /** - * @param islands the islands to set - */ - public void setIslands(int islands) { - this.islands = islands; - } - - /** - * @param swamps the swamps to set - */ - public void setSwamps(int swamps) { - this.swamps = swamps; - } - - /** - * @param forests the forests to set - */ - public void setForests(int forests) { - this.forests = forests; - } - - /** - * @param mountains the mountains to set - */ - public void setMountains(int mountains) { - this.mountains = mountains; - } -} diff --git a/src/eu/equalparts/cardbase/cardstorage/StandaloneCardContainer.java b/src/eu/equalparts/cardbase/cardstorage/StandaloneCardContainer.java deleted file mode 100644 index 53d248d..0000000 --- a/src/eu/equalparts/cardbase/cardstorage/StandaloneCardContainer.java +++ /dev/null @@ -1,66 +0,0 @@ -package eu.equalparts.cardbase.cardstorage; - -import java.util.HashMap; -import java.util.LinkedList; -import java.util.List; -import java.util.Map; - -import com.fasterxml.jackson.annotation.JsonProperty; - -import eu.equalparts.cardbase.cards.Card; - -/** - * TODO fix comments - * Holds actual card data in addition to the card counts in {@code ReferenceCardContainer}. - * - * @author Eduardo Pedroni - * - */ -public class StandaloneCardContainer extends ReferenceCardContainer { - /** - * A map with card hashes as entry keys (calculated used {@code Card.hashCode()}) - * and card objects as entry values. - */ - @JsonProperty private Map<Integer, Card> cardData = new HashMap<>(); - - /** - * Returns a card from the cardbase by set code and number. - * If no such card is in the cardbase, returns null. - * - * @param setCode the set to which the requested card belongs. - * @param number the requested card's set number. - * @return the requested {@code Card} or null if no card is found. - */ - public Card getCard(String setCode, String number) { - return cardData.get(Card.makeHash(setCode, number)); - } - - /** - * This method is intended to allow iteration directly on the list of cards, - * while at the same time retaining control over the insert and remove procedures. - * The returned {@code List} is a read-only; trying to modify its structure will - * result in an {@code UnsupportedOperationException}. - * - * @return an unmodifiable list of all the cards in the cardbase. - */ - public List<Card> getCards() { - return new LinkedList<Card>(cardData.values()); - } - - @Override - public void addCard(Card cardToAdd, int count) { - super.addCard(cardToAdd, count); - cardData.putIfAbsent(cardToAdd.hashCode(), cardToAdd); - } - - @Override - public int removeCard(Card cardToRemove, int count) { - int removed = super.removeCard(cardToRemove, count); - - if (getCount(cardToRemove) <= 0) { - cardData.remove(cardToRemove.hashCode()); - } - - return removed; - } -} |