The happiness of seizing one of these tall barriers to a room by the porcelain knob of its belly; this quick hand-to-hand, during which progress slows for a moment, your eye opens up and your whole body adapts to its new apartment.
— Francis Ponge (1899–1988), Les plaisirs de la porte
When is a door
not a door? It might be a rope-bridge or a ladder,
for instance. Inform provides doors for any situation in which some
game object is intermediate between one place and another, and
might on occasion become a barrier. Doors have a good deal in
common with containers, in that they need to be open to allow access and
to this end can also have openable
, lockable
or locked
. Just as with containers, any key they have
should be stored in the with_key
property. The same
actions Open
, Close
, Lock
and Unlock
all apply to doors just as they apply to
containers. There are four steps in creating a new door
:
door
attribute;door_to
property to the location on
the other side;door_dir
property to the direction which
that would be, such as n_to
;For example, here is a closed and locked door, blocking the way into the ‘Ruins’ Shrine:
Object Corridor "Stooped Corridor" with description "A low, square-cut corridor, running north to south, stooping you over.", n_to Square_Chamber, s_to StoneDoor; Object -> StoneDoor "stone door" with description "It's just a big stone door.", name 'door' 'massive' 'big' 'stone' 'yellow', when_closed "Passage south is barred by a massive door of yellow stone.", when_open "The great yellow stone door to the south is open.", door_to Shrine, door_dir s_to, with_key stone_key has static door openable lockable locked;
Note that the door is static
–
otherwise the player could pick it up and walk away with it.
(Experienced play-testers of Inform games try this every time,
and usually come away with a door or two.) The properties when_closed
and when_open
give descriptions appropriate for the door
in these two states.
A door is ordinarily only present on one side of
a map connection. If a door needs to be accessible, say openable or
lockable, from either side, then the standard trick is to make it
present in both locations using found_in
and to fix the
door_to
and door_dir
to be the right way
round for whichever side the player is on. Here, then, is a two-way door:
Object -> StoneDoor "stone door" with description "It's just a big stone door.", name 'door' 'massive' 'big' 'stone' 'yellow', when_closed "The passage is barred by a massive door of yellow stone.", when_open "The great yellow stone door is open.", door_to [; if (self in Corridor) return Shrine; return Corridor; ], door_dir [; if (self in Shrine) return n_to; return s_to; ], with_key stone_key, found_in Corridor Shrine, has static door openable lockable locked;
where Corridor
has s_to
set
to StoneDoor
, and Shrine
has n_to
set to StoneDoor
. The door can now be opened, closed, entered,
locked or unlocked from either side. We could also make when_open
and when_closed
into routines to print different descriptions
of the door on each side.
Puzzles more interesting than lock-and-key involve writing some code to intervene when the player tries to pass through. The interactive fiction literature has no shortage of doors which only a player with no possessions can pass through, for instance.
Care is required here because two different actions
can make the player pass through the door. In the Corridor above,
the player might type “s” or “go south”,
causing the action Go s_obj
. Or might “enter
stone door” or “go through door”, causing Enter
StoneDoor
. Provided the door is actually open,
the Enter
action then looks at the door's door_dir
property, finds
that the door faces south and generates the action Go s_obj
.
Thus, provided that the door is open, the outcome is the
same and you need only write code to trap the Go
action.
A neater alternative is to make the door_to
property a routine. If a door_to
routine returns false
instead of a room, then the player is told that the door “leads
nowhere”, like the broken bridge of Avignon. If door_to
returns true
, then the library stops the action on the
assumption that something has happened and the player has been told
already.
•
EXERCISE 20
Create a plank bridge across a chasm, which collapses if the player
walks across it while carrying anything.
•
EXERCISE 21
Create a locked door which turns out to be an immaterial illusion
only when the player tries to walk through it in blind faith.
• REFERENCES
‘Advent’ is especially rich in two-way doors: the steel
grate in the streambed, two bridges (one of crystal, the other of rickety
wood) and a door with rusty hinges. See also the iron gate in
‘Balances’.
•The library extension "doors.h"
by L. Ross Raszewski defines a class called Connector
of
two-way doors, which are slotted automatically into the map for convenience.
Max Kalus's further extension "doors2.h" enables
such doors to respond to, say, “the north door” from one
side and “the south door” from the other.