================================================================================
File:		Readme.txt/htm
Subject: 		ICE
Author: 		jibe
Email:		jibe@planetquake.com
Web:		http://planetquake.com/ice
Version: 		1.0
Build Time: 	considerable...
If you have any comments, contributions, questions or suggestions, contact 
me via the address above.
The ICE bot and ICER Launcher are original works, written from scratch by 
jibe. Copyright (c) jibe 1998
================================================================================
CONTENTS
What's New in v1.0
What is ICE?
Features
Installation
Requirements
Starting the Game Right Now!
ICE Files and Folders
Maps & ICE
Creating Route Tables
	How to Route a New Map
	Route Building Tips
	Route Table Commands
	Advanced Rote Table Commands
ICE Commands
ICE Bot Personalities
Gameplay
	Deathmatch
		CTF Features in Deathmatch
	Teamplay
	Capture The Flag
		Advanced CTF Settings
		ICE CTF Strategy
Dedicated Server Support
Internet Play
Other ICE Features
	Grapple
	Auto Grapple
	Bot Chat
	Bot Gloating
	Bot Stats
	Bot Velocity
	Modes of Play
	Advanced Information Management (AIM)
	Camera
	ChatCentre
	Welcome Banner
	Client Commands
	Human Invisibility
	Map Cycling
	Pausing the Game
	Radio
	Viewable Weapons
Frequently Asked Questions - FAQ
Credits
Version History
DISCLAIMER
COPYRIGHT
DISTRIBUTION

 

WHAT'S NEW IN VERSION ICE 1.0 - Please see below for detailed commands and info.
================================================================================
================================================================================
Note About ICER - the ICE Bot Launcher

The ICE bot can be setup and run using ICER: the ICE bot Launcher,
which can be found at the web address above. You do not have to use the 
launcher to get ICE up and running, but it might make things simpler...
================================================================================

 

What is ICE?
The ICE Bot is a simulated player, capable of most human player 
behaviour within the Quake2 environment. ICE will play DeathMatch, CTF and it's own blend of Teamplay.
You can use ICER: the ICE Bot Launcher to get ICE up and running quickly.

 

================================================================================

 

FEATURES
	* Human-like roaming ai.
		- Bots move directly between objectives, using only 
		  'realistic' movements
	* Highly customisable, individual skill set:
		- Aggression
		- Agility
		- Accuracy
		- Cunning
		- Favourite Weapon
	* Melee skills include:
		- circle strafing
		- best weapon selection
		- target leading (anticipates enemy motion)
		- rocket dodging
		- crouching
		- rockets aimed at enemy feet
		- may pursue enemy until kill (if possible)
	* Uses all weapons / most items, including Grapple.
	* Create your own route-table for any map.
	* Dynamic skill - ICE bots can adjust their skill to 
	  give you a good game.
	* Map rotations.
	* Follow the bot action with ICE Camera.
	* Globally change bot skills with a single command.
	* Hazard avoidance.
	* Increasingly happy in water. Goes for air if necessary / able.
	* Supports Hentai's Viewable Weapons.
	* Supports Zoid's Threewave CTF 1.02
		- option to use CTF features in Deathmatch 
		  (id, grapple, techs)
	*'Advanced' CTF strategy code includes: 
		- Team ORDERS - available to humans & bots:
			+ coordinated attacks on base
			+ squadron forming, and leading to objective
			+ retreats to base defence
		- Allocate ROLES to your teammembers
			+ command certain players to guard the base
			+ designate players to attack
			+ choose members of the team to roam
		- Alternative team strategy screen which displays your
		  colleagues' plans, actions and status
	* Custom Teamplay mode with:
		- Custom Teamplay scoreboard
		- Custom skins or ICE managed skins
	* Internet Play management:
		- Adjusts bot skills based on your connection quality
		- Configurable features such as
			+ Weapon reload / fire speed
			+ Weapon fire travel speed
			+ Grapple Speed
	* Chat: Bots will threaten, welcome, gloat etc. 
	   All comments are customisable.
	* AutoGrapple
		- Allows use of grapple whilst firing another weapon.
	* ICE Modes of Play
		- Challenge Mode & Training variations on regular play.

 

================================================================================
REQUIREMENTS
The registered version of id software's Quake2.
v3.20 point release upgrade (although ICE should run on 
earlier versions AFTER 3.15).
The ICE Bot currently runs only on the Win95/98/NT platforms.
ICE supports Zoid's CTF and Hentai's Viewable Weapons.
	*If you wish to use ICE's CTF and Viewable Weapons
	features, then you must obtain the appropriate .pak 
	files from their respective authors. See above for 
	URLs.
For info., ICE was written on an AMD K6 200 MHZ with 32 
Meg Ram, and on that platform seems to handle decent 
numbers of bots just fine (ie up to 20 in DM, 14 in CTF)
================================================================================
INSTALLATION
Unzip the files contained in ICE_xxxx.zip into your Quake2 directory.
You MUST RESTORE PATHNAMES.
(Winzip users select the "Use Folder Names" option when extracting.
PKunzip users use the -d option.)
After extracting, confirm successful installation by checking for the 
existence of the "ICE" folder within your Quake2 directory.
================================================================================
STARTING THE GAME RIGHT NOW!
If you aren't using ICER: the ICE bot launcher, then start the ICE Bot by 
creating a shortcut to the file quake2.exe in your Quake2 folder.
The shortcut should read:
	quake2 +set game ICE +set deathmatch 1 +map <mapname>
You may specify other commands as detailed below, but this is 
sufficient to start up the ICE Bot.
Once inside the game, you can type at the console:
	bnum xxx
where xxx is the number of bots you wish ICE to randomly
choose and load (max 32 per command)
*or*
	bload xxx xxx xxx...
where xxx is the name of any bot contained in the file bots.cfg
(bots.cfg is stored in the ICE folder)
================================================================================
MAPS & THE ICE BOT
The ICE Bot can play on any map, once a suitable route table exists to
support it.
Read the section below (ROUTE TABLES) for advice on using the ICE Bot
in any map other than those detailed here.
ROUTE TABLES CONTAINED IN THIS RELEASE
This release of the ICE Bot contains route tables for the following maps:
DM:
	Q2DM1
	Q2DM2
	Q2DM3
	Q2DM4
	Q2DM5
	Q2DM6
	Q2DM7
	Q2DM8
	Evilq2dm
