diff options
| author | Eduardo Pedroni <e.pedroni91@gmail.com> | 2015-06-08 16:57:44 +0200 | 
|---|---|---|
| committer | Eduardo Pedroni <e.pedroni91@gmail.com> | 2015-06-08 16:57:44 +0200 | 
| commit | 4ee655bef4cdf9e62a1b247e77754441de806f22 (patch) | |
| tree | 87fa71cbd2508d6458aae02f610850182ef9c5cc /src/eu/equalparts/cardbase/data | |
| parent | 4816a489e476c324155fa1f4e8adfe30867a766c (diff) | |
Implemented sorting using reflection, not sure it was a good idea though
Diffstat (limited to 'src/eu/equalparts/cardbase/data')
| -rw-r--r-- | src/eu/equalparts/cardbase/data/Card.java | 22 | ||||
| -rw-r--r-- | src/eu/equalparts/cardbase/data/CardSetInformation.java (renamed from src/eu/equalparts/cardbase/data/CardSet.java) | 2 | ||||
| -rw-r--r-- | src/eu/equalparts/cardbase/data/Cardbase.java | 24 | ||||
| -rw-r--r-- | src/eu/equalparts/cardbase/data/CardbaseManager.java | 126 | ||||
| -rw-r--r-- | src/eu/equalparts/cardbase/data/FullCardSet.java | 32 | 
5 files changed, 40 insertions, 166 deletions
| diff --git a/src/eu/equalparts/cardbase/data/Card.java b/src/eu/equalparts/cardbase/data/Card.java index 1bf6a75..03e7dea 100644 --- a/src/eu/equalparts/cardbase/data/Card.java +++ b/src/eu/equalparts/cardbase/data/Card.java @@ -1,19 +1,19 @@  package eu.equalparts.cardbase.data; -import java.util.ArrayList; +import java.util.List;  public class Card { -	public String layout; -	public String name; -	public ArrayList<String> names; -	public String manaCost; -	public Integer cmc; -	public ArrayList<String> colors; +	public String layout = ""; +	public String name = ""; +	public List<String> names; +	public String manaCost = ""; +	public Integer cmc = 0; +	public List<String> colors;  	public String type; -	public ArrayList<String> supertypes; -	public ArrayList<String> types; -	public ArrayList<String> subtypes; +	public List<String> supertypes; +	public List<String> types; +	public List<String> subtypes;  	public String rarity;  	public String text;  	public String flavor; @@ -23,7 +23,7 @@ public class Card {  	public String toughness;  	public Integer loyalty;  	public Integer multiverseid; -	public ArrayList<String> variations; +	public List<String> variations;  	public String imageName;  	public String border;  	public String watermark; diff --git a/src/eu/equalparts/cardbase/data/CardSet.java b/src/eu/equalparts/cardbase/data/CardSetInformation.java index b06be7c..d3394b7 100644 --- a/src/eu/equalparts/cardbase/data/CardSet.java +++ b/src/eu/equalparts/cardbase/data/CardSetInformation.java @@ -1,6 +1,6 @@  package eu.equalparts.cardbase.data; -public class CardSet { +public class CardSetInformation {  	private String name;  	private String code; diff --git a/src/eu/equalparts/cardbase/data/Cardbase.java b/src/eu/equalparts/cardbase/data/Cardbase.java deleted file mode 100644 index 021fac2..0000000 --- a/src/eu/equalparts/cardbase/data/Cardbase.java +++ /dev/null @@ -1,24 +0,0 @@ -package eu.equalparts.cardbase.data; - -import java.util.ArrayList; - -public class Cardbase { - -	public ArrayList<Card> cards = new ArrayList<>(); -	public ArrayList<Deck> decks = new ArrayList<>(); -	 -	/** -	 * @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 getCardByNumber(String setCode, String number) { -		for (Card card : cards) { -			if (card.setCode.equals(setCode) && card.number.equals(number)) -				return card; -		} -		 -		return null; -	} -	 -} diff --git a/src/eu/equalparts/cardbase/data/CardbaseManager.java b/src/eu/equalparts/cardbase/data/CardbaseManager.java deleted file mode 100644 index d6ba6ee..0000000 --- a/src/eu/equalparts/cardbase/data/CardbaseManager.java +++ /dev/null @@ -1,126 +0,0 @@ -package eu.equalparts.cardbase.data; -import java.io.File; -import java.io.IOException; -import java.util.Iterator; - -import com.fasterxml.jackson.core.JsonGenerationException; -import com.fasterxml.jackson.core.JsonParseException; -import com.fasterxml.jackson.databind.JsonMappingException; - -import eu.equalparts.cardbase.utils.IO; - -/** - * Provides a variety of utility methods to interact with the loaded cardbase. - *  - * @author Eduardo Pedroni - */ -public class CardbaseManager { - -	/** -	 * The cardbase being managed. -	 */ -	private Cardbase cardbase; -	 -	/** -	 * Creates an empty cardbase. -	 *  -	 */ -	public CardbaseManager() { -		cardbase = new Cardbase(); -	} -	 -	/** -	 * Initialises the cardbase with the contents of a file. -	 * -	 * @param cardbaseFile the cardbase JSON to load. -	 *  -	 * @throws JsonParseException if the specified file does not contain valid JSON. -	 * @throws JsonMappingException if the specified file structure does not match that of {@code Cardbase}. -	 * @throws IOException if a low-level I/O problem (unexpected end-of-input, network error) occurs. -	 */ -	public CardbaseManager(File cardbaseFile) throws JsonParseException, JsonMappingException, IOException { -		cardbase = IO.jsonMapper.readValue(cardbaseFile, Cardbase.class); -	} - -	/** -	 * Writes the provided {@code Cardbase} to the provided file in JSON format. -	 *  -	 * @param file the file to which to write the {@code Cardbase}. -	 * @param cardbase the {@code Cardbase} to write out. -	 *  -	 * @throws JsonGenerationException if the data structure given does not generate valid JSON. -	 * @throws JsonMappingException if the data structure given does not generate valid JSON as well? -	 * @throws IOException if a low-level I/O problem (unexpected end-of-input, network error) occurs. -	 */ -	public void writeCardbase(File outputFile) throws JsonGenerationException, JsonMappingException, IOException { -		IO.jsonMapper.writeValue(outputFile, cardbase); -	} - -	/** -	 * Adds a specific amount of a card to the cardbase. -	 * If the card is not already in the cardbase, it is added. -	 * If it is already present, the count is simply updated. -	 *  -	 * @param cardToAdd the card to be added. -	 * @param count the amount of the card to be added. -	 */ -	public void addCard(Card cardToAdd, Integer count) { -		Card card = cardbase.getCardByNumber(cardToAdd.setCode, cardToAdd.number); -		if (card != null) { -			card.count += count; -		} else { -			cardToAdd.count = count; -			cardbase.cards.add(cardToAdd); -		} -	} - -	/** -	 * Removes a specific amount of a card from the cardbase. -	 * If the card is not present in the cardbase, nothing happens. -	 * If the card is present in the cardbase, the specified amount is removed. -	 * If that amount is equal to or exceeds the count already in the cardbase, -	 * the card entry is removed altogether. -	 * <br><br> -	 * In any case, the value returned is the actual number of cards removed. -	 * For example, if 5 Shivan Dragons are in the cardbase and the method is -	 * called to remove 10 Shivan Dragons, the {@code Card} representing the -	 * Shivan Dragon is removed from the cardbase, and the value returned is 5. -	 *  -	 * @param cardToRemove the card to be removed. -	 * @param count the amount of the card to be removed. -	 * @return the number of cards actually removed. -	 */ -	public Integer removeCard(Card cardToRemove, Integer count) { -		Card card = cardbase.getCardByNumber(cardToRemove.setCode, cardToRemove.number); -		Integer removed = 0; -		if (card != null) { -			if (card.count <= count) { -				cardbase.cards.remove(card); -				removed = card.count; -			} else { -				card.count -= count; -				removed = count; -			} -		}  -		return removed; -	} - -	/** -	 * @return an iterator to the {@code Card}s in the cardbase. -	 */ -	public Iterator<Card> cardIterator() { -		return cardbase.cards.iterator(); -	} - -	/** -	 * 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 cardbase.getCardByNumber(setCode, number); -	} -} diff --git a/src/eu/equalparts/cardbase/data/FullCardSet.java b/src/eu/equalparts/cardbase/data/FullCardSet.java index 0f58633..d469829 100644 --- a/src/eu/equalparts/cardbase/data/FullCardSet.java +++ b/src/eu/equalparts/cardbase/data/FullCardSet.java @@ -1,16 +1,40 @@  package eu.equalparts.cardbase.data; -import java.util.ArrayList; +import java.util.List; -public class FullCardSet extends CardSet { +public class FullCardSet { +	private String name; +	private String code; +	private String releaseDate;  	private String border;  	private String type;  	private String block;  	private String gathererCode; -	private ArrayList<Card> cards; +	private List<Card> cards;  	/** +	 * @return the set's name. +	 */ +	public String getName() { +		return name; +	} + +	/** +	 * @return the set code. +	 */ +	public String getCode() { +		return code; +	} + +	/** +	 * @return the set's release date. +	 */ +	public String getReleaseDate() { +		return releaseDate; +	} +	 +	/**  	 * @return the set's border type.  	 */  	public String getBorder() { @@ -41,7 +65,7 @@ public class FullCardSet extends CardSet {  	/**  	 * @return a full list of the set's cards.  	 */ -	public ArrayList<Card> getCards() { +	public List<Card> getCards() {  		return cards;  	} | 
