From eabde2ba37b57a8019604c9eb341878386535c3d Mon Sep 17 00:00:00 2001 From: Erik Lunna Date: Thu, 21 Sep 2023 20:22:21 +0200 Subject: [PATCH] Fix: Crash with Nighthorn curing and causing fear. --- hackem_changelog.txt | 1 + src/apply.c | 23 +++++++++++++++-------- 2 files changed, 16 insertions(+), 8 deletions(-) diff --git a/hackem_changelog.txt b/hackem_changelog.txt index ee72cc043..ab286ae4a 100644 --- a/hackem_changelog.txt +++ b/hackem_changelog.txt @@ -5,6 +5,7 @@ Version 1.2.1 (unreleased) +Fix: Crash with Nighthorn curing and causing fear. Imported rumors from SLASH'EM, SlashTHEM, UnNetHack, and xNetHack. Fix: Screamer's message when wearing a toque. Vampires and the vampiric race cannot eat even if polymorphed. diff --git a/src/apply.c b/src/apply.c index 9ddd18d1c..e56fc5690 100644 --- a/src/apply.c +++ b/src/apply.c @@ -2246,7 +2246,7 @@ void use_unicorn_horn(obj) struct obj *obj; { -#define PROP_COUNT 7 /* number of properties we're dealing with */ +#define PROP_COUNT 8 /* number of properties we're dealing with */ #define ATTR_COUNT (A_MAX * 3) /* number of attribute points we might fix */ int idx, val, val_limit, trouble_count, unfixable_trbl, did_prop; int trouble_list[PROP_COUNT + ATTR_COUNT]; @@ -2261,6 +2261,12 @@ struct obj *obj; if (obj && obj->cursed) { long lcount = (long) rn1(90, 10); + /* Always makes you afraid if cursed */ + if (obj && obj->oartifact == ART_NIGHTHORN) { + if (Afraid) /* No feedback when already afraid */ + pline("Nothing seems to happen."); + make_afraid((HAfraid & TIMEOUT) + (long) rn1(10, 5), TRUE); + } switch (rn2(15) / 2) { /* case 7 is half as likely as the others */ case 0: make_sick((Sick & TIMEOUT) ? (Sick & TIMEOUT) / 3L + 1L @@ -2328,6 +2334,8 @@ struct obj *obj; prop_trouble(STUNNED); if (TimedTrouble(HDeaf)) prop_trouble(DEAF); + if (TimedTrouble(HAfraid)) + prop_trouble(AFRAID); unfixable_trbl = unfixable_trouble_count(TRUE); @@ -2405,19 +2413,18 @@ struct obj *obj; make_deaf(0L, TRUE); did_prop++; break; + case prop2trbl(AFRAID): + if (obj && obj->oartifact == ART_NIGHTHORN) { + make_afraid(0L, TRUE); + did_prop++; + } + break; default: panic("use_unicorn_horn: bad trouble? (%d)", idx); break; } } } - - if (obj->oartifact == ART_NIGHTHORN) { - if (!obj->cursed && rn2(10) < chance) - make_afraid(0L, TRUE); - else if (obj->cursed) - make_afraid((HAfraid & TIMEOUT) + (long) rn1(10, 5), TRUE); - } if (did_prop) context.botl = TRUE;