CTF:
	Q2CTF1
	Q2CTF2
	Q2CTF3
	Q2CTF4
	Q2CTF5
	starctf2
Read the section below (CREATING ROUTE TABLES) for advice on using the 
ICE Bot in any map other than those detailed above.
================================================================================
ICE BOT FILES/FOLDERS
Everything used by ICE is contained in the ICE folder within your Quake2
directory.
The .qit and .qrt files in the ROUTES subdirectory are generated by ICE, and
should not be altered manually.
BOTS.CFG
...contains details about all the ICE Bots. You may, of course, add to and adjust
the data in this text file (notepad.exe will do as an editor).
YOU MUST, however, keep to the exact structure as detailed within the file itself.
A replacement copy of BOTS.CFG is available from the ICE homepage.
LOADER.CFG
... is contained within the ICE folder, and CAN be read in each time the
game starts, and each time there is a map change (depending on your run_loader
setting - see below).
You can populate this file with any ICE Bot 'console' commands as detailed in
this file.
Useful for loading bots in teams, etc.
YOU MUST specify whether or not LOADER.CFG should be executed 
(using +set run_loader 0/1) as detailed below.
Default is NOT to execute it.
Remember that the ORDER of commands is important..
 eg you must load a team ('team' command) before you can change it's skin 
('teamskin' command).

================================================================================
ICE BOT PERSONALITIES 
ICE bots have a variety of personality traits, bad habits etc. which can all
be set within BOTS.CFG, or by using ICER. These settings are:
	Aggression		How likely the bot is to start a fight.
	Agility			How well the bot dodges, jumps, strafes, grapples.
	Accuracy			From 'inaccurate' to 'oh so accurate'
	Cunning			Brainpower. eg. Shall I attack, or get health and armour first?
	Favourite Weapon	The weapon the bot will always aim to use first.

Bear in mind that the most aggressive bot won't always win over the cunning bot
who leaves the melee in search of health.
Bear in mind also that the bot with highest aim accuracy and the railgun as a 
favourite weapon will almost ALWAYS win if he sees you first...
================================================================================
COMMANDS
	Note:
	Where applicable, commands are given for console and command line use.
	Where a 0/1 toggle is offered as the command argument, the first of the 
	toggle options is the default if not specified.
	Eg in the case of '+set camera 1/0', camera will be enabled even if the
	variable is never set.
	Some commans MUST be run from the command line (ie before the game starts)
	Some commands are for Dedicated Servers (eg dedicated: sv red) but they usually 
	work on the console in single player games.
command line: 	+set run_loader 0/1
console:	run_loader 0/1
	LOADER.CFG
	... is contained within the ICE folder, and MAY be read in each time
	the game starts, and each time there is a map change. This command tells
	ICE whether or not to load the file. The file can contain any number of
	Console commands, an example might be:
	Bload arc brag chog
	bot_dynamic 1
	map_change 1
	fraglimit 25
	This will load the bots arc, brag & chog. Dynamic skill changing will be 
	enabled, and the map will rotate every 25 frags. Note that map_change
	must be set to 1 or the maps in the maps.cfg file will not be used when
	rotating (instead the same map will just be reloaded).
console: 	bload xxx xxx xxx xxx...
dedicated:	sv bload xxx xxx xxx xxx...
	For loading bots into the game. 
	Where xxx is the name(s) of a bot contained within the bots.cfg file.
	Separate the bot names with a space.
console: 	bremove xxx xxx xxx xxx... [all]
dedicated:	sv bremove xxx xxx xxx xxx... [all]
	For removing bots from the game. 
	Where xxx is the name(s) of each bot you wish to remove.
	'bremove all' will remove every bot.
console: 	bnum xxx
dedicated:	sv bnum xxx
	where xxx is the number of bots you wish ICE to randomly
	choose and load. The maximum *per command* is 32.
	This just limits the loading traffic, you can add 10 lots
	of 32 if you wish (er, and you are running a Kray)
command line: 	+set bot_skill -2 -1 0 1 2
console:	bot_skill -2 -1 0 1 2
	You can alter the skill of all bots using the global bot_skill setting.
	 2 	will INCREASE bot skills quite a lot.
	 1 	will INCREASE all bot skills a little.
	 0 	is normal. Bot skills are unchanged.
	-1 	will DECREASE all bot skills a little.
	-2 	will DECREASE bot skills quite a lot.
	Values outside these ranges will have no effect. The default is 0
command line: 	+set bot_dynamic 0/1
console:	bot_dynamic 0/1
NB: 	DeathMatch ONLY.
	By allowing the bots to adjust their skills dynamically, ICE will
	try to provide the most balanced game for YOU.
	If, on the whole, you're whipping your opponents, the bots will try and
	make life harder for you. Alternatively, they will ease up if your
	score becomes embarrassing.
	If there is more than one human player in the game, bots will try
	to match the average human ability.
================================================================================
DEDICATED SERVER SUPPORT
As of version 0.3, ICE can be run in the dedicated environment (using the
'+set dedicated 1' argument on the quake2.exe command line, or by using 
ICER v0.2 and later)
All bot loading and configuration commands MUST be run with the prefix 'sv '.
Commands are:
	sv bload
	sv bnum
	sv bremove
	sv red
	sv blue
	sv team
	sv teamskin
You ONLY need to use the 'sv ' prefix if you are running a dedicated server, 
but the commands are also valid in the non-dedicated environment. Clients
MUST still use the standard command WITHOUT 'sv ', and client_commands must
be enable for this.
Manually added loader.cfg commands should usually employ 'sv ' format just
in case. (ICER v0.2 and later uses sv format)
TIPS
================================================================================
GAMEPLAY
ICE supports DEATHMATCH, TEAMPLAY, and CAPTURE THE FLAG.
DEATHMATCH
This is the default mode of play. Every man (bot) for himself.
TEAMPLAY
ICE currently supports up to four teams playing simultaneously, up to 16
players in each. Teamplay is initiated automatically, as soon as there is 1
team containing 1 player.
All team commands start with the same root: team
You can not yet delete a team, you must instead reload the map. (ie type: map x
At the console, where x is the mapname)
console:	team
dedicated:	sv team
	Lists all the current teams.
console:	team xxx
dedicated:	sv team
	Creates a team of name xxx. If the team exists, lists all the players
	in that team.
