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
**  ---------|------------|-----------------------------------------------
**  24Aug98     subtle       start of recorded history
**
*/

package key.commands;

import key.*;
import key.util.LinkedList;

import java.util.StringTokenizer;
import java.util.Enumeration;
import java.io.IOException;

public class Status extends Command
{
	public Status()
	{
		setKey( "status" );
		usage = "";
	}

	public void run( Player p, StringTokenizer args, String fullLine, CategoryCommand caller, InteractiveConnection ic, Flags flags ) throws IOException
	{
		Key key = Key.instance();
		Runtime rt = Runtime.getRuntime();
		
		ic.send( new java.util.Date().toString() );
		ic.blankLine();
		ic.send( key.getName() + " has been running since "
			+ key.bootStats.getLastConnection() );
		
		ic.send( Long.toString( rt.totalMemory() ) + " bytes allocated, "
			+ Long.toString( rt.freeMemory() ) + " bytes of that remaining" );
		
		int po = key.numberPlayers();
		
		ic.send( "There " + Grammar.isAre( po ) + " " + po + " "
			+ Grammar.personPeople( po ) + " online" );
		
		int atoms, containers, scapes, players, lists;
		
		atoms = Atom.getTotalAtoms();
		containers = Container.getTotalContainers();
		atoms -= containers;

		scapes = Scape.getTotalScapes();
		containers -= scapes;

		players = Player.getTotalPlayers();
		containers -= players;

		lists = LinkedList.getTotalLists();
		
		ic.send( "Totals: " + atoms + " atoms, " + containers
			+ " containers, " + scapes + " scapes, " + players + " players, "
			+ lists + " lists" );

		ic.blankLine();
		ic.send( Registry.instance.statistics() );
	}
}