MAke object weight functions more meaningful - getobmass() and getobweight()
This commit is contained in:
parent
d676a33072
commit
a4735d597c
42
Makefile
42
Makefile
|
@ -1,62 +1,64 @@
|
||||||
#all: Makefile defs.h nexus.c nexus.h ai.c ai.h attack.c attack.h data.c data.h flag.c flag.h god.c god.h io.c io.h lf.c lf.h map.c map.h move.c move.h objects.c objects.h text.c text.h save.c save.h shops.c shops.h spell.c spell.h vault.c vault.h
|
#all: Makefile defs.h nexus.c nexus.h ai.c ai.h attack.c attack.h data.c data.h flag.c flag.h god.c god.h io.c io.h lf.c lf.h map.c map.h move.c move.h objects.c objects.h text.c text.h save.c save.h shops.c shops.h spell.c spell.h vault.c vault.h
|
||||||
# gcc -Werror -Wall -g -pg -o nexus nexus.c ai.c attack.c data.c flag.c god.c io.c lf.c map.c move.c objects.c text.c save.c spell.c shops.c vault.c -lncurses -lsqlite3
|
# gcc $(CFLAGS) -o nexus nexus.c ai.c attack.c data.c flag.c god.c io.c lf.c map.c move.c objects.c text.c save.c spell.c shops.c vault.c -lncurses -lsqlite3
|
||||||
|
|
||||||
|
CFLAGS=-fdiagnostics-color=always -g -pg -Wall -Werror
|
||||||
|
|
||||||
nexus: ai.o astar.o attack.o data.o flag.o god.o io.o lf.o map.o move.o nexus.o objects.o save.o shops.o spell.o text.o vault.o ai.h attack.h data.h defs.h flag.h god.h io.h lf.h map.h move.h nexus.h objects.h save.h shops.h spell.h text.h vault.h
|
nexus: ai.o astar.o attack.o data.o flag.o god.o io.o lf.o map.o move.o nexus.o objects.o save.o shops.o spell.o text.o vault.o ai.h attack.h data.h defs.h flag.h god.h io.h lf.h map.h move.h nexus.h objects.h save.h shops.h spell.h text.h vault.h
|
||||||
gcc -Werror -g -pg -Wall -o nexus ai.o astar.o attack.o data.o flag.o god.o io.o lf.o map.o move.o nexus.o objects.o save.o shops.o spell.o text.o vault.o -lncurses -lsqlite3
|
gcc $(CFLAGS) -o nexus ai.o astar.o attack.o data.o flag.o god.o io.o lf.o map.o move.o nexus.o objects.o save.o shops.o spell.o text.o vault.o -lncurses -lsqlite3
|
||||||
|
|
||||||
ai.o: ai.c ai.h attack.h astar.h data.h defs.h flag.h god.h io.h lf.h map.h move.h ai.h objects.h save.h shops.h spell.h text.h vault.h
|
ai.o: ai.c ai.h attack.h astar.h data.h defs.h flag.h god.h io.h lf.h map.h move.h ai.h objects.h save.h shops.h spell.h text.h vault.h
|
||||||
gcc -Werror -Wall -c -g -pg -o ai.o ai.c
|
gcc $(CFLAGS) -c -o ai.o ai.c
|
||||||
|
|
||||||
attack.o: attack.c ai.h attack.h astar.h data.h defs.h flag.h god.h io.h lf.h map.h move.h attack.h astar.h objects.h save.h shops.h spell.h text.h vault.h
|
attack.o: attack.c ai.h attack.h astar.h data.h defs.h flag.h god.h io.h lf.h map.h move.h attack.h astar.h objects.h save.h shops.h spell.h text.h vault.h
|
||||||
gcc -Werror -Wall -c -g -pg -o attack.o attack.c
|
gcc $(CFLAGS) -c -o attack.o attack.c
|
||||||
|
|
||||||
astar.o: astar.c ai.h attack.h astar.h data.h defs.h flag.h god.h io.h lf.h map.h move.h attack.h astar.h objects.h save.h shops.h spell.h text.h vault.h
|
astar.o: astar.c ai.h attack.h astar.h data.h defs.h flag.h god.h io.h lf.h map.h move.h attack.h astar.h objects.h save.h shops.h spell.h text.h vault.h
|
||||||
gcc -Werror -Wall -c -g -pg -o astar.o astar.c
|
gcc $(CFLAGS) -c -o astar.o astar.c
|
||||||
|
|
||||||
data.o: data.c ai.h attack.h astar.h data.h defs.h flag.h god.h io.h lf.h map.h move.h data.h objects.h save.h shops.h spell.h text.h vault.h
|
data.o: data.c ai.h attack.h astar.h data.h defs.h flag.h god.h io.h lf.h map.h move.h data.h objects.h save.h shops.h spell.h text.h vault.h
|
||||||
gcc -Werror -Wall -c -g -pg -o data.o data.c
|
gcc $(CFLAGS) -c -o data.o data.c
|
||||||
|
|
||||||
: ai.h attack.h astar.h data.h defs.h flag.h god.h io.h lf.h map.h move.h objects.h save.h shops.h spell.h text.h vault.h
|
: ai.h attack.h astar.h data.h defs.h flag.h god.h io.h lf.h map.h move.h objects.h save.h shops.h spell.h text.h vault.h
|
||||||
gcc -Werror -Wall -c -g -pg -o
|
gcc $(CFLAGS) -c -o
|
||||||
|
|
||||||
flag.o: flag.c ai.h attack.h astar.h data.h defs.h flag.h god.h io.h lf.h map.h move.h flag.h objects.h save.h shops.h spell.h text.h vault.h
|
flag.o: flag.c ai.h attack.h astar.h data.h defs.h flag.h god.h io.h lf.h map.h move.h flag.h objects.h save.h shops.h spell.h text.h vault.h
|
||||||
gcc -Werror -Wall -c -g -pg -o flag.o flag.c
|
gcc $(CFLAGS) -c -o flag.o flag.c
|
||||||
|
|
||||||
god.o: god.c ai.h attack.h astar.h data.h defs.h flag.h god.h io.h lf.h map.h move.h god.h objects.h save.h shops.h spell.h text.h vault.h
|
god.o: god.c ai.h attack.h astar.h data.h defs.h flag.h god.h io.h lf.h map.h move.h god.h objects.h save.h shops.h spell.h text.h vault.h
|
||||||
gcc -Werror -Wall -c -g -pg -o god.o god.c
|
gcc $(CFLAGS) -c -o god.o god.c
|
||||||
|
|
||||||
io.o: io.c ai.h attack.h astar.h data.h defs.h flag.h god.h io.h lf.h map.h move.h io.h objects.h save.h shops.h spell.h text.h vault.h
|
io.o: io.c ai.h attack.h astar.h data.h defs.h flag.h god.h io.h lf.h map.h move.h io.h objects.h save.h shops.h spell.h text.h vault.h
|
||||||
gcc -Werror -Wall -c -g -pg -o io.o io.c
|
gcc $(CFLAGS) -c -o io.o io.c
|
||||||
|
|
||||||
lf.o: lf.c ai.h attack.h astar.h data.h defs.h flag.h god.h io.h lf.h map.h move.h lf.h objects.h save.h shops.h spell.h text.h vault.h
|
lf.o: lf.c ai.h attack.h astar.h data.h defs.h flag.h god.h io.h lf.h map.h move.h lf.h objects.h save.h shops.h spell.h text.h vault.h
|
||||||
gcc -Werror -Wall -c -g -pg -o lf.o lf.c
|
gcc $(CFLAGS) -c -o lf.o lf.c
|
||||||
|
|
||||||
map.o: map.c ai.h attack.h astar.h data.h defs.h flag.h god.h io.h lf.h map.h move.h map.h objects.h save.h shops.h spell.h text.h vault.h
|
map.o: map.c ai.h attack.h astar.h data.h defs.h flag.h god.h io.h lf.h map.h move.h map.h objects.h save.h shops.h spell.h text.h vault.h
|
||||||
gcc -Werror -Wall -c -g -pg -o map.o map.c
|
gcc $(CFLAGS) -c -o map.o map.c
|
||||||
|
|
||||||
move.o: move.c ai.h attack.h astar.h data.h defs.h flag.h god.h io.h lf.h map.h move.h move.h objects.h save.h shops.h spell.h text.h vault.h
|
move.o: move.c ai.h attack.h astar.h data.h defs.h flag.h god.h io.h lf.h map.h move.h move.h objects.h save.h shops.h spell.h text.h vault.h
|
||||||
gcc -Werror -Wall -c -g -pg -o move.o move.c
|
gcc $(CFLAGS) -c -o move.o move.c
|
||||||
|
|
||||||
nexus.o: nexus.c ai.h attack.h astar.h data.h defs.h flag.h god.h io.h lf.h map.h move.h nexus.h objects.h save.h shops.h spell.h text.h vault.h
|
nexus.o: nexus.c ai.h attack.h astar.h data.h defs.h flag.h god.h io.h lf.h map.h move.h nexus.h objects.h save.h shops.h spell.h text.h vault.h
|
||||||
gcc -Werror -Wall -c -g -pg -o nexus.o nexus.c
|
gcc $(CFLAGS) -c -o nexus.o nexus.c
|
||||||
|
|
||||||
objects.o: objects.c ai.h attack.h astar.h data.h defs.h flag.h god.h io.h lf.h map.h move.h objects.h objects.h save.h shops.h spell.h text.h vault.h
|
objects.o: objects.c ai.h attack.h astar.h data.h defs.h flag.h god.h io.h lf.h map.h move.h objects.h objects.h save.h shops.h spell.h text.h vault.h
|
||||||
gcc -Werror -Wall -c -g -pg -o objects.o objects.c
|
gcc $(CFLAGS) -c -o objects.o objects.c
|
||||||
|
|
||||||
save.o: save.c ai.h attack.h astar.h data.h defs.h flag.h god.h io.h lf.h map.h move.h save.h objects.h save.h shops.h spell.h text.h vault.h
|
save.o: save.c ai.h attack.h astar.h data.h defs.h flag.h god.h io.h lf.h map.h move.h save.h objects.h save.h shops.h spell.h text.h vault.h
|
||||||
gcc -Werror -Wall -c -g -pg -o save.o save.c
|
gcc $(CFLAGS) -c -o save.o save.c
|
||||||
|
|
||||||
shops.o: shops.c ai.h attack.h astar.h data.h defs.h flag.h god.h io.h lf.h map.h move.h shops.h objects.h save.h shops.h spell.h text.h vault.h
|
shops.o: shops.c ai.h attack.h astar.h data.h defs.h flag.h god.h io.h lf.h map.h move.h shops.h objects.h save.h shops.h spell.h text.h vault.h
|
||||||
gcc -Werror -Wall -c -g -pg -o shops.o shops.c
|
gcc $(CFLAGS) -c -o shops.o shops.c
|
||||||
|
|
||||||
spell.o: spell.c ai.h attack.h astar.h data.h defs.h flag.h god.h io.h lf.h map.h move.h spell.h objects.h save.h shops.h spell.h text.h vault.h
|
spell.o: spell.c ai.h attack.h astar.h data.h defs.h flag.h god.h io.h lf.h map.h move.h spell.h objects.h save.h shops.h spell.h text.h vault.h
|
||||||
gcc -Werror -Wall -c -g -pg -o spell.o spell.c
|
gcc $(CFLAGS) -c -o spell.o spell.c
|
||||||
|
|
||||||
text.o: text.c ai.h attack.h astar.h data.h defs.h flag.h god.h io.h lf.h map.h move.h text.h objects.h save.h shops.h spell.h text.h vault.h
|
text.o: text.c ai.h attack.h astar.h data.h defs.h flag.h god.h io.h lf.h map.h move.h text.h objects.h save.h shops.h spell.h text.h vault.h
|
||||||
gcc -Werror -Wall -c -g -pg -o text.o text.c
|
gcc $(CFLAGS) -c -o text.o text.c
|
||||||
|
|
||||||
vault.o: vault.c ai.h attack.h astar.h data.h defs.h flag.h god.h io.h lf.h map.h move.h vault.h objects.h save.h shops.h spell.h text.h vault.h
|
vault.o: vault.c ai.h attack.h astar.h data.h defs.h flag.h god.h io.h lf.h map.h move.h vault.h objects.h save.h shops.h spell.h text.h vault.h
|
||||||
gcc -Werror -Wall -c -g -pg -o vault.o vault.c
|
gcc $(CFLAGS) -c -o vault.o vault.c
|
||||||
|
|
||||||
|
|
||||||
######################
|
######################
|
||||||
|
|
8
ai.c
8
ai.c
|
@ -995,7 +995,7 @@ int aigetspelltarget(lifeform_t *lf, objecttype_t *spelltype, lifeform_t *victim
|
||||||
object_t *o;
|
object_t *o;
|
||||||
for (o = lf->los[i]->obpile->first ; o ; o = o->next) {
|
for (o = lf->los[i]->obpile->first ; o ; o = o->next) {
|
||||||
if (!hasflag(o->flags, F_NOPICKUP) &&
|
if (!hasflag(o->flags, F_NOPICKUP) &&
|
||||||
getobweight(o) <= maxweight) {
|
getobmass(o) <= maxweight) {
|
||||||
poss[nposs] = o;
|
poss[nposs] = o;
|
||||||
nposs++;
|
nposs++;
|
||||||
if (nposs >= MAXPILEOBS) break;
|
if (nposs >= MAXPILEOBS) break;
|
||||||
|
@ -1734,7 +1734,7 @@ int ai_inventory_mgt(lifeform_t *lf, int *canattack) {
|
||||||
for (o = lf->pack->first ; o ; o = o->next) {
|
for (o = lf->pack->first ; o ; o = o->next) {
|
||||||
if (!isequipped(o)) {
|
if (!isequipped(o)) {
|
||||||
float thisweight;
|
float thisweight;
|
||||||
thisweight = getobweight(o);
|
thisweight = getobmass(o);
|
||||||
if (thisweight > hevweight) {
|
if (thisweight > hevweight) {
|
||||||
hevweight = thisweight;
|
hevweight = thisweight;
|
||||||
heaviest = o;
|
heaviest = o;
|
||||||
|
@ -2104,7 +2104,7 @@ int aimovetolf(lifeform_t *lf, lifeform_t *target, int wantattack) {
|
||||||
object_t *o;
|
object_t *o;
|
||||||
for (o = lf->los[i]->obpile->first ; o ; o = o->next) {
|
for (o = lf->los[i]->obpile->first ; o ; o = o->next) {
|
||||||
if (!hasflag(o->flags, F_NOPICKUP) &&
|
if (!hasflag(o->flags, F_NOPICKUP) &&
|
||||||
getobweight(o) <= maxweight) {
|
getobmass(o) <= maxweight) {
|
||||||
poss[nposs] = o;
|
poss[nposs] = o;
|
||||||
nposs++;
|
nposs++;
|
||||||
if (nposs >= MAXPILEOBS) break;
|
if (nposs >= MAXPILEOBS) break;
|
||||||
|
@ -3069,7 +3069,7 @@ int aispellok(lifeform_t *lf, enum OBTYPE spellid, lifeform_t *victim, enum FLAG
|
||||||
object_t *o;
|
object_t *o;
|
||||||
for (o = lf->los[i]->obpile->first ; o ; o = o->next) {
|
for (o = lf->los[i]->obpile->first ; o ; o = o->next) {
|
||||||
if (!hasflag(o->flags, F_NOPICKUP) &&
|
if (!hasflag(o->flags, F_NOPICKUP) &&
|
||||||
getobweight(o) <= maxweight) {
|
getobmass(o) <= maxweight) {
|
||||||
ok = B_TRUE;
|
ok = B_TRUE;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
8
io.c
8
io.c
|
@ -3881,7 +3881,7 @@ int askobjectmulti(obpile_t *op, char *prompt, condset_t *cs, int includenothing
|
||||||
nselected++;
|
nselected++;
|
||||||
if (selcount[n] == ALL) thiscount = mylist[n]->amt;
|
if (selcount[n] == ALL) thiscount = mylist[n]->amt;
|
||||||
else thiscount = selcount[n];
|
else thiscount = selcount[n];
|
||||||
selweight += (getobunitweight(mylist[n]) * thiscount);
|
selweight += (getobweight(mylist[n]) * thiscount);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// draw prompt
|
// draw prompt
|
||||||
|
@ -6304,7 +6304,7 @@ char *makedesc_ob(object_t *o, char *retbuf) {
|
||||||
o->material->name);
|
o->material->name);
|
||||||
}
|
}
|
||||||
|
|
||||||
obw = getobweight(o);
|
obw = getobmass(o);
|
||||||
if (o->amt == 1) {
|
if (o->amt == 1) {
|
||||||
char wbuf[BUFLEN];
|
char wbuf[BUFLEN];
|
||||||
getweighttext(obw, wbuf, B_FALSE);
|
getweighttext(obw, wbuf, B_FALSE);
|
||||||
|
@ -6314,7 +6314,7 @@ char *makedesc_ob(object_t *o, char *retbuf) {
|
||||||
char wbuf[BUFLEN];
|
char wbuf[BUFLEN];
|
||||||
char wbuf2[BUFLEN];
|
char wbuf2[BUFLEN];
|
||||||
getweighttext(obw, wbuf, B_FALSE);
|
getweighttext(obw, wbuf, B_FALSE);
|
||||||
getweighttext(getobunitweight(o), wbuf2, B_FALSE);
|
getweighttext(getobweight(o), wbuf2, B_FALSE);
|
||||||
snprintf(buf2, BUFLEN, "and weigh %s (%s each)",wbuf, wbuf2);
|
snprintf(buf2, BUFLEN, "and weigh %s (%s each)",wbuf, wbuf2);
|
||||||
strcat(buf, buf2);
|
strcat(buf, buf2);
|
||||||
}
|
}
|
||||||
|
@ -6323,7 +6323,7 @@ char *makedesc_ob(object_t *o, char *retbuf) {
|
||||||
if (compareob && (o->amt == 1)) {
|
if (compareob && (o->amt == 1)) {
|
||||||
int diff;
|
int diff;
|
||||||
float compareobw;
|
float compareobw;
|
||||||
compareobw = getobweight(compareob);
|
compareobw = getobmass(compareob);
|
||||||
diff = obw - compareobw;
|
diff = obw - compareobw;
|
||||||
if (diff == 0) {
|
if (diff == 0) {
|
||||||
strcpy(buf2, " (=)");
|
strcpy(buf2, " (=)");
|
||||||
|
|
16
lf.c
16
lf.c
|
@ -1257,7 +1257,7 @@ int canpickup(lifeform_t *lf, object_t *o, int amt) {
|
||||||
|
|
||||||
// too heavy to lift?
|
// too heavy to lift?
|
||||||
//max = getlfweight(lf, B_NOOBS) * 2; // twice your body weight
|
//max = getlfweight(lf, B_NOOBS) * 2; // twice your body weight
|
||||||
if (getobunitweight(o) + getobpileweight(lf->pack) > (getmaxcarryweight(lf)*2)) {
|
if (getobweight(o) + getobpileweight(lf->pack) > (getmaxcarryweight(lf)*2)) {
|
||||||
reason = E_TOOHEAVY;
|
reason = E_TOOHEAVY;
|
||||||
return B_FALSE;
|
return B_FALSE;
|
||||||
}
|
}
|
||||||
|
@ -1298,7 +1298,7 @@ int canpush(lifeform_t *lf, object_t *o, int dir) {
|
||||||
|
|
||||||
// check object weight vs. lf weight
|
// check object weight vs. lf weight
|
||||||
// adjust object weight for cell sliperriness.
|
// adjust object weight for cell sliperriness.
|
||||||
adjweight = getobweight(o);
|
adjweight = getobmass(o);
|
||||||
if (o->pile->where) {
|
if (o->pile->where) {
|
||||||
adjweight -= getslipperyness(o->pile->where, NULL);
|
adjweight -= getslipperyness(o->pile->where, NULL);
|
||||||
limitf(&adjweight, 0, NA);
|
limitf(&adjweight, 0, NA);
|
||||||
|
@ -5112,7 +5112,7 @@ int eat(lifeform_t *lf, object_t *o) {
|
||||||
// isn't normally edible (ie. a goat eating wood).
|
// isn't normally edible (ie. a goat eating wood).
|
||||||
if (lfhasflagval(lf, F_CANEATMATERIAL, o->material->id, NA, NA, NULL)) {
|
if (lfhasflagval(lf, F_CANEATMATERIAL, o->material->id, NA, NA, NULL)) {
|
||||||
// nutrition based on object weight
|
// nutrition based on object weight
|
||||||
nutrition = getobweight(o)*5;
|
nutrition = getobmass(o)*5;
|
||||||
} else {
|
} else {
|
||||||
if (isplayer(lf)) {
|
if (isplayer(lf)) {
|
||||||
msg("That doesn't seem very nutritious...");
|
msg("That doesn't seem very nutritious...");
|
||||||
|
@ -5188,7 +5188,7 @@ int eat(lifeform_t *lf, object_t *o) {
|
||||||
turnstoeat = 1;
|
turnstoeat = 1;
|
||||||
} else {
|
} else {
|
||||||
// time to eat entire food:
|
// time to eat entire food:
|
||||||
turnstoeat = getobunitweight(o) / (getlfweight(lf, B_NOOBS) / 10);
|
turnstoeat = getobweight(o) / (getlfweight(lf, B_NOOBS) / 10);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (startpcteaten > 0) {
|
if (startpcteaten > 0) {
|
||||||
|
@ -7830,7 +7830,7 @@ int getarmournoise(lifeform_t *lf) {
|
||||||
for (o = lf->pack->first ; o ; o = o->next) {
|
for (o = lf->pack->first ; o ; o = o->next) {
|
||||||
if (isarmour(o) && isequipped(o)) {
|
if (isarmour(o) && isequipped(o)) {
|
||||||
// heavy metal armour makes noise
|
// heavy metal armour makes noise
|
||||||
if (ismetal(o->material->id) && (getobweight(o) >= 4)) {
|
if (ismetal(o->material->id) && (getobmass(o) >= 4)) {
|
||||||
volmod++;
|
volmod++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -8300,7 +8300,7 @@ float getequippedweight(lifeform_t *lf) {
|
||||||
float total = 0;
|
float total = 0;
|
||||||
for (o = lf->pack->first ; o ; o = o->next) {
|
for (o = lf->pack->first ; o ; o = o->next) {
|
||||||
if (isequipped(o) && isarmour(o)) {
|
if (isequipped(o) && isarmour(o)) {
|
||||||
total += getobweight(o);
|
total += getobmass(o);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return total;
|
return total;
|
||||||
|
@ -25062,7 +25062,7 @@ int steal(lifeform_t *lf, obpile_t *op, enum FLAG wantflag) {
|
||||||
initprompt(&prompt, buf);
|
initprompt(&prompt, buf);
|
||||||
for (o = op->first ; o ; o = o->next) {
|
for (o = op->first ; o ; o = o->next) {
|
||||||
int ok = B_TRUE;
|
int ok = B_TRUE;
|
||||||
if ((slev < PR_SKILLED) && (getobunitweight(o) >= 3)) {
|
if ((slev < PR_SKILLED) && (getobweight(o) >= 3)) {
|
||||||
// too heavy to steal
|
// too heavy to steal
|
||||||
ok = B_FALSE;
|
ok = B_FALSE;
|
||||||
} else if ((slev < PR_MASTER) && isequipped(o)) {
|
} else if ((slev < PR_MASTER) && isequipped(o)) {
|
||||||
|
@ -28313,7 +28313,7 @@ int willbleedfrom(lifeform_t *lf, enum BODYPART bp) {
|
||||||
// if lf picks up 'o', will they be burdened afterwards?
|
// if lf picks up 'o', will they be burdened afterwards?
|
||||||
// (if they are _already_ burdened, then stil return true)
|
// (if they are _already_ burdened, then stil return true)
|
||||||
int willburden(lifeform_t *lf, object_t *o, int howmany) {
|
int willburden(lifeform_t *lf, object_t *o, int howmany) {
|
||||||
if (getobpileweight(lf->pack) + (getobunitweight(o)*howmany) > getmaxcarryweight(lf) ) {
|
if (getobpileweight(lf->pack) + (getobweight(o)*howmany) > getmaxcarryweight(lf) ) {
|
||||||
return B_TRUE;
|
return B_TRUE;
|
||||||
}
|
}
|
||||||
return B_FALSE;
|
return B_FALSE;
|
||||||
|
|
28
objects.c
28
objects.c
|
@ -3076,7 +3076,7 @@ void applyobmod(object_t *o, obmod_t *om) {
|
||||||
if (!hasflag(o->flags, F_OBHP)) {
|
if (!hasflag(o->flags, F_OBHP)) {
|
||||||
int myhp;
|
int myhp;
|
||||||
// give hp
|
// give hp
|
||||||
myhp = getobweight(o) * 20;
|
myhp = getobmass(o) * 20;
|
||||||
if (myhp <= 0) myhp = 2;
|
if (myhp <= 0) myhp = 2;
|
||||||
|
|
||||||
addtempflag(o->flags, F_OBHP, myhp, myhp, NA, NULL, FROMOBMOD);
|
addtempflag(o->flags, F_OBHP, myhp, myhp, NA, NULL, FROMOBMOD);
|
||||||
|
@ -4675,7 +4675,7 @@ int getbreakob(object_t *o, char *bigobname, char *smallobname) {
|
||||||
small = findot(smalloid);
|
small = findot(smalloid);
|
||||||
|
|
||||||
// now find out how many big obejcts make up the wight.
|
// now find out how many big obejcts make up the wight.
|
||||||
weight = getobweight(o) / 2;
|
weight = getobmass(o) / 2;
|
||||||
if (big) {
|
if (big) {
|
||||||
nbig = weight / big->weight;
|
nbig = weight / big->weight;
|
||||||
weight -= (nbig*big->weight);
|
weight -= (nbig*big->weight);
|
||||||
|
@ -4944,7 +4944,7 @@ int real_getobvalue(object_t *o, int amt) {
|
||||||
price = f->val[0];
|
price = f->val[0];
|
||||||
} else {
|
} else {
|
||||||
// base value: weight * material value
|
// base value: weight * material value
|
||||||
price = (float)getobweight(o) * (float)getmaterialvalue(o->material->id);
|
price = (float)getobmass(o) * (float)getmaterialvalue(o->material->id);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (o->type->id == OT_SPELLBOOK) {
|
if (o->type->id == OT_SPELLBOOK) {
|
||||||
|
@ -5704,7 +5704,7 @@ int getmaxthrowrange(lifeform_t *lf, object_t *o) {
|
||||||
str -= 2;
|
str -= 2;
|
||||||
limitf(&str, 1, NA); // ie. 1 to 16
|
limitf(&str, 1, NA); // ie. 1 to 16
|
||||||
|
|
||||||
obweight = getobunitweight(o);
|
obweight = getobweight(o);
|
||||||
|
|
||||||
maxdist = ceil(str - obweight);
|
maxdist = ceil(str - obweight);
|
||||||
|
|
||||||
|
@ -5742,7 +5742,7 @@ char getnextletter(obpile_t *op, char *wantletter) {
|
||||||
|
|
||||||
int getnumshards(object_t *o) {
|
int getnumshards(object_t *o) {
|
||||||
int numshards,maxshards;
|
int numshards,maxshards;
|
||||||
maxshards = ceil(getobunitweight(o)) * 10;
|
maxshards = ceil(getobweight(o)) * 10;
|
||||||
if (maxshards < 1) maxshards = 1;
|
if (maxshards < 1) maxshards = 1;
|
||||||
numshards = rnd(1,maxshards);
|
numshards = rnd(1,maxshards);
|
||||||
numshards *= o->amt;
|
numshards *= o->amt;
|
||||||
|
@ -5754,7 +5754,7 @@ int getnutritionbase(object_t *o) {
|
||||||
flag_t *f;
|
flag_t *f;
|
||||||
if (o->material->id == MT_ICE) {
|
if (o->material->id == MT_ICE) {
|
||||||
// use the object's weight
|
// use the object's weight
|
||||||
basenutr = getobweight(o) * 10;
|
basenutr = getobmass(o) * 10;
|
||||||
} else {
|
} else {
|
||||||
// use nutrition flag
|
// use nutrition flag
|
||||||
f = hasflag(o->flags, F_EDIBLE);
|
f = hasflag(o->flags, F_EDIBLE);
|
||||||
|
@ -6900,7 +6900,7 @@ float getobpileweight(obpile_t *op) {
|
||||||
}
|
}
|
||||||
|
|
||||||
for (o = op->first ; o ; o = o->next) {
|
for (o = op->first ; o ; o = o->next) {
|
||||||
weight += getobweight(o);
|
weight += getobmass(o);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (op->owner) {
|
if (op->owner) {
|
||||||
|
@ -7022,10 +7022,10 @@ char *getobhurtname(object_t *o, enum DAMTYPE damtype) {
|
||||||
return "is damaged";
|
return "is damaged";
|
||||||
}
|
}
|
||||||
|
|
||||||
float getobweight(object_t *o) {
|
float getobmass(object_t *o) {
|
||||||
float weight;
|
float weight;
|
||||||
|
|
||||||
weight = getobunitweight(o) * o->amt;
|
weight = getobweight(o) * o->amt;
|
||||||
|
|
||||||
// object contents
|
// object contents
|
||||||
if (hasflag(o->flags, F_CONTAINER) && !hasflag(o->flags, F_HOLDING)) {
|
if (hasflag(o->flags, F_CONTAINER) && !hasflag(o->flags, F_HOLDING)) {
|
||||||
|
@ -7037,7 +7037,7 @@ float getobweight(object_t *o) {
|
||||||
return weight;
|
return weight;
|
||||||
}
|
}
|
||||||
|
|
||||||
float getobunitweight(object_t *o) {
|
float getobweight(object_t *o) {
|
||||||
float weight;
|
float weight;
|
||||||
flag_t *f;
|
flag_t *f;
|
||||||
|
|
||||||
|
@ -7586,7 +7586,7 @@ int getshatterdam(object_t *o) {
|
||||||
int shatterdam = 0;
|
int shatterdam = 0;
|
||||||
if (willshatter(o->material->id)) {
|
if (willshatter(o->material->id)) {
|
||||||
int maxshatterdam;
|
int maxshatterdam;
|
||||||
maxshatterdam = ceil(getobweight(o));
|
maxshatterdam = ceil(getobmass(o));
|
||||||
if (maxshatterdam < 1) maxshatterdam = 1;
|
if (maxshatterdam < 1) maxshatterdam = 1;
|
||||||
|
|
||||||
shatterdam = rnd(1, maxshatterdam);
|
shatterdam = rnd(1, maxshatterdam);
|
||||||
|
@ -7638,7 +7638,7 @@ int getthrowdam(object_t *o) {
|
||||||
// ie. 5 kg object does 1 damage
|
// ie. 5 kg object does 1 damage
|
||||||
// ie. 100 kg object does 20 damage (person)
|
// ie. 100 kg object does 20 damage (person)
|
||||||
// ie. 1 tonne object does 200 damage (car)
|
// ie. 1 tonne object does 200 damage (car)
|
||||||
dam = ceil((double)getobunitweight(o)) / 2;
|
dam = ceil((double)getobweight(o)) / 2;
|
||||||
// non-missile objects do 25% less damage
|
// non-missile objects do 25% less damage
|
||||||
if (!hasflag(o->flags, F_THROWMISSILE)) {
|
if (!hasflag(o->flags, F_THROWMISSILE)) {
|
||||||
dam = pctof(75, dam);
|
dam = pctof(75, dam);
|
||||||
|
@ -8323,7 +8323,7 @@ int isknownot(objecttype_t *ot) {
|
||||||
|
|
||||||
|
|
||||||
int isheavyweapon(object_t *o) {
|
int isheavyweapon(object_t *o) {
|
||||||
if (getobunitweight(o) >= HEAVYWEPKG) {
|
if (getobweight(o) >= HEAVYWEPKG) {
|
||||||
return B_TRUE;
|
return B_TRUE;
|
||||||
}
|
}
|
||||||
return B_FALSE;
|
return B_FALSE;
|
||||||
|
@ -16107,7 +16107,7 @@ int real_fireat(lifeform_t *thrower, object_t *o, int amt, cell_t *where, int sp
|
||||||
|
|
||||||
// heavy ob?
|
// heavy ob?
|
||||||
if (youhit && target) {
|
if (youhit && target) {
|
||||||
if ((getobunitweight(o)*amt) >= getlfweight(target, B_NOOBS)) {
|
if ((getobweight(o)*amt) >= getlfweight(target, B_NOOBS)) {
|
||||||
int dir;
|
int dir;
|
||||||
dir = getdirtowards(srcloc, target->cell, target, B_FALSE, DT_COMPASS);
|
dir = getdirtowards(srcloc, target->cell, target, B_FALSE, DT_COMPASS);
|
||||||
knockback(target, dir, 1, thrower, 0, B_DOANNOUNCE, B_DODAM);
|
knockback(target, dir, 1, thrower, 0, B_DOANNOUNCE, B_DODAM);
|
||||||
|
|
|
@ -156,8 +156,8 @@ char *real_getobname(object_t *o, char *buf, int count, int wantpremods, int wan
|
||||||
float getobpileweight(obpile_t *op);
|
float getobpileweight(obpile_t *op);
|
||||||
char *getobconditionname(object_t *o, char *buf);
|
char *getobconditionname(object_t *o, char *buf);
|
||||||
char *getobhurtname(object_t *o, enum DAMTYPE damtype);
|
char *getobhurtname(object_t *o, enum DAMTYPE damtype);
|
||||||
|
float getobmass(object_t *o);
|
||||||
float getobweight(object_t *o);
|
float getobweight(object_t *o);
|
||||||
float getobunitweight(object_t *o);
|
|
||||||
objecttype_t *getoppositestairs(objecttype_t *ot);
|
objecttype_t *getoppositestairs(objecttype_t *ot);
|
||||||
//objecttype_t *real_getrandomob(map_t *map, char *buf, int forcedepth, int forcehabitat, enum LFSIZE maxsize, enum SKILL wepsk, enum RARITY forcerr, int forpickup, ... );
|
//objecttype_t *real_getrandomob(map_t *map, char *buf, int forcedepth, int forcehabitat, enum LFSIZE maxsize, enum SKILL wepsk, enum RARITY forcerr, int forpickup, ... );
|
||||||
objecttype_t *real_getrandomob(cell_t *cell, char *buf, int forcedepth, int forcehabitat, enum RARITY forcerr, int forpickup, condset_t *cs);
|
objecttype_t *real_getrandomob(cell_t *cell, char *buf, int forcedepth, int forcehabitat, enum RARITY forcerr, int forpickup, condset_t *cs);
|
||||||
|
|
40
spell.c
40
spell.c
|
@ -4235,15 +4235,15 @@ int dospelleffects(lifeform_t *caster, enum OBTYPE spellid, int power, lifeform_
|
||||||
c = getcellindir(caster->cell, d);
|
c = getcellindir(caster->cell, d);
|
||||||
if (c) {
|
if (c) {
|
||||||
for (o = c->obpile->first ; o ; o = o->next){
|
for (o = c->obpile->first ; o ; o = o->next){
|
||||||
if (o->type->obclass->id == OC_FLORA) totweight += getobweight(o);
|
if (o->type->obclass->id == OC_FLORA) totweight += getobmass(o);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for (o = caster->cell->obpile->first ; o ; o = o->next){
|
for (o = caster->cell->obpile->first ; o ; o = o->next){
|
||||||
if (o->type->obclass->id == OC_FLORA) totweight += getobweight(o);
|
if (o->type->obclass->id == OC_FLORA) totweight += getobmass(o);
|
||||||
}
|
}
|
||||||
for (o = caster->pack->first ; o ; o = o->next){
|
for (o = caster->pack->first ; o ; o = o->next){
|
||||||
if (o->type->obclass->id == OC_FLORA) totweight += getobweight(o);
|
if (o->type->obclass->id == OC_FLORA) totweight += getobmass(o);
|
||||||
}
|
}
|
||||||
powerinc = totweight / 50;
|
powerinc = totweight / 50;
|
||||||
if (powerinc > 0) {
|
if (powerinc > 0) {
|
||||||
|
@ -4338,7 +4338,7 @@ int dospelleffects(lifeform_t *caster, enum OBTYPE spellid, int power, lifeform_
|
||||||
if (isequipped(o) && ismetal(o->material->id)) {
|
if (isequipped(o) && ismetal(o->material->id)) {
|
||||||
takedamage(o, 9999, DT_DIRECT, caster);
|
takedamage(o, 9999, DT_DIRECT, caster);
|
||||||
if (hasflag(o->flags, F_DEAD)) {
|
if (hasflag(o->flags, F_DEAD)) {
|
||||||
totalmass += getobweight(o);
|
totalmass += getobmass(o);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -4352,7 +4352,7 @@ int dospelleffects(lifeform_t *caster, enum OBTYPE spellid, int power, lifeform_
|
||||||
if (ismetal(o->material->id)) {
|
if (ismetal(o->material->id)) {
|
||||||
takedamage(o, 9999, DT_DIRECT, caster);
|
takedamage(o, 9999, DT_DIRECT, caster);
|
||||||
if (hasflag(o->flags, F_DEAD)) {
|
if (hasflag(o->flags, F_DEAD)) {
|
||||||
totalmass += getobweight(o);
|
totalmass += getobmass(o);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -4366,7 +4366,7 @@ int dospelleffects(lifeform_t *caster, enum OBTYPE spellid, int power, lifeform_
|
||||||
if (isequipped(o) && ismetal(o->material->id)) {
|
if (isequipped(o) && ismetal(o->material->id)) {
|
||||||
takedamage(o, 9999, DT_DIRECT, caster);
|
takedamage(o, 9999, DT_DIRECT, caster);
|
||||||
if (hasflag(o->flags, F_DEAD)) {
|
if (hasflag(o->flags, F_DEAD)) {
|
||||||
totalmass += getobweight(o);
|
totalmass += getobmass(o);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -4422,7 +4422,7 @@ int dospelleffects(lifeform_t *caster, enum OBTYPE spellid, int power, lifeform_
|
||||||
if (o->material->id == MT_WOOD) {
|
if (o->material->id == MT_WOOD) {
|
||||||
takedamage(o, 9999, DT_DIRECT, caster);
|
takedamage(o, 9999, DT_DIRECT, caster);
|
||||||
if (hasflag(o->flags, F_DEAD)) {
|
if (hasflag(o->flags, F_DEAD)) {
|
||||||
totalmass += getobweight(o);
|
totalmass += getobmass(o);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -4438,7 +4438,7 @@ int dospelleffects(lifeform_t *caster, enum OBTYPE spellid, int power, lifeform_
|
||||||
if (isequipped(o) && (o->material->id == MT_WOOD)) {
|
if (isequipped(o) && (o->material->id == MT_WOOD)) {
|
||||||
takedamage(o, 9999, DT_DIRECT, caster);
|
takedamage(o, 9999, DT_DIRECT, caster);
|
||||||
if (hasflag(o->flags, F_DEAD)) {
|
if (hasflag(o->flags, F_DEAD)) {
|
||||||
totalmass += getobweight(o);
|
totalmass += getobmass(o);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -4555,7 +4555,7 @@ int dospelleffects(lifeform_t *caster, enum OBTYPE spellid, int power, lifeform_
|
||||||
op = targob->pile;
|
op = targob->pile;
|
||||||
obamt = targob->amt;
|
obamt = targob->amt;
|
||||||
getobname(targob, obname, targob->amt);
|
getobname(targob, obname, targob->amt);
|
||||||
obweight = getobweight(targob);
|
obweight = getobmass(targob);
|
||||||
// get conversion rate
|
// get conversion rate
|
||||||
powerpct = ((double)power / getspellmaxpower(spellid)) ;
|
powerpct = ((double)power / getspellmaxpower(spellid)) ;
|
||||||
convrate = (powerpct * (4.0 - 0.5)) + 0.5;
|
convrate = (powerpct * (4.0 - 0.5)) + 0.5;
|
||||||
|
@ -4834,7 +4834,7 @@ int dospelleffects(lifeform_t *caster, enum OBTYPE spellid, int power, lifeform_
|
||||||
// modify by power
|
// modify by power
|
||||||
maxweight = 10;
|
maxweight = 10;
|
||||||
|
|
||||||
if (getobweight(targob) > maxweight) {
|
if (getobmass(targob) > maxweight) {
|
||||||
if (haslos(player, obloc)) {
|
if (haslos(player, obloc)) {
|
||||||
msg("%s fades out of view slightly, then reappears.",obname);
|
msg("%s fades out of view slightly, then reappears.",obname);
|
||||||
if (seenbyplayer) *seenbyplayer = B_TRUE;
|
if (seenbyplayer) *seenbyplayer = B_TRUE;
|
||||||
|
@ -5401,7 +5401,7 @@ int dospelleffects(lifeform_t *caster, enum OBTYPE spellid, int power, lifeform_
|
||||||
// modify by power
|
// modify by power
|
||||||
maxweight += (10*power);
|
maxweight += (10*power);
|
||||||
|
|
||||||
if (getobweight(targob) > maxweight) {
|
if (getobmass(targob) > maxweight) {
|
||||||
cell_t *obloc;
|
cell_t *obloc;
|
||||||
char obname[BUFLEN];
|
char obname[BUFLEN];
|
||||||
obloc = getoblocation(targob);
|
obloc = getoblocation(targob);
|
||||||
|
@ -6856,7 +6856,7 @@ int dospelleffects(lifeform_t *caster, enum OBTYPE spellid, int power, lifeform_
|
||||||
nexto = o->next;
|
nexto = o->next;
|
||||||
if (getmaterialstate(o->material->id) == MS_LIQUID) {
|
if (getmaterialstate(o->material->id) == MS_LIQUID) {
|
||||||
// if 20kilos or more, make steam
|
// if 20kilos or more, make steam
|
||||||
if (getobweight(o) >= 25) {
|
if (getobmass(o) >= 25) {
|
||||||
dosteam = B_TRUE;
|
dosteam = B_TRUE;
|
||||||
if (cellseen) nsteamseen++;
|
if (cellseen) nsteamseen++;
|
||||||
}
|
}
|
||||||
|
@ -6969,7 +6969,7 @@ int dospelleffects(lifeform_t *caster, enum OBTYPE spellid, int power, lifeform_
|
||||||
nexto = o->next;
|
nexto = o->next;
|
||||||
// destroy metal items on the ground
|
// destroy metal items on the ground
|
||||||
if (ismetal(o->material->id)) {
|
if (ismetal(o->material->id)) {
|
||||||
totalmass += getobweight(o);
|
totalmass += getobmass(o);
|
||||||
removeob(o, o->amt);
|
removeob(o, o->amt);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -8867,7 +8867,7 @@ int dospelleffects(lifeform_t *caster, enum OBTYPE spellid, int power, lifeform_
|
||||||
if (isequipped(o) && ismetal(o->material->id)) {
|
if (isequipped(o) && ismetal(o->material->id)) {
|
||||||
takedamage(o, 9999, DT_DIRECT, caster);
|
takedamage(o, 9999, DT_DIRECT, caster);
|
||||||
if (hasflag(o->flags, F_DEAD)) {
|
if (hasflag(o->flags, F_DEAD)) {
|
||||||
totalmass += getobweight(o);
|
totalmass += getobmass(o);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -8881,7 +8881,7 @@ int dospelleffects(lifeform_t *caster, enum OBTYPE spellid, int power, lifeform_
|
||||||
if (ismetal(o->material->id)) {
|
if (ismetal(o->material->id)) {
|
||||||
takedamage(o, 9999, DT_DIRECT, caster);
|
takedamage(o, 9999, DT_DIRECT, caster);
|
||||||
if (hasflag(o->flags, F_DEAD)) {
|
if (hasflag(o->flags, F_DEAD)) {
|
||||||
totalmass += getobweight(o);
|
totalmass += getobmass(o);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -8893,7 +8893,7 @@ int dospelleffects(lifeform_t *caster, enum OBTYPE spellid, int power, lifeform_
|
||||||
if (isequipped(o) && ismetal(o->material->id)) {
|
if (isequipped(o) && ismetal(o->material->id)) {
|
||||||
takedamage(o, 9999, DT_DIRECT, caster);
|
takedamage(o, 9999, DT_DIRECT, caster);
|
||||||
if (hasflag(o->flags, F_DEAD)) {
|
if (hasflag(o->flags, F_DEAD)) {
|
||||||
totalmass += getobweight(o);
|
totalmass += getobmass(o);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -10072,7 +10072,7 @@ int dospelleffects(lifeform_t *caster, enum OBTYPE spellid, int power, lifeform_
|
||||||
if (ismetal(o->material->id) && isequipped(o)) {
|
if (ismetal(o->material->id) && isequipped(o)) {
|
||||||
if (!isequippedon(o, BP_WEAPON) && !isequippedon(o, BP_SECWEAPON)) {
|
if (!isequippedon(o, BP_WEAPON) && !isequippedon(o, BP_SECWEAPON)) {
|
||||||
gotmetal = B_TRUE;
|
gotmetal = B_TRUE;
|
||||||
metalweight += getobweight(o);
|
metalweight += getobmass(o);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -10122,7 +10122,7 @@ int dospelleffects(lifeform_t *caster, enum OBTYPE spellid, int power, lifeform_
|
||||||
} else if (cansee(player, caster)) {
|
} else if (cansee(player, caster)) {
|
||||||
if (seenbyplayer) *seenbyplayer = B_TRUE;
|
if (seenbyplayer) *seenbyplayer = B_TRUE;
|
||||||
}
|
}
|
||||||
if (getobpileweight(caster->pack) + getobweight(targob) <= getmaxcarryweight(caster)) {
|
if (getobpileweight(caster->pack) + getobmass(targob) <= getmaxcarryweight(caster)) {
|
||||||
// move it to the player
|
// move it to the player
|
||||||
pullobto(targob, caster);
|
pullobto(targob, caster);
|
||||||
} else {
|
} else {
|
||||||
|
@ -10784,7 +10784,7 @@ int dospelleffects(lifeform_t *caster, enum OBTYPE spellid, int power, lifeform_
|
||||||
for (o = op->first ; o ; o = nexto) {
|
for (o = op->first ; o ; o = nexto) {
|
||||||
nexto = o->next;
|
nexto = o->next;
|
||||||
if (!hasflag(o->flags, F_NOSTEAL) && !hasflag(o->flags, F_NOPICKUP) && !hasflag(o->flags, F_COSMETIC)) {
|
if (!hasflag(o->flags, F_NOSTEAL) && !hasflag(o->flags, F_NOPICKUP) && !hasflag(o->flags, F_COSMETIC)) {
|
||||||
if ((getobunitweight(o) <= 5) ||
|
if ((getobweight(o) <= 5) ||
|
||||||
((isweapon(o)) && (isequipped(o))) ) {
|
((isweapon(o)) && (isequipped(o))) ) {
|
||||||
poss[nposs++] = o;
|
poss[nposs++] = o;
|
||||||
}
|
}
|
||||||
|
@ -13197,7 +13197,7 @@ int dospelleffects(lifeform_t *caster, enum OBTYPE spellid, int power, lifeform_
|
||||||
// modify by power
|
// modify by power
|
||||||
maxweight += (10*power);
|
maxweight += (10*power);
|
||||||
|
|
||||||
if (getobweight(targob) > maxweight) {
|
if (getobmass(targob) > maxweight) {
|
||||||
cell_t *obloc;
|
cell_t *obloc;
|
||||||
char obname[BUFLEN];
|
char obname[BUFLEN];
|
||||||
obloc = getoblocation(targob);
|
obloc = getoblocation(targob);
|
||||||
|
|
Loading…
Reference in New Issue