- move all definitions into data.c / data.h
- [+] monsters should start sprinting if targetlf is sprinting && we can sprint && we aren't sprinting * [+] The kobold throws a potion of sleep at you. A potion of sleep hits you. A potion of sleep shatters! You are showered in glass shards! * [+] in getchoicestr, when there is only one valid choice, show its description below! - [+] in getchoicestr: - [+] remember desc_end_y - [+] if our typed text doesn't match, and desc_end_y is set - [+] blank out those lines - [+] in ], show letters and let you view amrour - [+] Still occasionally have bugs where no up stairs are placed in the first level!!!!! - [+] put in debugging to show if we ever destroy a staircase - [+] test when it happens again..... - [+] for "pentagram pulses black", if you can't see the estination, still say "your xxx flies away" - [+] change listen code: you can only hear one _footstep_ noise per turn, but any number of other things. - [+] instead of jobs replaceing hitdice, make them _modify_ maxhp by a certain %age. ie. f_modmaxhp 80% to get lower. - [+] jobs can no longer have F_HITDICE - [+] instead, they have F_MAXHPMOD - [+] why am i getting wet and drowning while flying?? - [+] show f_canwill SPELLS under abilities, not spells?? - More playable races - [+] need f_playablerace - [+] can pick when you start the game (before you pick job) - [+] human - [+] implement f_jobattrmod - [+] MOST JOBS SHOULD USE F_JOBATTRMOD instead of F_STARTATT. - [+] ALL PLAYABLE RACES must have FULL sets of STARTATT * [+] elf * [+] dwarf - [+] aviad (birdfolk) - [+] can fly - [+] vuln to electric attacks - [+] vuln++ to fire - [+] ---str - [+] cyborg - [+] +str, +int, +dex, +con - [+] ---cha - [+] -wis - [+] vulnerable to lightning, water,cold - [+] cannot use any magic, or med-high chance of spell failure - [+] bleeds oil rather than water - [+] see exact hp damage (f_extrainfo) - [+] tech usage. - [+] remember race in highscores.
This commit is contained in:
parent
b200e3acf7
commit
7f33b6351c
6
ai.c
6
ai.c
|
@ -677,6 +677,12 @@ int aimovetolf(lifeform_t *lf, lifeform_t *target, int wantattack) {
|
||||||
if (db) {
|
if (db) {
|
||||||
dblog(".oO { moving towards target. }");
|
dblog(".oO { moving towards target. }");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// do we need to sprint got catch up?
|
||||||
|
if (lfhasflag(target, F_SPRINTING) && !lfhasflag(lf, F_SPRINTING) && cancast(lf, OT_A_SPRINT, NULL)) {
|
||||||
|
useability(lf, OT_A_SPRINT, NULL,NULL); // doesn't matter if it fails
|
||||||
|
}
|
||||||
|
|
||||||
if (!movetowards(lf, target->cell, DT_ORTH, B_FALSE)) {
|
if (!movetowards(lf, target->cell, DT_ORTH, B_FALSE)) {
|
||||||
turntoface(lf, target->cell);
|
turntoface(lf, target->cell);
|
||||||
// success
|
// success
|
||||||
|
|
|
@ -0,0 +1,9 @@
|
||||||
|
#include "defs.h"
|
||||||
|
|
||||||
|
command_t *addcommand(enum COMMAND id, char c, char *desc);
|
||||||
|
void initcommands(void);
|
||||||
|
void initjobs(void);
|
||||||
|
void initobjects(void);
|
||||||
|
void initrace(void);
|
||||||
|
void initskills(void);
|
||||||
|
void sortcommands(void);
|
BIN
data/hiscores.db
BIN
data/hiscores.db
Binary file not shown.
27
defs.h
27
defs.h
|
@ -251,7 +251,7 @@ enum RELATIVEDIR {
|
||||||
#define SAVEDIR "data/save"
|
#define SAVEDIR "data/save"
|
||||||
#define VAULTDIR "vaults"
|
#define VAULTDIR "vaults"
|
||||||
// rank, score, name, job, killer
|
// rank, score, name, job, killer
|
||||||
#define HISCOREFORMAT "%-6s%-7s%-14s%-18s%s"
|
#define HISCOREFORMAT "%-6s%-7s%-10s%-18s%s"
|
||||||
|
|
||||||
// game strings
|
// game strings
|
||||||
#define MORESTRING "--More--"
|
#define MORESTRING "--More--"
|
||||||
|
@ -364,8 +364,9 @@ enum CASTTYPE {
|
||||||
|
|
||||||
enum NOISECLASS {
|
enum NOISECLASS {
|
||||||
NC_NONE = 0,
|
NC_NONE = 0,
|
||||||
NC_SPEECH = 1,
|
NC_WALK = 1,
|
||||||
NC_OTHER = 2,
|
NC_SPEECH = 2,
|
||||||
|
NC_OTHER = 3,
|
||||||
};
|
};
|
||||||
|
|
||||||
enum QUADRANT {
|
enum QUADRANT {
|
||||||
|
@ -755,8 +756,13 @@ enum RACE {
|
||||||
R_RANDOM, R_SPECIFIED,
|
R_RANDOM, R_SPECIFIED,
|
||||||
// unique monstesr
|
// unique monstesr
|
||||||
R_JAILER,
|
R_JAILER,
|
||||||
// human monsters
|
// playable races
|
||||||
|
R_AVIAD,
|
||||||
|
R_CYBORG,
|
||||||
|
R_DWARF,
|
||||||
|
R_ELF,
|
||||||
R_HUMAN,
|
R_HUMAN,
|
||||||
|
// human monsters
|
||||||
R_BANDITLDR,
|
R_BANDITLDR,
|
||||||
R_BANDIT,
|
R_BANDIT,
|
||||||
R_BEGGAR,
|
R_BEGGAR,
|
||||||
|
@ -2026,6 +2032,7 @@ enum FLAG {
|
||||||
F_COUNTER, // generic counter flag for race abilities.
|
F_COUNTER, // generic counter flag for race abilities.
|
||||||
F_DEBUG, // debugging enabled
|
F_DEBUG, // debugging enabled
|
||||||
F_ACCURACYMOD, // modify your accuracy by val0
|
F_ACCURACYMOD, // modify your accuracy by val0
|
||||||
|
F_PLAYABLE, // player can select to be this race.
|
||||||
F_VAMPIRIC, // successful bite attacks form this lf will heal it
|
F_VAMPIRIC, // successful bite attacks form this lf will heal it
|
||||||
F_VEGETARIAN, // this lf will not eat meat.
|
F_VEGETARIAN, // this lf will not eat meat.
|
||||||
F_PARTVEGETARIAN,// this lf will only eat if hunger >= 'hungry'
|
F_PARTVEGETARIAN,// this lf will only eat if hunger >= 'hungry'
|
||||||
|
@ -2038,6 +2045,7 @@ enum FLAG {
|
||||||
// v0 is accuracy penalty, v1 is evasion penalty.
|
// v0 is accuracy penalty, v1 is evasion penalty.
|
||||||
F_LEVRACE, // at level v0, this race is promoted to race v1
|
F_LEVRACE, // at level v0, this race is promoted to race v1
|
||||||
// must apply this to the BASE race.
|
// must apply this to the BASE race.
|
||||||
|
F_JOBATTRMOD, // add v1 to attr v0. only used in jobs.
|
||||||
F_ATTRMOD, // modify attribute val0 by val1. ie. 0=A_STR,1=-3
|
F_ATTRMOD, // modify attribute val0 by val1. ie. 0=A_STR,1=-3
|
||||||
F_ATTRSET, // forces attribute val0 to be val1. ie. 0=A_STR,1=18
|
F_ATTRSET, // forces attribute val0 to be val1. ie. 0=A_STR,1=18
|
||||||
F_SIZE, // val0 = lf size (enum LFSIZE)
|
F_SIZE, // val0 = lf size (enum LFSIZE)
|
||||||
|
@ -2212,6 +2220,7 @@ enum FLAG {
|
||||||
F_NUMAPPEAR, // when randomly appearing, can have > 1. val[0] = min, val[1] = max
|
F_NUMAPPEAR, // when randomly appearing, can have > 1. val[0] = min, val[1] = max
|
||||||
F_MINIONS, // val0 % chance of appearing with v1-v2 lf of type text
|
F_MINIONS, // val0 % chance of appearing with v1-v2 lf of type text
|
||||||
F_HITDICE, // text = xdy+z to roll for maxhp per level.
|
F_HITDICE, // text = xdy+z to roll for maxhp per level.
|
||||||
|
F_MAXHPMOD, // maxhp = pctof(v0, maxhp)
|
||||||
F_MPDICE, // val0: # d4 to roll for maxmp per level. val1: +xx
|
F_MPDICE, // val0: # d4 to roll for maxmp per level. val1: +xx
|
||||||
F_JOB, // val0 = player's class/job
|
F_JOB, // val0 = player's class/job
|
||||||
F_GODOF, // text = what this lf is the god of. use capitals.
|
F_GODOF, // text = what this lf is the god of. use capitals.
|
||||||
|
@ -2276,7 +2285,9 @@ enum FLAG {
|
||||||
F_MAGICARMOUR,// armour is magically boosted. f->text is the description
|
F_MAGICARMOUR,// armour is magically boosted. f->text is the description
|
||||||
// ie 'magic armour', 'force field'
|
// ie 'magic armour', 'force field'
|
||||||
// v0 is power left.
|
// v0 is power left.
|
||||||
F_ASLEEP, // is asleep. if v2 is set, means we are sleeping on
|
F_ASLEEP, // lf is asleep.
|
||||||
|
// if v1 is set, means we are 'meditating' instead
|
||||||
|
// if v2 is set, means we are sleeping on
|
||||||
// purpose and will wake up when at full hp/mp/etc.
|
// purpose and will wake up when at full hp/mp/etc.
|
||||||
F_ATTACHEDTO, // you are attached to lf id v0, and will move with it
|
F_ATTACHEDTO, // you are attached to lf id v0, and will move with it
|
||||||
F_AWARENESS, // you can see 360 degrees around yourself
|
F_AWARENESS, // you can see 360 degrees around yourself
|
||||||
|
@ -2352,6 +2363,7 @@ enum FLAG {
|
||||||
// (bypasses armour)
|
// (bypasses armour)
|
||||||
F_GRAVBOOSTED,// cannot walk or throw stuff
|
F_GRAVBOOSTED,// cannot walk or throw stuff
|
||||||
F_GRAVLESSENED,// knockback maeks you go further, can jump further
|
F_GRAVLESSENED,// knockback maeks you go further, can jump further
|
||||||
|
F_MEDITATES, // meditates instead of sleeping.
|
||||||
F_NEEDSWATER, // cannot survive out of deep water
|
F_NEEDSWATER, // cannot survive out of deep water
|
||||||
F_PAIN, // take damage if you walk. v0=damtype,text is damage (xdy+z).
|
F_PAIN, // take damage if you walk. v0=damtype,text is damage (xdy+z).
|
||||||
// if text not set, default dam is 1d2
|
// if text not set, default dam is 1d2
|
||||||
|
@ -3202,8 +3214,9 @@ typedef struct obmod_s {
|
||||||
|
|
||||||
typedef struct choice_s {
|
typedef struct choice_s {
|
||||||
char ch;
|
char ch;
|
||||||
char *text;
|
char *text; // what you type to select this one
|
||||||
char *desc;
|
char *desc; // what is displayed on the screen
|
||||||
|
char *longdesc; // what to display once you've selected this
|
||||||
void *data;
|
void *data;
|
||||||
int heading;
|
int heading;
|
||||||
int valid; // used in askchoicestr
|
int valid; // used in askchoicestr
|
||||||
|
|
|
@ -27,6 +27,7 @@ x = small creature/monster
|
||||||
q = quadraped
|
q = quadraped
|
||||||
Q = large quadraped
|
Q = large quadraped
|
||||||
r = rodent
|
r = rodent
|
||||||
|
R = robot
|
||||||
s = snake
|
s = snake
|
||||||
S = spider
|
S = spider
|
||||||
h = humanoid
|
h = humanoid
|
||||||
|
@ -37,6 +38,7 @@ V = vampire
|
||||||
z = lizard-like creature
|
z = lizard-like creature
|
||||||
Z = undead
|
Z = undead
|
||||||
|
|
||||||
|
|
||||||
---
|
---
|
||||||
C
|
C
|
||||||
hybrid human animal?
|
hybrid human animal?
|
||||||
|
|
6
io.h
6
io.h
|
@ -1,6 +1,6 @@
|
||||||
#include <ncurses.h>
|
#include <ncurses.h>
|
||||||
#include "defs.h"
|
#include "defs.h"
|
||||||
void addchoice(prompt_t *p, char ch, char *text, char *desc, void *data);
|
void addchoice(prompt_t *p, char ch, char *text, char *desc, void *data, char *longdesc);
|
||||||
void addheading(prompt_t *p, char *text);
|
void addheading(prompt_t *p, char *text);
|
||||||
void addmsghist(char *text);
|
void addmsghist(char *text);
|
||||||
void addpromptq(prompt_t *p, char *q);
|
void addpromptq(prompt_t *p, char *q);
|
||||||
|
@ -96,6 +96,10 @@ void initgfx(void);
|
||||||
void initprompt(prompt_t *p, char *q1);
|
void initprompt(prompt_t *p, char *q1);
|
||||||
int keycodetokey(int keycode);
|
int keycodetokey(int keycode);
|
||||||
void listobs(WINDOW *win, object_t **mylist, int *sellist, int *selcount, int firstob, int *counter, int lastline, int *y, char *myletters, int forpickup, int showpoints);
|
void listobs(WINDOW *win, object_t **mylist, int *sellist, int *selcount, int firstob, int *counter, int lastline, int *y, char *myletters, int forpickup, int showpoints);
|
||||||
|
char *makedesc_god(lifeform_t *god, char *retbuf);
|
||||||
|
char *makedesc_ob(object_t *o, char *retbuf);
|
||||||
|
char *makedesc_skill(enum SKILL skid, char *retbuf);
|
||||||
|
char *makedesc_spell(objecttype_t *ot, char *retbuf);
|
||||||
void makespellchoicelist(prompt_t *pr, lifeform_t *lf, char *ques, char *ques2, enum SPELLSCHOOL wantschool, int wantunknown, int wantlowmp, int wanttoohard,int mpcutoff);
|
void makespellchoicelist(prompt_t *pr, lifeform_t *lf, char *ques, char *ques2, enum SPELLSCHOOL wantschool, int wantunknown, int wantlowmp, int wanttoohard,int mpcutoff);
|
||||||
void more(void);
|
void more(void);
|
||||||
void warn(char *format, ... );
|
void warn(char *format, ... );
|
||||||
|
|
431
lf.c
431
lf.c
|
@ -1266,7 +1266,7 @@ int castspell(lifeform_t *lf, enum OBTYPE sid, lifeform_t *targlf, object_t *tar
|
||||||
strcat(buf, "\t");
|
strcat(buf, "\t");
|
||||||
strcat(buf, desc);
|
strcat(buf, desc);
|
||||||
}
|
}
|
||||||
addchoice(&prompt, '0' + i, buf, buf, NULL);
|
addchoice(&prompt, '0' + i, buf, buf, NULL, NULL);
|
||||||
}
|
}
|
||||||
ch = getchoice(&prompt);
|
ch = getchoice(&prompt);
|
||||||
power = ch - '0';
|
power = ch - '0';
|
||||||
|
@ -1506,6 +1506,10 @@ int checkfordrowning(lifeform_t *lf, object_t *o) {
|
||||||
flag_t *f;
|
flag_t *f;
|
||||||
enum SKILLLEVEL slev;
|
enum SKILLLEVEL slev;
|
||||||
|
|
||||||
|
if (!isairborne(lf)) {
|
||||||
|
return B_FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
i = getskill(lf, SK_SWIMMING) - isburdened(lf);
|
i = getskill(lf, SK_SWIMMING) - isburdened(lf);
|
||||||
limit(&i, 0, NA);
|
limit(&i, 0, NA);
|
||||||
slev = i;
|
slev = i;
|
||||||
|
@ -1593,44 +1597,6 @@ int checkfordrowning(lifeform_t *lf, object_t *o) {
|
||||||
return didsomething;
|
return didsomething;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
void checkxp(enum RACE rid) {
|
|
||||||
int i,xp;
|
|
||||||
race_t *r;
|
|
||||||
|
|
||||||
r = findrace(rid);
|
|
||||||
if (!r) {
|
|
||||||
dblog("checkxp(): can't find race for rid %d",rid);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
xp = calcxprace(rid);
|
|
||||||
|
|
||||||
|
|
||||||
if (xp < xpposs[0]) {
|
|
||||||
dblog("** Recommended rarity for %s: 100 (before %s/%d)",
|
|
||||||
r->name,
|
|
||||||
raceposs[0]->name, getracerarity(raceposs[0]->id));
|
|
||||||
} else if (xp > xpposs[xplistlen-1]) {
|
|
||||||
dblog("** Recommended rarity for %s: above %d (after %s/%d)",
|
|
||||||
r->name, getracerarity(raceposs[xplistlen-1]->id),
|
|
||||||
raceposs[xplistlen-1]->name, getracerarity(raceposs[xplistlen-1]->id));
|
|
||||||
} else {
|
|
||||||
for (i = 0; i < xplistlen-1; i++) {
|
|
||||||
if ((raceposs[i]->d != r->id) && (raceposs[i+1] != r->id))
|
|
||||||
if ((xp >= xpposs[i]) && (xp <= xpposs[i+1])) {
|
|
||||||
dblog("** Recommended rarity for %s: %d (between %s/%d and %s/%d)",
|
|
||||||
r->name, (int)((float)xpposs[i] + (float)xpposs[i+1])/2,
|
|
||||||
raceposs[i]->name, getracerarity(raceposs[i]->id),
|
|
||||||
raceposs[i+1]->name, getracerarity(raceposs[i+1]->id)
|
|
||||||
);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
int check_rest_ok(lifeform_t *lf) {
|
int check_rest_ok(lifeform_t *lf) {
|
||||||
if (!safetorest(lf)) {
|
if (!safetorest(lf)) {
|
||||||
if (isplayer(lf)) {
|
if (isplayer(lf)) {
|
||||||
|
@ -2675,12 +2641,6 @@ int eat(lifeform_t *lf, object_t *o) {
|
||||||
pcteaten = (eateachturn / nutrition) * 100;
|
pcteaten = (eateachturn / nutrition) * 100;
|
||||||
|
|
||||||
// announce
|
// announce
|
||||||
/*
|
|
||||||
msg("totnutr:%0.0lf,startpcteaten:%0.0lf,endpcteaten:%0.0f,eatperturn:%0.0f,turnstoeat:%0.0lf,fullyeaten:%s",
|
|
||||||
nutrition,
|
|
||||||
startpcteaten,pcteaten,
|
|
||||||
eateachturn,turnstoeat,fullyeaten ? "YES" : "NO");
|
|
||||||
*/
|
|
||||||
snprintf(buf, BUFLEN, "%ld",o->id);
|
snprintf(buf, BUFLEN, "%ld",o->id);
|
||||||
alreadyeating = lfhasflagval(lf, F_EATING, NA, NA, NA, buf);
|
alreadyeating = lfhasflagval(lf, F_EATING, NA, NA, NA, buf);
|
||||||
|
|
||||||
|
@ -3032,13 +2992,15 @@ void enhanceskills(lifeform_t *lf) {
|
||||||
cost = getskilllevcost(f->val[1] + 1);
|
cost = getskilllevcost(f->val[1] + 1);
|
||||||
if (lf->skillpoints >= cost) {
|
if (lf->skillpoints >= cost) {
|
||||||
char buf[BUFLEN];
|
char buf[BUFLEN];
|
||||||
|
char buf2[HUGEBUFLEN];
|
||||||
snprintf(buf, BUFLEN, "%s (%s, cost:%d points)", getskillname(f->val[0]),
|
snprintf(buf, BUFLEN, "%s (%s, cost:%d points)", getskillname(f->val[0]),
|
||||||
getskilllevelname(f->val[1] + 1), cost);
|
getskilllevelname(f->val[1] + 1), cost);
|
||||||
addchoice(&prompt, ch++, getskillname(f->val[0]), buf, f);
|
makedesc_skill(f->val[0], buf2);
|
||||||
|
addchoice(&prompt, ch++, getskillname(f->val[0]), buf, f, buf2);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
addchoice(&prompt, '-', "None", "None", NULL);
|
addchoice(&prompt, '-', "None", "None", NULL, NULL);
|
||||||
|
|
||||||
while (!done) {
|
while (!done) {
|
||||||
getchoicestr(&prompt, B_FALSE, B_TRUE);
|
getchoicestr(&prompt, B_FALSE, B_TRUE);
|
||||||
|
@ -3079,11 +3041,13 @@ void enhanceskills(lifeform_t *lf) {
|
||||||
for (sk = firstskill ; sk ; sk = sk->next) {
|
for (sk = firstskill ; sk ; sk = sk->next) {
|
||||||
if (!getskill(player, sk->id) && canlearn(player, sk->id)) {
|
if (!getskill(player, sk->id) && canlearn(player, sk->id)) {
|
||||||
char buf[BUFLEN];
|
char buf[BUFLEN];
|
||||||
|
char buf2[HUGEBUFLEN];
|
||||||
snprintf(buf, BUFLEN, "%-18s(%s)", getskillname(sk->id), getskilldesc(sk->id));
|
snprintf(buf, BUFLEN, "%-18s(%s)", getskillname(sk->id), getskilldesc(sk->id));
|
||||||
addchoice(&prompt, ch++, getskillname(sk->id), buf, sk);
|
makedesc_skill(sk->id, buf2);
|
||||||
|
addchoice(&prompt, ch++, getskillname(sk->id), buf, sk, buf2);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
addchoice(&prompt, '-', "None", "None", NULL);
|
addchoice(&prompt, '-', "None", "None", NULL, NULL);
|
||||||
while (!done) {
|
while (!done) {
|
||||||
getchoicestr(&prompt, B_FALSE, B_TRUE);
|
getchoicestr(&prompt, B_FALSE, B_TRUE);
|
||||||
sk = (skill_t *)prompt.result;
|
sk = (skill_t *)prompt.result;
|
||||||
|
@ -3841,13 +3805,6 @@ void gainlevel(lifeform_t *lf) {
|
||||||
lf->skillpoints++;
|
lf->skillpoints++;
|
||||||
}
|
}
|
||||||
|
|
||||||
//if (postready && !preready) {
|
|
||||||
/*
|
|
||||||
} else {
|
|
||||||
killflagsofid(lf->flags, F_HASNEWLEVEL);
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
if (isplayer(lf)) {
|
if (isplayer(lf)) {
|
||||||
msg("^GYou are ready to train a new experience level!");
|
msg("^GYou are ready to train a new experience level!");
|
||||||
more();
|
more();
|
||||||
|
@ -4871,17 +4828,6 @@ object_t *getbestweapon(lifeform_t *lf) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
if (op && (bestwep == op->first)) {
|
|
||||||
// ie. use no weapon
|
|
||||||
bestwep = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (op) {
|
|
||||||
killobpile(op);
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
if (bestwep && (bestwep->pile->owner == NULL)) {
|
if (bestwep && (bestwep->pile->owner == NULL)) {
|
||||||
// ie. best weapon is an innate attack
|
// ie. best weapon is an innate attack
|
||||||
bestwep = NULL;
|
bestwep = NULL;
|
||||||
|
@ -5034,22 +4980,6 @@ int getguntargetid(lifeform_t *lf) {
|
||||||
return f->val[0];
|
return f->val[0];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
// get time to heal 1 hp
|
|
||||||
int gethealtime(lifeform_t *lf) {
|
|
||||||
int healtime;
|
|
||||||
flag_t *f;
|
|
||||||
f = lfhasflag(lf, F_HEALTIME);
|
|
||||||
if (f) {
|
|
||||||
healtime = f->val[0];
|
|
||||||
} else {
|
|
||||||
healtime = DEF_HEALTIME;
|
|
||||||
}
|
|
||||||
return healtime;
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
int gethearingrange(lifeform_t *lf) {
|
int gethearingrange(lifeform_t *lf) {
|
||||||
int range = 8; // deafult
|
int range = 8; // deafult
|
||||||
range = 2 + (getskill(lf, SK_LISTEN)*2);
|
range = 2 + (getskill(lf, SK_LISTEN)*2);
|
||||||
|
@ -5557,12 +5487,6 @@ char *getseenlfconditionname(lifeform_t *lf, lifeform_t *viewer) {
|
||||||
|
|
||||||
glyph_t *getlfglyph(lifeform_t *lf) {
|
glyph_t *getlfglyph(lifeform_t *lf) {
|
||||||
flag_t *f;
|
flag_t *f;
|
||||||
/*
|
|
||||||
if (isplayer(lf) && !ispolymorphed(lf)) {
|
|
||||||
return &playerglyph;
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
if (lfhasflag(lf, F_FEIGNINGDEATH)) {
|
if (lfhasflag(lf, F_FEIGNINGDEATH)) {
|
||||||
// look like a corpse
|
// look like a corpse
|
||||||
tempglyph.ch = '%';
|
tempglyph.ch = '%';
|
||||||
|
@ -6951,9 +6875,12 @@ void givejob(lifeform_t *lf, enum JOB jobid) {
|
||||||
job_t *j;
|
job_t *j;
|
||||||
flag_t *f;
|
flag_t *f;
|
||||||
int i;
|
int i;
|
||||||
int rollhp = B_FALSE, rollmp = B_FALSE;
|
//int rollhp = B_FALSE;
|
||||||
|
int rollmp = B_FALSE;
|
||||||
int rollatt[MAXATTS];
|
int rollatt[MAXATTS];
|
||||||
int db = B_FALSE;
|
int db = B_FALSE;
|
||||||
|
flag_t *retflag[MAXCANDIDATES];
|
||||||
|
int nretflags;
|
||||||
|
|
||||||
if (db) dblog("givejob() starting.\n");
|
if (db) dblog("givejob() starting.\n");
|
||||||
|
|
||||||
|
@ -6965,13 +6892,11 @@ void givejob(lifeform_t *lf, enum JOB jobid) {
|
||||||
addflag(lf->flags, F_JOB, jobid, NA, NA, NULL);
|
addflag(lf->flags, F_JOB, jobid, NA, NA, NULL);
|
||||||
j = findjob(jobid);
|
j = findjob(jobid);
|
||||||
|
|
||||||
// override hitdice from race
|
// apply job's maxhp mod
|
||||||
if (hasflag(j->flags, F_HITDICE)) {
|
f = hasflag(j->flags, F_MAXHPMOD);
|
||||||
rollhp = B_TRUE;
|
if (f) {
|
||||||
f = lfhasflag(lf, F_HITDICE);
|
lf->maxhp = pctof(f->val[0], lf->maxhp);
|
||||||
if (f) {
|
lf->hp = lf->maxhp;
|
||||||
killflag(f);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
// override mpdice from race
|
// override mpdice from race
|
||||||
if (hasflag(j->flags, F_MPDICE)) {
|
if (hasflag(j->flags, F_MPDICE)) {
|
||||||
|
@ -6982,7 +6907,15 @@ void givejob(lifeform_t *lf, enum JOB jobid) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// inherit all flags except startob ones
|
// apply attrib mods from this job
|
||||||
|
getflags(j->flags, retflag, &nretflags, F_JOBATTRMOD, F_NONE);
|
||||||
|
for (i = 0; i < nretflags; i++) {
|
||||||
|
f = retflag[i];
|
||||||
|
modattr(lf, f->val[0], f->val[1]);
|
||||||
|
}
|
||||||
|
|
||||||
|
// inherit all flags except:
|
||||||
|
// - hpmod ones
|
||||||
for (f = j->flags->first ; f ; f = f->next) {
|
for (f = j->flags->first ; f ; f = f->next) {
|
||||||
int ignorethis = B_FALSE;
|
int ignorethis = B_FALSE;
|
||||||
int val[3];
|
int val[3];
|
||||||
|
@ -7018,12 +6951,21 @@ void givejob(lifeform_t *lf, enum JOB jobid) {
|
||||||
ignorethis = B_TRUE;
|
ignorethis = B_TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
switch (f->id) {
|
||||||
|
case F_MAXHPMOD:
|
||||||
|
case F_JOBATTRMOD:
|
||||||
|
ignorethis = B_TRUE;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
if (!ignorethis) {
|
if (!ignorethis) {
|
||||||
if (db) dblog("inheriting flagid %d.", f->id);
|
if (db) dblog("inheriting flagid %d.", f->id);
|
||||||
addflag_real(lf->flags, id, val[0], val[1], val[2], text, FROMJOB,B_TRUE, -1);
|
addflag_real(lf->flags, id, val[0], val[1], val[2], text, FROMJOB,B_TRUE, -1);
|
||||||
if (id == F_STARTATT) {
|
if (id == F_STARTATT) { // need to reroll attribs if we override them.
|
||||||
rollatt[val[0]] = B_TRUE;
|
rollatt[val[0]] = B_TRUE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -7035,6 +6977,7 @@ void givejob(lifeform_t *lf, enum JOB jobid) {
|
||||||
|
|
||||||
|
|
||||||
// override hp/mp from race
|
// override hp/mp from race
|
||||||
|
/*
|
||||||
if (rollhp) {
|
if (rollhp) {
|
||||||
lf->maxhp = 0;
|
lf->maxhp = 0;
|
||||||
for (i = 0; i < lf->level; i++) {
|
for (i = 0; i < lf->level; i++) {
|
||||||
|
@ -7043,6 +6986,7 @@ void givejob(lifeform_t *lf, enum JOB jobid) {
|
||||||
}
|
}
|
||||||
lf->hp = lf->maxhp;
|
lf->hp = lf->maxhp;
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
if (rollmp) {
|
if (rollmp) {
|
||||||
f = hasflag(lf->flags, F_MPDICE);
|
f = hasflag(lf->flags, F_MPDICE);
|
||||||
|
@ -7461,7 +7405,7 @@ void givestartobs(lifeform_t *lf, object_t *targob, flagpile_t *fp) {
|
||||||
initprompt(&prompt, buf);
|
initprompt(&prompt, buf);
|
||||||
|
|
||||||
for (i = 0; i < nposs; i++) {
|
for (i = 0; i < nposs; i++) {
|
||||||
addchoice(&prompt, ch++, poss[i]->name, NULL, poss[i]);
|
addchoice(&prompt, ch++, poss[i]->name, NULL, poss[i], NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (prompt.nchoices == 1) {
|
if (prompt.nchoices == 1) {
|
||||||
|
@ -7684,7 +7628,7 @@ int gotosleep(lifeform_t *lf, int onpurpose) {
|
||||||
return B_TRUE;
|
return B_TRUE;
|
||||||
}
|
}
|
||||||
if (onpurpose) taketime(lf, getactspeed(lf));
|
if (onpurpose) taketime(lf, getactspeed(lf));
|
||||||
addflag(lf->flags, F_ASLEEP, B_TRUE, NA, onpurpose ? B_TRUE : NA, NULL);
|
addflag(lf->flags, F_ASLEEP, B_TRUE, lfhasflag(lf, F_MEDITATES) ? B_TRUE : NA, onpurpose ? B_TRUE : NA, NULL);
|
||||||
return B_FALSE;
|
return B_FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -7923,48 +7867,6 @@ int lfcanbestoned(lifeform_t *lf) {
|
||||||
// conferred by a held/equipped object?
|
// conferred by a held/equipped object?
|
||||||
flag_t *lfhasflag(lifeform_t *lf, enum FLAG fid) {
|
flag_t *lfhasflag(lifeform_t *lf, enum FLAG fid) {
|
||||||
flag_t *f;
|
flag_t *f;
|
||||||
|
|
||||||
// note: we check conferred flags first because we want
|
|
||||||
// these to override ones direclty on the player.
|
|
||||||
|
|
||||||
// does a held object give us this flag?
|
|
||||||
/*
|
|
||||||
o = hasobwithflagval(lf->pack, F_HOLDCONFER, fid, NA, NA, NULL);
|
|
||||||
if (o) {
|
|
||||||
// return the flag, not the objcet
|
|
||||||
f = hasflagval(o->flags, F_HOLDCONFER, fid, NA, NA, NULL);
|
|
||||||
if (f) return f;
|
|
||||||
}
|
|
||||||
|
|
||||||
for (o = lf->pack->first ; o ; o = o->next) {
|
|
||||||
f = hasflagval(o->flags, F_HOLDCONFER, fid, NA, NA, NULL);
|
|
||||||
if (f) {
|
|
||||||
if (f->val[2] == B_IFIDENT) {
|
|
||||||
if (isknown(o)) return f;
|
|
||||||
} else {
|
|
||||||
return f;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
// does an equipped object give us this flag?
|
|
||||||
for (o = lf->pack->first ; o ; o = o->next) {
|
|
||||||
if (hasflag(o->flags, F_EQUIPPED)) {
|
|
||||||
f = hasflagval(o->flags, F_EQUIPCONFER, fid, NA, NA, NULL);
|
|
||||||
if (f) {
|
|
||||||
if (f->val[2] == B_IFIDENT) {
|
|
||||||
if (isknown(o)) return f;
|
|
||||||
} else {
|
|
||||||
return f;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
// do we have this flag directly?
|
|
||||||
f = hasflag(lf->flags, fid);
|
f = hasflag(lf->flags, fid);
|
||||||
if (f) return f;
|
if (f) return f;
|
||||||
return NULL;
|
return NULL;
|
||||||
|
@ -7974,86 +7876,12 @@ flag_t *lfhasflagval(lifeform_t *lf, enum FLAG fid, int val0, int val1, int val2
|
||||||
flag_t *f;
|
flag_t *f;
|
||||||
f = hasflagval(lf->flags, fid, val0, val1, val2, text);
|
f = hasflagval(lf->flags, fid, val0, val1, val2, text);
|
||||||
if (f) return f;
|
if (f) return f;
|
||||||
|
|
||||||
// does a held object give us this flag?
|
|
||||||
/*
|
|
||||||
o = hasobwithflagval(lf->pack, F_HOLDCONFER, fid, val0, val1, text);
|
|
||||||
if (o) {
|
|
||||||
// return the flag, not the objcet
|
|
||||||
f = hasflagval(o->flags, F_HOLDCONFER, fid, val0, val1, text);
|
|
||||||
if (f) return f;
|
|
||||||
}
|
|
||||||
|
|
||||||
for (o = lf->pack->first ; o ; o = o->next) {
|
|
||||||
f = hasflagval(o->flags, F_HOLDCONFER, fid, val0, val1, text);
|
|
||||||
if (f) {
|
|
||||||
if (f->val[2] == B_IFIDENT) {
|
|
||||||
if (isknown(o)) return f;
|
|
||||||
} else {
|
|
||||||
return f;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
// does an equipped object give us this flag?
|
|
||||||
/*
|
|
||||||
for (o = lf->pack->first ; o ; o = o->next) {
|
|
||||||
if (hasflag(o->flags, F_EQUIPPED)) {
|
|
||||||
f = hasflagval(o->flags, F_EQUIPCONFER, fid, val0, val1, NULL);
|
|
||||||
if (f) {
|
|
||||||
if (f->val[2] == B_IFIDENT) {
|
|
||||||
if (isknown(o)) return f;
|
|
||||||
} else {
|
|
||||||
return f;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
flag_t *lfhasknownflag(lifeform_t *lf, enum FLAG fid) {
|
flag_t *lfhasknownflag(lifeform_t *lf, enum FLAG fid) {
|
||||||
flag_t *f;
|
flag_t *f;
|
||||||
|
|
||||||
// note: we check conferred flags first because we want
|
|
||||||
// these to override ones direclty on the player.
|
|
||||||
|
|
||||||
/*
|
|
||||||
|
|
||||||
for (o = lf->pack->first ; o ; o = o->next) {
|
|
||||||
if (isknown(o)) {
|
|
||||||
f = hasflagval(o->flags, F_HOLDCONFER, fid, NA, NA, NULL);
|
|
||||||
if (f && f->known) {
|
|
||||||
if (f->val[2] == B_IFIDENT) {
|
|
||||||
if (isknown(o)) return f;
|
|
||||||
} else {
|
|
||||||
return f;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
*/
|
|
||||||
// does an equipped object give us this flag?
|
|
||||||
/*
|
|
||||||
for (o = lf->pack->first ; o ; o = o->next) {
|
|
||||||
if (isknown(o)) {
|
|
||||||
if (hasflag(o->flags, F_EQUIPPED)) {
|
|
||||||
f = hasflagval(o->flags, F_EQUIPCONFER, fid, NA, NA, NULL);
|
|
||||||
if (f && f->known) {
|
|
||||||
if (f->val[2] == B_IFIDENT) {
|
|
||||||
if (isknown(o)) return f;
|
|
||||||
} else {
|
|
||||||
return f;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
// do we have this flag directly?
|
// do we have this flag directly?
|
||||||
f = hasflagknown(lf->flags, fid);
|
f = hasflagknown(lf->flags, fid);
|
||||||
if (f && f->known) return f;
|
if (f && f->known) return f;
|
||||||
|
@ -8062,38 +7890,6 @@ flag_t *lfhasknownflag(lifeform_t *lf, enum FLAG fid) {
|
||||||
|
|
||||||
flag_t *lfhasknownflagval(lifeform_t *lf, enum FLAG fid, int val0, int val1, int val2, char *text) {
|
flag_t *lfhasknownflagval(lifeform_t *lf, enum FLAG fid, int val0, int val1, int val2, char *text) {
|
||||||
flag_t *f;
|
flag_t *f;
|
||||||
|
|
||||||
/*
|
|
||||||
for (o = lf->pack->first ; o ; o = o->next) {
|
|
||||||
if (isknown(o)) {
|
|
||||||
f = hasflagval(o->flags, F_HOLDCONFER, fid, val0, val1, text);
|
|
||||||
if (f && f->known) {
|
|
||||||
if (f->val[2] == B_IFIDENT) {
|
|
||||||
if (isknown(o)) return f;
|
|
||||||
} else {
|
|
||||||
return f;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// does an equipped object give us this flag?
|
|
||||||
for (o = lf->pack->first ; o ; o = o->next) {
|
|
||||||
if (isknown(o)) {
|
|
||||||
if (hasflag(o->flags, F_EQUIPPED)) {
|
|
||||||
f = hasflagval(o->flags, F_EQUIPCONFER, fid, val0, val1, NULL);
|
|
||||||
if (f && f->known) {
|
|
||||||
if (f->val[2] == B_IFIDENT) {
|
|
||||||
if (isknown(o)) return f;
|
|
||||||
} else {
|
|
||||||
return f;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
// got the flag directly?
|
// got the flag directly?
|
||||||
f = hasflagvalknown(lf->flags, fid, val0, val1, val2, text);
|
f = hasflagvalknown(lf->flags, fid, val0, val1, val2, text);
|
||||||
if (f && f->known) return f;
|
if (f && f->known) return f;
|
||||||
|
@ -8583,9 +8379,11 @@ int isbleeding(lifeform_t *lf) {
|
||||||
}
|
}
|
||||||
|
|
||||||
int isblind(lifeform_t *lf) {
|
int isblind(lifeform_t *lf) {
|
||||||
|
flag_t *f;
|
||||||
if (!lf) return B_FALSE;
|
if (!lf) return B_FALSE;
|
||||||
|
|
||||||
if (lfhasflag(lf, F_ASLEEP)) {
|
f = lfhasflag(lf, F_ASLEEP);
|
||||||
|
if (f && (f->val[1] == NA)) {
|
||||||
return B_TRUE;
|
return B_TRUE;
|
||||||
}
|
}
|
||||||
if (lfhasflag(lf, F_BLIND)) {
|
if (lfhasflag(lf, F_BLIND)) {
|
||||||
|
@ -9267,7 +9065,6 @@ void addtrail(lifeform_t *lf, int dir) {
|
||||||
// footprints first
|
// footprints first
|
||||||
if (!isairborne(lf) && !lfhasflag(lf, F_NONCORPOREAL)) {
|
if (!isairborne(lf) && !lfhasflag(lf, F_NONCORPOREAL)) {
|
||||||
int fpdir;
|
int fpdir;
|
||||||
|
|
||||||
if (getskill(lf, SK_PERCEPTION) >= PR_EXPERT) {
|
if (getskill(lf, SK_PERCEPTION) >= PR_EXPERT) {
|
||||||
// no footprints!
|
// no footprints!
|
||||||
return;
|
return;
|
||||||
|
@ -9613,11 +9410,6 @@ int areallies(lifeform_t *lf1, lifeform_t *lf2) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
/*
|
|
||||||
if (getallegiance(lf1) == getallegiance(lf2)) {
|
|
||||||
return B_TRUE;
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
return B_FALSE;
|
return B_FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -10419,7 +10211,7 @@ void makenoise(lifeform_t *lf, enum NOISETYPE nid) {
|
||||||
if (nid == N_WALK) {
|
if (nid == N_WALK) {
|
||||||
volume += getarmournoise(lf);
|
volume += getarmournoise(lf);
|
||||||
}
|
}
|
||||||
noise(lf->cell, lf, NC_OTHER, volume, noisetext, verb);
|
noise(lf->cell, lf, (nid == N_WALK) ? NC_WALK : NC_OTHER, volume, noisetext, verb);
|
||||||
} else {
|
} else {
|
||||||
// some defaults
|
// some defaults
|
||||||
if (nid == N_WALK) {
|
if (nid == N_WALK) {
|
||||||
|
@ -10462,7 +10254,7 @@ void makenoise(lifeform_t *lf, enum NOISETYPE nid) {
|
||||||
}
|
}
|
||||||
volume += getarmournoise(lf);
|
volume += getarmournoise(lf);
|
||||||
if (strlen(movetext)) {
|
if (strlen(movetext)) {
|
||||||
noise(lf->cell, lf, NC_OTHER, volume, movetext, NULL);
|
noise(lf->cell, lf, (nid == N_WALK) ? NC_WALK : NC_OTHER, volume, movetext, NULL);
|
||||||
}
|
}
|
||||||
} else if (nid == N_WARCRY) {
|
} else if (nid == N_WARCRY) {
|
||||||
noise(lf->cell, lf, NC_OTHER, 4, "a blood-curdling war cry!", "shouts a blood-curdling war-cry!");
|
noise(lf->cell, lf, NC_OTHER, 4, "a blood-curdling war cry!", "shouts a blood-curdling war-cry!");
|
||||||
|
@ -10837,7 +10629,8 @@ int noise(cell_t *c, lifeform_t *noisemaker, enum NOISECLASS nt, int volume, cha
|
||||||
msg("%s %s.", lfname, realseetext);
|
msg("%s %s.", lfname, realseetext);
|
||||||
rv = B_TRUE;
|
rv = B_TRUE;
|
||||||
}
|
}
|
||||||
} else if (text && !lfhasflag(l, F_DEAF) && ((nt == NC_SPEECH) || !lfhasflag(l, F_DONELISTEN))) {
|
} else if (text && !lfhasflag(l, F_DEAF) && ((nt != NC_WALK) || !lfhasflag(l, F_DONELISTEN))) {
|
||||||
|
// this means you can only hear one 'walk' sound per turn
|
||||||
char textnopunc[BUFLEN];
|
char textnopunc[BUFLEN];
|
||||||
char punc;
|
char punc;
|
||||||
int dist;
|
int dist;
|
||||||
|
@ -10922,8 +10715,8 @@ int noise(cell_t *c, lifeform_t *noisemaker, enum NOISECLASS nt, int volume, cha
|
||||||
msg("You hear %s", text);
|
msg("You hear %s", text);
|
||||||
rv = B_TRUE;
|
rv = B_TRUE;
|
||||||
}
|
}
|
||||||
// only hear one thing per turn.
|
// can only hear one 'walk' sound per turn.
|
||||||
if (isplayer(l)) {
|
if (isplayer(l) && (nt == NC_WALK)) {
|
||||||
addflag(l->flags, F_DONELISTEN, B_TRUE, NA, NA, NULL);
|
addflag(l->flags, F_DONELISTEN, B_TRUE, NA, NA, NULL);
|
||||||
practice(l, SK_LISTEN, 1);
|
practice(l, SK_LISTEN, 1);
|
||||||
}
|
}
|
||||||
|
@ -11127,9 +10920,6 @@ int pickup(lifeform_t *lf, object_t *what, int howmany, int fromground, int want
|
||||||
msg("%s picks up %s.",buf, obname);
|
msg("%s picks up %s.",buf, obname);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
/*
|
|
||||||
taketime(lf, (SPEED_PICKUP * howmany));
|
|
||||||
*/
|
|
||||||
taketime(lf, SPEED_PICKUP);
|
taketime(lf, SPEED_PICKUP);
|
||||||
|
|
||||||
// TODO: update burdened status
|
// TODO: update burdened status
|
||||||
|
@ -11367,16 +11157,6 @@ void precalclos_new(lifeform_t *lf) {
|
||||||
calcbresnham(lf->cell->map, lf->cell->x, lf->cell->y, endx[nn], endy[nn], retcell, &numpixels );
|
calcbresnham(lf->cell->map, lf->cell->x, lf->cell->y, endx[nn], endy[nn], retcell, &numpixels );
|
||||||
// keep going until we lose los
|
// keep going until we lose los
|
||||||
for (n = 0; keepgoing && (n < numpixels); n++) {
|
for (n = 0; keepgoing && (n < numpixels); n++) {
|
||||||
/*
|
|
||||||
// calc x/y change
|
|
||||||
xd = precos[ang];
|
|
||||||
yd = presin[ang];
|
|
||||||
//limitd(&xd, -1, 1);
|
|
||||||
//limitd(&yd, -1, 1);
|
|
||||||
// get new cell
|
|
||||||
x += xd;
|
|
||||||
y += yd;
|
|
||||||
*/
|
|
||||||
c = retcell[n];
|
c = retcell[n];
|
||||||
if (n != 0) currange++;
|
if (n != 0) currange++;
|
||||||
if (currange > maxvisrange) c = NULL;
|
if (currange > maxvisrange) c = NULL;
|
||||||
|
@ -11419,33 +11199,6 @@ void precalclos_new(lifeform_t *lf) {
|
||||||
}
|
}
|
||||||
assert(nlos < (MAX_MAPW * MAX_MAPH));
|
assert(nlos < (MAX_MAPW * MAX_MAPH));
|
||||||
|
|
||||||
// deal with enhanced smell - do a second sweep in all directions.
|
|
||||||
/*
|
|
||||||
if (enhancesmell) {
|
|
||||||
int n;
|
|
||||||
get_circular_fov_endpoints(lf, enhancesmell->val[0], endx, endy, &nendcells);
|
|
||||||
|
|
||||||
for (i = 0;i < nendcells; i++) {
|
|
||||||
calcbresnham(lf->cell->map, lf->cell->x, lf->cell->y, endx[i], endy[i], retcell, &numpixels );
|
|
||||||
// keep going until we lose los
|
|
||||||
for (n = 0; n < numpixels; n++) {
|
|
||||||
if ((retcell[n]->lf && (retcell[n]->lf->race->raceclass->id != RC_UNDEAD)) ||
|
|
||||||
hasobwithflag(retcell[n]->obpile, F_SMELLY) ) { // && (endcell[i]->lf != lf)) {
|
|
||||||
int nn,found = B_FALSE;
|
|
||||||
for (nn = 0; nn < nlos; nn++) { // can we already see this cell?
|
|
||||||
if (los[nn] == retcell[n]) {
|
|
||||||
found = B_TRUE; break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (!found) {
|
|
||||||
los[nlos++] = retcell[n];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
// now fill in lifeform structure
|
// now fill in lifeform structure
|
||||||
lf->los = malloc(sizeof(cell_t *) * nlos);
|
lf->los = malloc(sizeof(cell_t *) * nlos);
|
||||||
for (i = 0; i < nlos; i++) {
|
for (i = 0; i < nlos; i++) {
|
||||||
|
@ -12333,25 +12086,6 @@ void interrupt(lifeform_t *lf) {
|
||||||
killflagsofid(lf->flags, F_AUTOCMD);
|
killflagsofid(lf->flags, F_AUTOCMD);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*j
|
|
||||||
void setlftarget(lifeform_t *lf, lifeform_t *victim) {
|
|
||||||
// first remove existing targets
|
|
||||||
killflagsofid(lf->flags, F_TARGET);
|
|
||||||
killflagsofid(lf->flags, F_TARGETCELL);
|
|
||||||
|
|
||||||
// set new target
|
|
||||||
addflag(lf->flags, F_TARGET, victim->id, victim->cell->x, victim->cell->x, NULL);
|
|
||||||
|
|
||||||
if (!areenemies(lf, victim)) {
|
|
||||||
if (getallegiance(victim) == AL_FRIENDLY) {
|
|
||||||
if (!hasflag(lf->flags, F_HOSTILE)) {
|
|
||||||
addflag(lf->flags, F_HOSTILE, B_TRUE, NA, NA, NULL);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
int setlfmaterial(lifeform_t *lf, enum MATERIAL id) {
|
int setlfmaterial(lifeform_t *lf, enum MATERIAL id) {
|
||||||
if (getlfmaterial(lf) == id) {
|
if (getlfmaterial(lf) == id) {
|
||||||
return B_TRUE;
|
return B_TRUE;
|
||||||
|
@ -13689,12 +13423,12 @@ int steal(lifeform_t *lf, obpile_t *op, enum FLAG wantflag) {
|
||||||
}
|
}
|
||||||
if (ok) {
|
if (ok) {
|
||||||
getobname(o, buf, 1);
|
getobname(o, buf, 1);
|
||||||
addchoice(&prompt, fromground ? letter++ : o->letter, buf, NULL, o);
|
addchoice(&prompt, fromground ? letter++ : o->letter, buf, NULL, o, NULL);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (prompt.nchoices > 1) {
|
if (prompt.nchoices > 1) {
|
||||||
if (isplayer(lf) && (slev >= PR_ADEPT)) {
|
if (isplayer(lf) && (slev >= PR_ADEPT)) {
|
||||||
addchoice(&prompt, '-', "Nothing", NULL, NULL);
|
addchoice(&prompt, '-', "Nothing", NULL, NULL, NULL);
|
||||||
// pick what you want
|
// pick what you want
|
||||||
getchoice(&prompt);
|
getchoice(&prompt);
|
||||||
o = (object_t *)prompt.result;
|
o = (object_t *)prompt.result;
|
||||||
|
@ -13808,11 +13542,11 @@ void stopresting(lifeform_t *lf) {
|
||||||
if (f) {
|
if (f) {
|
||||||
killflag(f);
|
killflag(f);
|
||||||
if (isplayer(lf)) {
|
if (isplayer(lf)) {
|
||||||
msg("Your rest is interrupted!");
|
msg("Your %s is interrupted!", (f->val[1] == NA) ? "rest" : "meditation");
|
||||||
} else if (cansee(player, lf)) {
|
} else if (cansee(player, lf)) {
|
||||||
char buf[BUFLEN];
|
char buf[BUFLEN];
|
||||||
getlfname(lf, buf);
|
getlfname(lf, buf);
|
||||||
msg("%s stops resting.",buf);
|
msg("%s stops %s.",buf, (f->val[1] == NA) ? "resting" : "meditating");
|
||||||
}
|
}
|
||||||
statdirty = B_TRUE;
|
statdirty = B_TRUE;
|
||||||
}
|
}
|
||||||
|
@ -13960,12 +13694,6 @@ void taketime(lifeform_t *lf, long howlong) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
if (isplayer(lf)) {
|
|
||||||
statdirty = B_TRUE;
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
map = lf->cell->map;
|
map = lf->cell->map;
|
||||||
|
|
||||||
assert(howlong > 0);
|
assert(howlong > 0);
|
||||||
|
@ -14845,6 +14573,15 @@ int validateraces(void) {
|
||||||
printf("ERROR in race '%s' - F_HITCONFER, but no HITCONFERVALS defined.\n", r->name);
|
printf("ERROR in race '%s' - F_HITCONFER, but no HITCONFERVALS defined.\n", r->name);
|
||||||
goterror = B_TRUE;
|
goterror = B_TRUE;
|
||||||
}
|
}
|
||||||
|
} else if (f->id == F_PLAYABLE) {
|
||||||
|
// playable races must have fully defined stats
|
||||||
|
enum ATTRIB a;
|
||||||
|
for (a = 0 ; a < MAXATTS; a++) {
|
||||||
|
if (!hasflagval(r->flags, F_STARTATT, a, NA, NA, NULL)) {
|
||||||
|
printf("ERROR in race '%s' - race is f_playable but has no f_startatt %s\n", r->name, getattrname(a));
|
||||||
|
goterror = B_TRUE;
|
||||||
|
}
|
||||||
|
}
|
||||||
} else if (f->id == F_STARTATT) {
|
} else if (f->id == F_STARTATT) {
|
||||||
if (strlen(f->text) && (f->val[1] != NA)) {
|
if (strlen(f->text) && (f->val[1] != NA)) {
|
||||||
printf("ERROR in race '%s' - F_STARTATT has both text range and val1.", r->name);
|
printf("ERROR in race '%s' - F_STARTATT has both text range and val1.", r->name);
|
||||||
|
@ -15212,9 +14949,9 @@ int wear(lifeform_t *lf, object_t *o) {
|
||||||
} else {
|
} else {
|
||||||
snprintf(buf, BUFLEN, "%s", getbodypartname(possbp[i]));
|
snprintf(buf, BUFLEN, "%s", getbodypartname(possbp[i]));
|
||||||
}
|
}
|
||||||
addchoice(&prompt, ch++, buf, NULL, &possbp[i]);
|
addchoice(&prompt, ch++, buf, NULL, &possbp[i], NULL);
|
||||||
}
|
}
|
||||||
addchoice(&prompt, '-', "(cancel)", NULL, NULL);
|
addchoice(&prompt, '-', "(cancel)", NULL, NULL, NULL);
|
||||||
ch = getchoice(&prompt);
|
ch = getchoice(&prompt);
|
||||||
|
|
||||||
if (ch == '-') {
|
if (ch == '-') {
|
||||||
|
@ -15336,20 +15073,6 @@ int wear(lifeform_t *lf, object_t *o) {
|
||||||
|
|
||||||
maketried(o->type->id);
|
maketried(o->type->id);
|
||||||
|
|
||||||
/*
|
|
||||||
if (isplayer(lf)) {
|
|
||||||
// equipping unknown objects makes them known
|
|
||||||
if (!isknown(o)) {
|
|
||||||
// announce
|
|
||||||
announceob(o->type->id);
|
|
||||||
|
|
||||||
// make the obejct type known
|
|
||||||
makeknown(o->type->id);
|
|
||||||
getobname(o, obname, 1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
// when you wear armour, you find out
|
// when you wear armour, you find out
|
||||||
// its bonuses.
|
// its bonuses.
|
||||||
if (isplayer(lf) && (o->type->obclass->id == OC_ARMOUR)) {
|
if (isplayer(lf) && (o->type->obclass->id == OC_ARMOUR)) {
|
||||||
|
@ -15562,20 +15285,6 @@ int weild(lifeform_t *lf, object_t *o) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
/*
|
|
||||||
// this weapon is two handed and uses the other hand
|
|
||||||
if (hasflag(oo->flags, F_TWOHANDED)) {
|
|
||||||
f = hasflagval(oo->flags, F_EQUIPPED, otherloc, -1, -1, NULL);
|
|
||||||
if (f) {
|
|
||||||
// unweild it
|
|
||||||
if (unweild(lf, oo)) {
|
|
||||||
// if we can't unweild old weapon, stop
|
|
||||||
return B_TRUE;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
// new weapon is two handed? check other hand too.
|
// new weapon is two handed? check other hand too.
|
||||||
if (twohanded) {
|
if (twohanded) {
|
||||||
f = hasflagval(oo->flags, F_EQUIPPED, otherloc, -1, -1, NULL);
|
f = hasflagval(oo->flags, F_EQUIPPED, otherloc, -1, -1, NULL);
|
||||||
|
|
19
map.c
19
map.c
|
@ -1519,6 +1519,19 @@ int calcroompos(map_t *map, int w, int h, int xmargin, int ymargin, int *bx, int
|
||||||
for (rx = x; (rx < x+w) && valid; rx++) {
|
for (rx = x; (rx < x+w) && valid; rx++) {
|
||||||
int includethiscell = B_FALSE;
|
int includethiscell = B_FALSE;
|
||||||
cell = getcellat(map, rx,ry);
|
cell = getcellat(map, rx,ry);
|
||||||
|
|
||||||
|
|
||||||
|
// NEVER create a vault whcih will:
|
||||||
|
// - be on top of the player (normally this can't happen,
|
||||||
|
// but debugging via 'create vault' could do it)
|
||||||
|
if (cell->lf && isplayer(cell->lf)) {
|
||||||
|
valid = B_FALSE;
|
||||||
|
}
|
||||||
|
// - be on top of an existing staircase
|
||||||
|
if (hasobwithflag(cell->obpile, F_CLIMBABLE)) {
|
||||||
|
valid = B_FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
// is this cell adjacent to an empty cell and not a
|
// is this cell adjacent to an empty cell and not a
|
||||||
// corner (ie. a valid door location)
|
// corner (ie. a valid door location)
|
||||||
if (countcellexits(cell)) {
|
if (countcellexits(cell)) {
|
||||||
|
@ -1548,12 +1561,6 @@ int calcroompos(map_t *map, int w, int h, int xmargin, int ymargin, int *bx, int
|
||||||
valid = B_FALSE;
|
valid = B_FALSE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// NEVER create it on top of the player!
|
|
||||||
// (normally this can't happen, but debugging via 'create
|
|
||||||
// vault' could do it)
|
|
||||||
if (cell->lf && isplayer(cell->lf)) {
|
|
||||||
valid = B_FALSE;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
52
nexus.c
52
nexus.c
|
@ -108,7 +108,7 @@ int main(int argc, char **argv) {
|
||||||
char welcomemsg[BUFLEN];
|
char welcomemsg[BUFLEN];
|
||||||
int ch;
|
int ch;
|
||||||
FILE *playerfile = NULL;
|
FILE *playerfile = NULL;
|
||||||
int x,y;
|
int x,y,i;
|
||||||
cell_t *c;
|
cell_t *c;
|
||||||
vault_t *v;
|
vault_t *v;
|
||||||
enum SKILLLEVEL slev;
|
enum SKILLLEVEL slev;
|
||||||
|
@ -150,11 +150,21 @@ int main(int argc, char **argv) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// init prompt
|
||||||
|
for (i = 0; i < MAXCHOICES; i++) {
|
||||||
|
choice_t *c;
|
||||||
|
c = &prompt.choice[i];
|
||||||
|
c->text = NULL;
|
||||||
|
c->desc = NULL;
|
||||||
|
c->longdesc = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// if no player (ie. didn't load a game), add them
|
// if no player (ie. didn't load a game), add them
|
||||||
if (!player) {
|
if (!player) {
|
||||||
char *user,pname[BUFLEN],buf[BUFLEN];
|
char *user,pname[BUFLEN],buf[BUFLEN];
|
||||||
job_t *j = NULL;
|
job_t *j = NULL;
|
||||||
|
race_t *startrace = NULL;
|
||||||
char ch;
|
char ch;
|
||||||
object_t *o;
|
object_t *o;
|
||||||
cell_t *where;
|
cell_t *where;
|
||||||
|
@ -166,7 +176,7 @@ int main(int argc, char **argv) {
|
||||||
// populate scroll, potion, etc names
|
// populate scroll, potion, etc names
|
||||||
genhiddennames();
|
genhiddennames();
|
||||||
|
|
||||||
// read from input file if required
|
// read from rc file if required
|
||||||
if (playerfile) {
|
if (playerfile) {
|
||||||
char *p;
|
char *p;
|
||||||
while (!feof(playerfile)) {
|
while (!feof(playerfile)) {
|
||||||
|
@ -181,13 +191,31 @@ int main(int argc, char **argv) {
|
||||||
fseek(playerfile, 0, SEEK_SET);
|
fseek(playerfile, 0, SEEK_SET);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!j) {
|
|
||||||
|
if (!startrace) {
|
||||||
|
race_t *r;
|
||||||
// ask for race
|
// ask for race
|
||||||
|
initprompt(&prompt, "Select your race:");
|
||||||
|
ch = 'a';
|
||||||
|
for (r = firstrace ; r ; r = r->next) {
|
||||||
|
if (hasflag(r->flags, F_PLAYABLE)) {
|
||||||
|
addchoice(&prompt, ch++, r->name, NULL, r, NULL);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
startrace = NULL;
|
||||||
|
while (!startrace) {
|
||||||
|
getchoicestr(&prompt, B_FALSE, B_TRUE);
|
||||||
|
startrace = prompt.result;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!j) {
|
||||||
|
// ask for job
|
||||||
initprompt(&prompt, "Select your job:");
|
initprompt(&prompt, "Select your job:");
|
||||||
ch = 'a';
|
ch = 'a';
|
||||||
for (j = firstjob ; j ; j = j->next) {
|
for (j = firstjob ; j ; j = j->next) {
|
||||||
if (!hasflag(j->flags, F_NOPLAYER)) {
|
if (!hasflag(j->flags, F_NOPLAYER)) {
|
||||||
addchoice(&prompt, ch++, j->name, NULL, j);
|
addchoice(&prompt, ch++, j->name, NULL, j, NULL);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
j = NULL;
|
j = NULL;
|
||||||
|
@ -232,7 +260,7 @@ int main(int argc, char **argv) {
|
||||||
more();
|
more();
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
real_addlf(where, R_HUMAN, 1, C_PLAYER); // this will assign 'player'
|
real_addlf(where, startrace->id, 1, C_PLAYER); // this will assign 'player'
|
||||||
addflag(player->flags, F_CANWILL, OT_A_PRAY, NA, NA, NULL);
|
addflag(player->flags, F_CANWILL, OT_A_PRAY, NA, NA, NULL);
|
||||||
addflag(player->flags, F_CANWILL, OT_A_TRAIN, NA, NA, NULL);
|
addflag(player->flags, F_CANWILL, OT_A_TRAIN, NA, NA, NULL);
|
||||||
addflag(player->flags, F_CANWILL, OT_A_DEBUG, NA, NA, NULL); /////////
|
addflag(player->flags, F_CANWILL, OT_A_DEBUG, NA, NA, NULL); /////////
|
||||||
|
@ -252,9 +280,9 @@ int main(int argc, char **argv) {
|
||||||
if (j->id == J_WIZARD) {
|
if (j->id == J_WIZARD) {
|
||||||
skill_t *sk;
|
skill_t *sk;
|
||||||
initprompt(&prompt, "Select your primary spell specialty:");
|
initprompt(&prompt, "Select your primary spell specialty:");
|
||||||
addchoice(&prompt, 'a', getskillname(SK_SS_AIR), NULL, findskill(SK_SS_AIR));
|
addchoice(&prompt, 'a', getskillname(SK_SS_AIR), NULL, findskill(SK_SS_AIR), NULL);
|
||||||
addchoice(&prompt, 'c', getskillname(SK_SS_COLD), NULL, findskill(SK_SS_COLD));
|
addchoice(&prompt, 'c', getskillname(SK_SS_COLD), NULL, findskill(SK_SS_COLD), NULL);
|
||||||
addchoice(&prompt, 'f', getskillname(SK_SS_FIRE), NULL, findskill(SK_SS_FIRE));
|
addchoice(&prompt, 'f', getskillname(SK_SS_FIRE), NULL, findskill(SK_SS_FIRE), NULL);
|
||||||
getchoice(&prompt);
|
getchoice(&prompt);
|
||||||
sk = (skill_t *) prompt.result;
|
sk = (skill_t *) prompt.result;
|
||||||
giveskilllev(player, sk->id, PR_BEGINNER);
|
giveskilllev(player, sk->id, PR_BEGINNER);
|
||||||
|
@ -272,10 +300,10 @@ int main(int argc, char **argv) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
initprompt(&prompt, "Select your secondary spell school:");
|
initprompt(&prompt, "Select your secondary spell school:");
|
||||||
addchoice(&prompt, 'd', getskillname(SK_SS_DIVINATION), NULL, findskill(SK_SS_DIVINATION));
|
addchoice(&prompt, 'd', getskillname(SK_SS_DIVINATION), NULL, findskill(SK_SS_DIVINATION), NULL);
|
||||||
addchoice(&prompt, 'm', getskillname(SK_SS_MODIFICATION), NULL, findskill(SK_SS_MODIFICATION));
|
addchoice(&prompt, 'm', getskillname(SK_SS_MODIFICATION), NULL, findskill(SK_SS_MODIFICATION), NULL);
|
||||||
addchoice(&prompt, 's', getskillname(SK_SS_SUMMONING), NULL, findskill(SK_SS_SUMMONING));
|
addchoice(&prompt, 's', getskillname(SK_SS_SUMMONING), NULL, findskill(SK_SS_SUMMONING), NULL);
|
||||||
addchoice(&prompt, 't', getskillname(SK_SS_TRANSLOCATION), NULL, findskill(SK_SS_TRANSLOCATION));
|
addchoice(&prompt, 't', getskillname(SK_SS_TRANSLOCATION), NULL, findskill(SK_SS_TRANSLOCATION), NULL);
|
||||||
getchoice(&prompt);
|
getchoice(&prompt);
|
||||||
sk = (skill_t *) prompt.result;
|
sk = (skill_t *) prompt.result;
|
||||||
giveskilllev(player, sk->id, PR_NOVICE);
|
giveskilllev(player, sk->id, PR_NOVICE);
|
||||||
|
|
188
objects.c
188
objects.c
|
@ -1739,19 +1739,9 @@ objecttype_t *addot(enum OBTYPE id, char *name, char *description, int material,
|
||||||
a->obclass = findoc(obclassid);
|
a->obclass = findoc(obclassid);
|
||||||
a->flags = addflagpile(NULL, NULL);
|
a->flags = addflagpile(NULL, NULL);
|
||||||
// inherit flags from object class
|
// inherit flags from object class
|
||||||
/*
|
|
||||||
for (f = a->obclass->flags->first ; f ; f = f->next) {
|
|
||||||
addflag(a->flags, f->id, f->val[0], f->val[1], f->val[2], f->text);
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
copyflags(a->flags, a->obclass->flags, NA);
|
copyflags(a->flags, a->obclass->flags, NA);
|
||||||
if (a->material) {
|
if (a->material) {
|
||||||
// inherit flags from material
|
// inherit flags from material
|
||||||
/*
|
|
||||||
for (f = a->material->flags->first ; f ; f = f->next) {
|
|
||||||
addflag(a->flags, f->id, f->val[0], f->val[1], f->val[2], f->text);
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
copyflags(a->flags, a->material->flags, FROMMAT);
|
copyflags(a->flags, a->material->flags, FROMMAT);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1959,17 +1949,6 @@ void adjustdamob(object_t *o, unsigned int *dam, enum DAMTYPE damtype) {
|
||||||
adjustdamhardness(dam, damtype, o->material->id);
|
adjustdamhardness(dam, damtype, o->material->id);
|
||||||
}
|
}
|
||||||
|
|
||||||
// adjust price for magical effects etc
|
|
||||||
/*
|
|
||||||
void adjustprice(objecttype_t *ot, float *price) {
|
|
||||||
int min,max;
|
|
||||||
flag_t *f;
|
|
||||||
|
|
||||||
// bonuses/penalties
|
|
||||||
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
// adjusts armour's ac//evasion penalty based on skill
|
// adjusts armour's ac//evasion penalty based on skill
|
||||||
int adjustarmourpenalty(lifeform_t *lf, float amt) {
|
int adjustarmourpenalty(lifeform_t *lf, float amt) {
|
||||||
enum SKILLLEVEL slev;
|
enum SKILLLEVEL slev;
|
||||||
|
@ -2113,15 +2092,6 @@ void brightflash(cell_t *centre, int range, lifeform_t *immunelf) {
|
||||||
msg("You see an intense flash of light!");
|
msg("You see an intense flash of light!");
|
||||||
more();
|
more();
|
||||||
}
|
}
|
||||||
/*
|
|
||||||
if (getcelldist(player->cell, centre) <= range) {
|
|
||||||
// player is in range but can't see - announce it beacuse it
|
|
||||||
// will make you deaf!
|
|
||||||
youhear(centre, "a deafening bang!");
|
|
||||||
} else { // not in range of the flash
|
|
||||||
youhear(centre, "a loud bang!");
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
// blind monsters
|
// blind monsters
|
||||||
for (y = centre->y - range; y <= centre->y + range; y++) {
|
for (y = centre->y - range; y <= centre->y + range; y++) {
|
||||||
for (x = centre->x - range; x <= centre->x + range; x++) {
|
for (x = centre->x - range; x <= centre->x + range; x++) {
|
||||||
|
@ -2616,19 +2586,6 @@ void explodeob(object_t *o, flag_t *f, int bigness) {
|
||||||
}
|
}
|
||||||
explodecells(c, dam * o->amt, bigness ? B_TRUE : B_FALSE, o, bigness ? 1 : 0, DT_COMPASS, B_FALSE);
|
explodecells(c, dam * o->amt, bigness ? B_TRUE : B_FALSE, o, bigness ? 1 : 0, DT_COMPASS, B_FALSE);
|
||||||
|
|
||||||
// hurt everything!
|
|
||||||
/*
|
|
||||||
if (bigness) {
|
|
||||||
int dir;
|
|
||||||
cell_t *cc;
|
|
||||||
explodecell(c, dam, (bigness) ? B_TRUE : B_FALSE, NULL);
|
|
||||||
for (dir = DC_N; dir <= DC_NW; dir++) {
|
|
||||||
cc = getcellindir(c, dir);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
explodecell(c, dam, (bigness) ? B_TRUE : B_FALSE, NULL);
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
// object dies.
|
// object dies.
|
||||||
removeob(o, o->amt);
|
removeob(o, o->amt);
|
||||||
}
|
}
|
||||||
|
@ -3350,18 +3307,6 @@ int getobvalue(object_t *o) {
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
/*
|
|
||||||
if (rarity >= 70) {
|
|
||||||
price /= 1.5;
|
|
||||||
} else if (rarity <= 40) {
|
|
||||||
price *= 1.5;
|
|
||||||
} else if (rarity <= 20) {
|
|
||||||
price *= 2;
|
|
||||||
} else if (rarity <= 10) {
|
|
||||||
price *= 5;
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
// blessed/cursed
|
// blessed/cursed
|
||||||
if (isblessed(o) || iscursed(o)) price *= 1.25;
|
if (isblessed(o) || iscursed(o)) price *= 1.25;
|
||||||
|
|
||||||
|
@ -3372,20 +3317,6 @@ int getobvalue(object_t *o) {
|
||||||
return (int) price;
|
return (int) price;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
int getobtypevalue(objecttype_t *ot) {
|
|
||||||
float price;
|
|
||||||
if (ot->id == OT_GOLD) {
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
// base value: weight * material value
|
|
||||||
price = (float)ot->weight * (float)getmaterialvalue(ot->material->id);
|
|
||||||
|
|
||||||
adjustprice(ot, &price);
|
|
||||||
return (int) price;
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
char *getoperateverb(object_t *o) {
|
char *getoperateverb(object_t *o) {
|
||||||
if (hasflag(o->flags, F_CONTAINER) && (o->type->id != OT_VENDINGMACHINE)) {
|
if (hasflag(o->flags, F_CONTAINER) && (o->type->id != OT_VENDINGMACHINE)) {
|
||||||
return "open";
|
return "open";
|
||||||
|
@ -3397,12 +3328,6 @@ char *getoperateverb(object_t *o) {
|
||||||
// ie if you call this on a gem inside a bag inside
|
// ie if you call this on a gem inside a bag inside
|
||||||
// a barrel, will return the barrel.
|
// a barrel, will return the barrel.
|
||||||
object_t *getoutercontainer(object_t *o) {
|
object_t *getoutercontainer(object_t *o) {
|
||||||
/*
|
|
||||||
while (o->pile->parentob) {
|
|
||||||
o = o->pile->parentob;
|
|
||||||
}
|
|
||||||
return o;
|
|
||||||
*/
|
|
||||||
return getoutercontainerop(o->pile);
|
return getoutercontainerop(o->pile);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -4073,20 +3998,6 @@ char *getobextrainfo(object_t *o, char *buf) {
|
||||||
|
|
||||||
cell_t *getoblocation(object_t *o) {
|
cell_t *getoblocation(object_t *o) {
|
||||||
return getobpilelocation(o->pile);
|
return getobpilelocation(o->pile);
|
||||||
/*
|
|
||||||
if (o->pile->owner) { // held by someone
|
|
||||||
return o->pile->owner->cell;
|
|
||||||
} else if (o->pile->where) { // on the ground
|
|
||||||
return o->pile->where;
|
|
||||||
} else if (o->pile->parentob) { // inside another object
|
|
||||||
object_t *outerob;
|
|
||||||
// get outside object
|
|
||||||
outerob = getoutercontainer(o);
|
|
||||||
return getoblocation(outerob);
|
|
||||||
}
|
|
||||||
// in a dummy cell
|
|
||||||
return NULL;
|
|
||||||
*/
|
|
||||||
}
|
}
|
||||||
|
|
||||||
cell_t *getobpilelocation(obpile_t *op) {
|
cell_t *getobpilelocation(obpile_t *op) {
|
||||||
|
@ -5592,14 +5503,6 @@ int isbetterwepthan(object_t *a, object_t *b) {
|
||||||
if (!a) return B_FALSE;
|
if (!a) return B_FALSE;
|
||||||
if (!b) return B_TRUE;
|
if (!b) return B_TRUE;
|
||||||
|
|
||||||
/* if (a->pile->owner && lfhasflag(a->pile->owner, F_DEBUG)) {
|
|
||||||
db = B_TRUE;
|
|
||||||
}
|
|
||||||
if (b->pile->owner && lfhasflag(b->pile->owner, F_DEBUG)) {
|
|
||||||
db = B_TRUE;
|
|
||||||
} */
|
|
||||||
|
|
||||||
|
|
||||||
if (db) {
|
if (db) {
|
||||||
getobname(a, namea, a->amt);
|
getobname(a, namea, a->amt);
|
||||||
getobname(b, nameb, b->amt);
|
getobname(b, nameb, b->amt);
|
||||||
|
@ -7300,17 +7203,6 @@ int operate(lifeform_t *lf, object_t *o, cell_t *where) {
|
||||||
return B_TRUE;
|
return B_TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
if (lf->controller != C_PLAYER) {
|
|
||||||
|
|
||||||
if (haslos(player, lf->cell)) {
|
|
||||||
getlfname(lf, buf);
|
|
||||||
capitalise(buf);
|
|
||||||
msg("%s operates %s.", buf, obname);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
if (hasflag(o->flags, F_CONTAINER) && (o->type->id != OT_VENDINGMACHINE)) { // loot it
|
if (hasflag(o->flags, F_CONTAINER) && (o->type->id != OT_VENDINGMACHINE)) { // loot it
|
||||||
if (isplayer(lf)) { // only player can loot.
|
if (isplayer(lf)) { // only player can loot.
|
||||||
char ch;
|
char ch;
|
||||||
|
@ -7318,16 +7210,16 @@ int operate(lifeform_t *lf, object_t *o, cell_t *where) {
|
||||||
initprompt(&prompt, buf);
|
initprompt(&prompt, buf);
|
||||||
if (countobs(lf->pack, B_FALSE)) {
|
if (countobs(lf->pack, B_FALSE)) {
|
||||||
snprintf(buf, BUFLEN, "Put items in %s",obname);
|
snprintf(buf, BUFLEN, "Put items in %s",obname);
|
||||||
addchoice(&prompt, 'i', buf, NULL, NULL);
|
addchoice(&prompt, 'i', buf, NULL, NULL, NULL);
|
||||||
}
|
}
|
||||||
if (countobs(o->contents, B_FALSE)) {
|
if (countobs(o->contents, B_FALSE)) {
|
||||||
snprintf(buf, BUFLEN, "Take items out of %s",obname);
|
snprintf(buf, BUFLEN, "Take items out of %s",obname);
|
||||||
addchoice(&prompt, 'o', buf, NULL, NULL);
|
addchoice(&prompt, 'o', buf, NULL, NULL, NULL);
|
||||||
}
|
}
|
||||||
snprintf(buf, BUFLEN, "Both");
|
snprintf(buf, BUFLEN, "Both");
|
||||||
addchoice(&prompt, 'b', buf, NULL, NULL);
|
addchoice(&prompt, 'b', buf, NULL, NULL, NULL);
|
||||||
snprintf(buf, BUFLEN, "Neither");
|
snprintf(buf, BUFLEN, "Neither");
|
||||||
addchoice(&prompt, 'n', buf, NULL, NULL);
|
addchoice(&prompt, 'n', buf, NULL, NULL, NULL);
|
||||||
ch = getchoice(&prompt);
|
ch = getchoice(&prompt);
|
||||||
switch (ch) {
|
switch (ch) {
|
||||||
case 'i':
|
case 'i':
|
||||||
|
@ -9561,7 +9453,6 @@ int shatter(object_t *o, int hitlf, char *damstring, lifeform_t *fromlf) {
|
||||||
strcpy(prefix, "");
|
strcpy(prefix, "");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
msg("%s%s shatter%s!",prefix, strlen(prefix) ? noprefix(obname) : obname,
|
msg("%s%s shatter%s!",prefix, strlen(prefix) ? noprefix(obname) : obname,
|
||||||
(o->amt == 1) ? "s" : "");
|
(o->amt == 1) ? "s" : "");
|
||||||
|
|
||||||
|
@ -9582,7 +9473,6 @@ int shatter(object_t *o, int hitlf, char *damstring, lifeform_t *fromlf) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// place shards
|
// place shards
|
||||||
if (o->material->id == MT_GLASS) {
|
if (o->material->id == MT_GLASS) {
|
||||||
int numshards;
|
int numshards;
|
||||||
|
@ -9648,6 +9538,7 @@ int shatter(object_t *o, int hitlf, char *damstring, lifeform_t *fromlf) {
|
||||||
case OT_POT_POLYMORPH:
|
case OT_POT_POLYMORPH:
|
||||||
case OT_POT_INVIS:
|
case OT_POT_INVIS:
|
||||||
case OT_POT_SANCTUARY: // apply regular potion effects, and make them known
|
case OT_POT_SANCTUARY: // apply regular potion effects, and make them known
|
||||||
|
case OT_POT_SLEEP:
|
||||||
if (target) {
|
if (target) {
|
||||||
if (seen) {
|
if (seen) {
|
||||||
makeknown(o->type->id);
|
makeknown(o->type->id);
|
||||||
|
@ -10236,7 +10127,7 @@ int fireat(lifeform_t *thrower, object_t *o, int amt, cell_t *where, int speed,
|
||||||
// identify as cursed!
|
// identify as cursed!
|
||||||
}
|
}
|
||||||
|
|
||||||
if (haslos(player, where)) {
|
if (haslos(player, where) || haslos(player, srcloc)) { // can see the src/dst location
|
||||||
seen = B_TRUE;
|
seen = B_TRUE;
|
||||||
} else {
|
} else {
|
||||||
seen = B_FALSE;
|
seen = B_FALSE;
|
||||||
|
@ -10296,14 +10187,6 @@ int fireat(lifeform_t *thrower, object_t *o, int amt, cell_t *where, int speed,
|
||||||
} else if (seen) {
|
} else if (seen) {
|
||||||
char throwstring[BUFLEN];
|
char throwstring[BUFLEN];
|
||||||
// an object is moving on its own
|
// an object is moving on its own
|
||||||
|
|
||||||
/*
|
|
||||||
if (target) {
|
|
||||||
msg("Something %ss %s at %s.", throwverbpres, obname, targetname);
|
|
||||||
} else {
|
|
||||||
msg("Something %ss %s.",throwverbpres, obname);
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
if (o->pile->owner && cansee(player, o->pile->owner)) {
|
if (o->pile->owner && cansee(player, o->pile->owner)) {
|
||||||
char ownername[BUFLEN];
|
char ownername[BUFLEN];
|
||||||
getlfname(o->pile->owner, ownername);
|
getlfname(o->pile->owner, ownername);
|
||||||
|
@ -10708,14 +10591,6 @@ void timeeffectsob(object_t *o) {
|
||||||
getobname(o, obname, o->amt);
|
getobname(o, obname, o->amt);
|
||||||
|
|
||||||
location = getoblocation(o);
|
location = getoblocation(o);
|
||||||
/*
|
|
||||||
if (o->pile->where) {
|
|
||||||
location = o->pile->where;
|
|
||||||
} else {
|
|
||||||
location = NULL;
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
if (o->pile->owner) {
|
if (o->pile->owner) {
|
||||||
owner = o->pile->owner;
|
owner = o->pile->owner;
|
||||||
getlfname(owner, ownername);
|
getlfname(owner, ownername);
|
||||||
|
@ -10775,15 +10650,6 @@ void timeeffectsob(object_t *o) {
|
||||||
if (!glowflag) {
|
if (!glowflag) {
|
||||||
// start glowing
|
// start glowing
|
||||||
glowflag = addtempflag(o->flags, F_PRODUCESLIGHT, 2, NA, NA, NULL, FROMBLESSING);
|
glowflag = addtempflag(o->flags, F_PRODUCESLIGHT, 2, NA, NA, NULL, FROMBLESSING);
|
||||||
/*
|
|
||||||
if (isplayer(o->pile->owner)) {
|
|
||||||
msg("Your %s start%s glowing!",noprefix(obname), (o->amt == 1) ? "s" : "");
|
|
||||||
if (!o->blessknown) o->blessknown = B_TRUE;
|
|
||||||
} else if (haslos(player, ourcell)) {
|
|
||||||
msg("%s start%s glowing!",obname, (o->amt == 1) ? "s" : "");
|
|
||||||
if (!o->blessknown) o->blessknown = B_TRUE;
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
if (haslos(player, ourcell)) {
|
if (haslos(player, ourcell)) {
|
||||||
if (!o->blessknown) o->blessknown = B_TRUE;
|
if (!o->blessknown) o->blessknown = B_TRUE;
|
||||||
}
|
}
|
||||||
|
@ -10795,15 +10661,6 @@ void timeeffectsob(object_t *o) {
|
||||||
if (glowflag) {
|
if (glowflag) {
|
||||||
killflag(glowflag);
|
killflag(glowflag);
|
||||||
glowflag = NULL;
|
glowflag = NULL;
|
||||||
/*
|
|
||||||
if (isplayer(o->pile->owner)) {
|
|
||||||
msg("Your %s stop%s glowing.",noprefix(obname), (o->amt == 1) ? "s" : "");
|
|
||||||
if (!o->blessknown) o->blessknown = B_TRUE;
|
|
||||||
} else if (haslos(player, ourcell)) {
|
|
||||||
msg("%s stop%s glowing.",obname, (o->amt == 1) ? "s" : "");
|
|
||||||
if (!o->blessknown) o->blessknown = B_TRUE;
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -11542,13 +11399,6 @@ int validateobs(void) {
|
||||||
printf("ERROR - spell %s doesn't have F_SPELLSCHOOL.\n", ot->name);
|
printf("ERROR - spell %s doesn't have F_SPELLSCHOOL.\n", ot->name);
|
||||||
goterror = B_TRUE;
|
goterror = B_TRUE;
|
||||||
}
|
}
|
||||||
/*
|
|
||||||
if (!hasflag(ot->flags, F_SPELLLETTER)) {
|
|
||||||
printf("ERROR - spell %s doesn't have F_SPELLLETTER.\n", ot->name);
|
|
||||||
goterror = B_TRUE;
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
if ((ot->obclass->id == OC_SPELL) && !hasflag(ot->flags, F_SPELLLEVEL)) {
|
if ((ot->obclass->id == OC_SPELL) && !hasflag(ot->flags, F_SPELLLEVEL)) {
|
||||||
printf("ERROR - spell %s doesn't have F_SPELLLEVEL.\n", ot->name);
|
printf("ERROR - spell %s doesn't have F_SPELLLEVEL.\n", ot->name);
|
||||||
goterror = B_TRUE;
|
goterror = B_TRUE;
|
||||||
|
@ -11661,23 +11511,6 @@ int validateobs(void) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
for (sk = firstskill ; sk ; sk = sk->next) {
|
|
||||||
int found = B_FALSE;
|
|
||||||
// make sure every skill have an object providing it
|
|
||||||
for (ot = objecttype ; ot ; ot = ot->next) {
|
|
||||||
if (hasflagval(ot->flags, F_MANUALOF, sk->id, NA, NA, NULL)) {
|
|
||||||
found = B_TRUE;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (!found) {
|
|
||||||
printf("ERROR - skill '%s' has no matching manual.\n", sk->name);
|
|
||||||
goterror = B_TRUE;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
return goterror;
|
return goterror;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -11870,15 +11703,6 @@ int getmissileaccuracy(lifeform_t *thrower, cell_t *where, object_t *missile, ob
|
||||||
rangemod = 30 - ((int) (((float)howfar / (float)maxrange) * 60.0));
|
rangemod = 30 - ((int) (((float)howfar / (float)maxrange) * 60.0));
|
||||||
acc += rangemod;
|
acc += rangemod;
|
||||||
}
|
}
|
||||||
/*
|
|
||||||
if (howfar == 1) {
|
|
||||||
acc += 30;
|
|
||||||
} else if (howfar == maxrange) {
|
|
||||||
if (slev != PR_MASTER) {
|
|
||||||
acc -= 30;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
// modify for dexterity
|
// modify for dexterity
|
||||||
if (whichatt != A_NONE) {
|
if (whichatt != A_NONE) {
|
||||||
|
|
5
save.c
5
save.c
|
@ -1085,6 +1085,7 @@ int writehiscore(lifeform_t *lf, int *rank) {
|
||||||
int rc;
|
int rc;
|
||||||
char filename[BUFLEN],*cmd;
|
char filename[BUFLEN],*cmd;
|
||||||
char pname[BUFLEN];
|
char pname[BUFLEN];
|
||||||
|
char racename[BUFLEN];
|
||||||
char jobname[BUFLEN];
|
char jobname[BUFLEN];
|
||||||
char killedby[BUFLEN];
|
char killedby[BUFLEN];
|
||||||
char *errmsg = NULL;
|
char *errmsg = NULL;
|
||||||
|
@ -1106,7 +1107,9 @@ int writehiscore(lifeform_t *lf, int *rank) {
|
||||||
|
|
||||||
getplayername(pname);
|
getplayername(pname);
|
||||||
j = getjob(player);
|
j = getjob(player);
|
||||||
snprintf(jobname, BUFLEN, "Lv%d %s", player->level, j->name);
|
strcpy(racename, player->race->name);
|
||||||
|
capitalise(racename);
|
||||||
|
snprintf(jobname, BUFLEN, "Lv%d %s %s", player->level, racename, j->name);
|
||||||
|
|
||||||
makekillertext(killedby, lf->lastdam, B_FALSE);
|
makekillertext(killedby, lf->lastdam, B_FALSE);
|
||||||
|
|
||||||
|
|
53
spell.c
53
spell.c
|
@ -858,7 +858,7 @@ int abilityeffects(lifeform_t *user, enum OBTYPE abilid, cell_t *targcell, lifef
|
||||||
// 1.compile a list of repairable objects
|
// 1.compile a list of repairable objects
|
||||||
// sk_armour lets you repair armour up to xx% (depends on skill)
|
// sk_armour lets you repair armour up to xx% (depends on skill)
|
||||||
initprompt(&prompt, "Repair which object?");
|
initprompt(&prompt, "Repair which object?");
|
||||||
addchoice(&prompt, '-', "Cancel", "Cancel", NULL);
|
addchoice(&prompt, '-', "Cancel", "Cancel", NULL, NULL);
|
||||||
for (o = user->pack->first ; o ; o = o->next) {
|
for (o = user->pack->first ; o ; o = o->next) {
|
||||||
int ok = B_FALSE;
|
int ok = B_FALSE;
|
||||||
int cutoff = 0;
|
int cutoff = 0;
|
||||||
|
@ -877,7 +877,7 @@ int abilityeffects(lifeform_t *user, enum OBTYPE abilid, cell_t *targcell, lifef
|
||||||
char buf[BUFLEN];
|
char buf[BUFLEN];
|
||||||
getobname(o, buf, o->amt);
|
getobname(o, buf, o->amt);
|
||||||
// we can repair this object
|
// we can repair this object
|
||||||
addchoice(&prompt, o->letter, buf, buf, o);
|
addchoice(&prompt, o->letter, buf, buf, o, NULL);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1002,7 +1002,7 @@ int abilityeffects(lifeform_t *user, enum OBTYPE abilid, cell_t *targcell, lifef
|
||||||
}
|
}
|
||||||
|
|
||||||
// ask what to inspect
|
// ask what to inspect
|
||||||
initprompt(&prompt, "Study which scroll");
|
initprompt(&prompt, "Study which scroll?");
|
||||||
for (o = user->pack->first ; o ; o = o->next) {
|
for (o = user->pack->first ; o ; o = o->next) {
|
||||||
if ((o->type->obclass->id == OC_SCROLL) && isknown(o)) {
|
if ((o->type->obclass->id == OC_SCROLL) && isknown(o)) {
|
||||||
f = hasflag(o->flags, F_LINKSPELL);
|
f = hasflag(o->flags, F_LINKSPELL);
|
||||||
|
@ -1011,10 +1011,15 @@ int abilityeffects(lifeform_t *user, enum OBTYPE abilid, cell_t *targcell, lifef
|
||||||
getobname(o, buf, o->amt);
|
getobname(o, buf, o->amt);
|
||||||
difficulty = 20 + (getspelllevel(f->val[0])*3);
|
difficulty = 20 + (getspelllevel(f->val[0])*3);
|
||||||
sprintf(buf2, "%s (%d%% success chance)", buf, difficulty);
|
sprintf(buf2, "%s (%d%% success chance)", buf, difficulty);
|
||||||
addchoice(&prompt, o->letter, buf, NULL, f);
|
addchoice(&prompt, o->letter, buf, NULL, f, NULL);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!prompt.nchoices) {
|
||||||
|
msg("You have no scrolls which you need to study.");
|
||||||
|
return B_TRUE;
|
||||||
|
}
|
||||||
getchoice(&prompt);
|
getchoice(&prompt);
|
||||||
f = (flag_t *)prompt.result;
|
f = (flag_t *)prompt.result;
|
||||||
if (!f) {
|
if (!f) {
|
||||||
|
@ -1348,8 +1353,10 @@ int abilityeffects(lifeform_t *user, enum OBTYPE abilid, cell_t *targcell, lifef
|
||||||
initprompt(&prompt, "Which skill will you learn?");
|
initprompt(&prompt, "Which skill will you learn?");
|
||||||
ch = 'a';
|
ch = 'a';
|
||||||
for (sk = firstskill ; sk ; sk = sk->next) {
|
for (sk = firstskill ; sk ; sk = sk->next) {
|
||||||
|
char buf2[HUGEBUFLEN];
|
||||||
snprintf(buf, BUFLEN, "%s (%s)",getskillname(sk->id), getskilldesc(sk->id));
|
snprintf(buf, BUFLEN, "%s (%s)",getskillname(sk->id), getskilldesc(sk->id));
|
||||||
addchoice(&prompt, ch++, getskillname(sk->id), buf, sk);
|
makedesc_skill(sk->id, buf2);
|
||||||
|
addchoice(&prompt, ch++, getskillname(sk->id), buf, sk, buf2);
|
||||||
}
|
}
|
||||||
getchoicestr(&prompt, B_FALSE, B_TRUE);
|
getchoicestr(&prompt, B_FALSE, B_TRUE);
|
||||||
sk = (skill_t *)prompt.result;
|
sk = (skill_t *)prompt.result;
|
||||||
|
@ -1359,7 +1366,7 @@ int abilityeffects(lifeform_t *user, enum OBTYPE abilid, cell_t *targcell, lifef
|
||||||
initprompt(&prompt, "How much will you learn this skill?");
|
initprompt(&prompt, "How much will you learn this skill?");
|
||||||
for (i = getskill(user, sk->id) + 1 ; i <= PR_MASTER; i++) {
|
for (i = getskill(user, sk->id) + 1 ; i <= PR_MASTER; i++) {
|
||||||
snprintf(buf, BUFLEN, "%s",getskilllevelname(i));
|
snprintf(buf, BUFLEN, "%s",getskilllevelname(i));
|
||||||
addchoice(&prompt, ch++, buf, buf, NULL);
|
addchoice(&prompt, ch++, buf, buf, NULL, NULL);
|
||||||
}
|
}
|
||||||
if (prompt.nchoices <= 0) {
|
if (prompt.nchoices <= 0) {
|
||||||
msg("You have already mastered this skill!");
|
msg("You have already mastered this skill!");
|
||||||
|
@ -1890,7 +1897,7 @@ int abilityeffects(lifeform_t *user, enum OBTYPE abilid, cell_t *targcell, lifef
|
||||||
if (classok && !isknown(o)) {
|
if (classok && !isknown(o)) {
|
||||||
char buf[BUFLEN];
|
char buf[BUFLEN];
|
||||||
getobname(o, buf, o->amt);
|
getobname(o, buf, o->amt);
|
||||||
addchoice(&prompt, o->letter, buf, NULL, o);
|
addchoice(&prompt, o->letter, buf, NULL, o, NULL);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
getchoice(&prompt);
|
getchoice(&prompt);
|
||||||
|
@ -2576,10 +2583,10 @@ int dospelleffects(lifeform_t *caster, enum OBTYPE spellid, int power, lifeform_
|
||||||
|
|
||||||
// which object to take?
|
// which object to take?
|
||||||
initprompt(&prompt, "Confiscate which object?");
|
initprompt(&prompt, "Confiscate which object?");
|
||||||
addchoice(&prompt, '-', "(Cancel)", NULL, NULL);
|
addchoice(&prompt, '-', "(Cancel)", NULL, NULL, NULL);
|
||||||
for (o = target->pack->first ; o ; o = o->next) {
|
for (o = target->pack->first ; o ; o = o->next) {
|
||||||
getobname(o, obname, o->amt);
|
getobname(o, obname, o->amt);
|
||||||
addchoice(&prompt, ch, obname, NULL, o);
|
addchoice(&prompt, ch, obname, NULL, o, NULL);
|
||||||
if (ch == 'z') {
|
if (ch == 'z') {
|
||||||
ch = 'A';
|
ch = 'A';
|
||||||
} else {
|
} else {
|
||||||
|
@ -4899,7 +4906,7 @@ int dospelleffects(lifeform_t *caster, enum OBTYPE spellid, int power, lifeform_
|
||||||
for (l = caster->cell->map->lf ; l ; l = l->next) {
|
for (l = caster->cell->map->lf ; l ; l = l->next) {
|
||||||
if (l != caster) {
|
if (l != caster) {
|
||||||
if (isimmuneto(l->flags, DT_NECROTIC) ||
|
if (isimmuneto(l->flags, DT_NECROTIC) ||
|
||||||
spellresisted(target, caster, spellid, power, seenbyplayer, B_FALSE)) {
|
spellresisted(l, caster, spellid, power, seenbyplayer, B_FALSE)) {
|
||||||
if (isplayer(l)) {
|
if (isplayer(l)) {
|
||||||
msg("Luckily, the evil doesn't seem to harm you.");
|
msg("Luckily, the evil doesn't seem to harm you.");
|
||||||
if (seenbyplayer) *seenbyplayer = B_TRUE;
|
if (seenbyplayer) *seenbyplayer = B_TRUE;
|
||||||
|
@ -4915,7 +4922,7 @@ int dospelleffects(lifeform_t *caster, enum OBTYPE spellid, int power, lifeform_
|
||||||
}
|
}
|
||||||
|
|
||||||
// now hit the caster!
|
// now hit the caster!
|
||||||
if (isimmuneto(caster->flags, DT_NECROTIC) || spellresisted(target, caster, spellid, power, seenbyplayer, B_FALSE)) {
|
if (isimmuneto(caster->flags, DT_NECROTIC) || spellresisted(caster, caster, spellid, power, seenbyplayer, B_FALSE)) {
|
||||||
if (isplayer(caster)) {
|
if (isplayer(caster)) {
|
||||||
msg("Luckily, the evil doesn't seem to harm you.");
|
msg("Luckily, the evil doesn't seem to harm you.");
|
||||||
if (seenbyplayer) *seenbyplayer = B_TRUE;
|
if (seenbyplayer) *seenbyplayer = B_TRUE;
|
||||||
|
@ -5161,7 +5168,7 @@ int dospelleffects(lifeform_t *caster, enum OBTYPE spellid, int power, lifeform_
|
||||||
for (r = firstregion ; r ; r = r->next) {
|
for (r = firstregion ; r ; r = r->next) {
|
||||||
regiontype_t *rt;
|
regiontype_t *rt;
|
||||||
rt = r->rtype;
|
rt = r->rtype;
|
||||||
addchoice(&prompt, ch++, rt->name, NULL, r);
|
addchoice(&prompt, ch++, rt->name, NULL, r, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
ch = getchoice(&prompt);
|
ch = getchoice(&prompt);
|
||||||
|
@ -5944,7 +5951,7 @@ int dospelleffects(lifeform_t *caster, enum OBTYPE spellid, int power, lifeform_
|
||||||
char obname[BUFLEN];
|
char obname[BUFLEN];
|
||||||
real_getobname(o, obname, o->amt, B_TRUE, B_TRUE, B_FALSE, B_FALSE, B_FALSE);
|
real_getobname(o, obname, o->amt, B_TRUE, B_TRUE, B_FALSE, B_FALSE, B_FALSE);
|
||||||
if (strcasestr(obname, wantname)) {
|
if (strcasestr(obname, wantname)) {
|
||||||
addchoice(&prompt, ch++, obname, NULL, o);
|
addchoice(&prompt, ch++, obname, NULL, o, NULL);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -5966,7 +5973,7 @@ int dospelleffects(lifeform_t *caster, enum OBTYPE spellid, int power, lifeform_
|
||||||
strcat(obname, lfname);
|
strcat(obname, lfname);
|
||||||
strcat(obname, ")");
|
strcat(obname, ")");
|
||||||
|
|
||||||
addchoice(&prompt, ch++, obname, NULL, o);
|
addchoice(&prompt, ch++, obname, NULL, o, NULL);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -6009,7 +6016,7 @@ int dospelleffects(lifeform_t *caster, enum OBTYPE spellid, int power, lifeform_
|
||||||
sk = findskill(skid);
|
sk = findskill(skid);
|
||||||
if (sk && isloreskill(skid)) {
|
if (sk && isloreskill(skid)) {
|
||||||
if (!getskill(caster, skid)) {
|
if (!getskill(caster, skid)) {
|
||||||
addchoice(&prompt, ch++, sk->name, NULL, sk);
|
addchoice(&prompt, ch++, sk->name, NULL, sk, NULL);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -7013,8 +7020,8 @@ int dospelleffects(lifeform_t *caster, enum OBTYPE spellid, int power, lifeform_
|
||||||
getobname(corpse, corpsename, 1);
|
getobname(corpse, corpsename, 1);
|
||||||
snprintf(buf, BUFLEN, "What will you ask %s?", corpsename);
|
snprintf(buf, BUFLEN, "What will you ask %s?", corpsename);
|
||||||
initprompt(&prompt, buf);
|
initprompt(&prompt, buf);
|
||||||
addchoice(&prompt, 'a', "How did you die?", NULL, NULL);
|
addchoice(&prompt, 'a', "How did you die?", NULL, NULL, NULL);
|
||||||
addchoice(&prompt, '-', "(nothing)", NULL, NULL);
|
addchoice(&prompt, '-', "(nothing)", NULL, NULL, NULL);
|
||||||
|
|
||||||
ch = getchoice(&prompt);
|
ch = getchoice(&prompt);
|
||||||
if (ch == 'a') {
|
if (ch == 'a') {
|
||||||
|
@ -8062,12 +8069,12 @@ int dospelleffects(lifeform_t *caster, enum OBTYPE spellid, int power, lifeform_
|
||||||
char ch;
|
char ch;
|
||||||
if (!target) target = caster;
|
if (!target) target = caster;
|
||||||
initprompt(&prompt, "For what do you wish?");
|
initprompt(&prompt, "For what do you wish?");
|
||||||
addchoice(&prompt, 'a', "Wealth", NULL, NULL);
|
addchoice(&prompt, 'a', "Wealth", NULL, NULL, NULL);
|
||||||
addchoice(&prompt, 'b', "Power", NULL, NULL);
|
addchoice(&prompt, 'b', "Power", NULL, NULL, NULL);
|
||||||
addchoice(&prompt, 'c', "Protection", NULL, NULL);
|
addchoice(&prompt, 'c', "Protection", NULL, NULL, NULL);
|
||||||
addchoice(&prompt, 'd', "Fame", NULL, NULL);
|
addchoice(&prompt, 'd', "Fame", NULL, NULL, NULL);
|
||||||
addchoice(&prompt, 'e', "Knowledge", NULL, NULL);
|
addchoice(&prompt, 'e', "Knowledge", NULL, NULL, NULL);
|
||||||
addchoice(&prompt, 'f', "Magic", NULL, NULL);
|
addchoice(&prompt, 'f', "Magic", NULL, NULL, NULL);
|
||||||
if (isplayer(target)) {
|
if (isplayer(target)) {
|
||||||
ch = getchoice(&prompt);
|
ch = getchoice(&prompt);
|
||||||
} else {
|
} else {
|
||||||
|
|
Loading…
Reference in New Issue