Skip to main content

Indie game storeFree gamesFun gamesHorror games
Game developmentAssetsComics
SalesBundles
Jobs
TagsGame Engines

That was just the first example that came to mind. I've had no end of trouble with implicit actions doing stupid things (as a player), so I avoid them like the plague (as an author). I've had quite a few games where I've come to write up the solution and the solution in my notes didn't work because the game had done some sort of implicit action that I was completely oblivious of and I had to do endless trial and error to try and work out what it was.

No thank you. No unexpected surprises in my games. If you want to see if the door is locked, try OPEN DOOR. If it's locked it will tell you. It won't magically select the long brass key from the key ring stored in your backpack and unlock and open the door on your behalf. If you want to unlock the door, you have to say so and you have to say how you want to unlock it. And if you want to open the door, you have to explicitly say OPEN DOOR.

I agree with you on this one, Garry, although maybe that's because I like to make my doors complicated!  I always seem to end up having reams of stuff that happens on_unlock and on_open...

Unlock door: you unlock the door with the key.  Open door: as the door creaks open, a growl emits from the room inside, and in the dull light you spot a wild dog chained to the wall, looking at you balefully...

Can't remember the last time I coded a door that was just a door :)

I might argue the opposite in some cases. It might be more of an unexpected surprise to be required explicitly to carry out an implicit action.

I'd never implicitly unlock a door (as I say, that's usually a puzzle to solve in itself) but I might implicitly open it. And in real life, I'd have to apply some minimal thought to unlocking a door, but not to opening it. Similarly, if I had a cup of coffee in front of me on the table at which I was sitting, in a game, then I'd be tempted to allow 'drink coffee' to do the work of grasping the cup and bringing it into proximity with my lips without reporting 'you don't have the coffee' and then expecting the player to get the coffee before they drink it. As in reality, so in a game: automatic actions that would distract , if made explicit, from the more important things that a person needs to consciously attend to can remain safely implicit. In many, if not all, cases.

All games have an inventory limit. (You probably don't like that either.) The implicit TAKE prior to DRINK causes all sorts of inventory management issues. If your inventory is full prior to DRINK COFFEE, do you:

  • Tell the player they can't carry any more (and cause them some confusion because they weren't trying to pick something up).
  • Allow them to exceed the inventory limit in order to carry out the action (and possibly break future inventory limit checking in the process).
  • Drop a random object in order to allow them to pick up the coffee (and break the precious Ming vase in the process).
  • Allow them to drink the coffee and put down the empty cup so as not to exceed the inventory limit (but do they put down the empty cup when they were already carrying the coffee).

There are all sorts of other scenarios, but this gives you a small sample of some of the problems involved when you allow implicit actions. This all requires a hell of a lot of extra coding that is not needed when you don't allow implicit actions and is far less confusing to the player in the long run.

Inform has the concept of a "sack" object. (This idea is taken from Zork.) If you try to pick something up when your inventory is full and you are carrying the sack object and it is not full, then it picks an item at random and puts it in the sack, then picks up the coffee so that you can drink it.

I remember a game where you couldn't pick up the coffee because it was too hot. What do you do then?

In my last game (a future entry in IFComp 2020), I wanted the player to be able to PUT WATER IN BUCKET. The library would not allow anything to be put in a container unless it was held first, so it would implicitly try to get the water (this is similar to your implicitly getting the coffee), but you can't get the water. That's why you need the bucket in the first place. So it was impossible to put the water in the bucket without modifying the standard grammar.

Do you see what I mean yet?

My point is that you have to be consistent. If you're going to allow an implicit action in one particular scenario, then you have to allow it in all sensible scenarios. This leads to a hell of a lot of extra coding and possible confusion to the player. In every game that I've ever played that allows implicit actions, I've actually ended up taking more moves than had there not been any implicit actions. This is because I am very thorough when playing a game in order to write up the solution for CASA.

In the old days of two-word input, the indirect object was always implied. This was unavoidable because of the limitations of a two-word parser. But implicit actions are quite different to implicit objects. Think it through carefully before you decide to go the implicit actions route.

