Unify ad_pest

This commit is contained in:
Pasi Kallinen
2020-11-30 23:09:05 +02:00
parent cb55d7c30f
commit 2999233332
3 changed files with 30 additions and 4 deletions

View File

@@ -12,7 +12,6 @@ static void FDECL(missmu, (struct monst *, BOOLEAN_P, struct attack *));
static void FDECL(mswings, (struct monst *, struct obj *));
static void FDECL(wildmiss, (struct monst *, struct attack *));
static void FDECL(summonmu, (struct monst *, BOOLEAN_P));
static boolean FDECL(diseasemu, (struct permonst *));
static int FDECL(hitmu, (struct monst *, struct attack *));
static int FDECL(gulpmu, (struct monst *, struct attack *));
static int FDECL(explmu, (struct monst *, struct attack *, BOOLEAN_P));
@@ -853,7 +852,7 @@ boolean youseeit;
} /* were creature */
}
static boolean
boolean
diseasemu(mdat)
struct permonst *mdat;
{
@@ -1459,8 +1458,9 @@ register struct attack *mattk;
}
break;
case AD_PEST:
pline("%s reaches out, and you feel fever and chills.", Monnam(mtmp));
(void) diseasemu(mdat); /* plus the normal damage */
mhitm_ad_pest(mtmp, mattk, &g.youmonst, &mhm);
if (mhm.done)
return mhm.hitflags;
break;
case AD_FAMN:
mhitm_ad_famn(mtmp, mattk, &g.youmonst, &mhm);

View File

@@ -3241,6 +3241,30 @@ struct mhitm_data *mhm;
}
}
void
mhitm_ad_pest(magr, mattk, mdef, mhm)
struct monst *magr;
struct attack *mattk;
struct monst *mdef;
struct mhitm_data *mhm;
{
struct permonst *pa = magr->data;
if (magr == &g.youmonst) {
/* uhitm */
mhm->damage = 0;
} else if (mdef == &g.youmonst) {
/* mhitu */
pline("%s reaches out, and you feel fever and chills.", Monnam(magr));
(void) diseasemu(pa);
/* plus the normal damage */
} else {
/* mhitm */
mhm->damage = 0;
}
}
/* Template for monster hits monster for AD_FOO.
- replace "break" with return
- replace "return" with mhm->done = TRUE