- [+] pour poison potion on weapon should poison it.

- [+] coldness shoudl reduce object heat and heat should add f_hot
- [+] novice engineering should let you make arrows.
- [+] hunter shouhld have novice engineering.
- [+] BUG: during the game: i nvalid racename 'piranha' in vault
      pool_room
    - [+] this happened because more than 1 appeared.
    - [+] disallow minions/numapepar in vaults.
This commit is contained in:
Rob Pearce 2012-12-05 05:00:54 +00:00
parent 33abd2b948
commit 38a788ca5f
13 changed files with 352 additions and 148 deletions

4
ai.c
View File

@ -126,7 +126,7 @@ int aiattack(lifeform_t *lf, lifeform_t *victim, int timelimit) {
sayphrase(lf, SP_ALLY_ATTACKUNSEEN, SV_SHOUT, NA, text, victim); sayphrase(lf, SP_ALLY_ATTACKUNSEEN, SV_SHOUT, NA, text, victim);
} }
} else { } else {
makenoise(lf, N_GETANGRY); if (!lfhasflag(lf, F_HIDING)) makenoise(lf, N_GETANGRY);
} }
// become hostile? // become hostile?
@ -2977,7 +2977,7 @@ int aispellok(lifeform_t *lf, enum OBTYPE spellid, lifeform_t *victim, enum FLAG
int found = B_FALSE,i; int found = B_FALSE,i;
// must be a corpse in sight // must be a corpse in sight
for (i = 0; i < lf->nlos; i++) { for (i = 0; i < lf->nlos; i++) {
if (hasob(lf->los[0]->obpile, OT_CORPSE)) { if (hasob(lf->los[i]->obpile, OT_CORPSE)) {
found = B_TRUE; found = B_TRUE;
break; break;
} }

View File

@ -33,10 +33,10 @@ int applyarmourdamage(lifeform_t *lf, object_t *wep, int dam, enum DAMTYPE damty
int damtaken = 0; int damtaken = 0;
// first of all, only apply some of the damage // first of all, only apply some of the damage
//dam /= 2; dam /= 2;
//if (dam == 0) { if (dam == 0) {
// return 0; return 0;
// } }
// special case - missiles always hit flak jacket // special case - missiles always hit flak jacket
if (damtype == DT_PROJECTILE) { if (damtype == DT_PROJECTILE) {
@ -2271,7 +2271,7 @@ int check_for_block(lifeform_t *lf, lifeform_t *victim, int dam, enum DAMTYPE da
if (pctchance(fullchance)) { if (pctchance(fullchance)) {
blocked = B_TRUE; blocked = B_TRUE;
} }
} }
// did we block with this object? // did we block with this object?
if (!blocked && skillcheck(victim, SC_SHIELDBLOCK, difficulty, checkmod[i])) { if (!blocked && skillcheck(victim, SC_SHIELDBLOCK, difficulty, checkmod[i])) {
blocked = B_TRUE; blocked = B_TRUE;

26
data.c
View File

@ -599,6 +599,7 @@ void initjobs(void) {
addflag(lastjob->flags, F_STARTSKILL, SK_AXES, PR_NOVICE, NA, NULL); addflag(lastjob->flags, F_STARTSKILL, SK_AXES, PR_NOVICE, NA, NULL);
addflag(lastjob->flags, F_STARTSKILL, SK_COOKING, PR_BEGINNER, NA, NULL); addflag(lastjob->flags, F_STARTSKILL, SK_COOKING, PR_BEGINNER, NA, NULL);
addflag(lastjob->flags, F_STARTSKILL, SK_CLIMBING, PR_ADEPT, NA, NULL); addflag(lastjob->flags, F_STARTSKILL, SK_CLIMBING, PR_ADEPT, NA, NULL);
addflag(lastjob->flags, F_STARTSKILL, SK_ENGINEERING, PR_NOVICE, NA, NULL);
addflag(lastjob->flags, F_STARTSKILL, SK_LISTEN, PR_NOVICE, NA, NULL); addflag(lastjob->flags, F_STARTSKILL, SK_LISTEN, PR_NOVICE, NA, NULL);
addflag(lastjob->flags, F_STARTSKILL, SK_LORE_NATURE, PR_SKILLED, NA, NULL); addflag(lastjob->flags, F_STARTSKILL, SK_LORE_NATURE, PR_SKILLED, NA, NULL);
addflag(lastjob->flags, F_STARTSKILL, SK_CARTOGRAPHY, PR_ADEPT, NA, NULL); addflag(lastjob->flags, F_STARTSKILL, SK_CARTOGRAPHY, PR_ADEPT, NA, NULL);
@ -614,8 +615,8 @@ void initjobs(void) {
addflag(lastjob->flags, F_CANLEARN, SK_EVASION, NA, NA, NULL); addflag(lastjob->flags, F_CANLEARN, SK_EVASION, NA, NA, NULL);
addflag(lastjob->flags, F_CANLEARN, SK_STAVES, NA, NA, NULL); addflag(lastjob->flags, F_CANLEARN, SK_STAVES, NA, NA, NULL);
addflag(lastjob->flags, F_CANLEARN, SK_UNARMED, NA, NA, NULL); addflag(lastjob->flags, F_CANLEARN, SK_UNARMED, NA, NA, NULL);
addflag(lastjob->flags, F_CANLEARN, SK_TECHUSAGE, PR_ADEPT, NA, NULL); addflag(lastjob->flags, F_CANLEARN, SK_TECHUSAGE, PR_ADEPT, NA, NULL); // limit
addflag(lastjob->flags, F_CANLEARN, SK_ENGINEERING, NA, NA, NULL); addflag(lastjob->flags, F_CANLEARN, SK_ENGINEERING, PR_ADEPT, NA, NULL); // limit
addflag(lastjob->flags, F_CANLEARN, SK_LORE_HUMANOID, NA, NA, NULL); addflag(lastjob->flags, F_CANLEARN, SK_LORE_HUMANOID, NA, NA, NULL);
addflag(lastjob->flags, F_CANLEARN, SK_LORE_DRAGONS, NA, NA, NULL); addflag(lastjob->flags, F_CANLEARN, SK_LORE_DRAGONS, NA, NA, NULL);
// abilities // abilities
@ -3147,7 +3148,7 @@ void initobjects(void) {
addflag(lastot->flags, F_RARITY, H_CAVE, 100, RR_COMMON, NULL); addflag(lastot->flags, F_RARITY, H_CAVE, 100, RR_COMMON, NULL);
addflag(lastot->flags, F_NOBLESS, B_TRUE, NA, NA, NULL); addflag(lastot->flags, F_NOBLESS, B_TRUE, NA, NA, NULL);
addflag(lastot->flags, F_POWDER, B_TRUE, NA, NA, NULL); addflag(lastot->flags, F_POWDER, B_TRUE, NA, NA, NULL);
addflag(lastot->flags, F_FEELTEXT, NA, NA, NA, "some ash"); addflag(lastot->flags, F_FEELTEXT, NA, NA, NA, "some powder");
addflag(lastot->flags, F_NUMCONVERT, 100, OT_ASHLARGE, NA, NULL); addflag(lastot->flags, F_NUMCONVERT, 100, OT_ASHLARGE, NA, NULL);
addflag(lastot->flags, F_GROWSTO, OT_DUSTCLOUD, VT_OB, NA, NULL); addflag(lastot->flags, F_GROWSTO, OT_DUSTCLOUD, VT_OB, NA, NULL);
addot(OT_ASHLARGE, "large pile of ash", "A large pile of ash.", MT_STONE, 0.1, OC_ROCK, SZ_TINY); addot(OT_ASHLARGE, "large pile of ash", "A large pile of ash.", MT_STONE, 0.1, OC_ROCK, SZ_TINY);
@ -3157,7 +3158,7 @@ void initobjects(void) {
addflag(lastot->flags, F_RARITY, H_CAVE, 100, RR_RARE, NULL); addflag(lastot->flags, F_RARITY, H_CAVE, 100, RR_RARE, NULL);
addflag(lastot->flags, F_NOBLESS, B_TRUE, NA, NA, NULL); addflag(lastot->flags, F_NOBLESS, B_TRUE, NA, NA, NULL);
addflag(lastot->flags, F_POWDER, B_TRUE, NA, NA, NULL); addflag(lastot->flags, F_POWDER, B_TRUE, NA, NA, NULL);
addflag(lastot->flags, F_FEELTEXT, NA, NA, NA, "some ash"); addflag(lastot->flags, F_FEELTEXT, NA, NA, NA, "some powder");
addflag(lastot->flags, F_NUMCONVERT, 100, OT_ASHHUGE, NA, NULL); addflag(lastot->flags, F_NUMCONVERT, 100, OT_ASHHUGE, NA, NULL);
addflag(lastot->flags, F_SHRINKSTO, OT_ASH, VT_OB, NA, NULL); addflag(lastot->flags, F_SHRINKSTO, OT_ASH, VT_OB, NA, NULL);
addflag(lastot->flags, F_GROWSTO, OT_DUSTCLOUD, VT_OB, NA, NULL); addflag(lastot->flags, F_GROWSTO, OT_DUSTCLOUD, VT_OB, NA, NULL);
@ -3168,7 +3169,7 @@ void initobjects(void) {
addflag(lastot->flags, F_RARITY, H_CAVE, 100, RR_VERYRARE, NULL); addflag(lastot->flags, F_RARITY, H_CAVE, 100, RR_VERYRARE, NULL);
addflag(lastot->flags, F_NOBLESS, B_TRUE, NA, NA, NULL); addflag(lastot->flags, F_NOBLESS, B_TRUE, NA, NA, NULL);
addflag(lastot->flags, F_POWDER, B_TRUE, NA, NA, NULL); addflag(lastot->flags, F_POWDER, B_TRUE, NA, NA, NULL);
addflag(lastot->flags, F_FEELTEXT, NA, NA, NA, "some ash"); addflag(lastot->flags, F_FEELTEXT, NA, NA, NA, "some powder");
addflag(lastot->flags, F_SHRINKSTO, OT_ASH, VT_OB, NA, NULL); addflag(lastot->flags, F_SHRINKSTO, OT_ASH, VT_OB, NA, NULL);
addflag(lastot->flags, F_GROWSTO, OT_DUSTCLOUD, VT_OB, NA, NULL); addflag(lastot->flags, F_GROWSTO, OT_DUSTCLOUD, VT_OB, NA, NULL);
addot(OT_ASHCONCEAL, "pile of concealing powder", "A pile of ash.", MT_STONE, 0.1, OC_ROCK, SZ_TINY); addot(OT_ASHCONCEAL, "pile of concealing powder", "A pile of ash.", MT_STONE, 0.1, OC_ROCK, SZ_TINY);
@ -3179,7 +3180,7 @@ void initobjects(void) {
addflag(lastot->flags, F_NOBLESS, B_TRUE, NA, NA, NULL); addflag(lastot->flags, F_NOBLESS, B_TRUE, NA, NA, NULL);
addflag(lastot->flags, F_POWDER, B_TRUE, NA, NA, NULL); addflag(lastot->flags, F_POWDER, B_TRUE, NA, NA, NULL);
addflag(lastot->flags, F_HASHIDDENNAME, B_TRUE, NA, NA, "pile of ash"); addflag(lastot->flags, F_HASHIDDENNAME, B_TRUE, NA, NA, "pile of ash");
addflag(lastot->flags, F_FEELTEXT, NA, NA, NA, "some ash"); addflag(lastot->flags, F_FEELTEXT, NA, NA, NA, "some powder");
addflag(lastot->flags, F_AIFLEEITEM, B_TRUE, NA, NA, NULL); addflag(lastot->flags, F_AIFLEEITEM, B_TRUE, NA, NA, NULL);
addflag(lastot->flags, F_VALUE, 80, NA, NA, NULL); addflag(lastot->flags, F_VALUE, 80, NA, NA, NULL);
addflag(lastot->flags, F_GROWSTO, OT_DUSTCLOUD, VT_OB, NA, NULL); addflag(lastot->flags, F_GROWSTO, OT_DUSTCLOUD, VT_OB, NA, NULL);
@ -3192,7 +3193,7 @@ void initobjects(void) {
addflag(lastot->flags, F_NOBLESS, B_TRUE, NA, NA, NULL); addflag(lastot->flags, F_NOBLESS, B_TRUE, NA, NA, NULL);
addflag(lastot->flags, F_POWDER, B_TRUE, NA, NA, NULL); addflag(lastot->flags, F_POWDER, B_TRUE, NA, NA, NULL);
addflag(lastot->flags, F_HASHIDDENNAME, B_TRUE, NA, NA, "pile of ash"); addflag(lastot->flags, F_HASHIDDENNAME, B_TRUE, NA, NA, "pile of ash");
addflag(lastot->flags, F_FEELTEXT, NA, NA, NA, "some ash"); addflag(lastot->flags, F_FEELTEXT, NA, NA, NA, "some powder");
addflag(lastot->flags, F_VALUE, 100, NA, NA, NULL); addflag(lastot->flags, F_VALUE, 100, NA, NA, NULL);
addflag(lastot->flags, F_GROWSTO, OT_DUSTCLOUD, VT_OB, NA, NULL); addflag(lastot->flags, F_GROWSTO, OT_DUSTCLOUD, VT_OB, NA, NULL);
addot(OT_ASHINVIS, "pile of prankster's dust", "A pile of ash.", MT_STONE, 0.1, OC_ROCK, SZ_TINY); addot(OT_ASHINVIS, "pile of prankster's dust", "A pile of ash.", MT_STONE, 0.1, OC_ROCK, SZ_TINY);
@ -3203,7 +3204,7 @@ void initobjects(void) {
addflag(lastot->flags, F_NOBLESS, B_TRUE, NA, NA, NULL); addflag(lastot->flags, F_NOBLESS, B_TRUE, NA, NA, NULL);
addflag(lastot->flags, F_POWDER, B_TRUE, NA, NA, NULL); addflag(lastot->flags, F_POWDER, B_TRUE, NA, NA, NULL);
addflag(lastot->flags, F_HASHIDDENNAME, B_TRUE, NA, NA, "pile of ash"); addflag(lastot->flags, F_HASHIDDENNAME, B_TRUE, NA, NA, "pile of ash");
addflag(lastot->flags, F_FEELTEXT, NA, NA, NA, "some ash"); addflag(lastot->flags, F_FEELTEXT, NA, NA, NA, "some powder");
addflag(lastot->flags, F_AIFLEEITEM, B_TRUE, NA, NA, NULL); addflag(lastot->flags, F_AIFLEEITEM, B_TRUE, NA, NA, NULL);
addflag(lastot->flags, F_VALUE, 100, NA, NA, NULL); addflag(lastot->flags, F_VALUE, 100, NA, NA, NULL);
addflag(lastot->flags, F_GROWSTO, OT_DUSTCLOUD, VT_OB, NA, NULL); addflag(lastot->flags, F_GROWSTO, OT_DUSTCLOUD, VT_OB, NA, NULL);
@ -3215,7 +3216,7 @@ void initobjects(void) {
addflag(lastot->flags, F_NOBLESS, B_TRUE, NA, NA, NULL); addflag(lastot->flags, F_NOBLESS, B_TRUE, NA, NA, NULL);
addflag(lastot->flags, F_POWDER, B_TRUE, NA, NA, NULL); addflag(lastot->flags, F_POWDER, B_TRUE, NA, NA, NULL);
addflag(lastot->flags, F_HASHIDDENNAME, B_TRUE, NA, NA, "pile of ash"); addflag(lastot->flags, F_HASHIDDENNAME, B_TRUE, NA, NA, "pile of ash");
addflag(lastot->flags, F_FEELTEXT, NA, NA, NA, "some ash"); addflag(lastot->flags, F_FEELTEXT, NA, NA, NA, "some powder");
addflag(lastot->flags, F_VALUE, 80, NA, NA, NULL); addflag(lastot->flags, F_VALUE, 80, NA, NA, NULL);
addflag(lastot->flags, F_GROWSTO, OT_DUSTCLOUD, VT_OB, NA, NULL); addflag(lastot->flags, F_GROWSTO, OT_DUSTCLOUD, VT_OB, NA, NULL);
addot(OT_GEMOFSEEING, "gem of seeing", "Magically enhances your eyesight.", MT_STONE, 1, OC_ROCK, SZ_TINY); addot(OT_GEMOFSEEING, "gem of seeing", "Magically enhances your eyesight.", MT_STONE, 1, OC_ROCK, SZ_TINY);
@ -3613,6 +3614,7 @@ void initobjects(void) {
addflag(lastot->flags, F_MISSILEDAM, NA, NA, NA, "0"); addflag(lastot->flags, F_MISSILEDAM, NA, NA, NA, "0");
addflag(lastot->flags, F_THROWMISSILE, B_TRUE, NA, NA, NULL); addflag(lastot->flags, F_THROWMISSILE, B_TRUE, NA, NA, NULL);
addflag(lastot->flags, F_RARITY, H_DUNGEON, 100, RR_COMMON, NULL); addflag(lastot->flags, F_RARITY, H_DUNGEON, 100, RR_COMMON, NULL);
addflag(lastot->flags, F_FEELTEXT, NA, NA, NA, "some powder");
addot(OT_SANDWICHCHEESE, "cheese sandwich", "A tasty cheese sandwich. Filling, and restores all stamina plus some health.", MT_FOOD, 0.1, OC_FOOD, SZ_TINY); addot(OT_SANDWICHCHEESE, "cheese sandwich", "A tasty cheese sandwich. Filling, and restores all stamina plus some health.", MT_FOOD, 0.1, OC_FOOD, SZ_TINY);
addflag(lastot->flags, F_GLYPH, C_LIGHTBROWN, '%', NA, NULL); addflag(lastot->flags, F_GLYPH, C_LIGHTBROWN, '%', NA, NULL);
addflag(lastot->flags, F_EDIBLE, B_TRUE, 100, NA, ""); addflag(lastot->flags, F_EDIBLE, B_TRUE, 100, NA, "");
@ -6135,6 +6137,7 @@ void initobjects(void) {
addot(OT_GUNPOWDER, "pile of gunpowder", "A black metallic powder. Said to be highly unstable.", MT_METAL, 0.5, OC_TOOLS, SZ_TINY); addot(OT_GUNPOWDER, "pile of gunpowder", "A black metallic powder. Said to be highly unstable.", MT_METAL, 0.5, OC_TOOLS, SZ_TINY);
addflag(lastot->flags, F_HASHIDDENNAME, B_TRUE, NA, NA, "pile of black powder"); addflag(lastot->flags, F_HASHIDDENNAME, B_TRUE, NA, NA, "pile of black powder");
addflag(lastot->flags, F_FEELTEXT, NA, NA, NA, "some powder");
addflag(lastot->flags, F_GLYPH, NA, ',', NA, NULL); addflag(lastot->flags, F_GLYPH, NA, ',', NA, NULL);
addflag(lastot->flags, F_STACKABLE, B_TRUE, NA, NA, NULL); addflag(lastot->flags, F_STACKABLE, B_TRUE, NA, NA, NULL);
addflag(lastot->flags, F_RARITY, H_ALL, 65, NA, NULL); addflag(lastot->flags, F_RARITY, H_ALL, 65, NA, NULL);
@ -9177,7 +9180,7 @@ void initobjects(void) {
addot(OT_COMBATKNIFE, "combat knife", "A sharp, lightweight knife designed for military use.", MT_METAL, 1, OC_WEAPON, SZ_SMALL); addot(OT_COMBATKNIFE, "combat knife", "A sharp, lightweight knife designed for military use.", MT_METAL, 1, OC_WEAPON, SZ_SMALL);
addflag(lastot->flags, F_RARITY, H_DUNGEON, 65, NA, NULL); addflag(lastot->flags, F_RARITY, H_DUNGEON, 65, NA, NULL);
addflag(lastot->flags, F_RARITY, H_CAVE, 65, NA, NULL); addflag(lastot->flags, F_RARITY, H_CAVE, 65, NA, NULL);
addflag(lastot->flags, F_OBATTACKDELAY, 50, NA, NA, NULL); addflag(lastot->flags, F_OBATTACKDELAY, 65, NA, NA, NULL);
addflag(lastot->flags, F_DAM, DT_SLASH, 4, NA, NULL); addflag(lastot->flags, F_DAM, DT_SLASH, 4, NA, NULL);
addflag(lastot->flags, F_ALTDAM, DT_PIERCE, 3, NA, NULL); addflag(lastot->flags, F_ALTDAM, DT_PIERCE, 3, NA, NULL);
addflag(lastot->flags, F_ACCURACY, 100, NA, NA, NULL); addflag(lastot->flags, F_ACCURACY, 100, NA, NA, NULL);
@ -20418,12 +20421,13 @@ void initskills(void) {
addskill(SK_ENGINEERING, "Engineering", "Your construction knowledge and skill with devices like traps.", 25); addskill(SK_ENGINEERING, "Engineering", "Your construction knowledge and skill with devices like traps.", 25);
addskilldesc(SK_ENGINEERING, PR_INEPT, "Each level increases damage dealt to doors/walls by +2.", B_FALSE); addskilldesc(SK_ENGINEERING, PR_INEPT, "Each level increases damage dealt to doors/walls by +2.", B_FALSE);
addskillabil(SK_ENGINEERING, PR_NOVICE, OT_A_DISARM, NA, NULL, B_TRUE); addskillabil(SK_ENGINEERING, PR_NOVICE, OT_A_DISARM, NA, NULL, B_TRUE);
addskillabil(SK_ENGINEERING, PR_NOVICE, OT_A_BUILD, NA, NULL, B_TRUE);
addskilldesc(SK_ENGINEERING, PR_NOVICE, "You receive extra knowledge about walls/floors.", B_FALSE); addskilldesc(SK_ENGINEERING, PR_NOVICE, "You receive extra knowledge about walls/floors.", B_FALSE);
addskilldesc(SK_ENGINEERING, PR_BEGINNER, "You can now 'see' the remaining hit points of walls.", B_FALSE); addskilldesc(SK_ENGINEERING, PR_BEGINNER, "You can now 'see' the remaining hit points of walls.", B_FALSE);
addskillabil(SK_ENGINEERING, PR_BEGINNER, OT_A_DISMANTLE, NA, NULL, B_TRUE); addskillabil(SK_ENGINEERING, PR_BEGINNER, OT_A_DISMANTLE, NA, NULL, B_TRUE);
addskilldesc(SK_ENGINEERING, PR_BEGINNER, "You can now detect hollow spaces.", B_TRUE); addskilldesc(SK_ENGINEERING, PR_BEGINNER, "You can now detect hollow spaces.", B_TRUE);
addskilldesc(SK_ENGINEERING, PR_BEGINNER, "You can now identify trap types.", B_TRUE); addskilldesc(SK_ENGINEERING, PR_BEGINNER, "You can now identify trap types.", B_TRUE);
addskilldesc(SK_ENGINEERING, PR_ADEPT, "You can now create barricades and basic traps.", B_TRUE); //addskilldesc(SK_ENGINEERING, PR_ADEPT, "You can now create barricades and basic traps.", B_TRUE);
addskilldesc(SK_ENGINEERING, PR_ADEPT, "You can now dismantle doors and made-made walls.", B_TRUE); addskilldesc(SK_ENGINEERING, PR_ADEPT, "You can now dismantle doors and made-made walls.", B_TRUE);
addskilldesc(SK_ENGINEERING, PR_SKILLED, "You now automatically detect traps.", B_TRUE); addskilldesc(SK_ENGINEERING, PR_SKILLED, "You now automatically detect traps.", B_TRUE);
addskilldesc(SK_ENGINEERING, PR_SKILLED, "Your speed at dismantling walls is doubled.", B_TRUE); addskilldesc(SK_ENGINEERING, PR_SKILLED, "Your speed at dismantling walls is doubled.", B_TRUE);

Binary file not shown.

1
defs.h
View File

@ -489,6 +489,7 @@ enum CELLCONDITION {
CC_READABLE, CC_READABLE,
CC_SPECIFIED, // hard - does retlist contain this ?? CC_SPECIFIED, // hard - does retlist contain this ??
CC_WEARABLE, CC_WEARABLE,
CC_WEILDABLE,
CC_WEAPON, CC_WEAPON,
CC_WEPSK CC_WEPSK
}; };

10
god.c
View File

@ -555,6 +555,8 @@ void askforworship(enum RACE rid) {
msg("\"%s\"", getflagtext(god->flags, F_GODDECLINE)); more(); msg("\"%s\"", getflagtext(god->flags, F_GODDECLINE)); more();
} }
} }
// make god vanish
castspell(god, OT_S_PLANESHIFT, god, NULL, god->cell, NULL, NULL);
} }
void checkgodbonus(enum RACE rid, enum PIETYLEV newlev, enum PIETYLEV oldlev) { void checkgodbonus(enum RACE rid, enum PIETYLEV newlev, enum PIETYLEV oldlev) {
@ -737,7 +739,7 @@ void dooffer(void) {
if ((god->race->id == R_GODNATURE) && if ((god->race->id == R_GODNATURE) &&
(o->type->obclass->id == OC_FLORA) && (o->type->obclass->id == OC_FLORA) &&
newcell) { newcell) {
addmonster(player->cell, R_BUTTERFLY, NULL, B_FALSE, 1, B_FALSE, B_NOEXTRA, NULL); addmonster(newcell, R_BUTTERFLY, NULL, B_FALSE, 1, B_FALSE, B_NOEXTRA, NULL);
} }
if (o->type->obclass->id == OC_FLORA) { if (o->type->obclass->id == OC_FLORA) {
@ -2006,7 +2008,11 @@ void pleasegod(enum RACE rid, int amt) {
if (!prayedtoany() && !lfhasflag(player, F_GODOFFERDONE)) { if (!prayedtoany() && !lfhasflag(player, F_GODOFFERDONE)) {
if ((newplev > oldplev) && (newplev >= PL_PLEASED)) { if ((newplev > oldplev) && (newplev >= PL_PLEASED)) {
askforworship(rid); if ((rid == R_GODDEATH) && (getalignment(player) == AL_GOOD)) {
} else if ((rid == R_GODLIFE) && (getalignment(player) == AL_EVIL)) {
} else {
askforworship(rid);
}
} }
} }
} }

22
io.c
View File

@ -1249,7 +1249,7 @@ char askdir(char *prompt, int maycancel, int usedrunk) {
// retbuf must already be allocated // retbuf must already be allocated
// "def" is optional // "def" is optional
char *askstring(char *prompt, char punc, char *retbuf, int retBUFLEN, char *def) { char *askstring(char *prompt, char punc, char *retbuf, int retbuflen, char *def) {
char buf[BUFLEN],msghistbuf[BUFLEN]; char buf[BUFLEN],msghistbuf[BUFLEN];
char *ending; char *ending;
@ -1271,7 +1271,7 @@ char *askstring(char *prompt, char punc, char *retbuf, int retBUFLEN, char *def)
mvwprintw(msgwin, 0, 0, buf); mvwprintw(msgwin, 0, 0, buf);
wrefresh(msgwin); wrefresh(msgwin);
echo(); echo();
wgetnstr(msgwin, retbuf, retBUFLEN); wgetnstr(msgwin, retbuf, retbuflen);
noecho(); noecho();
clearmsg(); clearmsg();
if (def && (strlen(retbuf) == 0)) { if (def && (strlen(retbuf) == 0)) {
@ -5513,7 +5513,7 @@ int doweild(obpile_t *op) {
int rv; int rv;
condset_t cs; condset_t cs;
// include _anything_ which could be weilded, even if not neccesarily a weapon. // include _anything_ which could be weilded, even if not neccesarily a weapon.
initcondv(&cs, CC_HASFLAG, B_TRUE, F_DAM, initcondv(&cs, CC_WEILDABLE, B_TRUE, NA,
CC_NONE); CC_NONE);
o = askobject(op, "Weild what", "You have nothing to weild.", &count, 'w', &cs, B_TRUE); o = askobject(op, "Weild what", "You have nothing to weild.", &count, 'w', &cs, B_TRUE);
if (o) { if (o) {
@ -9828,7 +9828,7 @@ int drop(object_t *o, int count) {
} }
} }
*/ */
} else { } else if (!isdeadob(o)) {
// tell the player why! // tell the player why!
if (isplayer(op->owner)) { if (isplayer(op->owner)) {
switch (reason) { switch (reason) {
@ -10503,21 +10503,21 @@ int getkey(int escseqok) {
enum COLOUR getskilllevelcolour(enum SKILLLEVEL slev) { enum COLOUR getskilllevelcolour(enum SKILLLEVEL slev) {
switch (slev) { switch (slev) {
case PR_INEPT: case PR_INEPT:
return C_RED; return C_DARKGREY;
case PR_NOVICE: case PR_NOVICE:
return C_BROWN; return C_BROWN;
case PR_BEGINNER: case PR_BEGINNER:
return C_GREY; return C_LIGHTYELLOW;
case PR_ADEPT: case PR_ADEPT:
return C_GREEN; return C_LIGHTGREEN;
case PR_SKILLED: case PR_SKILLED:
return C_BLUE; return C_LIGHTBLUE;
case PR_EXPERT: case PR_EXPERT:
return C_CYAN; return C_LIGHTCYAN;
case PR_MASTER: case PR_MASTER:
return C_MAGENTA; return C_LIGHTMAGENTA;
} }
return C_GREY; return C_DARKGREY;
} }
void handle_ctrl_y(int arg) { void handle_ctrl_y(int arg) {

128
lf.c
View File

@ -596,68 +596,98 @@ int canattack(lifeform_t *lf) {
} }
// need ob is populated with with the obejcttype needed. // need ob is populated with with the obejcttype needed.
// returns TRUE if we can build it.
int canbuild(lifeform_t *lf, objecttype_t *ot, char *needtext, enum OBTYPE *needob, int *numneed) { int canbuild(lifeform_t *lf, objecttype_t *ot, char *needtext, enum OBTYPE *needob, int *numneed) {
char requiretext[BUFLEN]; char requiretext[BUFLEN];
objecttype_t *tempot; objecttype_t *tempot;
int i;
char *template = " (required %d x %s)"; char *template = " (required %d x %s)";
enum OBTYPE localneed = OT_NONE;
enum OBTYPE altob[MAXCANDIDATES];
int localnum = 0,nalt = 0;
object_t *o; object_t *o;
*needob = OT_NONE; for (i = 0; i < MAXCANDIDATES; i++) {
if (needtext) sprintf(needtext, "%s", ot->name); altob[i] = OT_NONE;
}
if (needtext) {
sprintf(needtext, "%s", ot->name);
}
switch (ot->id) { switch (ot->id) {
case OT_ARROW:
localneed = OT_WOODSHARD;
localnum = 1;
altob[0] = OT_STICK;
nalt = 1;
break;
case OT_BARRICADE: case OT_BARRICADE:
*needob = OT_IRONSTAFF; localneed = OT_IRONSTAFF;
*numneed = 2; localnum = 2;
break; break;
case OT_RUBBLE: case OT_RUBBLE:
*needob = OT_STONE; localneed = OT_STONE;
*numneed = 20; localnum = 20;
break; break;
case OT_FENCEWOOD: case OT_FENCEWOOD:
*needob = OT_WOODPLANK; localneed = OT_WOODPLANK;
*numneed = 1; localnum = 1;
break; break;
case OT_TRAPDOORFALL: case OT_TRAPDOORFALL:
*needob = OT_NONE; localneed = OT_NONE;
*numneed = 0; localnum = 0;
break; break;
case OT_TRAPNEEDLEP: case OT_TRAPNEEDLEP:
*needob = OT_NEEDLE; localneed = OT_NEEDLE;
*numneed = 1; localnum = 1;
break; break;
case OT_TRAPFIRE: case OT_TRAPFIRE:
*needob = OT_POT_RUM; localneed = OT_POT_RUM;
*numneed = 1; localnum = 1;
break; break;
case OT_TRAPMINE: case OT_TRAPMINE:
*needob = OT_GRENADE; localneed = OT_GRENADE;
*numneed = 1; localnum = 1;
break; break;
case OT_TRAPARROW: case OT_TRAPARROW:
*needob = OT_ARROW; localneed = OT_ARROW;
*numneed = 1; localnum = 1;
break; break;
case OT_TRAPROCK: case OT_TRAPROCK:
*needob = OT_STONE; localneed = OT_STONE;
*numneed = 1; localnum = 1;
break; break;
case OT_TRAPTRIP: case OT_TRAPTRIP:
*needob = OT_ROPE; localneed = OT_ROPE;
*numneed = 1; localnum = 1;
break; break;
default: default:
break; break;
} }
if (*needob == OT_NONE) { if (needob) *needob = localneed;
if (numneed) *numneed = localnum;
if (localneed == OT_NONE) {
return B_TRUE; return B_TRUE;
} }
o = hasob(lf->pack, *needob); o = hasob(lf->pack, localneed);
if (o && (o->amt >= *numneed)) { if (!o && nalt) {
tempot = findot(*needob); int i;
sprintf(requiretext, template, *numneed, tempot->name); for (i = 0; i < nalt; i++ ){
o = hasob(lf->pack, altob[i]);
if (o) {
localneed = altob[i];
if (needob) *needob = localneed;
break;
}
}
}
if (o && (o->amt >= localnum)) {
tempot = findot(localneed);
sprintf(requiretext, template, localnum, tempot->name);
if (needtext) strcat(needtext, requiretext); if (needtext) strcat(needtext, requiretext);
return B_TRUE; return B_TRUE;
} }
@ -3829,7 +3859,7 @@ void die(lifeform_t *lf) {
f = hasflag(corpse->flags, F_CORPSEOF); f = hasflag(corpse->flags, F_CORPSEOF);
if (f) { if (f) {
f->val[1] = lf->level; f->val[1] = gettr(lf);
} }
// some corpses will regenerate... // some corpses will regenerate...
@ -5201,7 +5231,7 @@ int eat(lifeform_t *lf, object_t *o) {
} }
} }
} }
if (fid != F_NONE) { if ((fid != F_NONE) && f->id == F_EATMUTATE) {
// lose half your max hp! // lose half your max hp!
losehp_real(lf, (lf->maxhp/2), DT_DIRECT, NULL, losehp_real(lf, (lf->maxhp/2), DT_DIRECT, NULL,
"the shock of mutation", "the shock of mutation",
@ -12386,6 +12416,10 @@ void givestartobs(lifeform_t *lf, object_t *targob, flagpile_t *fp) {
enum LFSIZE maxobsize = SZ_MAX; enum LFSIZE maxobsize = SZ_MAX;
int isshop = B_FALSE; int isshop = B_FALSE;
int depthmod2 = 0; int depthmod2 = 0;
cell_t fakecell;
map_t fakemap;
createfakes(&fakemap, &fakecell);
if (targob) { if (targob) {
cell_t *c; cell_t *c;
@ -12455,7 +12489,9 @@ void givestartobs(lifeform_t *lf, object_t *targob, flagpile_t *fp) {
for (i = 0; i < nposs; i++) { for (i = 0; i < nposs; i++) {
char thisdesc[BUFLEN]; char thisdesc[BUFLEN];
int dam,acc; int dam,acc;
int ok = B_TRUE;
enum DAMTYPE dt; enum DAMTYPE dt;
object_t *o = NULL;
flag_t *vf; flag_t *vf;
f2 = hasflag(poss[i]->flags, F_ACCURACY); f2 = hasflag(poss[i]->flags, F_ACCURACY);
@ -12468,9 +12504,27 @@ void givestartobs(lifeform_t *lf, object_t *targob, flagpile_t *fp) {
// don't allow this if the player is vulnerable to it! // don't allow this if the player is vulnerable to it!
vf = lfhasflagval(lf, F_MATVULN, poss[i]->material->id, NA, NA, NULL); vf = lfhasflagval(lf, F_MATVULN, poss[i]->material->id, NA, NA, NULL);
if (!vf || (vf->val[2] <= 0)) { if (vf && (vf->val[2] > 0)) {
ok = B_FALSE;
}
if (ok) {
o = addobfast(fakecell.obpile, poss[i]->id);
if (!o) {
ok = B_FALSE;
}
}
if (ok) {
if (!canpickup(lf, o, 1)) {
ok = B_FALSE;
}
}
if (ok) {
addchoice(&prompt, ch++, thisdesc, NULL, poss[i], NULL); addchoice(&prompt, ch++, thisdesc, NULL, poss[i], NULL);
} }
if (o) killob(o);
} }
if (prompt.nchoices == 1) { if (prompt.nchoices == 1) {
@ -12506,6 +12560,7 @@ void givestartobs(lifeform_t *lf, object_t *targob, flagpile_t *fp) {
} }
} // end if lf && selectweapon } // end if lf && selectweapon
killfakes(&fakemap, &fakecell);
// give start objects and id them // give start objects and id them
for (f = fp->first ; f ; f = f->next) { for (f = fp->first ; f ; f = f->next) {
@ -19752,7 +19807,8 @@ void spot_hiding_lf(lifeform_t *lf, lifeform_t *hider) {
// announce // announce
if (isplayer(lf)) { if (isplayer(lf)) {
char hidername[BUFLEN]; char hidername[BUFLEN];
getlfname(hider, hidername); getlfnamea(hider, hidername);
needredraw = B_TRUE;
msg("^wYou spot %s!", hidername); msg("^wYou spot %s!", hidername);
} else if (isplayer(hider) && cansee(hider, lf)) { } else if (isplayer(hider) && cansee(hider, lf)) {
if (getlorelevel(hider, lf->race->raceclass->id)) { if (getlorelevel(hider, lf->race->raceclass->id)) {
@ -23520,10 +23576,12 @@ void startlfturn(lifeform_t *lf) {
meltdam = roll("2d6"); meltdam = roll("2d6");
break; break;
} }
if (!skillcheck(lf, SC_CON, (exlimbs*coldmult), 0)) { if ((temp < T_NORMAL) && !isimmuneto(lf->flags, DT_COLD, B_FALSE) && !isresistantto(lf->flags, DT_COLD, B_FALSE)) {
poison(lf, coldtime, P_COLD, 0, "the cold", R_NONE, B_FALSE); if (!skillcheck(lf, SC_CON, (exlimbs*coldmult), 0)) {
} else if (!skillcheck(lf, SC_CON, (exlimbs*shivermult), 0)) { poison(lf, coldtime, P_COLD, 0, "the cold", R_NONE, B_FALSE);
shiver(lf); } else if (!skillcheck(lf, SC_CON, (exlimbs*shivermult), 0)) {
shiver(lf);
}
} }
// chance to melt if you are frozen or made of ice // chance to melt if you are frozen or made of ice

120
objects.c
View File

@ -504,6 +504,7 @@ object_t *addobject(obpile_t *where, char *name, int canstack, int dolinks, enum
enum OBTYPE wantfountaintype = OT_NONE; enum OBTYPE wantfountaintype = OT_NONE;
enum LFSIZE wantarmsize = SZ_ANY; enum LFSIZE wantarmsize = SZ_ANY;
enum MATERIAL wantdiffmat = MT_NOTHING; enum MATERIAL wantdiffmat = MT_NOTHING;
int wantoriginal = B_FALSE;
int minar = NA; // minimum AR for armour int minar = NA; // minimum AR for armour
int mindr = NA,maxdr = NA; // minimum DR for weapons int mindr = NA,maxdr = NA; // minimum DR for weapons
map_t *targetmap = NULL; // for portals map_t *targetmap = NULL; // for portals
@ -887,6 +888,12 @@ object_t *addobject(obpile_t *where, char *name, int canstack, int dolinks, enum
wantarmsize = getlfsize(matchlfskills); wantarmsize = getlfsize(matchlfskills);
} }
donesomething = B_TRUE; donesomething = B_TRUE;
} else if (strstarts(p, "original ")) {
// don't give different material etc
p += strlen("original ");
wantoriginal = B_TRUE;
donesomething = B_TRUE;
// weapon "goodness" // weapon "goodness"
} else if (strstarts(p, "average ")) { } else if (strstarts(p, "average ")) {
wantgoodness = G_AVERAGE; wantgoodness = G_AVERAGE;
@ -1362,15 +1369,17 @@ object_t *addobject(obpile_t *where, char *name, int canstack, int dolinks, enum
wantdiffmat = MT_NOTHING; wantdiffmat = MT_NOTHING;
} }
// chance of being a different material based on ob flags if (!wantoriginal) {
if ((gamemode != GM_GAMESTARTED) && isplayer(where->owner)) { // chance of being a different material based on ob flags
// ...but not in player's initial starting equipment if ((gamemode != GM_GAMESTARTED) && isplayer(where->owner)) {
} else { // ...but not in player's initial starting equipment
if ((wantdiffmat == MT_NOTHING) && (gamemode != GM_CHARGEN)) { } else {
getflags(ot->flags, retflag, &nretflags, F_CANBEDIFFMAT, F_NONE); if ((wantdiffmat == MT_NOTHING) && (gamemode != GM_CHARGEN)) {
for (i = 0; i < nretflags; i++) { getflags(ot->flags, retflag, &nretflags, F_CANBEDIFFMAT, F_NONE);
if (pctchance(retflag[i]->val[1])) { for (i = 0; i < nretflags; i++) {
wantdiffmat = retflag[i]->val[0]; break; if (pctchance(retflag[i]->val[1])) {
wantdiffmat = retflag[i]->val[0]; break;
}
} }
} }
} }
@ -7851,6 +7860,7 @@ int isfirearm(object_t *o) {
} }
int isflammable(object_t *o) { int isflammable(object_t *o) {
if (hasflag(o->flags, F_IMPORTANT)) return B_FALSE;
if (hasflag(o->flags, F_WET)) { if (hasflag(o->flags, F_WET)) {
return B_FALSE; return B_FALSE;
} }
@ -8710,6 +8720,28 @@ lifeform_t *makeanimated(lifeform_t *lf, object_t *o, int level) {
return newlf; return newlf;
} }
void makecool(object_t *o, int howmuch, int howlong) {
flag_t *f;
f = hasflag(o->flags, F_HOT);
if (f) {
int newlife,newpower;
newpower = f->val[0] - howmuch;
if (newpower <= 0) {
killflag(f);
return;
}
if (f->lifetime > 0) {
newlife = f->lifetime - howlong;
if (newlife <= 0) {
killflag(f);
return;
}
}
}
}
// returns true if something hapepned // returns true if something hapepned
int makeduller(object_t *o, int howmuch) { int makeduller(object_t *o, int howmuch) {
char obname[BUFLEN]; char obname[BUFLEN];
@ -8754,10 +8786,20 @@ int makeduller(object_t *o, int howmuch) {
void makehot(object_t *o, int howmuch, int howlong) { void makehot(object_t *o, int howmuch, int howlong) {
flag_t *f; flag_t *f;
int seen = B_FALSE; int seen = B_FALSE;
f = addtempflag(o->flags, F_HOT, howmuch, NA, NA, "1d2", howlong); f = hasflag(o->flags, F_HOT);
if (isequipped(o) && o->pile->owner) { if (f) {
if (isplayer(o->pile->owner) || cansee(player, o->pile->owner)) { if (howmuch > f->val[0]) {
seen = B_TRUE; f->val[0] = howmuch;
}
if (f->lifetime < howlong) {
f->lifetime = howlong;
}
} else {
f = addtempflag(o->flags, F_HOT, howmuch, NA, NA, "1d2", howlong);
if (isequipped(o) && o->pile->owner) {
if (isplayer(o->pile->owner) || cansee(player, o->pile->owner)) {
seen = B_TRUE;
}
} }
} }
// you only know an object is hot if you notice the effects on the // you only know an object is hot if you notice the effects on the
@ -9499,9 +9541,11 @@ void obdie(object_t *o) {
if (hasflag(o->flags, F_CONTAINER)) { if (hasflag(o->flags, F_CONTAINER)) {
object_t *oo, *nextoo;
// dump object's contents into parent container // dump object's contents into parent container
while (o->contents->first) { for (oo = o->contents->first ; oo ; oo = nextoo) {
moveob(o->contents->first, o->pile, ALL); nextoo = oo->next;
moveob(oo, o->pile, ALL);
} }
} }
@ -9805,6 +9849,9 @@ int obmeetscondition(object_t *o, enum CELLCONDITION cond, int arg, int value) {
case CC_WEARABLE: case CC_WEARABLE:
if (iswearable(o)) check = B_TRUE; if (iswearable(o)) check = B_TRUE;
break; break;
case CC_WEILDABLE:
if (isweapon(o) || isfirearm(o)) check = B_TRUE;
break;
case CC_WEAPON: case CC_WEAPON:
if (isweapon(o)) check = B_TRUE; if (isweapon(o)) check = B_TRUE;
break; break;
@ -10026,6 +10073,7 @@ int obmatchescondition(object_t *o, long opts) {
int obproduceslight(object_t *o) { int obproduceslight(object_t *o) {
flag_t *f; flag_t *f;
int amt = 0; int amt = 0;
if (isdeadob(o)) return B_FALSE;
f = hasflag(o->flags, F_PRODUCESLIGHT); f = hasflag(o->flags, F_PRODUCESLIGHT);
if (f) { if (f) {
int thisamt = 0; int thisamt = 0;
@ -11946,6 +11994,9 @@ int pour(lifeform_t *lf, object_t *o) {
if (isplayer(lf)) { if (isplayer(lf)) {
angergodmaybe(R_GODPURITY, 25, GA_HERESY); angergodmaybe(R_GODPURITY, 25, GA_HERESY);
} }
} else if ((o->type->id == OT_POT_POISON) && canbepoisoned(dst->type->id)) {
applyobmod(dst, findobmod(OM_POISONED));
msg("Your %s is now covered with a layer of venom.", noprefix(dstname));
} else if (o->type->id == OT_POT_INVULN) { } else if (o->type->id == OT_POT_INVULN) {
flag_t *f; flag_t *f;
f = hasflag(dst->flags, F_DAMAGABLE); f = hasflag(dst->flags, F_DAMAGABLE);
@ -13402,6 +13453,7 @@ int readsomething(lifeform_t *lf, object_t *o) {
object_t *relinkob(object_t *src, obpile_t *dst) { object_t *relinkob(object_t *src, obpile_t *dst) {
if (!obfits(src, dst)) return NULL; if (!obfits(src, dst)) return NULL;
if (isdeadob(src)) return NULL;
if (src->pile->owner) { if (src->pile->owner) {
// previous owner loses all flags conferred by this object // previous owner loses all flags conferred by this object
@ -13421,6 +13473,11 @@ object_t *relinkob(object_t *src, obpile_t *dst) {
if (src->pile->owner) { if (src->pile->owner) {
unequipeffects(src->pile->owner, src); unequipeffects(src->pile->owner, src);
// this might have killed the object - eg. unequipping
// a summoned energy blade.
if (isdeadob(src)) {
return NULL;
}
} }
// adjust letter... // adjust letter...
@ -14996,9 +15053,18 @@ int real_fireat(lifeform_t *thrower, object_t *o, int amt, cell_t *where, int sp
// an actual physical shield? // an actual physical shield?
if (thrower != target) { if (thrower != target) {
int dist;
dist = getcelldist(srcloc, where);
sprintf(attackname, "%s", obname); sprintf(attackname, "%s", obname);
difficulty = 60 + (speed*10); difficulty = 60 + (speed*10);
if (check_for_block(thrower, target, getthrowdam(o) + speed, DT_PROJECTILE, difficulty, attackname, B_RANGED)) { // harder the closer the projectile was shot from.
if (dist <= 1) {
difficulty += 40;
} else if (dist == 2) {
difficulty += 10;
}
if (check_for_block(thrower, target, getthrowdam(o) + speed,
DT_PROJECTILE, difficulty, attackname, B_RANGED)) {
announcedmiss = B_TRUE; announcedmiss = B_TRUE;
youhit = B_FALSE; youhit = B_FALSE;
missiledam += ((speed*2)+rnd(1,4)); missiledam += ((speed*2)+rnd(1,4));
@ -15728,6 +15794,28 @@ void timeeffectsob(object_t *o) {
} }
} }
} }
// affect hot
i = isheatable(o);
if (i) {
switch (temp) {
case T_VCOLD:
makecool(o, 1, 3);
break;
case T_COLD:
makecool(o, 1, 1);
break;
case T_HOT:
makehot(o, i, 10);
break;
case T_VHOT:
makehot(o, pctof(150,i), 20);
break;
default: break;
}
}
if ((o->type->material->id == MT_WATER) || (o->type->id == OT_SPLASHWATER)) { if ((o->type->material->id == MT_WATER) || (o->type->id == OT_SPLASHWATER)) {
if (location->type->absorbent) { if (location->type->absorbent) {
if (haslos(player, location)) { if (haslos(player, location)) {

View File

@ -246,6 +246,7 @@ void killoc(objectclass_t *oc);
void killot(objecttype_t *ot); void killot(objecttype_t *ot);
int knockbackob(object_t *o, int dir, int howfar, int power, lifeform_t *pusher); int knockbackob(object_t *o, int dir, int howfar, int power, lifeform_t *pusher);
lifeform_t *makeanimated(lifeform_t *lf, object_t *o, int level); lifeform_t *makeanimated(lifeform_t *lf, object_t *o, int level);
void makecool(object_t *o, int howmuch, int howlong);
int makeduller(object_t *o, int howmuch); int makeduller(object_t *o, int howmuch);
void makehot(object_t *o, int howmuch, int howlong); void makehot(object_t *o, int howmuch, int howlong);
void makeknown(enum OBTYPE otid); void makeknown(enum OBTYPE otid);

166
spell.c
View File

@ -110,12 +110,12 @@ int abilityeffects(lifeform_t *user, enum OBTYPE abilid, cell_t *targcell, lifef
} }
if (abilid == OT_A_BUILD) { if (abilid == OT_A_BUILD) {
char tempname[BUFLEN];
objecttype_t *tempot = NULL; objecttype_t *tempot = NULL;
int dir; int dir;
char ch = 'a'; char ch = 'a';
cell_t *c; cell_t *c;
object_t *o; object_t *o;
int numtobuild = 1;
enum SKILLLEVEL slev; enum SKILLLEVEL slev;
enum OBTYPE needob = OT_NONE; enum OBTYPE needob = OT_NONE;
int numneed = 0; int numneed = 0;
@ -137,61 +137,61 @@ int abilityeffects(lifeform_t *user, enum OBTYPE abilid, cell_t *targcell, lifef
} }
slev = getskill(user, SK_ENGINEERING); slev = getskill(user, SK_ENGINEERING);
dir = askdir("Build something in which direction (- to cancel)", B_TRUE, B_TRUE); dir = askdir("Build something in which direction (. for self, - to cancel)", B_TRUE, B_TRUE);
if (dir < 0) { if (dir == D_MYSELF) {
c = NULL;
initprompt(&prompt, "What will you build?");
if (slev >= PR_NOVICE) {
addbuildchoice(&prompt, user, OT_ARROW, &ch);
}
} else if (dir < 0) {
msg("Cancelled."); msg("Cancelled.");
return B_TRUE; return B_TRUE;
} } else {
c = getcellindir(user->cell, dir); c = getcellindir(user->cell, dir);
if (c->lf || c->type->solid) { if (c->lf || c->type->solid) {
msg("There is no space to build anything there!"); msg("There is no space to build anything there!");
return B_TRUE; return B_TRUE;
} }
// what can we build? // what can we build?
initprompt(&prompt, "What will you build?"); initprompt(&prompt, "What will you build?");
if (hasdoor(c)) { if (hasdoor(c)) {
if (slev >= PR_BEGINNER) {
if (slev >= PR_BEGINNER) { // collapsing door
// collapsing door addbuildchoice(&prompt, user, OT_TRAPDOORFALL, &ch);
tempot = findot(OT_TRAPDOORFALL); }
if (!haschoicedata(&prompt, tempot) && canbuild(user, tempot, tempname, &needob, &numneed)) {
addchoice(&prompt, ch++, tempname, NULL, tempot, NULL); if (slev >= PR_EXPERT) {
// other door traps
addbuildchoice(&prompt, user, OT_TRAPNEEDLEP, &ch);
addbuildchoice(&prompt, user, OT_TRAPFIRE, &ch);
addbuildchoice(&prompt, user, OT_TRAPMINE, &ch);
} }
} }
// floor traps?
if (slev >= PR_EXPERT) { if (cellwalkable(NULL, c, NULL)) {
// other door traps if (slev >= PR_BEGINNER) {
tempot = findot(OT_TRAPNEEDLEP); addbuildchoice(&prompt, user, OT_TRAPTRIP, &ch);
if (!haschoicedata(&prompt, tempot) && canbuild(user, tempot, tempname, &needob, &numneed)) addchoice(&prompt, ch++, tempname, NULL, tempot, NULL); addbuildchoice(&prompt, user, OT_BARRICADE, &ch);
tempot = findot(OT_TRAPFIRE); addbuildchoice(&prompt, user, OT_RUBBLE, &ch);
if (!haschoicedata(&prompt, tempot) && canbuild(user, tempot, tempname, &needob, &numneed)) addchoice(&prompt, ch++, tempname, NULL, tempot, NULL); addbuildchoice(&prompt, user, OT_FENCEWOOD, &ch);
tempot = findot(OT_TRAPMINE); }
if (!haschoicedata(&prompt, tempot) && canbuild(user, tempot, tempname, &needob, &numneed)) addchoice(&prompt, ch++, tempname, NULL, tempot, NULL); if (slev >= PR_ADEPT) {
addbuildchoice(&prompt, user, OT_TRAPARROW, &ch);
}
if (slev >= PR_EXPERT) {
addbuildchoice(&prompt, user, OT_TRAPROCK, &ch);
}
} }
} }
// floor traps?
if (cellwalkable(NULL, c, NULL)) {
if (slev >= PR_BEGINNER) {
tempot = findot(OT_TRAPTRIP);
if (!haschoicedata(&prompt, tempot) && canbuild(user, tempot, tempname, &needob, &numneed)) addchoice(&prompt, ch++, tempname, NULL, tempot, NULL);
tempot = findot(OT_BARRICADE); // diff50 - need 2 metal poles
if (!haschoicedata(&prompt, tempot) && canbuild(user, tempot, tempname, &needob, &numneed)) addchoice(&prompt, ch++, tempname, NULL, tempot, NULL);
tempot = findot(OT_RUBBLE); // diff70 - need 20 stones
if (!haschoicedata(&prompt, tempot) && canbuild(user, tempot, tempname, &needob, &numneed)) addchoice(&prompt, ch++, tempname, NULL, tempot, NULL);
tempot = findot(OT_FENCEWOOD); // diff80 - need 1 plank of wood
if (!haschoicedata(&prompt, tempot) && canbuild(user, tempot, tempname, &needob, &numneed)) addchoice(&prompt, ch++, tempname, NULL, tempot, NULL);
}
if (slev >= PR_EXPERT) {
tempot = findot(OT_TRAPARROW);
if (!haschoicedata(&prompt, tempot) && canbuild(user, tempot, tempname, &needob, &numneed)) addchoice(&prompt, ch++, tempname, NULL, tempot, NULL);
tempot = findot(OT_TRAPROCK);
if (!haschoicedata(&prompt, tempot) && canbuild(user, tempot, tempname, &needob, &numneed)) addchoice(&prompt, ch++, tempname, NULL, tempot, NULL);
}
}
if (prompt.nchoices <= 0) { if (prompt.nchoices <= 0) {
msg("There is nothing that you can build there."); if (c) {
msg("There is nothing that you can build there.");
} else {
msg("There is nothing that you can currently build.");
}
return B_TRUE; return B_TRUE;
} }
prompt.maycancel = B_TRUE; prompt.maycancel = B_TRUE;
@ -206,30 +206,63 @@ int abilityeffects(lifeform_t *user, enum OBTYPE abilid, cell_t *targcell, lifef
if (needob != OT_NONE) { if (needob != OT_NONE) {
o = hasob(user->pack, needob); o = hasob(user->pack, needob);
if (o && (o->amt >= numneed)) { if (o && (o->amt >= numneed)) {
removeob(o, numneed); if (c) {
// just build it
removeob(o, numneed);
} else {
int npossible;
npossible = (o->amt / numneed);
// ask how many
if (npossible >= 2) {
char ptext[BUFLEN],buf[BUFLEN];
char *p;
p = makeplural(tempot->name);
sprintf(ptext, "How many %s will you build (max %d)", p, npossible);
free(p);
askstring(ptext, '?', buf, BUFLEN, "1");
numtobuild = atoi(buf);
if (numtobuild <= 0) {
msg("Cancelled.");
return B_TRUE;
}
}
removeob(o, numneed*numtobuild);
}
} else { } else {
msg("You don't have the required components to build that."); msg("You don't have the required components to build that.");
return B_TRUE; return B_TRUE;
} }
} }
// create the trap/obstacle/whatever if (c) {
o = hasdoor(c); // create the trap/obstacle/whatever
if (o) { o = hasdoor(c);
addflag(o->flags, F_TRAPPED, tempot->id, NA, B_TRUE, NULL);
o = NULL;
} else {
o = addobfast(c->obpile, tempot->id);
if (o) { if (o) {
killflagsofid(o->flags, F_SECRET); addflag(o->flags, F_TRAPPED, tempot->id, NA, B_TRUE, NULL);
o = NULL;
} else { } else {
msg("For some reason, you can't build there."); o = addobfast(c->obpile, tempot->id);
return B_TRUE; if (o) {
killflagsofid(o->flags, F_SECRET);
} else {
msg("For some reason, you can't build there.");
return B_TRUE;
}
} }
} else {
char buf[BUFLEN];
sprintf(buf, "%d original %s", numtobuild, tempot->name);
o = addob(user->pack, buf);
} }
taketime(user, getactspeed(user)*2); taketime(user, getactspeed(user)*2);
setlosdirty(user); if (c) {
msg("You build %s %s.", needan(tempot->name) ? "an" : "a", tempot->name); setlosdirty(user);
msg("You build %s %s.", needan(tempot->name) ? "an" : "a", tempot->name);
} else {
char obname[BUFLEN];
getobname(o, obname, o->amt);
msgnocap("%c - %s", o->letter, obname);
}
} else if (abilid == OT_A_CHARGE) { } else if (abilid == OT_A_CHARGE) {
cell_t *adjcell = NULL,*origcell; cell_t *adjcell = NULL,*origcell;
@ -3921,7 +3954,15 @@ int abilityeffects(lifeform_t *user, enum OBTYPE abilid, cell_t *targcell, lifef
return B_FALSE; return B_FALSE;
} }
void addbuildchoice(prompt_t *p, lifeform_t *lf, enum OBTYPE oid, char *ch) {
objecttype_t *tempot;
char tempname[BUFLEN];
tempot = findot(oid);
if (!haschoicedata(p, tempot) && canbuild(lf, tempot, tempname, NULL, NULL)) {
addchoice(p, *ch, tempname, NULL, tempot, NULL);
(*ch)++;
}
}
// returns TRUE on error // returns TRUE on error
@ -5813,6 +5854,7 @@ int dospelleffects(lifeform_t *caster, enum OBTYPE spellid, int power, lifeform_
int pickagain = B_TRUE; int pickagain = B_TRUE;
flag_t *f; flag_t *f;
while (pickagain) { while (pickagain) {
pickagain = B_FALSE;
ot = getrandomobofclass(OC_FOOD, NA, NA, NULL, NULL); ot = getrandomobofclass(OC_FOOD, NA, NA, NULL, NULL);
if (hasflag(ot->flags, F_VENOMSAC)) { if (hasflag(ot->flags, F_VENOMSAC)) {
pickagain = B_TRUE; pickagain = B_TRUE;

View File

@ -3,6 +3,7 @@
#include "defs.h" #include "defs.h"
int abilityeffects(lifeform_t *user, enum OBTYPE abilid, cell_t *targcell, lifeform_t *target, flag_t *cwflag); int abilityeffects(lifeform_t *user, enum OBTYPE abilid, cell_t *targcell, lifeform_t *target, flag_t *cwflag);
void addbuildchoice(prompt_t *p, lifeform_t *lf, enum OBTYPE oid, char *ch);
int dospelleffects(lifeform_t *caster, enum OBTYPE spellid, int power, lifeform_t *target, object_t *targob, cell_t *targcell, int blessed, int *seenbyplayer, int frompot, object_t *fromob); int dospelleffects(lifeform_t *caster, enum OBTYPE spellid, int power, lifeform_t *target, object_t *targob, cell_t *targcell, int blessed, int *seenbyplayer, int frompot, object_t *fromob);
objecttype_t *findspelln(char *buf); objecttype_t *findspelln(char *buf);
enum SPELLSCHOOL findspellschoolbyname(char *buf); enum SPELLSCHOOL findspellschoolbyname(char *buf);

11
text.c
View File

@ -353,11 +353,14 @@ char *construct_hit_string(lifeform_t *lf, lifeform_t *victim, char *attackernam
needfree = B_TRUE; needfree = B_TRUE;
} }
if (victim && isplayer(victim) && !nodam) { if (victim) {
col = C_YELLOW; if (isplayer(victim) && !nodam) {
col = C_YELLOW;
} else {
col = chartocol(getlfcol(victim, CC_BAD));
}
} else { } else {
//col = C_GREY; col = C_GREY;
col = chartocol(getlfcol(victim, CC_BAD));
} }
strcpy(adjective, ""); strcpy(adjective, "");