Aren't some of the problems you're talking about also exist with "ALL" ?

Generally not, because ALL is only allowed with a limited number of verbs, typically GET and DROP. (I don't think I've ever seen a game that allows EXAMINE ALL, except maybe some Infocom games.) You can only get something that is not carried and drop something that is carried. Inform 6 has an "entry point routine" called ChooseObjects that you can customise to define what's acceptable for an ALL operation for a particular verb. For example, when you GET ALL, you don't want it trying to get scenery and giving a long list of rejection messages. Adventuron doesn't have anything equivalent to ChooseObjects, but the default GET ALL and DROP ALL now work fairly well after the feedback received in earlier game jams.

In a recent discussion on intfiction.org, I spoke about the complications of WEAR ALL when you have layered clothing and presented a little test program to illustrate the point. In this scenario, it was actually more efficient to wear the individual items of clothing than to WEAR ALL and have half the items give rejection messages. For example, if WEAR ALL resulted in the shirt being worn before the singlet, when it got to the singlet it would say, "You'll have to take the shirt off first." So you then had to do an inventory to see what you were wearing, remove a number of items and wear all the items again individually.

In case you haven't worked it out by now, I love writing about game theory as it applies to adventures. This comes from 40 years' experience playing, writing and writing about adventures. So please forgive me if you find this boring, but it's meant to be thought provoking.

Here's some more thoughts on the problems of an implicit OPEN after UNLOCK.

How many turns does it take to do an implicit open after unlock? One or two? With non-implicit unlock and open, it takes two turns, as there are two explicit commands resulting in two explicit actions and these actions can be separated in time. A common sequence would be UNLOCK DOOR WITH KEY. DROP KEY. OPEN DOOR. That's clearly 3 turns. With implicit actions, it should be the same, so you have to manually increment turns after the initial UNLOCK.

What happens if you attempt to UNLOCK DOOR when it's already unlocked? You can't unlock it again. Do you just give an error response or do you open the door, even though that's not what the player asked for?

From the above, it should be pretty obvious that you can't just make UNLOCK and OPEN synonyms, otherwise you would be able to say UNLOCK DOOR when it wasn't locked in the first place.

Earlier, I said that you must be consistent so as not to surprise the player with seemingly nonsensical responses. Therefore, if you have a locked box or a locked chest, these should also be automatically opened after an UNLOCK command if you have an implicit OPEN. But what happens if you don't want them automatically opened? Consider Pandora's box. You need to unlock it, but you don't want to open it or you'll unveil the horrors within. I recall a game like this where you had to unlock the box, but not open it and give the unlocked box to a monster. When the monster opened the box, the monster was killed when the contents of the box escaped. With your automatic OPEN after UNLOCK, it would be impossible to complete the game, because unlocking the box also opens it and the contents kill you.

Chris mentioned 'The Witch's Apprentice'. It contains a puzzle near the beginning where you need to unlock the front door, but you don't do it using a key. Are you suggesting that the unlock operation should also open the door, even when there's no one in the vicinity to do it? I don't think so.

What happens with LOCK and CLOSE? If you close the door, is it automatically locked? You were suggesting that it should be because that's what you would "naturally" do in the real world. But what if you've dropped the key somewhere? And what happens if you try to LOCK the door when it's open? You can't do this in real life. Are you suggesting that you should automatically close the door first, then lock it? Then we're back to the same problem the key is missing.

So, carefully consider ALL the consequences of using implicit OPEN after an UNLOCK.

Thanks Garry, for this disquisition. There is clearly a lot to think about here, but for the sake of expediency I must rely on intuition and be damned. I'm really looking forward to seeing how everyone's differing approaches translate into their games!

(1 edit)

I certainly don't mind the "busywork" of unlocking and opening a door but I don't think that auto-wiring it is evil either unless there is a serious innovation in unlocking the door with something that isn't a carried key.

I do have a fondness for attaching events to open and close (as in spooky castle).  Spooky Adventure featured this kind of tactility, and so did Witch's Apprentice.