key0-96/
key0-96/doc/key/
key0-96/doc/key/credits/
key0-96/doc/key/developers/
key0-96/doc/key/developers/resources/
key0-96/setup/caves/
key0-96/setup/help/
key0-96/setup/ruins/
key0-96/src/
key0-96/src/commands/
key0-96/src/events/
key0-96/src/hack/
key0-96/src/sql/
key0-96/src/swing/
key0-96/src/talker/forest/
key0-96/src/talker/objects/
key0-96/src/terminals/
/*
**               j###t  ########## ####   ####
**              j###t   ########## ####   ####
**             j###T               "###L J###"
**          ######P'    ##########  #########
**          ######k,    ##########   T######T
**          ####~###L   ####
**          #### q###L  ##########   .#####
**          ####  \###L ##########   #####"
**
**  $Id$
**
**  Class History
**
**  Date        Name         Description
**  ---------|------------|-----------------------------------------------
**  19Aug98     subtle       start of recorded history
**
*/

package key;

import java.util.Date;

/**
  *  To be implemented by atoms that expect to be
  *  deleted automatically - players, mail &
  *  news, etc, etc.
 */
public interface Expirable
{
	/**
	  *  Returns the expiry date of the atom - after
	  *  this date it is not guaranteed to exist -
	  *  it isn't necessarily killed right at this
	  *  time, though - some expiry's won't be
	  *  checked incredibly regularly.
	  *
	  *  Returning null is okay.
	 */
	public Date expireAt();

	/**
	  *  Routine to call which actually expires
	  *  the atom
	 */
	public void expire();
}