From fa20ef382d389eb214e643b86a3638975cc2d4a5 Mon Sep 17 00:00:00 2001 From: PatR Date: Wed, 13 Jan 2016 19:13:10 -0800 Subject: [PATCH] status line update Adding deafness to the status line spurred me on to something I've wanted to do for a long time. This adds 'Stone' and 'Strngl' as new status conditions, and moves the five fatal ones: "Stone Slime Strngl FoodPois TermIll" to the front of the status list since information about them is more important than any of the others. "Ill" has been renamed "TermIll"; "Df" has been renamed "Deaf"; "Lev", "Fly", and "Ride" are three additional new conditions, with Lev and Fly being mutually exclusive. After the fatal ones, the order of the rest is now Blind Deaf Stun Conf Hallu Lev Fly Ride To handle the longer potential status line, the basic bot2() is now smarter. If the line is wider than the map, 'T:moves' is moved from the middle to the end. If the line without time is still wider than the map, then experience (HD if polyd, Xp:M/nnnnnn is showexp is on, or Exp:M) is moved in front of time at the end. If the line without experience and time is still wider than the map, dungeon level plus gold is moved from the beginning to be in front of experience. The fields are just reordered, not truncated, so if the interface code can display lines wider than the map they'll retain the extra info. The gist is than health and associated fields (Hp, Pw, Ac) get first priority, status conditions get second priority, then the rest. In the usual case where there aren't many conditions, status display is the same as it has been in the past. STATUS_VIA_WINDOWPORT has been updated too, and it builds for tty and X11. But the bot2() revision to reorder sections has not been implemented for that. win/win32/mswproc.c has been updated but not tested. STATUS_VIA_WINDOWPORT without STATUS_HILITES had several compile problems; now fixed for core and tty. STATUS_VIA_WINDOWPORT with STATUS_HILITES has not been tested. --- doc/fixes36.1 | 4 +- include/botl.h | 43 +++-- src/botl.c | 405 +++++++++++++++++++++++++------------------- src/do_wear.c | 6 +- src/polyself.c | 5 +- src/potion.c | 37 ++-- src/steed.c | 9 +- src/trap.c | 2 + src/windows.c | 34 ++-- win/tty/wintty.c | 95 +++++++---- win/win32/mswproc.c | 57 ++++--- 11 files changed, 415 insertions(+), 282 deletions(-) diff --git a/doc/fixes36.1 b/doc/fixes36.1 index 4f2e0807f..bcc189206 100644 --- a/doc/fixes36.1 +++ b/doc/fixes36.1 @@ -155,13 +155,13 @@ poison breath leaves a trail of poison gas allow knife and stiletto as possible tin opening tools wizard mode #wizintrinsic command additional tribute passages for The Colour of Magic, The Light Fantastic, - Equal Rites, Snuff, and Raising Steam + Equal Rites, Mort, Snuff, and Raising Steam compile-time options SIMPLE_MAIL and SERVER_ADMIN_MSG for public server use database entries for Cleaver, Sunsword, Frost and Fire brands, and polymorph trap allow showing coordinates when picking a position on the map and autodescribe option is on -add a status line deafness indicator +new status line conditions Stone Strngl Deaf Lev Fly Ride Platform- and/or Interface-Specific New Features diff --git a/include/botl.h b/include/botl.h index 994b41009..e9c5644bb 100644 --- a/include/botl.h +++ b/include/botl.h @@ -9,14 +9,22 @@ * than COLNO * * longest practical second status line at the moment is - * Astral Plane $:12345 HP:700(700) Pw:111(111) AC:-127 Xp:30/123456789 - * T:123456 Satiated Conf FoodPois Ill Blind Stun Hallu Overloaded - * -- or somewhat over 130 characters +Astral Plane \GXXXXNNNN:123456 HP:1000(1000) Pw:111(111) AC:-127 + Xp:30/123456789 T:123456 Stone Slime Strngl FoodPois TermIll + Satiated Overloaded Blind Deaf Stun Conf Hallu Lev Ride + * -- or a bit under 185 characters. '$' gets encoded even when it + * could be used as-is. The first five status conditions are fatal + * so it's rare to have more than one at a time. + * + * When the full line is wider than the map, the basic status line + * formatting will move less important fields to the end, so if/when + * truncation is necessary, it will chop off the least significant + * information. */ -#if COLNO <= 140 -#define MAXCO 160 +#if COLNO <= 160 +#define MAXCO 200 #else -#define MAXCO (COLNO + 20) +#define MAXCO (COLNO + 40) #endif #ifdef STATUS_VIA_WINDOWPORT @@ -53,23 +61,28 @@ enum statusfields { BL_FLUSH = -1, BL_TITLE = 0, BL_STR, BL_DX, BL_CO, BL_IN, BL_WI, BL_CH, BL_ALIGN, BL_SCORE, BL_CAP, BL_GOLD, BL_ENE, BL_ENEMAX, BL_XP, BL_AC, BL_HD, BL_TIME, BL_HUNGER, BL_HP, BL_HPMAX, BL_LEVELDESC, BL_EXP, BL_CONDITION }; +#endif #define MAXBLSTATS BL_CONDITION+1 #define BEFORE 0 #define NOW 1 -#endif /* Boolean condition bits for the condition mask */ /* clang-format off */ -#define BL_MASK_BLIND 0x00000001L -#define BL_MASK_CONF 0x00000002L -#define BL_MASK_FOODPOIS 0x00000004L -#define BL_MASK_ILL 0x00000008L -#define BL_MASK_HALLU 0x00000010L -#define BL_MASK_STUNNED 0x00000020L -#define BL_MASK_SLIMED 0x00000040L -#define BL_MASK_DEAF 0x00000080L +#define BL_MASK_STONE 0x00000001L +#define BL_MASK_SLIME 0x00000002L +#define BL_MASK_STRNGL 0x00000004L +#define BL_MASK_FOODPOIS 0x00000008L +#define BL_MASK_TERMILL 0x00000010L +#define BL_MASK_BLIND 0x00000020L +#define BL_MASK_DEAF 0x00000040L +#define BL_MASK_STUN 0x00000080L +#define BL_MASK_CONF 0x00000100L +#define BL_MASK_HALLU 0x00000200L +#define BL_MASK_LEV 0x00000400L +#define BL_MASK_FLY 0x00000800L +#define BL_MASK_RIDE 0x00001000L /* clang-format on */ #define REASSESS_ONLY TRUE diff --git a/src/botl.c b/src/botl.c index 29aaf3839..49cb38154 100644 --- a/src/botl.c +++ b/src/botl.c @@ -78,54 +78,135 @@ bot1() STATIC_OVL void bot2() { - char newbot2[MAXCO]; + char newbot2[MAXCO], /* MAXCO: botl.h */ + /* dungeon location (and gold), hero health (HP, PW, AC), + experience (HD if poly'd, else Exp level and maybe Exp points), + time (in moves), varying number of status conditions */ + dloc[QBUFSZ], hlth[QBUFSZ], expr[QBUFSZ], tmmv[QBUFSZ], cond[QBUFSZ]; register char *nb; - int hp, hpmax; - int cap = near_capacity(); + unsigned dln, dx, hln, xln, tln, cln; + int hp, hpmax, cap; + long money; + /* + * Various min(x,9999)'s are to avoid having excessive values + * violate the field width assumptions in botl.h and should not + * impact normal play [not too sure about limiting spell power + * to 3 digits]. Particularly 64-bit long for gold which could + * require many more digits if someone figures out a way to get + * and carry a really large (or negative) amount of it. + * Turn counter is also long, but we'll risk that. + */ + + /* dungeon location plus gold */ + (void) describe_level(dloc); /* includes at least one trailing space */ + if ((money = money_cnt(invent)) < 0L) + money = 0L; /* ought to issue impossible() and then discard gold */ + Sprintf(eos(dloc), "%s:%-2ld", + encglyph(objnum_to_glyph(GOLD_PIECE)), min(money, 999999L)); + dln = strlen(dloc); + /* '$' encoded as \GXXXXNNNN is 9 chars longer than display will need */ + dx = strstri(dloc, "\\G") ? 9 : 0; + + /* health and armor class (has trailing space for AC 0..9) */ hp = Upolyd ? u.mh : u.uhp; hpmax = Upolyd ? u.mhmax : u.uhpmax; - if (hp < 0) hp = 0; - (void) describe_level(newbot2); - Sprintf(nb = eos(newbot2), "%s:%-2ld HP:%d(%d) Pw:%d(%d) AC:%-2d", - encglyph(objnum_to_glyph(GOLD_PIECE)), money_cnt(invent), hp, - hpmax, u.uen, u.uenmax, u.uac); + Sprintf(hlth, "HP:%d(%d) Pw:%d(%d) AC:%-2d", + min(hp, 9999), min(hpmax, 9999), + min(u.uen, 999), min(u.uenmax, 999), u.uac); + hln = strlen(hlth); + /* experience */ if (Upolyd) - Sprintf(nb = eos(nb), " HD:%d", mons[u.umonnum].mlevel); + Sprintf(expr, "HD:%d", mons[u.umonnum].mlevel); else if (flags.showexp) - Sprintf(nb = eos(nb), " Xp:%u/%-1ld", u.ulevel, u.uexp); + Sprintf(expr, "Xp:%u/%-1ld", u.ulevel, u.uexp); else - Sprintf(nb = eos(nb), " Exp:%u", u.ulevel); + Sprintf(expr, "Exp:%u", u.ulevel); + xln = strlen(expr); + /* time/move counter */ if (flags.time) - Sprintf(nb = eos(nb), " T:%ld", moves); - if (strcmp(hu_stat[u.uhs], " ")) { - Sprintf(nb = eos(nb), " "); - Strcat(newbot2, hu_stat[u.uhs]); - } - if (Confusion) - Sprintf(nb = eos(nb), " Conf"); + Sprintf(tmmv, "T:%ld", moves); + else + tmmv[0] = '\0'; + tln = strlen(tmmv); + + /* status conditions; worst ones first */ + cond[0] = '\0'; /* once non-empty, cond will have a leading space */ + nb = cond; + /* + * Stoned, Slimed, Strangled, and both types of Sick are all fatal + * unless remedied before timeout expires. Should we order them by + * shortest time left? [Probably not worth the effort, since it's + * unusual for more than one of them to apply at a time.] + */ + if (Stoned) + Strcpy(nb = eos(nb), " Stone"); + if (Slimed) + Strcpy(nb = eos(nb), " Slime"); + if (Strangled) + Strcpy(nb = eos(nb), " Strngl"); if (Sick) { if (u.usick_type & SICK_VOMITABLE) - Sprintf(nb = eos(nb), " FoodPois"); + Strcpy(nb = eos(nb), " FoodPois"); if (u.usick_type & SICK_NONVOMITABLE) - Sprintf(nb = eos(nb), " Ill"); + Strcpy(nb = eos(nb), " TermIll"); } + if (u.uhs != NOT_HUNGRY) + Sprintf(nb = eos(nb), " %s", hu_stat[u.uhs]); + if ((cap = near_capacity()) > UNENCUMBERED) + Sprintf(nb = eos(nb), " %s", enc_stat[cap]); if (Blind) - Sprintf(nb = eos(nb), " Blind"); + Strcpy(nb = eos(nb), " Blind"); + if (Deaf) + Strcpy(nb = eos(nb), " Deaf"); if (Stunned) - Sprintf(nb = eos(nb), " Stun"); + Strcpy(nb = eos(nb), " Stun"); + if (Confusion) + Strcpy(nb = eos(nb), " Conf"); if (Hallucination) - Sprintf(nb = eos(nb), " Hallu"); - if (Slimed) - Sprintf(nb = eos(nb), " Slime"); - if (Deaf) - Sprintf(nb = eos(nb), " Df"); - if (cap > UNENCUMBERED) - Sprintf(nb = eos(nb), " %s", enc_stat[cap]); + Strcpy(nb = eos(nb), " Hallu"); + /* levitation and flying are mutually exclusive; riding is not */ + if (Levitation) + Strcpy(nb = eos(nb), " Lev"); + if (Flying) + Strcpy(nb = eos(nb), " Fly"); + if (u.usteed) + Strcpy(nb = eos(nb), " Ride"); + cln = strlen(cond); + + /* + * Put the pieces together. If they all fit, keep the traditional + * sequence. Otherwise, move least important parts to the end in + * case the interface side of things has to truncate. Note that + * dloc[] contains '$' encoded in ten character sequence \GXXXXNNNN + * so we want to test its display length rather than buffer length. + * + * We don't have an actual display limit here, so have to go by the + * width of the map. Since we're reordering rather than truncating, + * wider displays can still show wider status than the map if the + * interface supports that. + */ + if ((dln - dx) + 1 + hln + 1 + xln + 1 + tln + 1 + cln <= COLNO) { + Sprintf(newbot2, "%s %s %s %s %s", dloc, hlth, expr, tmmv, cond); + } else { + if (dln + 1 + hln + 1 + xln + 1 + tln + 1 + cln + 1 > MAXCO) { + panic("bot2: second status line exceeds MAXCO (%u > %d)", + (dln + 1 + hln + 1 + xln + 1 + tln + 1 + cln + 1), MAXCO); + } else if ((dln - dx) + 1 + hln + 1 + xln + 1 + cln <= COLNO) { + Sprintf(newbot2, "%s %s %s %s %s", dloc, hlth, expr, cond, tmmv); + } else if ((dln - dx) + 1 + hln + 1 + cln <= COLNO) { + Sprintf(newbot2, "%s %s %s %s %s", dloc, hlth, cond, expr, tmmv); + } else { + Sprintf(newbot2, "%s %s %s %s %s", hlth, cond, dloc, expr, tmmv); + } + /* only two or three consecutive spaces available to squeeze out */ + mungspaces(newbot2); + } + curs(WIN_STATUS, 1, 1); putmixed(WIN_STATUS, 0, newbot2); } @@ -302,11 +383,10 @@ struct istat_s { STATIC_DCL void NDECL(init_blstats); STATIC_DCL char *FDECL(anything_to_s, (char *, anything *, int)); -STATIC_DCL void FDECL(s_to_anything, (anything *, char *, int)); STATIC_OVL int FDECL(percentage, (struct istat_s *, struct istat_s *)); STATIC_OVL int FDECL(compare_blstats, (struct istat_s *, struct istat_s *)); - #ifdef STATUS_HILITES +STATIC_DCL void FDECL(s_to_anything, (anything *, char *, int)); STATIC_DCL boolean FDECL(assign_hilite, (char *, char *, char *, char *, BOOLEAN_P)); STATIC_DCL const char *FDECL(clridx_to_s, (char *, int)); @@ -340,35 +420,6 @@ STATIC_DCL struct istat_s initblstats[MAXBLSTATS] = { { (genericptr_t) 0 }, (char *) 0, 0, 0, BL_CONDITION} }; -static struct fieldid_t { - const char *fieldname; - enum statusfields fldid; -} fieldids[] = { - {"title", BL_TITLE}, - {"strength", BL_STR}, - {"dexterity", BL_DX}, - {"constitution", BL_CO}, - {"intelligence", BL_IN}, - {"wisdom", BL_WI}, - {"charisma", BL_CH}, - {"alignment", BL_ALIGN}, - {"score", BL_SCORE}, - {"carrying-capacity", BL_CAP}, - {"gold", BL_GOLD}, - {"power", BL_ENE}, - {"power-max", BL_ENEMAX}, - {"experience-level", BL_XP}, - {"armor-class", BL_AC}, - {"HD", BL_HD}, - {"time", BL_TIME}, - {"hunger", BL_HUNGER}, - {"hitpoints", BL_HP}, - {"hitpoints-max", BL_HPMAX}, - {"dungeon-level", BL_LEVELDESC}, - {"experience", BL_EXP}, - {"condition", BL_CONDITION}, -}; - struct istat_s blstats[2][MAXBLSTATS]; static boolean blinit = FALSE, update_all = FALSE; @@ -378,11 +429,11 @@ bot() char buf[BUFSZ]; register char *nb; static int idx = 0, idx_p, idxmax; - boolean updated = FALSE; unsigned anytype; + long money; int i, pc, chg, cap; struct istat_s *curr, *prev; - boolean valset[MAXBLSTATS], chgval = FALSE; + boolean valset[MAXBLSTATS], chgval = FALSE, updated = FALSE; if (!blinit) panic("bot before init."); @@ -392,41 +443,35 @@ bot() return; } - cap = near_capacity(); idx_p = idx; idx = 1 - idx; /* 0 -> 1, 1 -> 0 */ /* clear the "value set" indicators */ - (void) memset((genericptr_t) valset, 0, MAXBLSTATS * sizeof(boolean)); + (void) memset((genericptr_t) valset, 0, MAXBLSTATS * sizeof (boolean)); + + /* + * Note: min(x,9999) - we enforce the same maximum on hp, maxhp, + * pw, maxpw, and gold as basic status formatting so that the two + * modes of status display don't produce different information. + */ /* * Player name and title. */ - buf[0] = '\0'; - Strcpy(buf, plname); - if ('a' <= buf[0] && buf[0] <= 'z') - buf[0] += 'A' - 'a'; - buf[10] = 0; - Sprintf(nb = eos(buf), " the "); + Strcpy(nb = buf, plname); + nb[0] = highc(nb[0]); + nb[10] = '\0'; + Sprintf(nb = eos(nb), " the "); if (Upolyd) { - char mbot[BUFSZ]; - int k = 0; - - Strcpy(mbot, mons[u.umonnum].mname); - while (mbot[k] != 0) { - if ((k == 0 || (k > 0 && mbot[k - 1] == ' ')) && 'a' <= mbot[k] - && mbot[k] <= 'z') - mbot[k] += 'A' - 'a'; - k++; - } - Sprintf1(nb = eos(nb), mbot); + for (i = 0, nb = strcpy(eos(nb), mons[u.umonnum].mname); nb[i]; i++) + if (i == 0 || nb[i - 1] == ' ') + nb[i] = highc(nb[i]); } else - Sprintf1(nb = eos(nb), rank()); + Strcpy(nb = eos(nb), rank()); Sprintf(blstats[idx][BL_TITLE].val, "%-29s", buf); valset[BL_TITLE] = TRUE; /* indicate val already set */ /* Strength */ - buf[0] = '\0'; blstats[idx][BL_STR].a.a_int = ACURR(A_STR); if (ACURR(A_STR) > 18) { @@ -442,7 +487,6 @@ bot() valset[BL_STR] = TRUE; /* indicate val already set */ /* Dexterity, constitution, intelligence, wisdom, charisma. */ - blstats[idx][BL_DX].a.a_int = ACURR(A_DEX); blstats[idx][BL_CO].a.a_int = ACURR(A_CON); blstats[idx][BL_IN].a.a_int = ACURR(A_INT); @@ -450,135 +494,119 @@ bot() blstats[idx][BL_CH].a.a_int = ACURR(A_CHA); /* Alignment */ - - Strcpy(blstats[idx][BL_ALIGN].val, - (u.ualign.type == A_CHAOTIC) - ? "Chaotic" - : (u.ualign.type == A_NEUTRAL) ? "Neutral" : "Lawful"); + Strcpy(blstats[idx][BL_ALIGN].val, (u.ualign.type == A_CHAOTIC) + ? "Chaotic" + : (u.ualign.type == A_NEUTRAL) + ? "Neutral" + : "Lawful"); /* Score */ - blstats[idx][BL_SCORE].a.a_long = #ifdef SCORE_ON_BOTL - botl_score(); + botl_score() #else - 0; + 0L #endif - /* Hit points */ + ; - blstats[idx][BL_HP].a.a_int = Upolyd ? u.mh : u.uhp; - blstats[idx][BL_HPMAX].a.a_int = Upolyd ? u.mhmax : u.uhpmax; - if (blstats[idx][BL_HP].a.a_int < 0) - blstats[idx][BL_HP].a.a_int = 0; + /* Hit points */ + i = Upolyd ? u.mh : u.uhp; + if (i < 0) + i = 0; + blstats[idx][BL_HP].a.a_int = min(i, 9999); + i = Upolyd ? u.mhmax : u.uhpmax; + blstats[idx][BL_HPMAX].a.a_int = min(i, 9999); /* Dungeon level. */ - (void) describe_level(blstats[idx][BL_LEVELDESC].val); valset[BL_LEVELDESC] = TRUE; /* indicate val already set */ /* Gold */ - - blstats[idx][BL_GOLD].a.a_long = money_cnt(invent); + if ((money = money_cnt(invent)) < 0L) + money = 0L; /* ought to issue impossible() and then discard gold */ + blstats[idx][BL_GOLD].a.a_long = min(money, 999999L); /* * The tty port needs to display the current symbol for gold * as a field header, so to accommodate that we pass gold with * that already included. If a window port needs to use the text * gold amount without the leading "$:" the port will have to - * add 2 to the value pointer it was passed in status_update() + * skip past ':' to the value pointer it was passed in status_update() * for the BL_GOLD case. * * Another quirk of BL_GOLD is that the field display may have * changed if a new symbol set was loaded, or we entered or left * the rogue level. + * + * The currency prefix is encoded as ten character \GXXXXNNNN + * sequence. */ - Sprintf(blstats[idx][BL_GOLD].val, "%s:%ld", encglyph(objnum_to_glyph(GOLD_PIECE)), blstats[idx][BL_GOLD].a.a_long); valset[BL_GOLD] = TRUE; /* indicate val already set */ /* Power (magical energy) */ - - blstats[idx][BL_ENE].a.a_int = u.uen; - blstats[idx][BL_ENEMAX].a.a_int = u.uenmax; + blstats[idx][BL_ENE].a.a_int = min(u.uen, 999); + blstats[idx][BL_ENEMAX].a.a_int = min(u.uenmax, 999); /* Armor class */ - blstats[idx][BL_AC].a.a_int = u.uac; /* Monster level (if Upolyd) */ - - if (Upolyd) - blstats[idx][BL_HD].a.a_int = mons[u.umonnum].mlevel; - else - blstats[idx][BL_HD].a.a_int = 0; + blstats[idx][BL_HD].a.a_int = Upolyd ? mons[u.umonnum].mlevel : 0; /* Experience */ - blstats[idx][BL_XP].a.a_int = u.ulevel; blstats[idx][BL_EXP].a.a_int = u.uexp; /* Time (moves) */ - blstats[idx][BL_TIME].a.a_long = moves; /* Hunger */ - blstats[idx][BL_HUNGER].a.a_uint = u.uhs; - *(blstats[idx][BL_HUNGER].val) = '\0'; - if (strcmp(hu_stat[u.uhs], " ") != 0) - Strcpy(blstats[idx][BL_HUNGER].val, hu_stat[u.uhs]); + Strcpy(blstats[idx][BL_HUNGER].val, + (u.uhs != NOT_HUNGRY) ? hu_stat[u.uhs] : ""); valset[BL_HUNGER] = TRUE; /* Carrying capacity */ - - *(blstats[idx][BL_CAP].val) = '\0'; + cap = near_capacity(); blstats[idx][BL_CAP].a.a_int = cap; - if (cap > UNENCUMBERED) - Strcpy(blstats[idx][BL_CAP].val, enc_stat[cap]); + Strcpy(blstats[idx][BL_CAP].val, + (cap > UNENCUMBERED) ? enc_stat[cap] : ""); valset[BL_CAP] = TRUE; /* Conditions */ - + blstats[idx][BL_CONDITION].a.a_ulong = 0L; + if (Stoned) + blstats[idx][BL_CONDITION].a.a_ulong |= BL_MASK_STONE; + if (Slimed) + blstats[idx][BL_CONDITION].a.a_ulong |= BL_MASK_SLIME; + if (Strangled) + blstats[idx][BL_CONDITION].a.a_ulong |= BL_MASK_STRNGL; + if (Sick && (u.usick_type & SICK_VOMITABLE) != 0) + blstats[idx][BL_CONDITION].a.a_ulong |= BL_MASK_FOODPOIS; + if (Sick && (u.usick_type & SICK_NONVOMITABLE) != 0) + blstats[idx][BL_CONDITION].a.a_ulong |= BL_MASK_TERMILL; + /* + * basic formatting puts hunger status and encumbrance here + */ if (Blind) blstats[idx][BL_CONDITION].a.a_ulong |= BL_MASK_BLIND; - else - blstats[idx][BL_CONDITION].a.a_ulong &= ~BL_MASK_BLIND; - if (Deaf) blstats[idx][BL_CONDITION].a.a_ulong |= BL_MASK_DEAF; - else - blstats[idx][BL_CONDITION].a.a_ulong &= ~BL_MASK_DEAF; - + if (Stunned) + blstats[idx][BL_CONDITION].a.a_ulong |= BL_MASK_STUN; if (Confusion) blstats[idx][BL_CONDITION].a.a_ulong |= BL_MASK_CONF; - else - blstats[idx][BL_CONDITION].a.a_ulong &= ~BL_MASK_CONF; - - if (Sick && u.usick_type & SICK_VOMITABLE) - blstats[idx][BL_CONDITION].a.a_ulong |= BL_MASK_FOODPOIS; - else - blstats[idx][BL_CONDITION].a.a_ulong &= ~BL_MASK_FOODPOIS; - - if (Sick && u.usick_type & SICK_NONVOMITABLE) - blstats[idx][BL_CONDITION].a.a_ulong |= BL_MASK_ILL; - else - blstats[idx][BL_CONDITION].a.a_ulong &= ~BL_MASK_ILL; - if (Hallucination) blstats[idx][BL_CONDITION].a.a_ulong |= BL_MASK_HALLU; - else - blstats[idx][BL_CONDITION].a.a_ulong &= ~BL_MASK_HALLU; - - if (Stunned) - blstats[idx][BL_CONDITION].a.a_ulong |= BL_MASK_STUNNED; - else - blstats[idx][BL_CONDITION].a.a_ulong &= ~BL_MASK_STUNNED; - - if (Slimed) - blstats[idx][BL_CONDITION].a.a_ulong |= BL_MASK_SLIMED; - else - blstats[idx][BL_CONDITION].a.a_ulong &= ~BL_MASK_SLIMED; + /* levitation and flying are mututally exclusive */ + if (Levitation) + blstats[idx][BL_CONDITION].a.a_ulong |= BL_MASK_LEV; + if (Flying) + blstats[idx][BL_CONDITION].a.a_ulong |= BL_MASK_FLY; + if (u.usteed) + blstats[idx][BL_CONDITION].a.a_ulong |= BL_MASK_RIDE; /* * Now pass the changed values to window port. @@ -594,10 +622,11 @@ bot() curr = &blstats[idx][i]; prev = &blstats[idx_p][i]; chg = 0; - if (update_all || ((chg = compare_blstats(prev, curr)) != 0) - || ((chgval = (valset[i] && strcmp(blstats[idx][i].val, - blstats[idx_p][i].val))) - != 0)) { + if (update_all + || ((chg = compare_blstats(prev, curr)) != 0) + || ((chgval = (valset[i] + && strcmp(blstats[idx][i].val, + blstats[idx_p][i].val))) != 0)) { idxmax = blstats[idx][i].idxmax; pc = (idxmax) ? percentage(curr, &blstats[idx][idxmax]) : 0; if (!valset[i]) @@ -606,9 +635,8 @@ bot() status_update(i, (genericptr_t) curr->val, valset[i] ? chgval : chg, pc); } else { - status_update(i, - /* send pointer to mask */ - (genericptr_t) &curr->a.a_ulong, chg, 0); + /* send pointer to mask */ + status_update(i, (genericptr_t) &curr->a.a_ulong, chg, 0); } updated = TRUE; } @@ -637,8 +665,8 @@ boolean reassessment; /* TRUE = just reassess fields w/o other initialization*/ { int i; - const char *fieldfmt = (const char *)0; - const char *fieldname = (const char *)0; + const char *fieldfmt = (const char *) 0; + const char *fieldname = (const char *) 0; if (!reassessment) { init_blstats(); @@ -868,6 +896,8 @@ int anytype; return buf; } +#ifdef STATUS_HILITES + STATIC_OVL void s_to_anything(a, buf, anytype) anything *a; @@ -916,6 +946,8 @@ int anytype; return; } +#endif + STATIC_OVL int compare_blstats(bl1, bl2) struct istat_s *bl1, *bl2; @@ -1047,6 +1079,35 @@ struct istat_s *bl, *maxbl; /* Core status hiliting support */ /****************************************************************************/ +static struct fieldid_t { + const char *fieldname; + enum statusfields fldid; +} fieldids[] = { + {"title", BL_TITLE}, + {"strength", BL_STR}, + {"dexterity", BL_DX}, + {"constitution", BL_CO}, + {"intelligence", BL_IN}, + {"wisdom", BL_WI}, + {"charisma", BL_CH}, + {"alignment", BL_ALIGN}, + {"score", BL_SCORE}, + {"carrying-capacity", BL_CAP}, + {"gold", BL_GOLD}, + {"power", BL_ENE}, + {"power-max", BL_ENEMAX}, + {"experience-level", BL_XP}, + {"armor-class", BL_AC}, + {"HD", BL_HD}, + {"time", BL_TIME}, + {"hunger", BL_HUNGER}, + {"hitpoints", BL_HP}, + {"hitpoints-max", BL_HPMAX}, + {"dungeon-level", BL_LEVELDESC}, + {"experience", BL_EXP}, + {"condition", BL_CONDITION}, +}; + struct hilite_s { boolean set; unsigned anytype; @@ -1118,6 +1179,7 @@ boolean from_configfile; { int i; anything it; + it = zeroany; for (i = 0; i < MAXBLSTATS; ++i) { (void) memset((genericptr_t) &status_hilites[i], 0, @@ -1196,15 +1258,11 @@ boolean from_configfile; /* actions */ for (i = 0; i < 2; ++i) { - if (!i) - how = sc; - else - how = sd; + how = !i ? sc : sd; if (!how) { if (!i) return FALSE; - else - break; /* sc is mandatory; sd is not */ + break; /* sc is mandatory; sd is not */ } if (strcmpi(how, "bold") == 0) { @@ -1215,6 +1273,7 @@ boolean from_configfile; normal[i] = TRUE; } else { int k = match_str2clr(how); + if (k >= CLR_MAX) return FALSE; coloridx[i] = k; @@ -1271,10 +1330,10 @@ boolean all; for (idx = 0; idx < MAXBLSTATS; ++idx) { if (status_hilites[idx].set) status_threshold(idx, status_hilites[idx].anytype, - status_hilites[idx].threshold, - status_hilites[idx].behavior, - status_hilites[idx].coloridx[0], - status_hilites[idx].coloridx[1]); + status_hilites[idx].threshold, + status_hilites[idx].behavior, + status_hilites[idx].coloridx[0], + status_hilites[idx].coloridx[1]); else status_threshold(idx, blstats[0][idx].anytype, it, 0, 0, 0); @@ -1358,6 +1417,7 @@ int bufsiz; text = "normal"; } else { char *blank; + (void) strcpy(colorname, c_obj_colors[coloridx]); for (blank = index(colorname, ' '); blank; blank = index(colorname, ' ')) @@ -1434,6 +1494,7 @@ status_hilite_menu() for (i = 0; i < MAXBLSTATS; i++) { if (field_picks[i]) { menu_item *pick = (menu_item *) 0; + Sprintf(buf, "Threshold behavior options for %s:", fieldids[i].fieldname); tmpwin = create_nhwindow(NHW_MENU); diff --git a/src/do_wear.c b/src/do_wear.c index ea73cace8..bedda5298 100644 --- a/src/do_wear.c +++ b/src/do_wear.c @@ -730,8 +730,9 @@ Amulet_on() case AMULET_OF_STRANGULATION: if (can_be_strangled(&youmonst)) { makeknown(AMULET_OF_STRANGULATION); - pline("It constricts your throat!"); Strangled = 6L; + context.botl = TRUE; + pline("It constricts your throat!"); } break; case AMULET_OF_RESTFUL_SLEEP: { @@ -780,11 +781,12 @@ Amulet_off() break; case AMULET_OF_STRANGULATION: if (Strangled) { + Strangled = 0L; + context.botl = TRUE; if (Breathless) Your("%s is no longer constricted!", body_part(NECK)); else You("can breathe more easily!"); - Strangled = 0L; } break; case AMULET_OF_RESTFUL_SLEEP: diff --git a/src/polyself.c b/src/polyself.c index 9cdc83be8..68936af8d 100644 --- a/src/polyself.c +++ b/src/polyself.c @@ -114,6 +114,7 @@ float_vs_flight() BFlying |= I_SPECIAL; else BFlying &= ~I_SPECIAL; + context.botl = TRUE; } /* for changing into form that's immune to strangulation */ @@ -127,10 +128,11 @@ boolean on; vulnerable form into another causes the counter to be reset */ if (uamul && uamul->otyp == AMULET_OF_STRANGULATION && can_be_strangled(&youmonst)) { + Strangled = 6L; + context.botl = TRUE; Your("%s %s your %s!", simpleonames(uamul), Strangled ? "still constricts" : "begins constricting", body_part(NECK)); /* "throat" */ - Strangled = 6L; makeknown(AMULET_OF_STRANGULATION); } @@ -138,6 +140,7 @@ boolean on; } else { if (Strangled && !can_be_strangled(&youmonst)) { Strangled = 0L; + context.botl = TRUE; You("are no longer being strangled."); } } diff --git a/src/potion.c b/src/potion.c index 2a54d5fa1..484b89806 100644 --- a/src/potion.c +++ b/src/potion.c @@ -165,12 +165,12 @@ const char *msg; if (Unaware) msg = 0; #endif - if ((!xtime && old) || (xtime && !old)) { + set_itimeout(&Slimed, xtime); + if ((xtime != 0L) ^ (old != 0L)) { + context.botl = TRUE; if (msg) pline1(msg); - context.botl = 1; } - set_itimeout(&Slimed, xtime); if (!Slimed) dealloc_killer(find_delayed_killer(SLIMED)); } @@ -189,12 +189,12 @@ const char *killername; if (Unaware) msg = 0; #endif - if ((!xtime && old) || (xtime && !old)) { + set_itimeout(&Stoned, xtime); + if ((xtime != 0L) ^ (old != 0L)) { + context.botl = TRUE; if (msg) pline1(msg); - /* context.botl = 1; --- Stoned is not a status line item */ } - set_itimeout(&Stoned, xtime); if (!Stoned) dealloc_killer(find_delayed_killer(STONED)); else if (!old) @@ -211,11 +211,11 @@ boolean talk; if (Unaware) talk = FALSE; + set_itimeout(&Vomiting, xtime); + context.botl = TRUE; if (!xtime && old) if (talk) You_feel("much less nauseated now."); - - set_itimeout(&Vomiting, xtime); } static const char vismsg[] = "vision seems to %s for a moment but is %s now."; @@ -292,7 +292,7 @@ boolean talk; set_itimeout(&Blinded, xtime); if (u_could_see ^ can_see_now) { /* one or the other but not both */ - context.botl = 1; + context.botl = TRUE; vision_full_recalc = 1; /* blindness just got toggled */ /* this vision recalculation used to be deferred until moveloop(), but that made it possible for vision @@ -383,7 +383,7 @@ long mask; /* nonzero if resistance status should change by mask */ (eg. Qt windowport's equipped items display) */ update_inventory(); - context.botl = 1; + context.botl = TRUE; if (talk) pline(message, verb); } @@ -396,25 +396,16 @@ long xtime; boolean talk; { long old = HDeaf; - boolean toggled = FALSE; if (Unaware) talk = FALSE; - if (!xtime && old) { - if (talk) - You("can hear again."); - toggled = TRUE; - } else if (xtime && !old) { + set_itimeout(&HDeaf, xtime); + if ((xtime != 0L) ^ (old != 0L)) { + context.botl = TRUE; if (talk) - You("are unable to hear anything."); - toggled = TRUE; + You(old ? "can hear again." : "are unable to hear anything."); } - /* request a status update */ - if (toggled) - context.botl = TRUE; - - set_itimeout(&HDeaf, xtime); } STATIC_OVL void diff --git a/src/steed.c b/src/steed.c index 1129a27cc..4070bbf74 100644 --- a/src/steed.c +++ b/src/steed.c @@ -285,7 +285,7 @@ boolean force; /* Quietly force this animal */ } if (!can_saddle(mtmp) || !can_ride(mtmp)) { You_cant("ride such a creature."); - return (0); + return FALSE; } /* Is the player impaired? */ @@ -332,7 +332,8 @@ boolean force; /* Quietly force this animal */ u.usteed = mtmp; remove_monster(mtmp->mx, mtmp->my); teleds(mtmp->mx, mtmp->my, TRUE); - return (TRUE); + context.botl = TRUE; + return TRUE; } /* You and your steed have moved */ @@ -610,11 +611,11 @@ int reason; /* Player was thrown off etc. */ in_steed_dismounting = TRUE; (void) float_down(0L, W_SADDLE); in_steed_dismounting = FALSE; - context.botl = 1; + context.botl = TRUE; (void) encumber_msg(); vision_full_recalc = 1; } else - context.botl = 1; + context.botl = TRUE; /* polearms behave differently when not mounted */ if (uwep && is_pole(uwep)) unweapon = TRUE; diff --git a/src/trap.c b/src/trap.c index 80f638e90..91bc589d3 100644 --- a/src/trap.c +++ b/src/trap.c @@ -2733,6 +2733,7 @@ boolean byplayer; void float_up() { + context.botl = TRUE; if (u.utrap) { if (u.utraptype == TT_PIT) { u.utrap = 0; @@ -2811,6 +2812,7 @@ long hmask, emask; /* might cancel timeout */ float_vs_flight(); /* before nomul() rather than after */ return 0; } + context.botl = TRUE; nomul(0); /* stop running or resting */ if (BFlying) { /* controlled flight no longer overridden by levitation */ diff --git a/src/windows.c b/src/windows.c index 1423f8cf1..ce6691347 100644 --- a/src/windows.c +++ b/src/windows.c @@ -751,8 +751,9 @@ hup_get_color_string(VOID_ARGS) /*ARGSUSED*/ static void hup_status_update(idx, ptr, chg, percent) -int idx UNUSED, chg UNUSED, percent UNUSED; +int idx UNUSED; genericptr_t ptr UNUSED; +int chg UNUSED, percent UNUSED; { return; } @@ -855,8 +856,9 @@ boolean enable; void genl_status_update(idx, ptr, chg, percent) -int idx, chg, percent; +int idx; genericptr_t ptr; +int chg UNUSED, percent UNUSED; { char newbot1[MAXCO], newbot2[MAXCO]; long cond, *condptr = (long *) ptr; @@ -879,20 +881,32 @@ genericptr_t ptr; case BL_CONDITION: cond = *condptr; *status_vals[idx] = '\0'; + if (cond & BL_MASK_STONE) + Strcat(status_vals[idx], " Stone"); + if (cond & BL_MASK_SLIME) + Strcat(status_vals[idx], " Slime"); + if (cond & BL_MASK_STRNGL) + Strcat(status_vals[idx], " Strngl"); + if (cond & BL_MASK_FOODPOIS) + Strcat(status_vals[idx], " FoodPois"); + if (cond & BL_MASK_TERMILL) + Strcat(status_vals[idx], " TermIll"); if (cond & BL_MASK_BLIND) Strcat(status_vals[idx], " Blind"); + if (cond & BL_MASK_DEAF) + Strcat(status_vals[idx], " Deaf"); + if (cond & BL_MASK_STUN) + Strcat(status_vals[idx], " Stun"); if (cond & BL_MASK_CONF) Strcat(status_vals[idx], " Conf"); - if (cond & BL_MASK_FOODPOIS) - Strcat(status_vals[idx], " FoodPois"); - if (cond & BL_MASK_ILL) - Strcat(status_vals[idx], " Ill"); - if (cond & BL_MASK_STUNNED) - Strcat(status_vals[idx], " Stun"); if (cond & BL_MASK_HALLU) Strcat(status_vals[idx], " Hallu"); - if (cond & BL_MASK_SLIMED) - Strcat(status_vals[idx], " Slime"); + if (cond & BL_MASK_LEV) + Strcat(status_vals[idx], " Lev"); + if (cond & BL_MASK_FLY) + Strcat(status_vals[idx], " Fly"); + if (cond & BL_MASK_RIDE) + Strcat(status_vals[idx], " Ride"); break; default: Sprintf(status_vals[idx], diff --git a/win/tty/wintty.c b/win/tty/wintty.c index acd1b86ad..82f96f1b0 100644 --- a/win/tty/wintty.c +++ b/win/tty/wintty.c @@ -3387,17 +3387,23 @@ tty_status_init() * -- ptr is usually a "char *", unless fldindex is BL_CONDITION. * If fldindex is BL_CONDITION, then ptr is a long value with * any or none of the following bits set (from botl.h): - * BL_MASK_BLIND 0x00000001L - * BL_MASK_CONF 0x00000002L - * BL_MASK_FOODPOIS 0x00000004L - * BL_MASK_ILL 0x00000008L - * BL_MASK_HALLU 0x00000010L - * BL_MASK_STUNNED 0x00000020L - * BL_MASK_SLIMED 0x00000040L - * -- The value passed for BL_GOLD includes a leading - * symbol for GOLD "$:nnn". If the window port needs to use - * the textual gold amount without the leading "$:" the port - * will have to add 2 to the passed "ptr" for the BL_GOLD case. + * BL_MASK_STONE 0x00000001L + * BL_MASK_SLIME 0x00000002L + * BL_MASK_STRNGL 0x00000004L + * BL_MASK_FOODPOIS 0x00000008L + * BL_MASK_TERMILL 0x00000010L + * BL_MASK_BLIND 0x00000020L + * BL_MASK_DEAF 0x00000040L + * BL_MASK_STUN 0x00000080L + * BL_MASK_CONF 0x00000100L + * BL_MASK_HALLU 0x00000200L + * BL_MASK_LEV 0x00000400L + * BL_MASK_FLY 0x00000800L + * BL_MASK_RIDE 0x00001000L + * -- The value passed for BL_GOLD includes an encoded leading + * symbol for GOLD "\GXXXXNNNN:nnn". If the window port needs to use + * the textual gold amount without the leading "$:" the port will + * have to skip past ':' in the passed "ptr" for the BL_GOLD case. */ void tty_status_update(fldidx, ptr, chg, percent) @@ -3412,8 +3418,6 @@ genericptr_t ptr; * BL_HILITE_INVERSE -2 + 3 = 1 (statusattr[1]) * BL_HILITE_BOLD -3 + 3 = 0 (statusattr[0]) */ - int statusattr[] = { ATR_BOLD, ATR_INVERSE, ATR_NONE }; - int attridx = 0; long value = -1L; static boolean beenhere = FALSE; enum statusfields fieldorder[2][15] = { @@ -3424,6 +3428,13 @@ genericptr_t ptr; BL_AC, BL_XP, BL_EXP, BL_HD, BL_TIME, BL_HUNGER, BL_CAP, BL_CONDITION, BL_FLUSH } }; +#ifdef STATUS_HILITES + static int statusattr[] = { ATR_BOLD, ATR_INVERSE, ATR_NONE }; + int attridx = 0; +#else + nhUse(chg); + nhUse(percent); +#endif if (fldidx != BL_FLUSH) { if (!status_activefields[fldidx]) @@ -3432,20 +3443,32 @@ genericptr_t ptr; case BL_CONDITION: cond = *condptr; *status_vals[fldidx] = '\0'; + if (cond & BL_MASK_STONE) + Strcat(status_vals[fldidx], " Stone"); + if (cond & BL_MASK_SLIME) + Strcat(status_vals[fldidx], " Slime"); + if (cond & BL_MASK_STRNGL) + Strcat(status_vals[fldidx], " Strngl"); + if (cond & BL_MASK_FOODPOIS) + Strcat(status_vals[fldidx], " FoodPois"); + if (cond & BL_MASK_TERMILL) + Strcat(status_vals[fldidx], " TermIll"); if (cond & BL_MASK_BLIND) Strcat(status_vals[fldidx], " Blind"); + if (cond & BL_MASK_DEAF) + Strcat(status_vals[fldidx], " Deaf"); + if (cond & BL_MASK_STUN) + Strcat(status_vals[fldidx], " Stun"); if (cond & BL_MASK_CONF) Strcat(status_vals[fldidx], " Conf"); - if (cond & BL_MASK_FOODPOIS) - Strcat(status_vals[fldidx], " FoodPois"); - if (cond & BL_MASK_ILL) - Strcat(status_vals[fldidx], " Ill"); - if (cond & BL_MASK_STUNNED) - Strcat(status_vals[fldidx], " Stun"); if (cond & BL_MASK_HALLU) Strcat(status_vals[fldidx], " Hallu"); - if (cond & BL_MASK_SLIMED) - Strcat(status_vals[fldidx], " Slime"); + if (cond & BL_MASK_LEV) + Strcat(status_vals[fldidx], " Lev"); + if (cond & BL_MASK_FLY) + Strcat(status_vals[fldidx], " Fly"); + if (cond & BL_MASK_RIDE) + Strcat(status_vals[fldidx], " Ride"); value = cond; break; default: @@ -3554,23 +3577,26 @@ genericptr_t ptr; int fldidx1 = fieldorder[0][i]; if (status_activefields[fldidx1]) { - if (tty_status_colors[fldidx1] < 0 && - tty_status_colors[fldidx1] >= -3) { +#ifdef STATUS_HILITES + if (tty_status_colors[fldidx1] < 0 + && tty_status_colors[fldidx1] >= -3) { /* attribute, not a color */ attridx = tty_status_colors[fldidx1] + 3; term_start_attr(statusattr[attridx]); putstr(WIN_STATUS, 0, status_vals[fldidx1]); term_end_attr(statusattr[attridx]); + } else #ifdef TEXTCOLOR - } else if (tty_status_colors[fldidx1] != CLR_MAX) { + if (tty_status_colors[fldidx1] != CLR_MAX) { if (tty_status_colors[fldidx1] != NO_COLOR) term_start_color(tty_status_colors[fldidx1]); putstr(WIN_STATUS, 0, status_vals[fldidx1]); if (tty_status_colors[fldidx1] != NO_COLOR) term_end_color(); -#endif } else - putstr(WIN_STATUS, 0, status_vals[fldidx1]); +#endif +#endif /* STATUS_HILITES */ + putstr(WIN_STATUS, 0, status_vals[fldidx1]); } } curs(WIN_STATUS, 1, 1); @@ -3578,28 +3604,31 @@ genericptr_t ptr; int fldidx2 = fieldorder[1][i]; if (status_activefields[fldidx2]) { - if (tty_status_colors[fldidx2] < 0 && - tty_status_colors[fldidx2] >= -3) { +#ifdef STATUS_HILITES + if (tty_status_colors[fldidx2] < 0 + && tty_status_colors[fldidx2] >= -3) { /* attribute, not a color */ attridx = tty_status_colors[fldidx2] + 3; term_start_attr(statusattr[attridx]); putstr(WIN_STATUS, 0, status_vals[fldidx2]); term_end_attr(statusattr[attridx]); + } else #ifdef TEXTCOLOR - } else if (tty_status_colors[fldidx2] != CLR_MAX) { + if (tty_status_colors[fldidx2] != CLR_MAX) { if (tty_status_colors[fldidx2] != NO_COLOR) term_start_color(tty_status_colors[fldidx2]); if (fldidx2 == BL_GOLD) { /* putmixed() due to GOLD glyph */ - putmixed(WIN_STATUS, 0, status_vals[fldidx2]); + putmixed(WIN_STATUS, 0, status_vals[fldidx2]); } else { - putstr(WIN_STATUS, 0, status_vals[fldidx2]); + putstr(WIN_STATUS, 0, status_vals[fldidx2]); } if (tty_status_colors[fldidx2] != NO_COLOR) term_end_color(); -#endif } else - putstr(WIN_STATUS, 0, status_vals[fldidx2]); +#endif +#endif /* STATUS_HILITES */ + putstr(WIN_STATUS, 0, status_vals[fldidx2]); } } return; diff --git a/win/win32/mswproc.c b/win/win32/mswproc.c index 073cd1501..a483bf223 100644 --- a/win/win32/mswproc.c +++ b/win/win32/mswproc.c @@ -2819,18 +2819,23 @@ status_update(int fldindex, genericptr_t ptr, int chg, int percentage) -- ptr is usually a "char *", unless fldindex is BL_CONDITION. If fldindex is BL_CONDITION, then ptr is a long value with any or none of the following bits set (from botl.h): - BL_MASK_BLIND 0x00000001L - BL_MASK_CONF 0x00000002L - BL_MASK_FOODPOIS 0x00000004L - BL_MASK_ILL 0x00000008L - BL_MASK_HALLU 0x00000010L - BL_MASK_STUNNED 0x00000020L - BL_MASK_SLIMED 0x00000040L - -- The value passed for BL_GOLD includes a leading - symbol for GOLD "$:nnn". If the window port needs to use - the textual gold amount without the leading "$:" the port - will have to add 2 to the passed "ptr" for the BL_GOLD -case. + BL_MASK_STONE 0x00000001L + BL_MASK_SLIME 0x00000002L + BL_MASK_STRNGL 0x00000004L + BL_MASK_FOODPOIS 0x00000008L + BL_MASK_TERMILL 0x00000010L + BL_MASK_BLIND 0x00000020L + BL_MASK_DEAF 0x00000040L + BL_MASK_STUN 0x00000080L + BL_MASK_CONF 0x00000100L + BL_MASK_HALLU 0x00000200L + BL_MASK_LEV 0x00000400L + BL_MASK_FLY 0x00000800L + BL_MASK_RIDE 0x00001000L + -- The value passed for BL_GOLD includes an encoded leading + symbol for GOLD "\GXXXXNNNN:nnn". If window port needs + textual gold amount without the leading "$:" the port will + have to skip past ':' in passed "ptr" for the BL_GOLD case. */ void mswin_status_update(int idx, genericptr_t ptr, int chg, int percent) @@ -2851,20 +2856,32 @@ mswin_status_update(int idx, genericptr_t ptr, int chg, int percent) case BL_CONDITION: { cond = *condptr; *_status_vals[idx] = '\0'; + if (cond & BL_MASK_STONE) + Strcat(_status_vals[idx], " Stone"); + if (cond & BL_MASK_SLIME) + Strcat(_status_vals[idx], " Slime"); + if (cond & BL_MASK_STRNGL) + Strcat(_status_vals[idx], " Strngl"); + if (cond & BL_MASK_FOODPOIS) + Strcat(_status_vals[idx], " FoodPois"); + if (cond & BL_MASK_TERMILL) + Strcat(_status_vals[idx], " TermIll"); if (cond & BL_MASK_BLIND) Strcat(_status_vals[idx], " Blind"); + if (cond & BL_MASK_DEAF) + Strcat(_status_vals[idx], " Deaf"); + if (cond & BL_MASK_STUN) + Strcat(_status_vals[idx], " Stun"); if (cond & BL_MASK_CONF) Strcat(_status_vals[idx], " Conf"); - if (cond & BL_MASK_FOODPOIS) - Strcat(_status_vals[idx], " FoodPois"); - if (cond & BL_MASK_ILL) - Strcat(_status_vals[idx], " Ill"); - if (cond & BL_MASK_STUNNED) - Strcat(_status_vals[idx], " Stun"); if (cond & BL_MASK_HALLU) Strcat(_status_vals[idx], " Hallu"); - if (cond & BL_MASK_SLIMED) - Strcat(_status_vals[idx], " Slime"); + if (cond & BL_MASK_LEV) + Strcat(_status_vals[idx], " Lev"); + if (cond & BL_MASK_FLY) + Strcat(_status_vals[idx], " Fly"); + if (cond & BL_MASK_RIDE) + Strcat(_status_vals[idx], " Ride"); value = cond; } break; case BL_GOLD: { -- 2.40.0