|||||oy ~~~~~43|Macros ~~~~~44|Keymaps #####R====================================================================== #####B ToME Macro FAQ Original Angband Macro FAQ by Jim Lyon (jplyon@attglobal.net) 09-Dec-2000 Compiled from usenet postings to r.g.r.a and Angband source & documentation #####B Edited by Dawnmist (angband@dawnmist.8m.com) #####B for PernAngband 5.x.x on 03-Aug-2001 #####B with permission from Jim Lyon ~~~~~30 #####R====================================================================== #####R1. Introduction #####R====================================================================== #####G---------------------------------------------------------------------- #####G1.1 About this FAQ #####G---------------------------------------------------------------------- This FAQ is mean to be a companion to the standard ToME help files for using inscriptions, macros, and keymaps. The ToME help files which also describe them are listed in the "References" section. This documentation is for ToME, version 4.2.x. #####B================================== #####B SPOILER ALERT #####B================================== This document gives some information on how the game does or doesn't work that might be considered spoiling. (Most players advanced enough to use macros probably won't notice.) #####G---------------------------------------------------------------------- #####G1.2 Table of contents #####G---------------------------------------------------------------------- *****macrofaq.txt*30[1. Introduction] *****macrofaq.txt*5[2. Quick start tutorial] *****macrofaq.txt*32[3. Overview] *****macrofaq.txt*33[4. Common macros and techniques] *****macrofaq.txt*34[5. Common questions] *****macrofaq.txt*35[6. Common problems] *****macrofaq.txt*36[7. Inscriptions added by the game] *****macrofaq.txt*37[8. Keys and commands] *****macrofaq.txt*38[9. Pref files] *****macrofaq.txt*39[10. Macro editing commands] *****macrofaq.txt*20[11. Advanced macro techniques] *****macrofaq.txt*41[12. Problems] *****macrofaq.txt*42[13. Miscellaneous] #####G---------------------------------------------------------------------- #####G1.3 Notation #####G---------------------------------------------------------------------- #####BSingle Quotes (') These are generally used to delimit a single character to be typed in. These shouldn't by typed in themselves. #####BDouble Quotes (") These are generally used to delimit a sequence of characters to be typed in. These shouldn't by typed in themselves. #####BParentheses ( ) These are generally used for single-key Angband commands. #####BBraces { } These are used to enclose inscriptions. These aren't typed in as part of inscribing an item. They are added by the interface. #####G= Special Keys = #####G----------------------------------- The following abbreviations are used in this document. These keys may be named differently or missing on some keyboards. Some keys may be duplicated. These abbreviations shouldn't be typed in literally. For example, when F1 is encountered in a string of keys to press it means to press the F1 function key, not 'F','1', unless otherwise stated. Additional special keys may be listed later. Alt Alt Ctrl Control Del Delete Esc Escape Enter Enter / Return F1 Function key F1, ... Shift Shift #####G= System abbreviations = #####G----------------------------------- Each system that ToME compiles on has a semi-standard 3-letter abbreviation. These are commonly referred to in the source and docs using "xxx" as a "wildcard" standing for any one of them. In this document "***" is used instead because there are actual generic files not associated with any specific system that use "xxx". Sometimes this refers to a feature instead of a specific system: "xxx" is used for a generic / default file, and "new" is used for Adam Bolt's tiles. ~~~~~5 #####R====================================================================== #####R2. Quick Start Tutorial #####R====================================================================== This section is designed to get you quickly using the most common keymaps and macros. Later sections explain the techniques used in more detail. These examples may not be the "best" ones to use in real play. #####G---------------------------------------------------------------------- #####G2.0 Definitions #####G---------------------------------------------------------------------- First, you should know some fundamental terms: Actions are sequences of keypresses that the game can recognise. They can't be recorded by the game, but must be input manually. Macros and keymaps map a keypress to an action. They can be used to customise the keyboard, reduce typing, and speed up game play. Macros must be used when the trigger key doesn't have a system-independent representation. Keymap actions can only contain underlying commands. [[[[[BMost customisation should be done with keymaps instead of macros when] [[[[[Bthere is a choice.] Inscriptions are "markings" which you can put on any game item. One use is to label items in a way that doesn't depend on inventory position. Another allows verifying the selection of an item. Under the right conditions they can save your life. #####G---------------------------------------------------------------------- #####G2.1 Swap weapons #####G---------------------------------------------------------------------- First inscribe your main weapon: (Press the following keys in sequence) 1) { Inscribe an object 2) * Show inventory list 3) / Switch to equipment list 4) a Main weapon slot 5) @w0 Wield when object 0 is chosen 6) (Hit Enter) Now inscribe the second weapon: 1) { Inscribe an object 2) * Show inventory list 3) (Choose letter of second weapon) 4) @w0 Wield when object 0 is chosen 5) (Hit Enter) Finally, ToME (unlike standard 'Vanilla' Angband) does not have an automatic trigger key to swap items, so it must be created. Select a key that is not being used for any other commands ('X' in the normal keyset is free - see *****command.txt*0[command.txt]), and create the following keymap: 1) @ Interact with macros 2) 8 Create a keymap 3) X The trigger key for the keymap 4) w0 Wield object 0 5) (Hit Enter) 6) (Hit Esc to exit the editor) Now to swap weapons, just press the trigger key 'X' which is bound to the default keymap "w0". You may also press "w0" directly to swap. ~~~~~45|Macros|Macro recorder ~~~~~46|Keymaps|Macro recorder #####G---------------------------------------------------------------------- #####G2.2 Using the macro-recorder #####G---------------------------------------------------------------------- You may find all the key-presses involved in ToME a long and time-consuming way to play the game. There are ways to speed up repeated commands by assigning them to a trigger key which can help. These are called macros or keymaps. The most obvious use for these in ToME is for mage-types, especially sorcerors, who rely on their spells for just about everything. Typing mbaa*t in order to fire a Manathrust is fine if you only have to do it once or twice, but can quickly get annoying when you're doing it every move. Far easier to assign that sequence of keypresses to a single trigger key which you can then press as many times as you need. (Until your SP run out of course!) The easiest way to assign a macro is to use the macro-recorder. Start this by hitting the '$' key. You'll then receive a message telling you that the macro recorder has now started and you will need to press the '$' key a second time to stop the recorder. Preparation is all important here. It is best to be in a situation where you really NEED to cast the spell before recording the macro, so you use all the correct casting techniques and the game behaves as it would in a real (combat) situation (if the spell is to be generally cast in combat). So assuming we're going to create a macro for manathrust. We've walked into a room and there's a nasty small kobold. What do we do? 1) $ Start macro recorder 2) *t target monster (or player if no monster in Line of sight) 3) m open skills menu 4) @ enters verbose mode 5) Cast a Spell selects skill to use - CASE SENSITIVE 6) @ enters verbose mode 7) Manathrust casts spell from any book/spell container - CASE SENSITIVE 8) $ end macro recorder 9) y confirms macro keystrokes[[[[[B*] 10) (choose trigger key) 11) @ opens macro saving/loading screen 12) 2 appends macros to a file 13) (choose a name for the file, e.g. sorceror.prf) 14) (Hit Enter) 15) (Hit Esc to exit the editor) This will search for the spell in all your books and equipment. If it is found, in either a book or a wielded item that contains a spell, then the spell is cast at the targetted monster. This technique can be used for all the other skills as well (Use Mindcraft, Forge Ammo) etc. [[[[[B*]If you answer no the recorder continues recording keypresses. If you know you have made a mistake, you need to answer yes, and then not save the macro! ~~~~~12 #####G---------------------------------------------------------------------- #####G2.3 Prevent unwanted use of an item #####G---------------------------------------------------------------------- #####BPrevent "losing" an item by "accident": 1) { Inscribe an object 2) * Show inventory list 3) (Choose an item) 4) !d!k!v !d - don't drop (d) !k - don't destroy (k) !v - don't throw (v) 5) (Hit Enter) This prevents dropping, destroying, or throwing the item. You will be asked if you really want to do so. This is one of the most common inscriptions used, and one of the most useful. #####BPrevent "using" an item at all: 1) { Inscribe an object 2) * Show inventory list 3) (Choose an item) 4) !* Don't do anything with this item without verifying 5) (Hit Enter) This inscription is commonly used on Scrolls of Word of Recall... ~~~~~8 #####G---------------------------------------------------------------------- #####G2.4 Saving these macros and keymaps for reuse #####G---------------------------------------------------------------------- Save the macros and keymaps for reuse by the current character: 1) @ Interact with macros 2) 2 Append macros to a file (optionally enter a filename: e.g. dump.prf or dump.txt) (Hit Enter to save the file with the filename shown) 3) 6 Append keymaps to a file (Hit Enter to save the file with the filename shown) 4) (Hit Esc to exit the editor) This pref file will be automatically loaded any time a character with a name, race, or class matching the filename is loaded. The "Append macros/keymaps to a file" commands will append ALL current macros/keymaps to the given file. They will not overwrite the file. You should edit the file to remove macros that weren't added by you, to reduce clutter and prevent errors. Unfortunately the best way to do this is still "by hand". Open up the pref file in a text editor and remove the duplicate macros and keymaps added. These will be added after the headers "# Automatic macro dump" and "# Automatic keymap dump". The ones you added will be the very last ones in the list. The others are the entire set of keymaps and macros from all other prefs loaded. (This step isn't necessary, but is very helpful.) ~~~~~32 #####R====================================================================== #####R3. Overview #####R====================================================================== #####G---------------------------------------------------------------------- #####G3.1 Inscriptions #####G---------------------------------------------------------------------- Inscriptions are "markings" which you can inscribe on any game item. One common use is recording where you got one of your favorite items. Example: The Broad Sword 'Glamdring' (2d5) (+10,+15) {icky thing, 50'!} Another is to note important resists or activations on an item to make figuring out resist combinations easier. Example: The Nice Shiny Armor (-3) [35,+25] {resDk,resDis,A:Geno} Inscriptions can "number" an item so that you don't have to know where it is in your inventory. Example: inscribing your scrolls {@r1} lets you use '1' at the prompt for which scroll to read, instead of having to use the inventory letter, which can change unnoticed. Number inscriptions work together with macros to allow reproducible labeling of items independent of inventory position. Note that the game produces "fake" inscriptions, which look like real inscriptions, but are really just displayed the same way (e.g. "cursed"). Finally, if you are in symbiosis with another creature, you can name it by inscribing it with "#named SomeName" (the word "#named" must be entered literally at the start of the inscription). This will tell the game that your symbiotic partner should be referred to by its name, rather than simply "Your white jelly". This has no effect on game play other than the aesthetic. #####G---------------------------------------------------------------------- #####G3.2 Macros #####G---------------------------------------------------------------------- Macros are mappings from a single "logical" keypress to a sequence of keypresses, allowing you to use special keys on the keyboard, such as function keys or keypad keys, possibly in conjunction with modifier keys, to "automate" repetitive multi-key commands that you use a lot. [[[[[BFor keys which don't have a system-independent representation, such as] [[[[[Bfunction keys, this is the only way to change their behavior.] #####G---------------------------------------------------------------------- #####G3.3 Keymaps #####G---------------------------------------------------------------------- Keymaps are vaguely related to macros. A keymap maps a single keypress to a series of keypresses, which bypass both other keymaps and any macros. Angband uses keymaps to map the original and the roguelike keysets to the underlying command set, and allows the user to modify or add keymaps of their own. All keymap actions must be specified using underlying commands. Keymaps and macros aren't expanded. The original keyset is almost identical to the underlying keyset, except that "numbers" are mapped to ";" plus a direction, "5" is mapped to ",", and a few control-keys are mapped to various things. See *****command.txt*0[command.txt] for the full set of underlying commands. Keymaps also allow the "disabling" of a command by mapping it to "\x00". #####G---------------------------------------------------------------------- #####G3.4 Pref files #####G---------------------------------------------------------------------- Preference files save commands such as macros and keymaps which are used to customise the game. They are used to implement the "original" and "roguelike" keysets. They provide default appearances for items. They also implement the default behaviors which make Angband look and play the same (for the most part) on different systems. Pref files can be saved with the name of a player name, class, and race, and anytime a player with a matching characteristic is loaded, the appropriate pref file is loaded. This makes some customisations transparent and automatic. Pref files let you do some things that could otherwise only reasonably be done by changing the info files or source, such as changing the appearance of a given terrain feature, or the symbol used for the player. Pref files let you set up and save your favorite game options, and have them available for new characters without having to redo them. ~~~~~33 #####R====================================================================== #####R4. Common macros and techniques #####R====================================================================== ~~~~~13 #####G---------------------------------------------------------------------- #####G4.1 Clearing the command buffer #####G---------------------------------------------------------------------- [[[[[v++++++++++ This is one of the most important techniques! ++++++++++] Almost all action strings should begin with a sequence to clear the buffer of existing commands and messages. These sequences are often omitted in usenet postings and in this FAQ because they clutter the description, but they should almost always be used. If an unfinished command is still waiting for input when you press the trigger key of a macro or keymap, the characters of its action string will be taken as input for the command. The command will ignore keys it doesn't know how to handle until it finds one that it does. This often leads to something completely unexpected, with embarrassing results such as your death, or losing a really nifty item. If there are still messages waiting, the first characters in the action will instead just clear the waiting messages. How this happens depends on whether the *****option.txt*1[option (quick_messages)] is set. Then the action will start executing in the middle of its action string, with equally dangerous results as in the above case. Note that some messages caused by a command are quite rare, and others could be produced by a game state change like becoming hungry that has nothing to do with the command. These types of problems are more common when using an action such as auto-firing where a trigger key is repeatedly pressed. [[[[[B"\e\e\e"] Multiple escapes are used to clear the command buffer. Escape cancels any command/input still being processed, and also clears a [single] message whether/not the (quick_messages) option is set. This string should be used to begin all action strings. It is also wise to put it between actions in multi-action macros. Note that this technique can also be dangerous, hiding warnings or important information. Example: an action like "*tf1" would be changed to "\e\e\e*tf1". There are a few situations in which you do not want to use escapes. For example, after the spell Detect Monsters, an escape will clear the detection. Or if the action is part of a multi-part action or is meant to wait for user input such as the firing action "f1" which will wait for targeting information. [[[[[B"\s\s\s"] Spaces are useful for clearing messages, but won't cancel a command that is waiting for an item choice. Sometimes it is useful to split an action into two parts and bind them to two separate trigger keys. Prefixing spaces before the 2nd action will discard any remaining messages without canceling unfinished commands from the 1st one. Some players create a macro consisting of a large number of spaces to be used to clear a flood of messages. See sections: - *****macrofaq.txt*1["Messages and Questions"] for how to deal with them. - *****macrofaq.txt*2["My macro outputs "e - Floating Eye"..."] for an example of a common mistake using escape sequences. - *****macrofaq.txt*3["My macro drops/takes off my main weapon!"] for an example of the kind of thing that can go wrong when you fail to use them. - *****macrofaq.txt*4["What just killed me?"] for an example of skipping over messages *too* fast. #####G---------------------------------------------------------------------- #####G4.2 Swap weapons #####G---------------------------------------------------------------------- If you followed the *****macrofaq.txt*5[Quick-Start Tutorial] in Section 2.1, the 'X' key has the keymapping "w0", which will wield the first item inscribed as "@0" or "@w0". This will swap between 2 weapons which are both inscribed with {@0} or {@w0}. If there is more than one item in the inventory inscribed as 0, it will use the first one. This will also work for other wieldable items. For example, if you have a helm which gives telepathy, which can be a real pain when you need to rest, it can be used to swap it with another helm. Inscribing weapons with {@w1@w0}, {@w2@w0} allows directly wielding a specific one. If you don't want that ability, you can just inscribe both with {@w0}. These can also be inscribed as just {@1@0} and {@2@0} if you don't inscribe any other items with numbers, although this is not recommended. #####G---------------------------------------------------------------------- #####G4.3 Resting #####G---------------------------------------------------------------------- #####B= Rest as needed = "R&\r" R - rest & - until 100% healthy \r - return. Note that this isn't particularly dangerous, because the game will break out of the resting command if you are disturbed by hunger, sensing a monster, ... #####B= Rest for a specific duration = "R100\r" R - rest 100 - turn count \r - return This version is useful if you are already healed up. For fighter pseudo-id, for example. Also useful for recovering a fixed amount of mana before/after a spell, waiting for a Recall spell to kick in,... Note that this is one of the few times when you can directly enter the count after the command. Usually you need to enter the count before the command, using the (0) count command. #####B= Maximum Rest = "R9999\r" The maximum number of turns you can use as an argument. This can be useful when waiting for shop inventory to change, etc. Be sure to take off any non-permanent light source, and have plenty of food when you rest for long periods of time. #####G---------------------------------------------------------------------- #####G4.4 Activate the phial #####G---------------------------------------------------------------------- "Am\s\s" A - Activate m - light source (the phial). \s - skip message \s - skip message "Am\s\sR50\r" Activate the phial and rest for 50 turns. This can be bound to 'F' key since you won't need to refuel lanterns much after you have the phial :). #####G---------------------------------------------------------------------- #####G4.5 Kill item(s) on floor #####G---------------------------------------------------------------------- The need to destroy large numbers of items arises as one reaches deeper levels of the dungeon. The auto-squelch feature only partially reduces the need for this. The behavior of these actions is affected by the option (quick_messages), and the possible presence of a pile of items on the floor. *****option.txt*1[(quick_messages)] allows any key to cancel a message. In ToME, multiple items on the floor are displayed in a list. This allows the player to select an item from the floor by entering an item index when there is a pile (more than one item). This generally complicates writing these macros. Note that space '\s' is used to clear messages in the action strings, but one could use escape '\e' just as well. Note: you cannot destroy artifacts, so these macros are safer and more useful than they might first appear. The (k) Destroy item command will fail when trying to destroy an artifact, leaving any following characters in the action string, which may be interpreted differently than anticipated. [[[[[B"k-yy"] k - Kill item - - Select item from floor y - "yes" to query "Really destroy a ?" y - skip the "you destroy the " message. This version only works when (quick_messages) option is on. Here the last 'y' key gets rid of the last message, since any key will. This won't work for piles. The 'y' will be ignored as an invalid item choice. [[[[[B"k-y\s"] k - Kill item - - Select item from floor y - "yes" to query "Really destroy a ?" \s - skip the "you destroy the " message. This version works as above, but also when (quick_messages) is off. [[[[[B"0k-y\s"] 0 - enter count (causes to skip prompt for how many to destroy) k - Kill item - - Select item from floor \s - skip the "you destroy the " message. Destroy a single item on floor below you. Doesn't prompt for a count. This won't work for piles, which will prompt you for the item. Works correctly when (quick_messages) is off, because there is no prompt for how many to destroy. [[[[[B"0k-ay\e"] 0 - enter count (causes to skip prompt for how many to destroy) k - Kill item - - Select item from floor a - either item 'a', or ignored \e - escape (ignored), or cancel message Destroy a single item on floor below you. Doesn't ask to confirm. [[[[[vWARNING:] This action can destroy the first item in your inventory if there aren't any items on the floor below you! The leading '0' causes a prompt for a count to be skipped. If there is a pile, the 'a' key will select the top item in the pile. If not, the 'a' will aim a wand, the following 'y' will be ignored, and the final escape will cancel the aiming. [[[[[B"0k-yay\e"] 0 - enter count (causes to skip prompt for how many to destroy) k - Kill item - - Select item from floor y - "yes" to query "Really destroy a ?", or ignored. a - top item (a) in a pile, or activate wand. y - "yes" to query "Really destroy a ?" (for piles). \e - skip the "you destroy the " message. The above action will work in most cases. This version works correctly for piles. If there is a pile, the 'y' is ignored and the 'a' selects the top item. If there isn't a pile, then the 'y' will correctly answer the yes/no question "Really destroy a ?", and the following "ay" will aim a rod, and then ignore the 'y' key press, and the final escape will cancel the aiming. Works correctly when (quick_messages) is off. When (quick_messages) is on, and there is no pile, the 'a' will cancel the message, and the following 'y' will be passed through as an unimplemented command, and the space will cancel the error message. Backslashes "\\" may be required to keep the 'y's from being interpreted as keymaps in case 'y' has been assigned one. #####G---------------------------------------------------------------------- #####G4.6 Fire missile at nearest target #####G---------------------------------------------------------------------- Each of these needs "\e\e\e\e" afterwards to cancel up to 4 possible messages. The first message will always occur. Note that adding too many escapes can cause you to miss the messages in which the monster fights back. - "You have NN left. -more-" - "The hits the . -more-" - "It was a hit! The monster ... -more-" - "The dies/grunts with pain/..." [[[[[B"f*t"] f - fire ammo from quiver slot * - target t - select first target Note that targeting is affected by the option (*****option.txt*4[use_old_target]). If this action is used with the (use_old_target) option set, the "f" part will fire the missile before the targeting part "*t" is reached. See section *****macrofaq.txt*6["My auto-firing macro shoots the wrong target!"]. [[[[[B"*tf"] *t - select first target f - fire ammo from quiver slot If (use_old_target) is on, this works correctly, by selecting the target before firing. If the option is off, it will still prompt you to select a target, even though you just selected one. [[[[[B"*tf*t"] *t - select first target f - fire ammo from quiver slot *t - select first target This works correctly for (use_old_target) either on/off. If the option is on, this works by selecting the target before firing. If the option is off, the first target selection will be ignored, and firing will wait on the second target selection. Note that if there are no valid targets, "*t" will select the player's current position. Also, it is fairly easy to make safe assumptions about the (use_old_target) option, since a player doesn't tend to change back and forth. It is generally easier to make one set of actions that work for (use_old_target) on, and another for it off. Note also that the swapping weapon macro can be very useful for swapping the type of ammo in the quiver slot when you have two different sets of ammo you use - your standard "fire at everyone normal" ammo (usually not enchanted), and your big damage "Uniques and nasty monster" enchanted ammo. #####G---------------------------------------------------------------------- #####G4.7 Preventing actions #####G---------------------------------------------------------------------- #####B= Prevent selling = {!d} Prevent selling - use on main weapon, artifacts. #####B= Prevent going up/down = {^<} Verify before going up stairs. {^>} Inscribe boots to make confirm before going down stairs. This can also be useful on Charisma boosting items that you wear around town but don't want to take into the dungeon. {^>^r^z^m^p} Prevent leaving town with this item. Need to catch stairs, scrolls and rods of Recall, and Mage and Priest Word of Recall spells. #####G---------------------------------------------------------------------- #####G4.8 Warrior macros and inscriptions #####G---------------------------------------------------------------------- #####B= Identify with list = Inscribe Identify scrolls {@r0}. Then action "r0*" will cast Identify and bring up the inventory list. #####B= Identify floor = "r0-" will Identify without showing the inventory. #####G---------------------------------------------------------------------- #####G4.9 Verification techniques #####G---------------------------------------------------------------------- #####B= Verify All = {!*} verify any attempt to use this item. Useful for some things such as Scrolls/rods of Recall that you don't want to lose or use by accident. #####B= Verify drop, destroy, throw = {!d!k!v} don't drop, destroy, or throw this item. Prevents dropping your favorite weapon,... This is one of the most useful inscriptions, as it prevents the kind of typing accidents that can get you killed. #####B= Verify selling = {!d} Prevents selling as well as dropping. #####B= Multiple verification = These inscriptions can be repeated. So {!*!*} will make you confirm twice for any action using that item. #####G---------------------------------------------------------------------- #####G4.10 Canceling targeting #####G---------------------------------------------------------------------- [[[[[B"*\e\s"] * - start targeting \e - cancel targeting. \s - skip message "Target Aborted." OR [[[[[B"*q\r"] * - start targeting q - cancels targeting. \r - skip message "Target Aborted." This is useful before casting Stone to Mud, or a ball spell. For ball spells you usually want to target the middle of a pack, or sometimes to "miss" the creature in order to get the ball to detonate on a nearby wall. Using a targeted action after this will cause the user to be prompted for a target. Canceling targeting is made necessary by the existence of the option (use_last_target), which causes an action which requires a target to use the last target without prompting. See section *****macrofaq.txt*6["My auto-firing macro shoots the wrong target!"] for more on this. ~~~~~15 #####G---------------------------------------------------------------------- #####G4.11 Automatically loading pref files #####G---------------------------------------------------------------------- Angband automatically loads pref files when a character is loaded or born. Among the last ones loaded are: "<$RACE>.prf", "<$CLASS>.prf", and "<$PLAYER>.prf", in that order. These are the best ones to use to customise the game for individuals. The order is important because pref files which load later will overwrite options and macros/keymaps from previous ones. Here <$RACE> is the name of the character's race, <$CLASS> is the name of its class, and <$PLAYER> is the character's name. Both <$RACE> and <$CLASS> have a fixed number of choices. These are listed for ToME in section *****macrofaq.txt*7["Pref file loading order"]. Your character's name is the one that appears during game play in the upper left hand corner of the screen. If it isn't visible there, you can use the (C) Character description command. Note that this name may be different than the filename of the character's save file. Filenames for the save and pref files are built from a "base name", which is the player name with all non-alphanumeric characters changed to underscores (_). On Windows and DOS systems the base name will also be truncated to 8 characters. This could lead to different characters having the same (default) pref files. Example: "Grog the Elder" and "Grog the Younger" would both try to load the same pref file "Grog_the.prf". In recent versions of ToME "<$PLAYER>.prf" is the default filename when saving your macros and keymaps from the (@) Interact with macros screen. Just hit Enter to accept that name. On some systems you may encounter problems automatically loading this file if your name is more than 8 characters, or if it contains spaces or special characters. See section *****macrofaq.txt*8["Saving these macros and keymaps for reuse"] for how to save your character's preferences. See section *****macrofaq.txt*7["Pref file loading order"] for the full list of pref files loaded and their order. Note: for pref files to load automatically they must end in the file extension "prf", which is the default when saving pref files. But it is possible to save and load pref files with any or no file extension, from the macros and visuals editor screens. #####G---------------------------------------------------------------------- #####G4.12 Multiple macros bound to one trigger key #####G---------------------------------------------------------------------- Angband supports using modifier keys on trigger keys. One thing this lets you do is easily choose between variants of an action. Another is to minimise the amount of moving your hands have to do, speeding up play and reducing stress on your wrists. [[[[[BYou can bind multiple versions of the same macro to the same trigger] [[[[[Bkey, using Alt, Control, Shift in different combinations] to choose among the different versions. Example: use for targeted, and for non-targeted. Another use is to heavily use modifiers on numeric keypad keys. The standard version already comes with Shift- bound to running in that direction. But by using various combinations of modifier keys, it is possibly to play with the right hand almost always on the numeric keypad, and the left on the modifier keys. #####G---------------------------------------------------------------------- #####G4.13 Multi-part actions #####G---------------------------------------------------------------------- Better to only do this when spells have ~0% failure. Be careful of the order of commands. Commands that leave useful info on the screen shouldn't be followed by ones that will clear it. Be careful of commands that set or clear targets. Use "\e\e\e\e" in-between commands to be safe. #####G---------------------------------------------------------------------- #####G4.14 Easy running #####G---------------------------------------------------------------------- Bind Shift+ to running for each of the directions. For example, running "North": 1) @ Interact with macros 2) 4 Create a macro 3) Shift+8 (Trigger key for the macro) 4) \\. Run 8 "North" 5) (Hit Enter) 6) (Hit Esc to exit the editor) Macros for the other directions are added similarly. Remember that the original and roguelike keysets differ, but using the backslashes makes sure that the "underlying" keyset gets used: 7 8 9 4 6 1 2 3 These macros are already in the "pref-***.prf" files that ship with the standard Angband distribution for some systems, but not all. Systems "mac", "win", "x11" have them. If you aren't sure if you have them, just try moving in any direction with the shift key down. [[[[[BThese do have to be macros instead of keymaps], because they rely on keypad keys having different scan codes than the top-row number keys. There are also default macros for Ctrl+ which applies the command (+) Alter to that direction. #####G---------------------------------------------------------------------- #####G4.15 Farming techniques #####G---------------------------------------------------------------------- #####v+++ NOTE: This is considered scumming! (cheating) +++ Farming is the practice of automatically "harvesting" large numbers of weaker monsters for their experience value. This is usually done to advance a lower level character. There are apparently several methods that the "old timers" used to use. I don't know that farming is that popular any more. Even then it was sort of a lark. Apparently a golf ball is just the right size and weight for many keyboards to hold a key down and get it to auto repeat. Then you walk away, and the next morning you have gained several levels. Ballpoint pen caps are also supposed to be good at wedging a key down. Using a farming macro for long periods of time like this requires a way of getting food, so it really needs to be employed by a magic user who can create their own food. Use turn counts with attack (move) commands to move around the room, mowing down creatures as you move. Periodically rest enough to regenerate to full mana. This may not be necessary if it takes long enough to kill the monsters as you move. This requires an effective macro and a room full of breeders which can't attack for enough damage to kill you. Farming for short periods of time with a fighter class is quite feasible. The limitation for fighters is food. The limitation for spell casters is probably hit points. You may also need to insert action sequences for healing if the farmed monsters are capable of significantly damaging you. Note that red and green worm masses can knock down the doors of the room you're in. Blues can destroy potions and flasks, so you will need to stash your potions outside somewhere before farming. ~~~~~10 #####G---------------------------------------------------------------------- #####G4.16 Macros can contain their own trigger key #####G---------------------------------------------------------------------- It is permissible to make a macro or keymap which contains its own key in its action. It won't cause recursion, but there are a few wrinkles. Example: you can bind "*tf1" to the 'f' key, to cause it to auto-fire at the nearest target. You can still use the 'f' key for Fire in other macros or keymaps. If you bound 'f' as a keymap you will need to use "\\f" for Fire when it is used in a macro action string. You don't need to do anything special to use it in a keymap in its usual sense. Keymap and macro expansion isn't done inside keymap action strings. If you bound 'f' as a macro, the problem will be in entering the new macro or keymap in the editor. When you try to press an 'f' key for the action, it will expand to "*tf1", even when you don't want it to. You will first have to remove the macro bound to 'f', then add the macro or keymap that uses 'f' in its action, and then reenter the 'f' macro. You can also create the macro in a pref file and load it using the "Load pref file" command in the (@) Interact with macros screen. #####G---------------------------------------------------------------------- #####G4.17 Changing the player's color and character (ASCII text display) #####G---------------------------------------------------------------------- #####B= Using the Visuals Editor = 1) % Interact with visuals. 2) 6 Change monster attr/chars 3) a (repeatedly) cycle thru colors (A moves backwards) 4) c (repeatedly) cycle thru characters (C moves backwards) 5) Esc accept changes 6) Esc exit the editor #####B= Using the Enter User Pref command = 1) " Enter user pref line 2) "R:0::" The user pref line. - the attr (color) specified as an integer index. - the (ASCII) character specified as an integer. 3) (Hit Enter) You can't directly use the Angband attr letters to specify colors, but must instead use their index. Eg 4 is Red. These indexes can be found from within the game using the (&) Interact with colors command. That editor also allows you to change the colors used by the game. The integer is generally the index of an (ASCII) character. Non-ASCII characters may be available on some systems. Available characters can found using the (%) Interact with visuals command. These integers can be specified in decimal, hexadecimal, or octal notation. Decimal is the default, hexadecimal numbers are prefixed with "0x", and octal numbers are prefixed with 0 (zero). Example: the standard character for the player is '@'. This may be entered as "64", "0x40", or "0100". Yellow may be entered as "11", "0x0B", or "013". This pref line can be added to any pref file to save the change for future reuse. Changes made using the internal colors editor screen can be dumped from that screen. Note that colors and characters saved in pref dumps are in hexadecimal. After making a change, you must move the character or otherwise cause a screen redraw for the change to be visible. If you make a mistake, you can use the (0) command in the editor to reset the visuals to their original colors and characters. #####B= Changing Using the Monster Info file = #####B---------------------------------------- This may also be done by changing the entry for the player in the info file "r_info.txt". The player data starts with line "N:0:Player". In the following line G:: the character is entered directly, and the attr (color) is specified by letter. See the section "Message color lines" for the list of standard colors. In many versions you will have to delete the file "lib\data\r_info.raw" and restart the game for this change to take effect. Note that that char/attr pair is entered in the opposite order as for an R: user pref line. #####B= Options which Change Player appearance = #####B------------------------------------------ These are accessible through the (=) Set options command. *****option.txt*2[(hilite_player)] -- causes the player's symbol to be drawn with the "cursor" on it. It will be drawn with the same color as the character. #####G---------------------------------------------------------------------- #####G4.18 Recharging a rod using a Recharge Item spell #####G---------------------------------------------------------------------- (You can also recharge staffs and wands with this technique.) Inscribe the rod with {@m}, where is any decimal digit not already used as a label. The trick is that we want to use a digit to label the rod so we can refer to it using its label instead of its inventory letter, but we have usually used up many of the digits for spell books. If we were to label the rod with {@m1} and the first spellbook was also labeled with {@m1}, then the spellbook will sort first in the inventory so it will be found first when looking for item '1' to use with the (m) command. So that would try to recharge the spellbook, which will fail. Angband doesn't restrict itself to "appropriate" items when looking for a labeled item. It simply finds the first one whose command letter and digit match. You can't get around this by omitting the letter 'm', or using 'z' instead. Using no command letter means it will still match. And if you use a command letter it has to be 'm', because that is the built-in trigger for the current command. Note that the digits used with different command triggers can be different, so inscribing {@z1@m0} is perfectly legal. Use digit 1 when zapping the rod, and 0 when referring to it during the casting of a [mage] spell. You can also use this technique with scrolls. In that case you need to use the inscription {@r} since the item is being referred to while processing the (r) Read scroll command. #####G---------------------------------------------------------------------- #####G4.19 Disabling a built-in command #####G---------------------------------------------------------------------- At times it may be useful to disable an underlying Angband command. For example, a dangerous key may be too easy to press by accident. The macro editor commands for removing macros and keymaps can't be used in this situation. [[[[[BInstead bind the trigger key to the action] [[[[[Bstring "\x00"]. This special 'command' takes no "energy" and won't generate an error message. It truly does "nothing". This will work for both macros and keymaps. If possible you should use a keymap instead of a macro to disable the key. A keymap will catch occurrences of the key both in macros and by typing, and will still allow you to use the key when it isn't being interpreted as a command. If you use the "Query a macro/keymap" on a trigger key bound to this action, it will report having found it, but no action string will be printed. Another technique is to use the action "\e\e\e". This is used in some of the standard pref files. [[[[[BIf you need to use the built-in command again you can use the '\' key] [[[[[Bat any prompt to bypass its macro/keymap.] #####G---------------------------------------------------------------------- #####G4.20 "Naming" an item (patch) #####G---------------------------------------------------------------------- #####B= 'Fake artifact' name = # "Name" an item This isn't an actual command in the interface, but a flag character that alters the way an item description is generated. This isn't part of standard Angband. It's added by Tom Morton's 'fake artifact' patch. Example: inscription {#Thumper} will cause a Club (+8,+8) to display as Club 'Thumper' (+8,+8) in your inventory and messages. ~~~~~34 #####R====================================================================== #####R5. Common Questions #####R====================================================================== #####G---------------------------------------------------------------------- #####G5.1 Why can't I add a keymap for a function key? #####G---------------------------------------------------------------------- Because keymaps can only be created for keys with system-independent representations. This leaves out function keys, and several other special keys. The "Create a keymap" command will continue waiting for a keypress until you press a valid keymap trigger. You can, however, create a macro for a function key. #####G---------------------------------------------------------------------- #####G5.2 How can I automatically inscribe items when I pick them up? #####G---------------------------------------------------------------------- (Content removed because it was obsolete. Inscribe-on-pickup is now the default.) #####G---------------------------------------------------------------------- #####G5.3 Can I use macros inside other macros? #####G---------------------------------------------------------------------- No. Macros don't expand macro triggers they contain in their actions, in order to avoid recursion and other problems. However, keymap substitution is done, so you can use keymaps to alter the behavior of macros. This keymap expansion can be bypassed by preceding a trigger with "\\" in the action. Keymaps don't expand macro or keymap triggers in their actions. Also see section *****macrofaq.txt*9["Can I create an infinite loop using a macro?"]. #####G---------------------------------------------------------------------- #####G5.4 How do I find out what the standard commands are? #####G---------------------------------------------------------------------- 1) ? Angband help 2) 6 *****command.txt*0[Command Descriptions (command.txt)] Space - moves you down by a page Minus - moves up by a page 2 - moves down by a line 8 - moves you up by a line Note that the original and roguelike command sets differ, and both are different from the "underlying" command set. #####G---------------------------------------------------------------------- #####G5.5 How can I tell if a key has a keymap/macro? #####G---------------------------------------------------------------------- #####B= Query Macro/Keymap = In ToME this is easy: 1) @ Interact with macros 2) 3 Query a macro OR 7 Query a keymap 3) (Press the trigger key to test) 4) Esc (Exit macro editor when done) It will report "Found no macro" or "Found a macro" at the top of the screen. The action it is bound to will be displayed at the bottom of the screen, under the "Current action..." line. You must test for both macros and keymaps, and keymaps will only show for the current "mode", i.e. original/roguelike. #####B= Notes = Note: on some machines, there are duplicate keys such as left and right Shift keys. These will generally produce different key codes and can have different macros and keymaps. Note: just because a key doesn't have a macro doesn't mean there isn't a command that uses that key. #####G---------------------------------------------------------------------- #####G5.6 How can I tell if a key has a built-in command bound to it? #####G---------------------------------------------------------------------- Er ... try pressing the key. If there is a command bound to that key it should usually generate a message of some kind. If there isn't one, it may respond: "Type '?' for help.". Some keys may not generate any message at all. Function keys are a good example. In ToME, the game will also generate "silly" error messages which may not look like error messages at first. After a few repeated key presses it uses the standard "Type '?' for help." message. Failing that, look in *****command.txt*0["command.txt"], which lists all commands, and is up-to-date. There is no specific method for checking if a key has a command bound to it from within the game. #####G---------------------------------------------------------------------- #####G5.7 Can I inscribe multiple items with the same number? #####G---------------------------------------------------------------------- You can, but it can cause problems if you aren't careful. Use the command letter in the inscriptions to minimise problems. For example, it is safe to inscribe both rods with {@z1} and a spell book with {@m1} because the command letter allows distinguishing the two. When the game looks for an item to use with a command, it tries the first one it finds that matches. If the command fails on that item, it doesn't continue looking. The search for a matching item also doesn't know how to only check the right kind of item, so if you have a Spellbook inscribed {@1} and scrolls inscribed {@1} or {@r1}, when you read a scroll it will find the spellbook first, even though it doesn't make sense to read it, and the command will fail. #####G---------------------------------------------------------------------- #####G5.8 How do I convert a macro to a keymap? #####G---------------------------------------------------------------------- You can simply remove it and re-add it "by hand", but for more complex actions there are faster, safer ways. #####B= Directly modifying the pref file = A macro with the following form in the pref file: A: P:\r Should be converted to the keymap form: A: C:0: The "\r" needs to be removed, and the 0 (zero) means standard keyset. Use 1 for roguelike keyset. To make a keymap for both keysets: A: C:0: C:1: #####G= Using the "Interact with Macros" editor = 1) @ Interact with Macros 2) 3 Query a macro The trigger key for the macro (its action string will now become the current action) 3) 5 Remove a macro The trigger key for the macro 4) 8 Create a keymap The trigger key for the keymap 5) (Hit Enter to accept the current action) (Hit Esc to clear the message "Added a keymap") This technique can also be used to move or copy actions between macros or keymaps of the same kind. [[[[[BAnd old macro MUST be removed from a key] [[[[[Bbefore it can be used as the trigger key for a keymap], otherwise the macro action will expand when you press the trigger key in the editor. Converting a keymap to a macro doesn't require removing the keymap first. Note that not all macros can be converted to keymaps. Keymaps don't do macro or keymap expansion on their action strings, so macros that rely on this will no longer work. Also, keymaps can only be bound to a trigger key with a printable internal representation. For example, a function key can't be a trigger for a keymap. ~~~~~9 #####G---------------------------------------------------------------------- #####G5.9 Can I create an infinite loop using a macro? #####G---------------------------------------------------------------------- No. Well, okay, you can, but only if you work *really* hard at it and abuse bugs in the macro handling code. This isn't something that will happen by accident just by using the trigger key inside its action. You also can't create recursion. So don't worry about this. See the section *****macrofaq.txt*10["Macros can contain their own trigger key"] for more info. ~~~~~4 #####G---------------------------------------------------------------------- #####G5.10 What just killed me? #####G---------------------------------------------------------------------- When you are using lots of escapes and spaces in your macros to skip over messages, you can miss important things happening. One of these is dying. Usually when something goes wrong, you can just use the (^P) Previous Messages command to see what happened. But if you died the escapes can take you past the tombstone screen, your last chance to examine the previous messages list. This also happens without macros. To examine your recall, load the savefile and start a new character. You will then be able to use the message recall command to see the last messages of that character's previous incarnation. ~~~~~35 #####R====================================================================== #####R6. Common Problems #####R====================================================================== #####G---------------------------------------------------------------------- #####G6.1 My macro works all the time when I press its key! #####G---------------------------------------------------------------------- Macros *do* work all the time. Every time you press a key, macro expansion is done on it, and then keymap expansion. So if you use 'y' as a trigger key for a macro, and then you try and answer a yes/no prompt with 'y', instead you will get the macro's action string. The answer to this is to change your macro to a keymap. These can be bound to keys which have a system-independent representation in the game, which includes all keys that you would use when interacting with the game interface. If you don't want to change it to a keymap, try changing the trigger key to a "special" key, such as a function key. ~~~~~6 #####G---------------------------------------------------------------------- #####G6.2 My auto-firing macro shoots the wrong target! #####G---------------------------------------------------------------------- Your macro is probably firing at the previous target. This will happen if the option (*****option.txt*4[use_old_target]) is set. Then a macro will like "f1*t" or "m1a*t" will execute as: f Fire 1 Ammo inscribed 1 (it will now fire at the last [wrong] target) * Choose a [new] target t Accept first target If there are no valid targets, the (t) targeting command will centre on your position. If you move, the target will still be your old square. The first time you use the "f1*t" macro it will fire at that square, even if there is now a valid target (monster) nearby. One fix is to turn off the (use_old_taret) option, since the action doesn't require it. This is done with the (=) Set Options command. Another is to change the action to choose the target before it fires. Example: "*tf1". [[[[[BNote:] just because you can "see" a monster doesn't mean you can target it. The code used for vision (line of sight) and firing (projection) is slightly different. So when shooting near corners or pillars it may happen that you can "see" a monster but not target it. If your action kills messages at the end, you could keep hitting your auto-fire macro and the only thing happening would be a large pile of missiles quietly accumulating underneath you. #####G---------------------------------------------------------------------- #####G6.3 I used to have items inscribed, and now they aren't! #####G---------------------------------------------------------------------- The game only knows about inscriptions that you are carrying. There is no way to "store" them independently of a character's save file. So if you lose all of an item that was inscribed, picking up another of that kind won't automatically inscribe it. Normal inscriptions aren't affected by your player's "memory". Note that some items, when fully identified, could have their descriptions grow so long that no inscription will show. In that case you can use the (I) Identify command. It will display the full description, even if nothing special is known about that item. #####G---------------------------------------------------------------------- #####G6.4 I changed some macros in a pref file and nothing happened! #####G---------------------------------------------------------------------- Settings loaded in later pref files will overwrite earlier ones. So if you add macros for the same trigger key to files "<$CLASS>.prf" and "<$PLAYER>.prf", the second one will get used because its file loads later. This affects macros, keymaps, actions, attrs/colors, and other info. See section *****macrofaq.txt*11["Pref lines summary"] for all the types of settings that can be loaded. Also see section *****macrofaq.txt*7["Pref file loading order"]. #####G---------------------------------------------------------------------- #####G6.5 It moves me when I try to use my bow/rod/wand! #####G---------------------------------------------------------------------- Example: you type "f1" and it moves you in direction 1 (South West). What is happening is that the 'f' key isn't being handled correctly. It may be remapped to a bogus command, or one which doesn't take an argument. So the 'f' command is skipped/dealt with, and the '1' key is then treated as a direction. You can examine what is going on with the 'f' key using the (@) Interact with macros screen to check for any macros or keymaps bound to that key. Use the appropriate "Remove ..." command to restore the built-in Angband command. ~~~~~3 #####G---------------------------------------------------------------------- #####G6.6 My macro drops/takes off my main weapon! #####G---------------------------------------------------------------------- This is probably caused by an auto-fire macro like "*tm1a" for magic missile. If you hold down the trigger key to repeatedly use it, and some game event (possibly caused by the macro) creates a message, then the action will be interpreted as: * (cancel message) t Take off item m (ignored as invalid) 1 (ignored as invalid) a Item a (main weapon) If there is room in your inventory, it will be put there. If not, your inventory will overflow and it will be dropped on the ground. If this happens during combat this is a very good way to die. This is just another good reason to have {!d!k!v} on your main weapon. See the section *****macrofaq.txt*12["Prevent unwanted use of an item"]. This can be fixed by using the escape sequence "\e\e\e" before and after the action string to cancel any pending messages or commands. See the section *****macrofaq.txt*13["Clearing the command buffer"]. ~~~~~2 #####G---------------------------------------------------------------------- #####G6.7 My macro outputs "e - Floating Eye" on the message line! #####G---------------------------------------------------------------------- It is wise to add an escape sequence "\e\e\e" to the beginning and end of all macros for which this doesn't destroy useful information. See section *****macrofaq.txt*13["Clearing the command buffer"] for more information on this. But many players play on flavors of unix, which uses '/' as the path separator for files, and automatically type a forward slash when they mean to type a backslash. So many actions in macros/keymaps in usenet posts have the wrong type of slash. Angband "gurus" are perhaps more vulnerable to this than novices. The game sees this as: / Identify a character e Character to be identified And outputs "e - Floating Eye" on the message line. If this sequence gets expanded when you are trying to select an item, it will lead to different behaviors. Example: / Switch between inventory and equipment e Select item e. Or: / Switch between inventory and equipment e (ignored because invalid) Select item e. / Switch between inventory and equipment e Select item e. ~~~~~36 #####R====================================================================== #####R7. Inscriptions added by the game #####R====================================================================== Some inscriptions are added by the game itself. These can overwrite your inscriptions. There are also "fake" and "special" inscriptions, which "look" like real inscriptions to the player. #####G---------------------------------------------------------------------- #####G7.1 Fake inscriptions #####G---------------------------------------------------------------------- These "fake" inscriptions are "covered up" by real inscriptions, but will reappear if the real inscription is removed. "fake" inscriptions are unaffected by the uninscribe command (}). {cursed} - cursed item {empty} - item out of charges {tried} - a "flavored" item which the character has used, but whose effects are unknown. {N% off} - item bought on sale {quest} - this item is a quest item. It may need to be taken to someone. #####G---------------------------------------------------------------------- #####G7.2 Auto-inscriptions #####G---------------------------------------------------------------------- These added when your character gets a "feeling" about an item. In ToME these are "special" inscriptions, like "fake" inscriptions above, which don't overwrite user inscriptions. They just hide user inscriptions, which are still there. {terrible} - cursed or broken artifact {broken} - broken item {cursed} - cursed item {uncursed} - previously cursed item {average} {good} - good (magical) item {excellent} - ego item {special} - unique item {on sale} - displayed only in the store ~~~~~37 #####R====================================================================== #####R8. Keys and commands #####R====================================================================== This section gives short descriptions of keys and commands used in actions and trigger key representations. They are only listed in this section if they aren't fully described elsewhere in this FAQ. Not all of these keys are actually for "commands". See the normal Angband help for a fuller description of these commands. The commands and keysets are documented in *****command.txt*0["command.txt"]. #####G---------------------------------------------------------------------- #####G8.1 Keysets #####G---------------------------------------------------------------------- ToME supports two "keysets", which are fully customisable sets of keymaps. The "original" command set is close to the built-in commands, with some additions for ease of use such as number keys moving you in that direction. The "roguelike" command set allows easy movement on a keyboard without a numeric keypad. As a consequence its letter keys are almost completely "full". These used to be hard-coded by the game, but are now fully customisable. The default keymaps are in "pref.prf". #####G---------------------------------------------------------------------- #####G8.2 Item selection #####G---------------------------------------------------------------------- (*) - gives list of choices (-) - selects item on the floor (/) - toggles between the inventory and equipment lists. (space) - shows list of choices. Pressing (space) again hides the list. (lower) - selects the inventory item with that letter. (upper) - selects the inventory item with that letter, and requires confirmation. (digit) - selects first item inscribed with "@#" or "@x#" where 'x' is the command, and '#' is the digit. Only legal items are allowed. #####G---------------------------------------------------------------------- #####G8.3 Directions and Movement #####G---------------------------------------------------------------------- Original keyset directions 7 8 9 4 5 6 1 2 3 Roguelike keyset directions y k u h 5 l b j n #####B= Underlying command keys = ; - walk (with pickup) + - alter . - run Digits AREN'T built-in movement commands in ToME. They are actually keymaps found in the standard pref file "pref.prf". The digits are direction arguments to the (;) Walk command. #####G---------------------------------------------------------------------- #####G8.4 Escape sequences #####G---------------------------------------------------------------------- Many [non-printable] characters have a standard printable encoding which uses an "escape" character to change the meaning of the following character. The backslash character is used as in the C language for many keys. The caret '^' is used for control keys. #####B= Escape sequences = \b backspace \e escape \n newline \r return \s space \t tab \xNN hex ASCII char \\ (literal) backslash \^ (literal) caret #####B= Backslash = In a macro, "\\" followed by a character uses the "underlying" command for that character without translation. This is useful in macros to avoid keymaps changing the behavior of the macro. In particular this can be used to make macros which work for both original and roguelike keysets. Keymaps don't have this problem. #####B= Newline and Return = These two characters can be used interchangeably. #####B= ASCII chars = Any ASCII character can be encoded in this way. So many keys will have more than one representation. For example, [Enter] can be "\r", "^M", and "\x09". The backslash representations are case sensitive, so "\t" is [Tab], but "\T" will just be interpreted as "T". The hexadecimal number must be exactly 2 digits. #####B= Escape and Space = See section *****macrofaq.txt*13["Clearing the command buffer"] for their main uses. #####G---------------------------------------------------------------------- #####G8.5 Repeats and Counts #####G---------------------------------------------------------------------- #####B= Auto repeat = Some commands will automatically repeat. These are: (T) Tunnel (B) Bash (D) Disarm (o) Open (c) Close (+) Alter #####B= Number keys = 0 - starts a repeat count. Some commands take a repeat count argument. They can be entered as "0". If the command is movement, it can (must) be preceded by space(s) to separate the direction (command) number from the count number. ~~~~~1 #####G---------------------------------------------------------------------- #####G8.6 Messages and Questions #####G---------------------------------------------------------------------- #####B= Yes/No queries = Yes/No questions can be answered with 'y', 'n', or Esc. These are not case sensitive. Only 'y' or 'Y' will respond Yes. 'n', 'N', and Esc are No. If the option (quick_messages) is on, any other keypress is also No. When the option is off, it will keep waiting for a valid key. #####B= "-more-" message prompts = These may be cleared by Esc(\e), Space(\s), Enter(\r), or Newline(\n). If the (quick_messages) option is on, they can be cleared by any key. #####G---------------------------------------------------------------------- #####G8.7 Special keys #####G---------------------------------------------------------------------- #####B= Function keys = Function keys are free for reassignment, but only as macros. [[[[[BFunction] [[[[[Bkeys can be modified by Alt, Ctrl, Shift like other keys.] #####B= Alt keys = Alt-modified keys are generally free for reassignment as either macros or keymaps. #####B= Control keys = Control keys can be entered in as "^x" where 'x' is the key. Note that the case of 'x' is unimportant. This also allows typing control keys which would be intercepted by the operating system, such as ^C. You must type the caret '^' and the following key separately. Note that some have special meanings, such as ^M for Return, and ^H for backspace. Some also have special Operating System meanings, such as "^Z" in un*x, and "^C" in DOS. Control keys can be trigger keys for both macros and keymaps. #####B= Interrupting the game = (^C) This will kill your character and quit the game, after verifying. #####G---------------------------------------------------------------------- #####G8.8 Keys used in inscriptions #####G---------------------------------------------------------------------- #####B= Confirm command = ^ Confirm the following command. This isn't an actual command, but a character with a special meaning inside command strings. {^*} will confirm all actions for the item. ~~~~~38 #####R====================================================================== #####R9. Pref files #####R====================================================================== All pref files are loaded from and saved to folder "\lib\user". The folder "\lib\pref" is unused at this time! The location and name of this folder can be configured. Warning: the directory "\lib\pref" is unused by the game. Pref files moved there will never get used (unless the user has redirected the folder locations). Integers can be in hex "0x10", decimal "16", or octal "020" formats. These are converted using the C library fn strtol(), and are case insensitive. Decimal numbers start with '1'-'9'. Octal numbers must start with '0' (zero). Hex numbers start with '0x' or '0X'. #####G---------------------------------------------------------------------- #####G9.1 Standard Pref files #####G---------------------------------------------------------------------- Below "***" stands for the 3-letter system abbreviations, such as "acn", "mac", "win", "x11", ... "font.prf" Includes "font-***.prf" files. This file defines special attr/char mappings for "text" mode. "graf.prf" Includes "graf-***.prf" files. This file defines special attr/char mappings for "graphics" mode. "pref.prf" Includes "pref-***.prf" files. This file defines "default" actions of various kinds. This includes mapping the original and roguelike keysets to the underlying keyset. "user.prf" Includes "user-***.prf" files. This file defines "override" actions of various kinds. It includes the pref files based on system, race, and class. "xtra-***.prf" This file defines special attr/char mappings for "graphics" mode. Currently this just maps the player icon based on race and class. "new" refers to Adam Bolt's tiles. [[[[[vWarning:] you shouldn't edit the base pref files without a good reason, and understanding what you are doing. Breaking these files can make your game unusable. They are, however, the place to make changes that should affect all users. ~~~~~7 #####G---------------------------------------------------------------------- #####G9.2 Pref file loading order #####G---------------------------------------------------------------------- This loading order follows from the order of includes in "pref.prf". Files which are "hard-coded" in the source are preceded with an index. The rest are included by the other files. Files which come later will overwrite settings from earlier files. (1) "pref.prf" "message.prf" "pref-***.prf" (2) "graf.prf" "font-xxx.prf" "graf-***.prf" (3) "font.prf" "font-xxx.prf" "font-***.prf" (4) "user.prf" "user-***.prf" "<$RACE>.prf" "<$CLASS>.prf" (5) "<$PLAYER>.prf" (6) ".angband.prf" = $RACE = Can be one of any of the races in ToME. = $CLASS = Can be one of any of the classes in ToME. = $PLAYER = The name of the current player being loaded or born. See section *****macrofaq.txt*15["Automatically loading pref files"] for more information. #####B= Specific pref files = #####B----------------------------------- "user-mac.prf" This is the only user pref file with example macros that ships with ToME. A good set of examples. "pref-win.prf" This is the same as (missing) "pref-dos.prf" and "pref-ibm.prf". "colours.prf" Amiga only. Contains Amiga palette. ".angband.prf" Only on multi-user systems. This doesn't ship with the source. This file must be located in the directory contained in environ variable "HOME". ~~~~~11 #####G---------------------------------------------------------------------- #####G9.3 Pref lines summary #####G---------------------------------------------------------------------- Comment lines start with a '#' and extend to end of line. Note: integer values can be specified as decimal, as hexadecimal by preceding with an "x", or as octal by using a leading "0" (zero). E:: - attr/char values for inventory objects by index F::: - attr/char values for features by index K::: - attr/char values for objects by index R::: - attr/char values for monsters by index S::: - attr/char values for special things by index A: - action line An action line should be followed by a keymap trigger "C:" line or a macro trigger "P:" line. There can be intervening comments and lines. The same action will be [re]used by all keymap and command lines which follow it until there is another action line. P: - macro line a macro encoding of a keypress. (system dependent) C:: - keymap line 0 = "original, 1 = "roguelike". logical keypress, including backslash codes such as "\e" and control codes such as "^K". (system independent) Note that there are 2 independent sets of keymaps now. Changing a keymap in one doesn't affect the other. V::::: - specify visual information is the color index (0-255, only 0-15 used) black (?) value -- unused red value (0-255) green value (0-255) blue value (0-255) W::: - turn a window flag on/off. window number (1-7) (0-31) 0 = off, 1 = on X: - turn option off Y: - turn option on the name of an option in option_text[]. These are the names displayed in the options screen (=). ?: - conditional expression %: - include another pref file #####G---------------------------------------------------------------------- #####G9.4 Option lines "X:" and "Y:" #####G---------------------------------------------------------------------- Options and their descriptions are listed in help file *****option.txt*0["option.txt"]. These options are set within the game using the (=) Options command, and the option names are the ones displayed within parentheses in the options screen. #####B= Common options = rogue_like_commands use_old_target always_pickup alert_hitpoint auto_scum #####G---------------------------------------------------------------------- #####G9.5 Conditional expression lines "?:" #####G---------------------------------------------------------------------- expressions are lisp-like prefix notation. names (class, race, ...) aren't placed in quotes. AND - logical AND IOR - inclusive OR EQU - (string) equals NOT - logical negation LEQ - (string) less than or equal to GEQ - (string) greater than or equal to [,] - group expressions $CLASS - current class $GRAF - 3-letter graphics abbr in "graf-***.prf" (old, new) $PLAYER - current player name $RACE - current race $SYS - 3-letter system abbr in "pref-***.prf" (ami, mac, win,...) 0 - false 1 - true (can't just be non-zero) If the conditional expression is false all pref file commands encountered until the next conditional pref line are skipped. This isn't an actual command. It only works in pref files. The variables $CLASS, $GRAF, $PLAYER, $RACE, $PLAYER, $SYS and the string values they take on are case sensitive. The values also can't contain spaces. These constraints on the values hold when they are used in a pref file, but might not when used as pref filenames. This can be "turned back on" using the pref line "?:1", which is generally the last line in a file which contains conditional macros, to make sure that any files loaded after it don't get ignored as well. #####G---------------------------------------------------------------------- #####G9.6 Macro trigger lines "P:" #####G---------------------------------------------------------------------- All "special" keys are translated by "main-***.c" into encoded "macro triggers". These macro triggers have the encoded form "^_MMMxSS\r", where the "modifier" flags are stored in "MMM", and the two digit hexadecimal scan code of the keypress is stored in "SS". See source file "main-ibm.c" and others for more info. Note that because these scan codes are system-dependent, macro trigger encodings are as well. Keymaps are used for system independent mapping of triggers to actions. #####BModifier flags A - Alt C - Control S - Shift O - Option key (Mac) #####BIBM Scan codes x47 - keypad 7 x48 - keypad 8 x49 - keypad 9 x4A - keypad - x4B - keypad 4 x4C - keypad 5 x4D - keypad 6 x4E - keypad + x4F - keypad 1 x50 - keypad 2 x51 - keypad 3 x52 - keypad Ins / . x53 - keypad Del / Enter x45 - Pause Others can be found using the "Query a macro" feature. Note that scan codes can't be assumed to be "in order", even for keys like function keys which "logically" should be! Note that you can't always just add a modifier to a known scan code because that combination might not be recognised by the hardware or the translation code in "main-***.c". Example: a Windows system will recognise function key F1, Shift-F1, and Ctrl-F1, but not Ctrl-Shift-F1. Similarly Pause and Alt-Pause are recognised, but not Ctrl-Pause, and Shift-Pause gives the same encoding as Pause alone. #####G---------------------------------------------------------------------- #####G9.7 Saving to a pref file #####G---------------------------------------------------------------------- Commands "Append macros to file" and "Append keymaps to file" don't erase the previous macros or keymaps. Instead they are appended. Note that this can produce *large* files after a while. Newer versions append to "<$PLAYER>.prf" by default, whereas older versions appended to "user.prf". The appended sections are preceded by headers of the form "Automatic macro/keymap dump". Using a distinctive comment line such as ###... after your entries can make editing the appended ones easier. [[[[[BNote: macros and keymaps aren't saved in the character file, so they] [[[[[Bmust be saved separately. All macros and keymaps entered by the user] [[[[[Bare lost when Angband terminates.] Note: keeping macros in the <$PLAYER>.prf files allows several users to share the same installation without interfering with each other. You can easily reuse or share preferences by moving them into a pref file ".prf" and using the pref line "%:.prf" to include them in "user.prf" for single user installations, or <$PLAYER>.prf for multi-user installations. #####G---------------------------------------------------------------------- #####G9.8 Editing pref files #####G---------------------------------------------------------------------- This is still most easily done in a text editor. ~~~~~39 #####R====================================================================== #####R10. Macro editing commands #####R====================================================================== #####G---------------------------------------------------------------------- #####G10.1 (") Enter a User Pref Command #####G---------------------------------------------------------------------- This allows entering a single pref line. Example: "X:auto_scum" turns auto-scum off. Example "A:" sets the current action string. If you open the "Interact with macros" screen this action will be the default used. Then using the (") command again with "P:" will create a macro for the action previously entered. Not all pref commands can be used here, or are meaningful. The "pseudo" pref commands (?), (%) cannot be used here. See section *****macrofaq.txt*20["Advanced macro techniques"] for ways to [ab]use this. #####G---------------------------------------------------------------------- #####G10.2 (@) Interact with macros #####G---------------------------------------------------------------------- #####B= Vanilla command set = (2.8.3 - 2.9.1) #####B----------------------------------- Load a user pref file Append macros to a file Query a macro action Create a macro Remove a macro Append keymaps to a file Query a keymap Create a keymap Remove a keymap Enter a new action #####B= Load a user pref file = #####B----------------------------------- Loads a user pref file from "lib\user". Defaults to the name of the current character. Macros/keymaps loaded will replace existing ones. #####B= Append macros to a file = #####B----------------------------------- Macros are dumped in macro list order. Newer ones are at the end. Macros are *appended* to the file. The old one isn't overwritten. This prevents you from accidentally wiping out your old pref file. However, the file can grow very long without your noticing it. Placing a line of ###'s at the end of your macros can help sort out what is what. Macros are labeled with comment "# Macro 'NNN' ". These numbers are the internal macro list numbers, and have no relation to key scan codes. The filename must end in ".prf". It will save correctly without this extension, or with a different one, but if you save as "<$NAME>" instead of "<$NAME>.prf", it won't be automatically loaded when you load the character with that name. #####B= Query a macro = #####B----------------------------------- Press the trigger key to test at the prompt. This will show "Found a macro" on the message line if it found one, and the line "Trigger: ". This will show "Found no macro" on the message line if it didn't find a macro. Some keys such as function keys won't be recognised by the prompt. It will wait until you hit a key it recognises. This command doesn't alter any settings. It will return to the main menu after you hit any key it recognises. #####B= Create a macro = #####B----------------------------------- After choosing this command, press the trigger key for the macro. The internal form will be shown after the "Trigger: " prompt. Note that some keys may not be recognised for remapping, such as the new Windows keys, as well as modifier keys such as Alt, Control, Shift pressed by themselves. In this case it will continue to wait for a valid trigger key. The current action (if any) will be shown *below* the "Trigger: " prompt line. On the prompt line ("Action: ") will be shown the last macro sequence entered. This is the action in the "action buffer". This isn't necessarily the macro sequence currently bound to this key. This is the action that will be bound to the current trigger key if you hit Enter. You may type in an action string to replace the one after the prompt. Hit Enter when you are finished. For ToME you can quit the command assignment by hitting Esc. The new action entered won't be assigned, and the previous one will remain unaltered. #####B= Remove a macro = #####B----------------------------------- Removes the macro from the trigger key by creating an identity macro on that key for itself. So the macro isn't completely removed, just overwritten. The new identity macro will be saved when the macros are appended to a file. This is different from the "Remove a keymap" command, which completely removes the keymap. #####B---------------------------------------------------------------------- The following "keymap" commands only apply to the current "mode" (original/roguelike). Keymaps for the other mode will be unaffected. Because keymaps can only be bound to trigger keys which have a system independent representation, some key presses won't be recognised by these editing commands. They will instead wait until you press a valid trigger key. #####B---------------------------------------------------------------------- #####B= Append keymaps to a file = #####B----------------------------------- Works just like "Append macros to a file". These are appended after a header comment "# Automatic keymap dump". #####B= Query a keymap = #####B----------------------------------- Works just like "Query a macro". This will show "Found a keymap" on the message line if it found one, and will display "Keypress: ". This will show "Found no keymap" on the message line if it didn't find a keymap. This command doesn't alter any settings. It will return to the main menu after you hit any key it recognises. #####B= Create a keymap = #####B----------------------------------- Works just like the "Create a macro" command. Keymaps can only be assigned to keys which have a system independent representation. Note that creating a keymap will cause the behavior of any macro whose action string contains that key to change. #####B= Remove a keymap = #####B----------------------------------- Removes the keymap completely from the trigger key. If the key had a built-in command it can now be used again. Note that removing a keymap will cause the behavior of any macro whose action string contained that key to change. This behaves differently from the "Remove a macro" command, which creates an identity macro. If the original "command" was itself a keymap, removing a user-entered keymap won't restore it. Example: the key (n) is bound to the built-in command "Repeat last action" in file "pref.prf" via a keymap. If you add a keymap for (n) and then remove it, the "Repeat last command" functionality won't be restored. You will have to add it back by hand, or reload a pref file that contains that stored keymap. [[[[[BIn particular] [[[[[Balmost all roguelike commands are now implemented as keymaps.] #####B= Enter a new action = #####B----------------------------------- Allows entering a new action. Actions are entered into a static buffer which is shared by both macros and keymaps. The action string entered will become the default action for creating a keymap or action, and will only change when a keymap or macro is created with a different action string, or when one is queried. Note that the same action can be bound to multiple trigger keys by hitting Enter when using the commands to create a keymap/macro. ~~~~~20 #####R====================================================================== #####R11. Advanced Macro Techniques #####R====================================================================== This section outlines advanced techniques not really required for game play. But macros become addictive after a while ... Action strings in this section are enclosed in braces {} because many use a double quote (") inside the action string. These are not inscriptions. #####G---------------------------------------------------------------------- #####G11.1 Set current action using (@) command in an action #####G---------------------------------------------------------------------- {"@0\r\e} @ - Interact with macros 0 - Enter a new action - (action string) \r - Enter the action \e - Exit the macro editor This will work when bound to a macro. #####G---------------------------------------------------------------------- #####G11.2 Set current action using (") command in an action #####G---------------------------------------------------------------------- {"A:\r} - sets the current action. " - Enter pref line A: - Action line - (action string) \r - Enter the action This works in either a macro or keymap. #####G---------------------------------------------------------------------- #####G11.3 Create a new keymap using (") command in an action #####G---------------------------------------------------------------------- {"A:\r"C:0:\r} Here can't contain an '\r' or '\e'. Example {"A:z0\r"C:0:J\r} binds action "z0" to (standard) keymap 'J'. #####G---------------------------------------------------------------------- #####G11.4 Create a new macro using (") command in an action #####G---------------------------------------------------------------------- {"A:\r"P:\r} Here can't contain an '\r' or '\e'. Here is a standard key. (not a "special" one like F1, \b, or ^A) Example {"A:\r"P:j\r} binds action to trigger 'j'. {"A:\r"P:j\r} binds action to trigger 'j'. If we bind these 2 macros to different trigger keys, the action that is on key (j) can be swapped back and forth. #####G---------------------------------------------------------------------- #####G11.5 Turning an option on/off in an action #####G---------------------------------------------------------------------- Turn an option on: {"Y:\r} Turn an option of: {"Y:\r} Example: Turn (quick_messages) on, do an action, and turn it back off: {"Y:quick_messages\r"X:quick_messages\r} This will work in either a macro or keymap. is the name of the option as it appears in the option editor accessed through the (=) command. These are also listed in the help file *****option.txt*0["option.txt"]. Note that option names contain underscores instead of spaces. #####G---------------------------------------------------------------------- #####G11.6 Inscribe/Uninscribe an item in an action #####G---------------------------------------------------------------------- (These action strings are enclosed in double quotes) Inscribe an item: "{\s\r" Uninscribe an item: "}\r" must be the inventory letter of the item, possibly preceded by a '/' to switch to the equipment list. You can't use digit labels for items with inscriptions that contain the command triggers '{' or '}', but you can use "@". This will work in either a macro or keymap. ~~~~~41 #####R====================================================================== #####R12. Problems #####R====================================================================== #####G---------------------------------------------------------------------- #####G12.1 Keys to avoid remapping #####G---------------------------------------------------------------------- These don't really *need* to be avoided, but all carry dangers of one kind or another. You should think through potential problems before deciding to use them. You have been warned. #####B= Navigation keys = Enter, Esc, Backspace, ... These aren't a good choice unless you *really* need them. If you do it is far better to use keymaps. If you bind a macro to the Enter key, you will lose the ability to enter line-based commands like Inscribe. #####B= Commands generated internally = (_) Enter store This command is generated internally by the game when the player moves onto the door of a store. In some versions, if this key has a keymap bound to it, that will fire when you try to enter a store. #####B= Keys with important Operating System meanings = ^Z (un*x) Suspends the game and returns to the command shell. This is an operating system command, not an Angband command. Command "fg" returns to Angband. ^\, ^D, ^S These are keys that shouldn't be bound to macros or have their behavior altered. #####B= Keys with dangerous ToME meanings = (Q) Quit (commit suicide), (k) destroy item, (^A) Enter Debug mode... Using these as triggers is dangerous in case, for some reason, you wind up in a situation where the macro hasn't loaded or is disabled. You also don't want to get into a habit of typing these too fast. #####B= Selection keys = (e) Equipment, (i) Inventory, (-) Floor item, (/) Switch inventory lists. You should avoid binding these as macro triggers, to prevent making inventory and choice management next to impossible. But even as keymaps they hold some dangers. Example: you bind keymap on '-' to destroy item on the floor. Now if you try to do an action on a floor item, and it fails (such as using rod to identify), then the '-' can be taken from the input stream and used as a keymap, which would destroy the item you tried to identify. #####B= Response keys = (y) yes, (n) no, (Esc) cancel, (Space) skip message,... Binding macros to these is a [[[[[vVery Bad Idea.] Macro expansion will then be done when you answer a question like "Are you sure you want to quit the game without saving?". The expanded macro action string will be used as the input, and may not lead to the answer you were trying for. Keymaps don't have this problem. As a rule you should never use a macro instead of a keymap unless necessary. #####G---------------------------------------------------------------------- #####G12.2 Num lock #####G---------------------------------------------------------------------- Whether/not NumLock is on can make a difference for some macros. For example, if NumLock is on under X11 the 'X' macro won't work. #####G---------------------------------------------------------------------- #####G12.3 Recovering #####G---------------------------------------------------------------------- Restarting ToME clears all macros entered during the last session. You can use "Load a pref file" in the "Interact with macros" screen to reload a good set of prefs, overwriting bad ones being used. This will not "erase" a macro/keymap which doesn't have a corresponding saved one in the pref file. So if you add a macro/keymap to a trigger key which didn't have anything bound to it, reloading the pref file won't restore the key to its original state. If you still have problems, restore or edit any modified *.prf files that might be loaded. Try saving your macros, and examine them to see what went wrong. [[[[[BYou can use the backspace '\' key at the command prompt to use the] [[[[[Boriginal "underlying" command bound to that key. For example, if you] [[[[[Bbound the key '@' to a macro, you wouldn't be able to enter the macro] [[[[[Beditor to rebind it to itself.] Pressing '\' first, then '@' causes the command handler to use the built-in command, which allows you to enter the command editor. Note: when you use the backspace inside an action string, you have to double it as "\\". Do not use just a single back- slash, or it will be ignored, and possibly alter the meaning of the character that follows it. You can remove a macro/keymap from an essential key (such as the Esc key). Use the (@) "Interact with macros" command to access the remove commands. #####G---------------------------------------------------------------------- #####G12.4 Unrecognised keys #####G---------------------------------------------------------------------- #####B= Un*x = Function keys may not be recognised on some Un*x systems. #####B= PC/Dos/Windows = Doesn't recognise the WINDOWS key (start menu) or the APPLICATION key (context menu). On some systems, doesn't recognise modifier keys (Alt, Ctrl, Shift) on keypad keys when NumLock is on. See special_key_list[] in "main-win.c" for list of "special" keys that are recognised. #####G---------------------------------------------------------------------- #####G12.5 Nonexistent commands #####G---------------------------------------------------------------------- Macros and keymaps can only be bound to keypresses. The game state changing isn't a keypress, so you can't trigger an action when you become hungry, blind, confused, slowed, pseudo-id an item, pick up an item, gain a level, have a rod recharge, or any other event that isn't directly triggered by a keypress. "Attacking" also isn't a command, but you can use commands (+) Alter grid, (;) Walk, and (.) Run. So you don't really _attack_ Morgoth, you just _alter_ him. First he's alive, then he's not. :) #####G---------------------------------------------------------------------- #####G12.6 File permissions #####G---------------------------------------------------------------------- If you lack write permission to the pref file currently loaded by the game, try saving to a file with a new name. The macros can be copied over "by hand" later. ~~~~~42 #####R====================================================================== #####R13. Miscellaneous #####R====================================================================== #####G---------------------------------------------------------------------- #####G13.1 References #####G---------------------------------------------------------------------- *****command.txt*0["COMMAND.TXT"] - lists standard and roguelike keys and commands. full descriptions. - long description of command behavior. - intro to macros and user pref files. *****dungeon.txt*8["DUNGEON.TXT"] - look under "Objects Found in the Dungeon". *****option.txt*0["OPTION.TXT"] - list of options and their descriptions. "INSCRIPTIONS.HTML" - short intro by Julian Lighton. Available from "http://www.fragment.com/~jl8e/angband/inscriptions.html". #####G---------------------------------------------------------------------- #####G13.2 Contributors #####G---------------------------------------------------------------------- This FAQ was largely compiled from newsgroup postings to "r.g.r.a". So thanks to the generous contributors to the newsgroup! Email addresses have been removed to foil spam-bots. Ben Harrison -- maintainer: Angband 2.7.1 - 2.8.5, =Ben= in source. Robert Ruehlman -- maintainer: Angband 2.9.0 - present. DarkGod -- maintainer: PernAngband 2.9.9a - present Scott Bigham, DamonShawX, Jonathan Ellis, George W. Harris, Roger Hoyle, Graham S. Johnson, Chris Kern, Matthias Kurzke, Steve Lamb, Julian Lighton, Art Mruczek, Daniel Nash, Timo Pietilä, Jack Wise, Greg Wooledge, and others. #####G---------------------------------------------------------------------- #####G13.3 Legalese #####G---------------------------------------------------------------------- Copyright 2000 Jim Lyon and others. Redistribution of unaltered copies of this document is permitted without restriction. Distribution of altered copies is permitted without restriction as long as the alteration does not significantly alter the content. (For example, translation and conversion to another format is permitted.) Distribution of all other altered copies is permitted as long as credit for previous authors is maintained, the contact information is replaced with that of the alterer, and redistribution is not further restricted. Edited for PernAngband V5.x.x by Dawnmist with permission from Jim Lyon August 2001. All comments to angband@dawnmist.8m.com