Change state of vase

Clear temporary save where it needs to be cleared instead of random places
This commit is contained in:
NHOrus 2017-07-01 18:23:51 +03:00
parent ab79fc7814
commit 3c8482a613
3 changed files with 20 additions and 16 deletions

View file

@ -224,24 +224,25 @@ static void blast(void)
static int vbreak(token_t verb, token_t obj) static int vbreak(token_t verb, token_t obj)
/* Break. Only works for mirror in repository and, of course, the vase. */ /* Break. Only works for mirror in repository and, of course, the vase. */
{ {
int spk = actions[verb].message; if (obj == MIRROR) {
if (obj == MIRROR) if (game.closed) {
spk = TOO_FAR;
if (obj == VASE && game.prop[VASE] == 0) {
if (TOTING(VASE))
drop(VASE, game.loc);
game.prop[VASE] = 2;
game.fixed[VASE] = -1;
spk = BREAK_VASE;
} else {
if (obj == MIRROR && game.closed) {
rspeak(BREAK_MIRROR); rspeak(BREAK_MIRROR);
return GO_DWARFWAKE; return GO_DWARFWAKE;
} } else {
} rspeak(TOO_FAR);
rspeak(spk);
return GO_CLEAROBJ; return GO_CLEAROBJ;
} }
}
if (obj == VASE && game.prop[VASE] == VASE_WHOLE) {
if (TOTING(VASE))
drop(VASE, game.loc);
state_change(VASE, VASE_BROKEN);
game.fixed[VASE] = -1;
return GO_CLEAROBJ;
}
rspeak(actions[verb].message);
return (GO_CLEAROBJ);
}
static int brief(void) static int brief(void)
/* Brief. Intransitive only. Suppress long descriptions after first time. */ /* Brief. Intransitive only. Suppress long descriptions after first time. */

View file

@ -3081,7 +3081,6 @@ arbitrary_messages: !!omap
- DONT_UNDERSTAND: 'I''m afraid I don''t understand.' - DONT_UNDERSTAND: 'I''m afraid I don''t understand.'
- HAND_PASSTHROUGH: 'Your hand passes through it as though it weren''t there.' - HAND_PASSTHROUGH: 'Your hand passes through it as though it weren''t there.'
- BREAK_MIRROR: 'You strike the mirror a resounding blow, whereupon it shatters into a\nmyriad tiny fragments.' - BREAK_MIRROR: 'You strike the mirror a resounding blow, whereupon it shatters into a\nmyriad tiny fragments.'
- BREAK_VASE: 'You have taken the vase and hurled it delicately to the ground.'
- PROD_DWARF: 'You prod the nearest dwarf, who wakes up grumpily, takes one look at\nyou, curses, and grabs for his axe.' - PROD_DWARF: 'You prod the nearest dwarf, who wakes up grumpily, takes one look at\nyou, curses, and grabs for his axe.'
- THIS_ACCEPTABLE: 'Is this acceptable?' - THIS_ACCEPTABLE: 'Is this acceptable?'
# This message is not currently used # This message is not currently used
@ -3678,6 +3677,10 @@ objects: !!omap
- [VASE_RESTING, 'The vase is now resting, delicately, on a velvet pillow.'] - [VASE_RESTING, 'The vase is now resting, delicately, on a velvet pillow.']
- [VASE_BROKEN, 'The floor is littered with worthless shards of pottery.'] - [VASE_BROKEN, 'The floor is littered with worthless shards of pottery.']
- [VASE_DROPS, 'The ming vase drops with a delicate crash.'] - [VASE_DROPS, 'The ming vase drops with a delicate crash.']
changes:
- ''
- ''
- 'You have taken the vase and hurled it delicately to the ground.'
- EMERALD: - EMERALD:
words: ['emera'] words: ['emera']
inventory: 'Egg-sized emerald' inventory: 'Egg-sized emerald'

View file

@ -70,7 +70,7 @@ savecheck: savegames
advent -l / < pitfall.log > /tmp/coverage_advent_logfail 2>&1 || exit 1 advent -l / < pitfall.log > /tmp/coverage_advent_logfail 2>&1 || exit 1
$(ECHO) "TEST advent: Test -r with valid input" $(ECHO) "TEST advent: Test -r with valid input"
advent -r thousand_saves.adv < pitfall.log > /tmp/coverage_advent_readfail 2>&1 || exit 1 advent -r thousand_saves.adv < pitfall.log > /tmp/coverage_advent_readfail 2>&1 || exit 1
rm -f scratch.tmp /tmp/coverage* rm -f /tmp/coverage*
# General regression testing of commands and output; look at the *.log and # General regression testing of commands and output; look at the *.log and
# corresponding *.chk files to see which tests this runs. # corresponding *.chk files to see which tests this runs.
@ -82,6 +82,6 @@ regress:
then diff --text -u $${file}.chk /tmp/regress$$$$ || exit 1; \ then diff --text -u $${file}.chk /tmp/regress$$$$ || exit 1; \
else echo "*** Nonzero return status on $${file}!"; exit 1; fi \ else echo "*** Nonzero return status on $${file}!"; exit 1; fi \
done; \ done; \
rm -f /tmp/regress$$$$ rm -f scratch.tmp /tmp/regress$$$$
# end # end