console:	team xxx yyy yyy yyy yyy...
dedicated:	sv team xxx yyy yyy yyy yyy...
	Creates a team of name xxx (if it doesn't already exist).
	Adds all the players named yyy (separated by a space) to that team.
	If the bot players specified are not already in the game, they will be
	spawned.
	Include human player names in the argument to add them to a team.
	Or use the 'join' command below.
	If any player specified is currently playing in another team, he will
	be removed from that team, and added to the new team as instructed.
console:	teamskin xxx yyy
dedicated:	sv teamskin xxx yyy
	Skins are allocated automatically to teams as they are created. This is
	intended to prevent any potential confusion.
	You can, however, change a team's skin AFTER it has joined the game,
	using the teamskin command.	
	Where xxx is the teamname and yyy is the skin.
	eg. 'teamskin baddudes kw_black'
	If you specify an invalid skin, ICE will allocate the default skin.
	Team members who join after the teamskin command will be allocated
	the new skin you have specified.
console:	join xxx
	For human players only.
	Adds the player who typed the command (ie you) to the team specified
	in xxx. An alternative to including your name with the team command.

	eg. join baddudes
	NB: the team xxx must already exist, so use this command AFTER the 
	appropriate 'team' command.

	To change teams, just change xxx and repeat the command.

	This command does NOT work on a dedicated server!
Scoring in Teamplay
The teamplay scoreboard groups players by team, and places the teams in order of 
highest score first.
Within in each team players are then sorted by score; highest first. The leader 
in each team also appears on the right of the screen as an icon.
If the friendly fire dm flag is not set, then you will lose a point for fragging
your teammates.
================================================================================
CAPTURE THE FLAG
As in regular CTF, ICE CTF supports two teams, red and blue.
ICE also offers a host of bot AI/commands specific to CTF play.
Note:
	You MUST copy Zoid's pak0.pak file (~12 Meg) from your CTF installation
	folder into the ICE folder in your Quake2 directory.
The general bot commands (bload, bremove, bnum) all work in ctf mode, as well 
as the ctf specific commands below.
In ctf, bots loaded using 'bload' or 'bnum' will automatically be assigned
a team (red or blue). ICE will automatically keep the team numbers even
(assuming, that is, that there are an even number of bots to split!).
When a CTF map is loaded, ICE will first try to find a route between the
two flags. If it is unsuccessful, the following message will appear:
	'WARNING: there is no complete route between flags'
This message will therefore appear when you first initialise a new route table for a
CTF map. Ignore it.
If, however, you are not creating a new route-table and you see this, see the notes on 
ROUTE TABLES below. Bear in mind that the bots will not capture many flags until
this is remedied!
command line: 	+set ctf 0/1
	You MUST enable CTF at the command line. It cannot be properly initiated from 
	within the game (console: ctf 1), UNLESS you then reload a CTF map. 
console:	ctfteam red
	Adds YOU to the red team (regular ctf command for this is just team).
console:	ctfteam blue
	Adds YOU to the blue team (regular ctf command for this is just team).
console:	red xxx xxx xxx...
dedicated:	sv red xxx xxx xxx...
	Adds bots to the red team.
	If they aren't playing already, they will be spawned.
console:	blue xxx xxx xxx...
dedicated:	sv blue xxx xxx xxx...
	Adds bots to the blue team.
	If they aren't playing already, they will be spawned.
console:	flagroute
	Ensures there is a route for the bots from one flag to another.
	It is called automatically at startup, but can be called anytime.
	There will ONLY be a response if there is NO route.
	By design, ICE bots will NOT always employ the same route
	from one flag to another.
================================================================================
ADVANCED CTF SETTINGS 
ROLES
console:	role attack yyy
console:	role guard yyy
console:	role roamer yyy
	Where yyy is the name of the bot.
	*ROLES...
	By default, ICE ctf bots are given a role to play in a ctf game.
	This will be one of:
		attack
		guard
		roamer
	Roles are handed out in this order, so if there are 5 bot players
	on a team, two will be in 'attack', two will be on 'guard', and
	only one will be a 'roamer'.
	'Attackers' will consistently arm themselves as necessary, and then
	go for the flag.
	'Baseguards' stay close to their own flag, straying only occasionally
	to find weapons and ammo for defensive purposes.
	'Roamers' will support the other team members, retrieve lost flags,
	divert enemy attention whilst attackers make their bid for the flag.
	As bots players leave and join a team, roles will be adjusted
	accordingly.
	Roles can easily be changed manually, however, to suit a particular
	style of play.
	Note: you can store your favourite settings to a file, and then	execute
	it from the console (use exec xxx where xxx is the name of a file 
	in the ICE directory).
	You CAN, of course, use LOADER.CFG for this purpose, but remember that 
	roles MUST be assigned AFTER the bot has been spawned, and AFTER it has
	joined either the red or blue team.
	As an example content for LOADER.CFG (exact order):
		red arc brag chog
		blue arabella dilla emmie
		role guard arc
		role guard emmie
	Subsequent addition/removal from the team WILL reset any manual changes.
*ADVANCED CTF SETTINGS...ORDERS
Orders can be issued to your teammates at any point during the game (and bots will 
form their own attack formations etc from time to time, informing you of status).
Bots will keep their orders until the objective is completed (eg retreating to base)
or until you dismiss them.
ADVANCED CTF SETTINGS   SOUND
All orders are accompanied by an audio message. For instance, when a bot 
called to group with you arrives, he will say "Reporting".
	
console:	group xxx xxx xxx... []
	Without any arguments, 'group' will instruct any and all of your
	'available' teammates to join you.
	Availability is determined by proximity, existing orders etc. Bots
	currently engaged in melee are unlikely to respond. Bots carrying the flag 
	will NOT respond.
	If you specify a teammate name (xxx), they are much more likely to drop
	what they are doing (unless they are actually returning to the base with
	the flag).
	If you move around, after issuing the command, the bots will adjust to 
	your new position, but will obviously take longer to reach you.
	As each grouping bot arrives, they will get into formation and
	follow you around until you issue a dismiss command (see below).
	If any of your 'followers' becomes engaged in battle, they will rejoin the 
	group when the fight is over (if they die, they will respawn and set about 
	finding you again).
console:	groupvisible
	This command has been substituted for follow_me command below.
	it will behave in exactly the same way as the 'follow_me' command.
console:	attack xxx xxx xxx...[]
	Without any arguments, 'attack' will instruct any and all of your
	'available' teammates to attack the enemy base.
	Availability is determined by proximity, existing orders etc. Bots
	currently engaged in melee are unlikely to respond.
	If you specify a teammate name (xxx), they are much more likely to drop
	what they are doing (unless they are actually returning to the base with
	the flag).
	This command is very effective when used in conjunction with the GROUP 
	command. Call a number of teammates to group with you outside the enemy 
	base. When they have arrived, issue an ATTACK command. This is a good way 
	to ensure that the ATTACK is coordinated with all bots hitting the target 
	at the same time. It may be the only way to overcome a heavily defended 
	base, and it is a strategy that Leading bots will use from time to time.
console:	retreat xxx xxx xxx...[]
	Without any arguments, 'retreat' will instruct any and all of your
	'available' teammates to return immediately to base.
	Availability is determined by proximity, existing orders etc. Bots
	currently engaged in melee are unlikely to respond.
	If you specify a teammate name (xxx), they are much more likely to drop
	what they are doing (unless they are actually returning to the base with
	the flag).
console:	dismiss xxx xxx xxx...[]
	Without any arguments, 'dismiss' will dismiss all teammates who are 
	currently in your command (following one of the above orders). They
	will go about their business as dictated by their roles.	
	Alternatively, specify bots by name.
console:	support_me xxx xxx xxx... []
	WARNING!
	'support_me' is a POWERFUL command which will give you 
	serious control over your teammates. Use with care!
	Without any arguments, 'support_me' will instruct *ALL* of your
	teammates to join you.
	*All* members of your team will drop what they are doing and come to 
	your aid - unless they have existing orders (This prevents humans 
	accidentally stealing each other's recruits!)
	This INCLUDES GUARDS! (but not FLAG CARRIERS)
	If you don't want EVERYONE to come, use the standard GROUP command.
	Recruited bots will NOT engage in melee again until they find you.
	They will not respond to pain caused by enemies either. 
	Nor will they collect items on their way to you. They come direct.
	You are now their priority.	
	If you move around, after issuing the command, the bots will adjust to 
	your new position, but will obviously take longer to reach you.
	As each grouping bot arrives, they will get into formation and
	follow you around until you issue a dismiss command (see below).
	If any of your 'followers' becomes engaged in battle, they will rejoin the 
	group when the fight is over (if they die, they will respawn and set about 
	finding you again).
console:	follow_me
	WARNING!
	'follow_me' is a POWERFUL command which will give you 
	serious control over your teammates. Use with care!
	'support_me' will instruct ANY teammates *under your crosshair* at time of 
	order to join you in a group - unless they have existing orders (This 
	prevents humans accidentally stealing each other's recruits!)	
	*All* applicable recruits will drop what they are doing and come to 
	your aid. 
	This INCLUDES GUARDS AND FLAG CARRIERS!
	If you don't want EVERYONE to come, use the standard GROUP command.	
	As each grouping bot arrives, they will get into formation and
	follow you around until you issue a dismiss command (see below).
	If any of your 'followers' becomes engaged in battle, they will rejoin the 
	group when the fight is over.
	UNLIKE other orders, however, if they die, they will NOT set about 
	finding you again, but will instead dismiss themselves.
console:	arm_me
	WARNING!
	'arm_me' is a POWERFUL command which will give you 
	serious control over your teammates. Use with care!
	Without any arguments, 'arm_me' will instruct any and all available 
	Roamers to bring ammo to you, wherever you are, wherever you go.
	Availability is determined existing orders etc. 
	When an 'arming' ROAMER finds you, he will drop a percentage of his
	ammunition stock, and inform you with the standard 'reporting' sound.
	A message will appear centrescreen, for example:
		DROPPING
		Grenades,
		Cells,
		Rockets,
		Slugs,
		Shells
		for jibe.
	The Roamer will then dismiss himself. If you call him back, he'll drop 
	some more. The premise for the command is that you need the ammo more 
	than he does, so he'll keep dropping it until he runs out. 
	ROAMERS with NO ammo will not be much use as flag run support!
	Bots currently engaged in melee are unlikely to respond. Bots carrying 
	the flag will NOT respond.
	If you specify a teammate name (xxx), they are much more likely to drop
	what they are doing (unless they are actually returning to the base with
	the flag).
	If you move around, after issuing the command, the bots will adjust to 
	your new position, but will obviously take longer to reach you.
	As each grouping bot arrives, they will get into formation and
	follow you around until you issue a dismiss command (see below).
	If any of your 'armers' becomes engaged in battle, they will start 
	searching for you again when the fight is over (if they die, they will 
	respawn and set about finding you again).
console:	strategy
console:	invnext
console:	invprev
	This will call up the 'strategy' screen which shows statistics on all your
	teammates. So called as it is intended to allow a more strategic coordination 
	of your team. It is an alternative to the regular CTF score screen, and the 
	two cannot be shown at the same time. A maximum of six players can be 
	displayed at one time (by default the first six that were loaded - see below
	for scroll commands). The display shows a model icon (mini photo) for each 
	player, and a coloured letter representing their role 
		G for Guard (RED)
		A for Attacker (GREEN)
		R for Roamer (YELLOW)
	Also displayed against each is their name, distance from you (in approximate 
	'virtual' metres), and their most recent message to the rest of the team 
	(if applicable). These messages also appear at the top of the screen as regular 
	chat. The model icon and the role letter will be highlighted with coloured 
	frames at certain times in the game. When bots in your team are recruited by 
	other bots or player (but not you) a RED frame appears around their model icon. 
	If a bod is LEADING a group, the RED frame will be splashed with blue. If the 
	frames are RED, the bots are effectively busy, and will not respond to your 
	general orders unless you call them specifically by name. When you do recruit a
	bot (to attack, retreat or group), a YELLOW frame will appear around their icon.
	This means they have responded to your command. If the order was "Group" then 
	the frame will be YELLOW while they are looking for you, but will change to green 
	when they find you. A small letter will appear in the bottom right corner of 
	each model icon to show its current orders (L, Leading Group, A: Attacking enemy
	base, R: Retreating to home base, G: Grouping with you or another Leader).
	Finally, if the bot is in a melee, a pale blue frame will appear around the ROLE 
	Letter (G, A, or R).
	You can scroll the display using these commands:
	invnext
	-or-
	invprev
	These are the standard Q2 commands for scrolling through your inventory (and are usually
	 bound 
	to [ and ] respectively.
	>> or << will appear over the top and bottom player icons respectively
	if there are more players to display.

 

ICE BOT CTF STRATEGY
The ICE bot is capable of independently issuing any of the commands above.
It will happily lead or join groups, attacks, retreats, as instructed by you, or
by another bot on the team.
You can change a bot's existing orders (ie those given to it by another bot)
by instructing it by name.
ONLY bots with the 'attack' role will actually issue orders to the other members
of the team.
Guards will NOT take orders from other bots.
Attackers and Roamers WILL.
To see the ROLES and ORDERS of all of your teammates, just call up the scores
screen. After each ICE bot's name is a dash, followed by their ROLE, then
another dash, followed by their current ORDER.
	eg. 	Arabella-a-l
	 	Barb-a-g
		Dilla-r-g
		Emmie-g-d
Above, Arabella(attacker) is leading Barb(attacker) and Dilla(roamer) in group
formation. Emmie(baseguard) is dismissed (default if without orders).
By design, ICE bots will NOT always employ the same route from one flag to another.
Scoring operates as in conventional CTF, with points awarded for assists etc.
================================================================================
INTERNET PLAY
ICE contains a number of features intended to assist human clients
who are suffering the effects of high ping and lag during Internet play
with the ICE bot (Inspired by personal experience).
The aim is FAIRNESS. If a number of human players are sitting on the server,
along with the bot clients, players accessing via the Internet are always at 
a disadvantage. ICE INTERNET PLAY seeks to address the imbalance where
it is significant. It's an imperfect alternative to NOT joining the server at all!
NONE of these features are enabled by default. The console commands are ONLY
valid on the server.
*INTERNET PLAY Initialisation...
command line: 	+set internet_play 0/1
console:	internet_play 0/1
	Enables/Disables all the features of Internet Play, for ALL HUMAN PLAYERS.
	YOU MUST ENABLE this for the following features to work.
	If you then enable features such as weapon_travel_speed WITHOUT enabling
	'ping proportional advantage' (below), ALL HUMAN PLAYERS will enjoy
	rockets travelling with the speed of chaingun fire.
command line: 	+set ping_prop_adv 0/1
console:	ping_prop_adv 0/1
	With Internet Play enabled, 'ping proportional advantage' will 
	adjust each player's Internet Play features accordingly, in an attempt to
	assist those human players suffering from sluggish controls and the other 
	side effects of a high ping. The assistance is directly proportional to
	the player's ping.
	Those with normal (low) pings will NOT see any of the effects of the 
	features below. All players will be reminded from time to time if there
	is any 'assistance' in effect.
	
*INTERNET PLAY Features...
command line: 	+set handicap 0-4
console: 	handicap 0-4
	Essentially numbs bots' reaction time, slows their movement etc.
	Influences ALL bots in the game. Reduces the likelihood of bots
	seemingly vanishing, common in games where players have poor Internet
	connections.
command line: 	+set weapon_repeat_speed 1-3
console: 	weapon_repeat_speed 1-3
	Reduces reloading time, firing time, weapon change time etc.
	A useful edge on other players.
	Similar to the Haste tech in CTF, and great with a ping of 400+.
	(amusing with no ping, too)
command line: 	+set weapon_travel_speed 1-3
console: 	weapon_travel_speed 1-3
	Increases weapon fire travel speed.
	Renders the rocket launcher closer to its Quake (1) counterpart.
	Opponents have less time to dodge, and are more likely to be in the same
	place even after high ping has trounced your aiming/firing reaction time.
	A setting of 3 or more effectively converts the blaster into a 
	hyperblaster. You can slow weapons down too (er, why?) by specifying a 
	point value of less than 1, but more than 0.
command line: 	+set grapple_speed 1..4
console: 	grapple_speed 1..4
	Everybody has an opinion about the speed of the grapple. YOU decide!
	NB MAX is 4 or the mechanism goes pear shaped.
================================================================================
CREATING ROUTE TABLES
ICE bots use route tables to find their way around maps. You can create a
route table for any map; DM or CTF (this includes Maps created for such mods 
as Loki's Minions etc).
Route table management is handled automatically by ICE.
If you still have questions about creating a route table after reading this 
section and the FAQ, contact me using the address at the top of the file.
Human players create the tables as they play. You are, however, STRONGLY
advised to create route tables for new maps WITHOUT first loading any bots,
and to make the learning process an end in itself (ie don't play the map until
you have created a good route table). ICE will actually try to prevent bots
from joining the game whilst a new route table is being created.
HOW TO ROUTE A NEW MAP

 

ROUTE BUILDING TIPS
	'WARNING: there is no complete route between flags'
This message will therefore appear when you first create a route table for a
new CTF map. Ignore it.
If, however, you are not creating a new route-table and you see this, it means
that the bots are unlikely to capture many flags. SO...
*When creating a route table for a ctf map, the first thing to do is walk from
one flag to the other. The more routes that exist between the flags, the more
'unpredictable' bots will be as they attack the enemy base, so recording several
different routes is also a good idea. One solid route between the flags will do,
however.
*You can force the route learning on (see 'learn toggle' command below) or you
can delete the route table altogether and start again (often the best plan).
You can also test the route quality using the tools below.

 

ROUTE TABLE COMMANDS:
The following commands are available if you wish to override ICE's automatic
settings.
console:	learn toggle
	You can toggle route learning on and off with this command.
console:	loadroute
	Manually loads/reloads a route (specific to the current map).
console:	showallnodes
	Toggle. Will show every node recorded on a map. Nodes will be green
	Unless they must be jumped to, in which case they are red.
	Beware of using this when lots of bots are playing as it is quite
	Demanding on the game.
console:	showroute
	Toggle. First call sets the start point, second call sets the end point.
	Wait a few seconds, and if able, ICE will light up the nodes & route
	between	the two points. Toggle once more to deactivate the highlighted
	route.
console:	show_bot_routes
	Toggle. Shows the route and nodes taken by the bot who most recently
	chose a path somewhere.
console:	evaluateroutestatus
	This is the route table loading mechanism, and is called every time a map 
	is loaded. It provides feedback on the current route table status, and 
	lights up all the map items which cannot be reached by the ICE bot. 
	Remember that having a few unreachable items on a map is normal - 
	especially if it is a CTF map where grapple use may be required. The bots 
	will usually find a way to these "unreachable" items. Regular reloading of 
	the map is advised when making any node changes - and is essential before 
	any bots are loaded.
console:	hideglow
	
		Hides the blue glow on items which indicates that bots will get to
		these items using 'unconventional means'
		By default: The glow is DEACTIVATED at startup on 'complete' routemaps.
console:	showglow
		Shows the blue glow on items which indicates that bots will get to
		these items using 'unconventional means'
		By default: The glow is ACTIVATED at startup on 'incomplete' routemaps.

 

ADVANCED ROUTE COMMANDS
WARNING: ADVANCED USERS ONLY!!!
console:	forcenode
	Will force a node to be recorded at your current position. Used to force
	Bots to take a certain route.
console:	movenode
	For tweaking specific nodes when the route table is complete. This command 
	will select the nearest node to your current position, and transport you 
	to it. The active node will be represented as a red ball, and nodes 
	connected to it will be blue. Using the command a second time will 
	actually move the node. The change is effective immediately. Remember that 
	the red node (the one you are moving) MUST remain in view of the blue 
	nodes. MAKE A BACKUP OF YOUR ROUTE TABLE BEFORE USING THIS COMMAND. 
	It is useful when moving nodes about to activate the "showallnodes" 
	Command - 'movenode' will do this automatically.
	The number of the selected node will be displayed at the top of the screen.
console:	unreachable
	After "evaluateroutestatus" is run (automatically when a map is loaded) 
	the number of items which are unreachable is displayed. To move directly 
	to each of these items in turn, use "unreachable" at the console. Make 
	sure learning is deactivated before using this command (use "learn 
	toggle"). ICE will try to ensure it is disabled automatically.
================================================================================
OTHER ICE FEATURES
VIEWABLE WEAPONS

command line: 	+set view_weapons 0/1
	This MUST be set on the command line.
	ICE fully supports Hentai's Viewable Weapons mod.
	Note:
	You MUST copy the vwep pak2.pak file (~2 Meg) into
	the ICE folder in your Quake2 directory.
MAP CYCLING

command line: 	+set map_change 0/1
console:	map_change 0/1
	You can instruct ICE to cycle through the list of maps contained in
	maps.cfg (in the ICE folder).
	You can store up to 50 maps, in any order, each one on a NEW line.
	When ICE reaches the end of the list, it restarts at the top.

	When the change is triggered (by 'fraglimit' or 'timelimit'	or 'capturelimit')
	then if the "Force Respawn" DM Flag is set, the next map will load 
	immediately. Otherwise, the next map will not load until a human 
	player hits their fire button. This means that if you want the maps to 
	keep cycling on an empty  dedicated server, you must set the "Force 
	Respawn" flag.
	'map_change' is used in conjunction with 'fraglimit' & 'timelimit'
	& 'capturelimit' detailed below.
	NB:	maps in maps.cfg will NOT be used unless 'map_change' is set to 1
command line: 	+set fraglimit xxx
console:	fraglimit xxx
	Map changes when a player gets this many frags.
	NB:	you MUST also set map_change 1
command line: 	+set timelimit xxx
console:	timelimit xxx
	Map changes when this many minutes have passed.
	NB:	you MUST also set map_change 1
command line: 	+set capturelimit xxx
console:	capturelimit xxx
	Map changes after this many captures. CTF ONLY!
	NB:	you MUST also set map_change 1
CAMERA
command line: 	+set camera 1/0
console:	camera 1/0
	To initialise the camera on the server. You must do this in order for the 
	client 'cam' commands to work at all.
console:	cam xxx
console:	cam on
console:	cam off
console:	invnext
console:	invprev
	You may choose WHO to watch, and HOW to watch them*
	WHO:
	Once the camera is initialised by the server, use 'cam' at the console
	with one of these options to choose WHO you want to watch:
	1.	'cam xxx' is the name of the bot you want to follow.
	2 	'cam on' will start the camera in auto mode when you first use it.
		In auto mode, ICE will move the camera from bot to bot depending 
		on a variety of criteria intended to show where the action
		is (eg who is fighting with the biggest weapon, who has the flag etc)
		Typing 'cam on' repeatedly will allow you to manually move the focus 
		from bot to bot, until the last bot is reached, whereupon the 
		camera will deactivate itself.
	3.	Whilst in camera mode, you can also move the display from player to 
		player using the inventory commands,
			invnext
			-or-
			invprev
		These are the standard Q2 commands for scrolling through your 
		inventory (and are usually bound to ] and [ respectively.)
	4.	'cam' without any arguments will instantly deactivate the camera. 
		So will 'cam off'.
	HOW:
	There are three camera modes, and you can scroll through them using your 
	*fire* button:
	1.	Hollywood MODE:
		ICE automatically pans, zooms and follows the action from all angles.
	2.	Eye MODE:
		Gives you the bot's eye view. Full on!
	3.	Freemouse MODE:
		Places you just above the bot, and allows you to control the view 
		angle with your mouse.
	Whenever you use the camera, information will appear in the lower left 
	corner of your screen, detailing who you are watching and how they are doing.
	If you call up the scores screen at anytime (or the strategy screen in CTF)
	the camera info will disappear and not return until you hit *fire* or type
	'cam on' again.

 

GRAPPLE

ICE bots will use the grapple by default. They will use it in DM too,
if enabled (see 'dmgrapple' below)
command line: 	+set bot_grapple 1/0
console:	bot_grapple 1/0
	ICE bots will happily get from a to b using the grapple.
	Or you can stop them doing so.
command line: 	+set bot_spiderman 1/0
console:	bot_spiderman 1/0
	ICE Bots can also swing around the map like Peter Parker (aka Spiderman!).
	This includes using the grapple to:
		...get out of nasty situations
		...get into position or chase an inaccessible enemy
		...show off in general

 

AUTO GRAPPLE
console:	auto_grapple 0/1
console:	auto_grapple_go, auto_grapple_stop (SEE BELOW FOR USAGE INFO)
	auto_grapple allows the grapple to be used concurrently with another 
	weapon (as in LMCTF). In order to do this, you must add some commands to 
	your autoexec.cfg in the ICE folder (as you may have done for Zoid's 
	standard grapple). It should look something like this:
	    bind "shift" +auto_grapple
	    alias +auto_grapple "auto_grapple_go"
	    alias -auto_grapple "auto_grapple_stop"
	The only parts you mustn't change are the words auto_grapple_go and 
	auto_grapple_stop. You can now fire the grapple whilst still using your 
	active weapon (and without actually selecting the grapple as a weapon 
	first). Hold down the auto_grapple key ('shift' in my example above) for 
	as long as you want the grapple activated. Of course you can still make 
	the grapple your active weapon if you like ("use grapple"), and the 
	command above will operate the regular grapple just fine.
	You MUST set the 'auto_grapple 1' server setting to enable this option - 
	or just choose Auto Grapple from the bot options page in ICER (v0.11 and 
	above).	The bots will use auto_grapple themselves and attack you whilst 
	grappling!

 

CTF FEATURES IN DEATHMATCH
command line: 	+set dmgrapple 0/1
	Allows use of the CTF grapple in DM games.
command line: 	+set dmtech 0/1
	Allows use of the four CTF techs in DM games.
command line: 	+set dmtech 1/0
	Adds the handy player identification option to DM games.

 

CHATCENTRE

command line: 	+set chatcentre 1/0
console:	chatcentre 1/0
	To enable/disable the realignment of human chat from the top of the screen
	to the centre of the screen.
	Useful if there are only a few (non-malicious) players who miss each others
	comments during play.

 

RADIO

command line: 	+set radio 1/0
console:	radio 1/0
	Plays 'radio' sound when messages from human (NOT bot) players are received.

 

 

WELCOME BANNER

command line: 	+set show_banner 1/0
console:	show_banner 1/0
	Displays the ICE welcome banner to clients as they connect.

 

CLIENT COMMANDS
command line: 	+set client_commands 1/0
console:	client_commands 1/0
	Determines whether or not clients (rather than just the server)
	can add or remove bots. By default they can.

 

BOT CHAT
The bots will use chat in a variety of circumstances. All the comments are held
in chat.cfg in the ICE folder. See the file for details on creating your own chat
for the bots to use.
command line: 	+set bot_chat 1/0
console:	bot_chat 1/0
	Toggles the bots' verbosity. Useful in CTF if you're not interested
	in hearing about their planned attack on the enemy base etc...
	Shuts them up in DM too.

 

BOT STATS
console:	bot_display_toggle
	With the scores screen *visible* toggles between: 
		*display of player scores
		*statistics of bots currently in the game
		*camera screen if activated
		*ctf strategy screen

 

 

PAUSING the GAME
console:	bot_pause 0/1
	Pauses ALL playing bots - but not human players.
	If you want to use bot_pause or bot_invisibility as toggles (ie 
	press a key once to turn invisibilty or pause on, press the same key again 
	to turn it off) then you need to add an alias/binding to your autoexec.cfg 
	file in the ICE folder. Something like this: 
	alias invis0 "bot_pause 0;echo bot_pause OFF;wait;bind i invis1"
    	alias invis1 "bot_pause 1;echo bot_pause ON;wait;bind i invis0"
    	bind i invis0 

 

 

HUMAN INVISIBILITY
console:	bot_invisibility 0/1
	Makes ALL humans invisible to bots. They won't attack you unless
	you attack them first!

 

 

BOT VELOCITY
console:	bot_velocity 0-3
	
	Where 0 is FASTEST, 3 is SLOWEST.
	Bot Velocity is now configurable using 'bot_velocity'. By default, bots 
	always run flat out (bot_velocity 0), which makes them harder targets but 
	isn't completely realistic.

 

BOT GLOATING
console:	bot_gloat_glow 1/0
	You can prevent ICE bots from flashing blue after they score a kill, using
	this command. Default is 'bot_gloat_glow 1' which is ON.
	This will NOT stop them insulting you!

 

MODES OF PLAY
console:	bot_mode 0-2
console:	challenge
	Additional, custom ICE modes of play exist for Deathmatch Only.
	0 : Normal mode
	Regular DM. No changes applied

	1 : Training Mode
	This is intended to help those who are new to ICE/Q2 or want to improve 
	their game without being repeatedly killed and continually having to respawn
	and collect weapons/armour/health.
	Gameplay ensues as normal in DM, but you receive no pain from bot attacks.
	Instead a warning message appears centrescreen, displaying the damage that 
	would have been done to you in normal mode. You also see who took it. eg:
		"Eskimo takes 25 with a Rocket Launcher"
	If you hurt yourself somehow, then you'll be told about that too.
	2 : Challenge Mode
	Just how good are you? It's hard to say against human players with inconsistent 
	play and circumstances. ICE Challenge Mode removes the uncertainty. The skill 
	level of your competition is determined by ICE and then rated against your 
	peformance. You are on your own. Every ICE bot player is out to get you.
	Factors taken into account:
	-	Number of enemies.
	-	The various skill settings of each enemy.
	-	Time. Your score falls off over time.
	-	Number of human players.

	As such, the better the enemies are, the more points you get for a kill. 
	Likewise the more enemies on the map, the faster your score will grow. 
	If you have human help, your score will reflect this. 
	If you camp or sit around, your score will drop - quickly.

	Scores will be between 0 and 999. Your score will appear in the top right 
	hand corner of the screen.
	
	You can also type 'challenge' at the console (at any time) in order to see 
	the highest score you have had during the game.

	Rate yourself.
		
	

 

ADVANCED INFORMATION MANAGEMENT (AIM)

console:	bot_aim 0/1
        This option will speed up certain key elements of bot behaviour, namely:

        -    Increases bot reaction times.
        -    Reduces bot route calculation delays.
        -    Improves bot perception of techs & flags.

        There is, however, a minor CPU overhead, and on slower processors (less than 200MHz)
        there may be some jerkiness or other noticeable slowdown. For this reason, bot_aim is not
        enabled by default. Try both settings at the consloe. bot_aim should be enabled if possible,
        as it will ultimately render a more challenging ICE opponent.

 

 


================================================================================
VERSION HISTORY
0.2

 

0.3

 

================================================================================

FAQ

Q:    ICE just doesn't work. Why not?
-or-
Q:    When I type bnum or bload in the console, nothing happens.
A:    Firstly, check to see if there is a gamex86.dll file in your quake2 folder. If there is, remove it,
       rename it or delete it.
       If that doesn't apply, check your folder structure. The ICE folder must be in the QUAKE2 folder.
       ICER should be in the ICE folder (if you are using it) eg c:\quake2\ice\icer
       Finally, what version of Quake2 are you running. Make sure that you have the v3.19 point
       release installed BEFORE you install ICE. If you've upgraded Q2 after installing ICE, reinstall the
       ICE zips.

Q:    The bots seem to carry a large white diamond shaped object instead of a weapon. Why?
A:    You have enabled Viewable Weapons, but haven't copied the viewable weapons .pak file
        to your ICE folder. If you are using custom models (eg. not Male/Female or Cyborg) then
        they must have their own viewable weapons models in their own model folder (see previous Q)

Q:    When I start the game, it stops, and gives me the message:

            "ERROR: Game is version 3.xx not 3.yy"

       Why is this?
A:    See above. You must have version 3.19 of Quake2 for ICE to run properly.

Q:    None of my custom models appear in the game. Instead the are all bald, male players.
A:    Have you installed the models in the quake2\baseq2\players\<modelname> folder? Each model
       must have its own folder, and the folder must also contain the sounds for that model,
       or they will use the default male sounds.

Q:    What are these kw_ skins?
A:    I am distributing Grimlock's Coloured Skin Pack with ICE so that teams of ICE players can each
       sport the same clothing in a Teamplay game. The kw_ files (eg. kw_blue, kw_green) are all
       copied to your quake2\baseq2\players\<male/female/cyborg> folders when you install ICE.
       This means that you can compose teams of Males, Females and Cyborgs and they can all
       have the same skin colour. This is not possible with the basic skins like Viper and Sniper
       that come with Quake2.

Q:    I started the game, but where are the ICE bots?
A:    Use bnum <number of bots> -or- bload <bot name> to load some bots from the console. Read
       about these commands above.

Q:    The game is a bit jerky for the first few seconds. Why?
A:    This is normal. When Quake2 starts, ICE loads the route table for the map you chose,
       and then loads any bots in loader.cfg. This is demanding stuff. The jerkiness will pass in
       a minute.

Q:    When I load a CTF map, no flags appear. Why not?
A:    You must add +set ctf 1 to the command line, or designate the map you are loading as a CTF type
       map in ICER.
       ICE will try and determine the gametype automatically when the map is loaded (ie CTF or not)
       but it is best to use the correct command line/ICER setup. If you are creating a route for a new CTF
       map, then when the route is complete, you should reload the map before playing it.

Q:    My friend wants to join me in my ICE game. Can he do this over the Internet?
A:    Every time you play a standard ICE Quake2 game on your pc, you are actually running your
       own server. If you are connected to the internet whilst running the game, you will have an
       IP address - something like 198.162.166.222
       If your friend knows this IP, he can connect to your game with a shortcut that looks something
       like this:

            quake2.exe +set game ice +set game deathmatch +connect 198.162.166.222

        Both players must be online for this to work. You can also use the connect option in ICER 0.2

Q:    I want to play a map that isn't yet supported in the ICE download. Where can I get routes from?
A:    There are a number of sites dedicated to providing routes for bots. Check them out. Or create
       your own. Check out the instructions above.

Q:    Can I use routes from other bots with ICE.
A:    Nope. ICE navigation is unique, the routes have to be created from new.

Q:    When I use ICER, I get the message "Can't find [BOTS] header". Why?
A:    The bots.cfg file MUST contain this exact line BEFORE the list of bots starts:

            [BOTS]

        Reinstall the file if you have to.

Q:    When I use ICER, I get the message "Can't find file or file in use". Why?
A:    Make sure that the following files are in your ICE folder:

            bots.cfg
            chat.cfg
            maps.cfg

Q:    Sometimes the screen freezes and the message "SZ_getspace" appears. What does it mean?
-or-
Q:    The game is crashing with the error: "No more free edicts". Why?
A:    This should only appear if Quake2 is low on memory (shut down ALL other apps when running ICE)
        -or- there are just too many bots loaded for the game to cope with. To give some idea of what is
        reasonable, my AMD K6 200MHz with 32MB RAM will play 20 DM bot no problem.
        It could also happen on a very large map containing lots of items. But I've never seen it...

Q:    When I connect to an Internet server, I can't load any ICE bots. Why not? I used ICER.
A:    You can't load ICE bots on a server that isn't running the ICE mod itself. Contact
        the server administrator, or run your own ICE server and have your friends connect to it.
        (see above for details)

Q:    When I set fraglimit/timelimit/capturelimit, I don't see any ICE bots. When the map changes.
        Why not?
A:    You MUST set map_change 1 (see above for details)

Q:    This long list of Q and As still hasn't fixed my problem. What should I do?
A:    Write to me at the email address above. Provide as much detail as you can about
       what you tried, what your setup is, what has worked and, of course what hasn't.
       I reply to all constructive messages.



================================================================================
CREDITS

id Software - of course:
    http://www.idsoftware.com/
PlanetQuake - The ICE Hosts:
    http://www.planetquake.com/
Dave 'Zoid' Kirsch - top CTF:
    ftp://ftp.idsoftware.com/idstuff/quake2/ctf/
Hentai - nice Viewable Weapons:
    http://www.telefragged.com/tsunami/
Quake Devels - lots of useful info.:
    http://www.planetquake.com/qdevels/
Quake2 DLLs - lots of useful info.:
    http://www.quake2.com/dll/
Jinx - hours of beta testing, html documentation, chat.cfg & creative input.
Grimlock's essential Coloured Skin Pack.
ALL the other BOT authors out there - for inspiration and some cool ideas - especially Ryan 'Ridah' Feltrin.
The ICE Beta Testers - thanks guys.
-&-
Everyone who has emailed ideas & bug reports, especially:
Terry Tor, Darkseid-D, Viper, Adam Ripley, Darrell Bynum
================================================================================

DISCLAIMER


THIS SOFTWARE IS MADE AVAILABLE "AS IS" AND WITHOUT WARRANTIES AS TO
PERFORMANCE OR MERCHANTABILITY OR ANY OTHER WARRANTIES WHETHER
EXPRESSED OR
IMPLIED.
NO WARRANTY OF FITNESS FOR A PARTICULAR PURPOSE IS OFFERED.
THE USER MUST ASSUME THE ENTIRE RISK OF USING THE PROGRAM.

Please bear in mind that this is a beta release, and is therefore in a 
continuous state of development. It may be unstable, though I am working 
hard to ensure that it is not.
I accept no responsibility for any effect, detrimental or otherwise, which 
the ICE Bot or the ICER Launcher may have on your system, life, etc.
Other than that, enjoy.
================================================================================
COPYRIGHT

The ICE bot and ICER: the ICE bot Launcher are Copyright (c) jibe 1998.
================================================================================
DISTRIBUTION

Feel free to distribute this archive subject to the following
conditions:
1. it remains PERFECTLY intact, as distributed on my web page:
   http://planetquake.com/ice
2. no money exchanges hands as part of the process.
3. any subsequent transfer of this software to another party must include
   their acceptance of the conditions stated under the disclaimer above.