X-Git-Url: https://jxself.org/git/?a=blobdiff_plain;ds=sidebyside;f=actions.c;h=682b03bd6cdecfa66e59203e967ef6552baf8cc8;hb=29b8f5b142d15f75cf37fc9c2cfd4b549d18d2d4;hp=df6bc2e3c215cb00338f7f8a54cdc9cd5990e47c;hpb=8ac4a59a678a6e522a0c70cca71f5e45896b2549;p=open-adventure.git diff --git a/actions.c b/actions.c index df6bc2e..682b03b 100644 --- a/actions.c +++ b/actions.c @@ -1143,17 +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. */ { - if (command->wd2 > 0) { - command->wd1 = command->wd2; - strncpy(command->raw1, command->raw2, LINESIZE - 1); - } - char word1[TOKLEN + 1]; - packed_to_token(command->wd1, word1); long wd; enum wordtype type; - get_vocab_metadata(word1, &wd, &type); + get_vocab_metadata(command->raw2, &wd, &type); if (wd == XYZZY || wd == PLUGH || wd == PLOVER || @@ -1163,11 +1157,9 @@ static int say(struct command_t *command) wd == FOO || wd == FUM || wd == PART) { - /* FIXME: scribbles on the interpreter's command block */ - wordclear(&command->wd2); - return GO_LOOKUP; + return GO_WORD2; } - sspeak(OKEY_DOKEY, command->raw1); + sspeak(OKEY_DOKEY, command->raw2); return GO_CLEAROBJ; } @@ -1360,7 +1352,7 @@ int action(struct command_t *command) switch (command->part) { case intransitive: - if (command->wd2 > 0 && command->verb != SAY) + if (command->raw2[0] != '\0' && command->verb != SAY) return GO_WORD2; if (command->verb == SAY) command->obj = command->wd2;