Inform 7 Home Page / Documentation


Chapter 17: Understanding

§17.1. Understand; §17.2. New commands for old grammar; §17.3. Overriding existing commands; §17.4. Standard tokens of grammar; §17.5. The text token; §17.6. Actions applying to kinds of value; §17.7. Understanding any, understanding rooms; §17.8. Understanding names; §17.9. Understanding kinds of value; §17.10. Commands consisting only of nouns; §17.11. Understanding values; §17.12. This/that; §17.13. New tokens; §17.14. Tokens can produce values; §17.15. Understanding things by their properties; §17.16. Understanding things by their relations; §17.17. Context: understanding when; §17.18. Changing the meaning of pronouns; §17.19. Does the player mean...; §17.20. Multiple action processing; §17.21. Understanding mistakes; §17.22. Precedence

arrow-up-left.png Contents of Writing with Inform
arrow-left.png Chapter 16: Tables
arrow-right.png Chapter 18: Activities
arrow-down-right.png Indexes of the examples

§17.1. Understand

During play, the computer and the player alternate in writing messages to each other: in the player's case, these are short instructions, usually saying what to do next. A wide range of such "commands" are automatically understood, but these only apply to the standard built-in actions. (This wide range is conveniently tabulated in the Commands part of the Actions index.) If we want the player to be able to command new actions, then we need to specify what is to be understood as what. For this, we supply special sentences starting with the word "Understand".

Suppose we return to the earlier example of a newly created action:

Photographing is an action applying to one visible thing and requiring light.

We then supply lines of grammar (as they are called) for Inform to recognise, like so:

Understand "photograph [someone]" as photographing.

Understand "photograph [an open door]" as photographing.

As usual, the square brackets indicate something which stands for text, rather than text to be taken verbatim. "[someone]" needs to be the name of anything of the kind "person", for instance (though as usual that person will need to be in sight of the player for the name to be accepted). The first word - in these examples "photograph" - must be something definite, not a substitution like this.

For obvious reasons, this pattern of words needs to match the expectations of the action. Photographing applies to "one visible thing" - the "visible" just means it does not need to be touched, only seen - so neither of these would be allowable:

Understand "photograph" as photographing.
Understand "photograph [someone] standing next to [something]" as photographing.

The first is probably bad because it supplies no things at all, the second is certainly because it supplies two: what we want, of course, is just the one. (The reason the first is only probably bad is that it's possible to tell Inform how to choose the object if the player doesn't: see the "supplying a missing noun" activity.)


arrow-up.png Start of Chapter 17: Understanding
arrow-left.png Back to Chapter 16: Tables: §16.19. Table amendments
arrow-right.png Onward to §17.2. New commands for old grammar

*ExampleIndirection
Renaming the directions of the compass so that "white" corresponds to north, "red" to east, "yellow" to south, and "black" to west.

*ExampleXYZZY
Basics of adding a new command reviewed, for the case of the simple magic word XYZZY.

**ExampleXylan
Creating a new command that does require an object to be named; and some comments about the choice of vocabulary, in general.