/
com/planet_ink/coffee_mud/Abilities/Common/
com/planet_ink/coffee_mud/Abilities/Diseases/
com/planet_ink/coffee_mud/Abilities/Druid/
com/planet_ink/coffee_mud/Abilities/Fighter/
com/planet_ink/coffee_mud/Abilities/Languages/
com/planet_ink/coffee_mud/Abilities/Misc/
com/planet_ink/coffee_mud/Abilities/Prayers/
com/planet_ink/coffee_mud/Abilities/Properties/
com/planet_ink/coffee_mud/Abilities/Skills/
com/planet_ink/coffee_mud/Abilities/Songs/
com/planet_ink/coffee_mud/Abilities/Spells/
com/planet_ink/coffee_mud/Abilities/Thief/
com/planet_ink/coffee_mud/Abilities/Traps/
com/planet_ink/coffee_mud/Behaviors/
com/planet_ink/coffee_mud/CharClasses/interfaces/
com/planet_ink/coffee_mud/Commands/
com/planet_ink/coffee_mud/Commands/interfaces/
com/planet_ink/coffee_mud/Common/
com/planet_ink/coffee_mud/Common/interfaces/
com/planet_ink/coffee_mud/Exits/interfaces/
com/planet_ink/coffee_mud/Items/Armor/
com/planet_ink/coffee_mud/Items/Basic/
com/planet_ink/coffee_mud/Items/CompTech/
com/planet_ink/coffee_mud/Items/MiscMagic/
com/planet_ink/coffee_mud/Items/Weapons/
com/planet_ink/coffee_mud/Items/interfaces/
com/planet_ink/coffee_mud/Libraries/
com/planet_ink/coffee_mud/Libraries/interfaces/
com/planet_ink/coffee_mud/Locales/
com/planet_ink/coffee_mud/MOBS/
com/planet_ink/coffee_mud/Races/
com/planet_ink/coffee_mud/Races/interfaces/
com/planet_ink/coffee_mud/WebMacros/
com/planet_ink/coffee_mud/WebMacros/interfaces/
com/planet_ink/coffee_mud/core/
com/planet_ink/coffee_mud/core/collections/
com/planet_ink/coffee_mud/core/interfaces/
com/planet_ink/coffee_mud/core/intermud/
com/planet_ink/coffee_mud/core/intermud/i3/
com/planet_ink/coffee_web/server/
com/planet_ink/siplet/applet/
lib/
resources/factions/
resources/fakedb/
resources/progs/autoplayer/
resources/quests/holidays/
web/
web/admin.templates/
web/admin/grinder/
web/admin/images/
web/clan.templates/
web/pub.templates/
web/pub/images/mxp/
web/pub/sounds/
web/pub/textedit/
package com.planet_ink.coffee_mud.Items.interfaces;

import java.util.Vector;

import com.planet_ink.coffee_mud.Locales.interfaces.Room;
import com.planet_ink.coffee_mud.MOBS.interfaces.MOB;
import com.planet_ink.coffee_mud.core.interfaces.Environmental;

/*
   Copyright 2004-2016 Bo Zimmerman

   Licensed under the Apache License, Version 2.0 (the "License");
   you may not use this file except in compliance with the License.
   You may obtain a copy of the License at

	   http://www.apache.org/licenses/LICENSE-2.0

   Unless required by applicable law or agreed to in writing, software
   distributed under the License is distributed on an "AS IS" BASIS,
   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
   See the License for the specific language governing permissions and
   limitations under the License.
*/
/**
 * An interface for a deck of playing cards, like you'd use to play
 * Gin or Poker or something. Includes methods for generating a Hand
 * of cards, shuffling, and so forth.
 * @see HandOfCards
 * @author Bo Zimmerman
 */
public interface DeckOfCards extends HandOfCards
{
	/**
	 * Creates a new deck of 52 cards of the same time as the
	 * underlying object.  The deck is then handed over to
	 * the mob or room specified. 
	 * @param owner a mob or room to receive the new deck.
	 * @return the new deck of 52 cards, not shuffled.
	 */
	public DeckOfCards createDeck(Environmental owner);
	
	/**
	 * Resets the deck back to 52 cards.  It will
	 * grab cards from all external sources first
	 * and return them to the deck container owner.
	 * If this fails to produce 52 cards, it will
	 * create a set of cards for the deck.
	 * this method also destroys any hands being
	 * managed.
	 * @return true 
	 */
	public boolean resetDeckBackTo52Cards();
	
	 /**
	 * If a hand of cards has previously been added to this
	 * deck for internal management, this method will return
	 * that hand given the player object.
	  * @param player the player whose hand to look for
	  * @return the hand belonging to that player, or null
	  */
	public HandOfCards getPlayerHand(MOB player);

	/**
	 * Adds and possibly creates a hand for the given player
	 * if no hand is passed in, a new empty one is created
	 * the hand is then added to our table, keyed by the player
	 * object
	 * @param player the player whose hand this will be
	 * @param cards the hand, or null to make a new one
	 * @return the hand of cards passed in or created
	 */
	public HandOfCards addPlayerHand(MOB player, HandOfCards cards);

	/**
	 * If the given player object has a hand of cards currently
	 * being managed by this deck, this method will remove all
	 * of the cards from the hand, return them to the deck,
	 * then remove the hand from management, and destroy the hand.
	 * @param player the player whose hand to remove.
	 */
	public void removePlayerHand(MOB player);
	
	/**
	 * This method adds to the base functionality found
	 * in HandOfCards.java by ensuring that all cards
	 * added to the deck are added face down.
	 * @param card the card to add back to the deck.
	 */
	@Override
	public boolean addCard(PlayingCard card);
}