X-Git-Url: https://jxself.org/git/?p=open-adventure.git;a=blobdiff_plain;f=actions.c;h=5433a7dad1c0839b90e09f4b2264a66302d64784;hp=209d257658ba3766d463487234a4ee28a4e8df47;hb=08c40bc9993ce5684077b9ceac492e4fb642a722;hpb=4e01669e06cebde88437935fd2b2938406cddcb5 diff --git a/actions.c b/actions.c index 209d257..5433a7d 100644 --- a/actions.c +++ b/actions.c @@ -1143,13 +1143,11 @@ static int rub(verb_t verb, obj_t obj) } static int say(struct command_t *command) -/* Say. Echo WD2 (or WD1 if no WD2 (SAY WHAT?, etc.).) Magic words override. */ +/* Say. Echo WD2. Magic words override. */ { - char word2[TOKLEN + 1]; - packed_to_token(command->wd2, word2); long wd; enum wordtype type; - get_vocab_metadata(word2, &wd, &type); + get_vocab_metadata(command->raw2, &wd, &type); if (wd == XYZZY || wd == PLUGH || wd == PLOVER || @@ -1357,7 +1355,10 @@ int action(struct command_t *command) if (command->raw2[0] != '\0' && command->verb != SAY) return GO_WORD2; if (command->verb == SAY) - command->obj = command->wd2; + /* KEYS is not special, anything not NO_OBJECT or INTRANSITIVE + * will do here. We're preventing interpretation as an intransitive + * verb when the word is unknown. */ + command->obj = command->raw2[0] != '\0' ? KEYS : NO_OBJECT; if (command->obj == NO_OBJECT || command->obj == INTRANSITIVE) { /* Analyse an intransitive verb (ie, no object given yet). */