getting rid of the olditemtypes[] array

reduce use of statics
reduce use of item_t enum
This commit is contained in:
Enno Rehling 2014-06-23 07:28:10 -07:00
parent 740b646e54
commit 73da14e305
25 changed files with 233 additions and 273 deletions

View file

@ -1297,6 +1297,7 @@ static void allocate_resource(unit * u, const resource_type * rtype, int want)
allocation *al; allocation *al;
attrib *a = a_find(rtype->attribs, &at_resourcelimit); attrib *a = a_find(rtype->attribs, &at_resourcelimit);
resource_limit *rdata = (resource_limit *) a->data.v; resource_limit *rdata = (resource_limit *) a->data.v;
const resource_type *rring;
int amount, skill; int amount, skill;
/* momentan kann man keine ressourcen abbauen, wenn man dafür /* momentan kann man keine ressourcen abbauen, wenn man dafür
@ -1347,7 +1348,7 @@ static void allocate_resource(unit * u, const resource_type * rtype, int want)
* Als magische Wesen 'sehen' Bergwächter alles und werden durch * Als magische Wesen 'sehen' Bergwächter alles und werden durch
* Belagerung nicht aufgehalten. (Ansonsten wie oben bei Elfen anpassen). * Belagerung nicht aufgehalten. (Ansonsten wie oben bei Elfen anpassen).
*/ */
if (itype == olditemtype[I_IRON] || itype == olditemtype[I_LAEN]) { if (itype->rtype && (itype->rtype==get_resourcetype(R_IRON) || itype->rtype==rt_find("laen"))) {
unit *u2; unit *u2;
for (u2 = r->units; u2; u2 = u2->next) { for (u2 = r->units; u2; u2 = u2->next) {
if (is_guard(u, GUARD_MINING) if (is_guard(u, GUARD_MINING)
@ -1397,9 +1398,11 @@ static void allocate_resource(unit * u, const resource_type * rtype, int want)
/* nun ist amount die Gesamtproduktion der Einheit (in punkten) */ /* nun ist amount die Gesamtproduktion der Einheit (in punkten) */
/* mit Flinkfingerring verzehnfacht sich die Produktion */ /* mit Flinkfingerring verzehnfacht sich die Produktion */
amount += rring = get_resourcetype(R_RING_OF_NIMBLEFINGER);
skill * _min(u->number, get_item(u, if (rring) {
I_RING_OF_NIMBLEFINGER)) * (roqf_factor() - 1); int dm = i_get(u->items, rring->itype);
amount += skill * _min(u->number, dm) * (roqf_factor() - 1);
}
/* Schaffenstrunk: */ /* Schaffenstrunk: */
if ((dm = get_effect(u, oldpotiontype[P_DOMORE])) != 0) { if ((dm = get_effect(u, oldpotiontype[P_DOMORE])) != 0) {
@ -2601,32 +2604,32 @@ static void breedtrees(region * r, unit * u, int raw)
/* züchte pferde */ /* züchte pferde */
static void breedhorses(region * r, unit * u) static void breedhorses(region * r, unit * u)
{ {
int n, c; int n, c, breed = 0;
int gezuechtet = 0;
struct building *b = inside_building(u); struct building *b = inside_building(u);
const struct building_type *btype = b ? b->type : NULL; const struct building_type *btype = b ? b->type : NULL;
const struct item_type *ihorse = it_find("horse");
assert(ihorse);
if (btype != bt_find("stables")) { if (btype != bt_find("stables")) {
cmistake(u, u->thisorder, 122, MSG_PRODUCE); cmistake(u, u->thisorder, 122, MSG_PRODUCE);
return; return;
} }
if (get_item(u, I_HORSE) < 2) { if (i_get(u->items, ihorse) < 2) {
cmistake(u, u->thisorder, 107, MSG_PRODUCE); cmistake(u, u->thisorder, 107, MSG_PRODUCE);
return; return;
} }
n = _min(u->number * eff_skill(u, SK_HORSE_TRAINING, r), get_item(u, I_HORSE)); n = _min(u->number * eff_skill(u, SK_HORSE_TRAINING, r), i_get(u->items, ihorse));
for (c = 0; c < n; c++) { for (c = 0; c < n; c++) {
if (rng_int() % 100 < eff_skill(u, SK_HORSE_TRAINING, r)) { if (rng_int() % 100 < eff_skill(u, SK_HORSE_TRAINING, r)) {
i_change(&u->items, olditemtype[I_HORSE], 1); i_change(&u->items, ihorse, 1);
gezuechtet++; ++breed;
} }
} }
produceexp(u, SK_HORSE_TRAINING, u->number); produceexp(u, SK_HORSE_TRAINING, u->number);
ADDMSG(&u->faction->msgs, msg_message("raised", ADDMSG(&u->faction->msgs, msg_message("raised", "unit amount", u, breed));
"unit amount", u, gezuechtet));
} }
static void breed_cmd(unit * u, struct order *ord) static void breed_cmd(unit * u, struct order *ord)
@ -2753,6 +2756,7 @@ static int max_skill(region * r, faction * f, skill_t sk)
static void steal_cmd(unit * u, struct order *ord, request ** stealorders) static void steal_cmd(unit * u, struct order *ord, request ** stealorders)
{ {
const resource_type *rring = get_resourcetype(R_RING_OF_NIMBLEFINGER);
int n, i, id; int n, i, id;
bool goblin = false; bool goblin = false;
request *o; request *o;
@ -2842,7 +2846,7 @@ static void steal_cmd(unit * u, struct order *ord, request ** stealorders)
} }
} }
i = _min(u->number, get_item(u, I_RING_OF_NIMBLEFINGER)); i = _min(u->number, i_get(u->items, rring->itype));
if (i > 0) { if (i > 0) {
n *= STEALINCOME * (u->number + i * (roqf_factor() - 1)); n *= STEALINCOME * (u->number + i * (roqf_factor() - 1));
} else { } else {

View file

@ -839,15 +839,17 @@ static const armor_type *select_armor(troop t, bool shield)
* - Artefakt I_TROLLBELT gibt Rüstung +1 * - Artefakt I_TROLLBELT gibt Rüstung +1
* - Zauber Rindenhaut gibt Rüstung +3 * - Zauber Rindenhaut gibt Rüstung +3
*/ */
static int trollbelts(const unit *u) {
const struct item_type *belt = it_find("trollbelt");
return belt ? i_get(u->items, belt) : 0;
}
int select_magicarmor(troop t) int select_magicarmor(troop t)
{ {
unit *u = t.fighter->unit; unit *u = t.fighter->unit;
int geschuetzt = 0;
int ma = 0; int ma = 0;
geschuetzt = _min(get_item(u, I_TROLLBELT), u->number); if (trollbelts(u) > t.index) /* unser Kandidat wird geschuetzt */
if (geschuetzt > t.index) /* unser Kandidat wird geschuetzt */
ma += 1; ma += 1;
return ma; return ma;
@ -3252,7 +3254,7 @@ fighter *make_fighter(battle * b, unit * u, side * s1, bool attack)
/* change_effect wird in ageing gemacht */ /* change_effect wird in ageing gemacht */
/* Effekte von Artefakten */ /* Effekte von Artefakten */
strongmen = _min(fig->unit->number, get_item(u, I_TROLLBELT)); strongmen = _min(fig->unit->number, trollbelts(u));
/* Hitpoints, Attack- und Defence-Boni für alle Personen */ /* Hitpoints, Attack- und Defence-Boni für alle Personen */
for (i = 0; i < fig->alive; i++) { for (i = 0; i < fig->alive; i++) {
@ -3371,15 +3373,15 @@ fighter *make_fighter(battle * b, unit * u, side * s1, bool attack)
fig->horses = fig->unit->number; fig->horses = fig->unit->number;
fig->elvenhorses = 0; fig->elvenhorses = 0;
} else { } else {
static const item_type *it_charger = 0; const item_type *it_horse = 0;
if (it_charger == 0) { const item_type *it_elvenhorse = 0;
it_charger = it_find("charger"); it_elvenhorse = it_find("elvenhorse");
if (!it_charger) { it_horse = it_find("charger");
it_charger = it_find("horse"); if (!it_horse) {
it_horse = it_find("horse");
} }
} fig->horses = i_get(u->items, it_horse);
fig->horses = i_get(u->items, it_charger); fig->elvenhorses = i_get(u->items, it_elvenhorse);
fig->elvenhorses = get_item(u, I_ELVENHORSE);
} }
if (u_race(u)->battle_flags & BF_EQUIPMENT) { if (u_race(u)->battle_flags & BF_EQUIPMENT) {

View file

@ -31,7 +31,7 @@ static void test_make_fighter(CuTest * tc)
set_level(au, SK_MAGIC, 3); set_level(au, SK_MAGIC, 3);
set_level(au, SK_RIDING, 3); set_level(au, SK_RIDING, 3);
au->status = ST_BEHIND; au->status = ST_BEHIND;
set_item(au, I_HORSE, 1); i_change(&au->items, it_find("horse"), 1);
b = make_battle(r); b = make_battle(r);
as = make_side(b, au->faction, 0, 0, 0); as = make_side(b, au->faction, 0, 0, 0);

View file

@ -326,7 +326,8 @@ void build_road(region * r, unit * u, int size, direction_t d)
/* n = maximum by skill. try to maximize it */ /* n = maximum by skill. try to maximize it */
n = u->number * eff_skill(u, SK_ROAD_BUILDING, r); n = u->number * eff_skill(u, SK_ROAD_BUILDING, r);
if (n < left) { if (n < left) {
item *itm = *i_find(&u->items, olditemtype[I_RING_OF_NIMBLEFINGER]); const resource_type *ring = get_resourcetype(R_RING_OF_NIMBLEFINGER);
item *itm = ring ? *i_find(&u->items, ring->itype) : 0;
if (itm != NULL && itm->number > 0) { if (itm != NULL && itm->number > 0) {
int rings = _min(u->number, itm->number); int rings = _min(u->number, itm->number);
n = n * ((roqf_factor() - 1) * rings + u->number) / u->number; n = n * ((roqf_factor() - 1) * rings + u->number) / u->number;
@ -516,10 +517,9 @@ int build(unit * u, const construction * ctype, int completed, int want)
/* Flinkfingerring wirkt nicht auf Mengenbegrenzte (magische) /* Flinkfingerring wirkt nicht auf Mengenbegrenzte (magische)
* Talente */ * Talente */
if (skill_limit(u->faction, type->skill) == INT_MAX) { if (skill_limit(u->faction, type->skill) == INT_MAX) {
int i = 0; const resource_type *ring = get_resourcetype(R_RING_OF_NIMBLEFINGER);
item *itm = *i_find(&u->items, olditemtype[I_RING_OF_NIMBLEFINGER]); item *itm = ring ? *i_find(&u->items, ring->itype) : 0;
if (itm != NULL) int i = itm ? itm->number : 0;
i = itm->number;
if (i > 0) { if (i > 0) {
int rings = _min(u->number, i); int rings = _min(u->number, i);
n = n * ((roqf_factor() - 1) * rings + u->number) / u->number; n = n * ((roqf_factor() - 1) * rings + u->number) / u->number;

View file

@ -2120,7 +2120,7 @@ int weight(const unit * u)
n += u->number * u_race(u)->weight; n += u->number * u_race(u)->weight;
w = get_item(u, I_BAG_OF_HOLDING) * BAGCAPACITY; w = i_get(u->items, it_find("magicbag")) * BAGCAPACITY;
if (w > in_bag) if (w > in_bag)
w = in_bag; w = in_bag;
n -= w; n -= w;

View file

@ -99,6 +99,12 @@ void free_faction(faction * f)
freelist(f->ursprung); freelist(f->ursprung);
} }
void set_show_item(faction * f, const struct item_type *itype)
{
attrib *a = a_add(&f->attribs, a_new(&at_showitem));
a->data.v = (void *)itype;
}
faction *get_monsters(void) faction *get_monsters(void)
{ {
static faction *monsters; static faction *monsters;

View file

@ -54,7 +54,6 @@ extern "C" {
#define FFL_SAVEMASK (FFL_DEFENDER|FFL_NEWID|FFL_GM|FFL_NPC|FFL_NOTIMEOUT|FFL_DBENTRY|FFL_NOIDLEOUT) #define FFL_SAVEMASK (FFL_DEFENDER|FFL_NEWID|FFL_GM|FFL_NPC|FFL_NOTIMEOUT|FFL_DBENTRY|FFL_NOIDLEOUT)
struct faction *get_monsters(void);
#define is_monsters(f) ((f)->flags&FFL_NPC) #define is_monsters(f) ((f)->flags&FFL_NPC)
typedef struct faction { typedef struct faction {
@ -114,16 +113,17 @@ extern "C" {
extern struct faction *factions; extern struct faction *factions;
struct faction *get_monsters(void);
int max_magicians(const faction * f); int max_magicians(const faction * f);
void set_show_item(faction * f, const struct item_type *itype);
extern const struct unit *random_unit_in_faction(const struct faction *f); const struct unit *random_unit_in_faction(const struct faction *f);
extern const char *factionname(const struct faction *f); const char *factionname(const struct faction *f);
extern struct unit *addplayer(struct region *r, faction * f); struct unit *addplayer(struct region *r, faction * f);
extern struct faction *addfaction(const char *email, const char *password, struct faction *addfaction(const char *email, const char *password,
const struct race *frace, const struct locale *loc, int subscription); const struct race *frace, const struct locale *loc, int subscription);
extern bool checkpasswd(const faction * f, const char *passwd, bool checkpasswd(const faction * f, const char *passwd, bool shortp);
bool shortp); void destroyfaction(faction * f);
extern void destroyfaction(faction * f);
extern void set_alliance(struct faction *a, struct faction *b, int status); extern void set_alliance(struct faction *a, struct faction *b, int status);
extern int get_alliance(const struct faction *a, const struct faction *b); extern int get_alliance(const struct faction *a, const struct faction *b);

View file

@ -399,12 +399,12 @@ item **i_find(item ** i, const item_type * it)
return i; return i;
} }
item *const *i_findc(item * const *i, const item_type * it) item *const* i_findc(item *const* iter, const item_type * it)
{ {
while (*i && (*i)->type != it) { while (*iter && (*iter)->type != it) {
i = &(*i)->next; iter = &(*iter)->next;
} }
return i; return iter;
} }
int i_get(const item * i, const item_type * it) int i_get(const item * i, const item_type * it)
@ -597,7 +597,6 @@ give_money(unit * s, unit * d, const item_type * itype, int n,
#define LASTLUXURY (I_INCENSE +1) #define LASTLUXURY (I_INCENSE +1)
#define MAXLUXURIES (LASTLUXURY - FIRSTLUXURY) #define MAXLUXURIES (LASTLUXURY - FIRSTLUXURY)
const item_type *olditemtype[MAXITEMS + 1];
const potion_type *oldpotiontype[MAXPOTIONS + 1]; const potion_type *oldpotiontype[MAXPOTIONS + 1];
/*** alte items ***/ /*** alte items ***/
@ -607,7 +606,7 @@ const char *itemnames[MAX_RESOURCES] = {
"aots", "roi", "rop", "ao_chastity", "aots", "roi", "rop", "ao_chastity",
"laen", "fairyboot", "aoc", "pegasus", "laen", "fairyboot", "aoc", "pegasus",
"elvenhorse", "dolphin", "roqf", "trollbelt", "elvenhorse", "dolphin", "roqf", "trollbelt",
"presspass", "aurafocus", "sphereofinv", "magicbag", "aurafocus", "sphereofinv", "magicbag",
"magicherbbag", "dreameye", "money", "aura", "permaura" "magicherbbag", "dreameye", "money", "aura", "permaura"
}; };
@ -616,24 +615,21 @@ const resource_type *get_resourcetype(resource_t type) {
return rtype; return rtype;
} }
int get_item(const unit * u, item_t it) int get_item(const unit * u, const item_type *itype)
{ {
const item_type *type = olditemtype[it]; const item *i = *i_findc(&u->items, itype);
const item *i = *i_findc(&u->items, type); assert(!i || i->number >= 0);
if (i)
assert(i->number >= 0);
return i ? i->number : 0; return i ? i->number : 0;
} }
int set_item(unit * u, item_t it, int value) int set_item(unit * u, const item_type *itype, int value)
{ {
const item_type *type = olditemtype[it];
item *i; item *i;
assert(type); assert(itype);
i = *i_find(&u->items, type); i = *i_find(&u->items, itype);
if (!i) { if (!i) {
i = i_add(&u->items, i_new(type, value)); i = i_add(&u->items, i_new(itype, value));
} else { } else {
i->number = value; i->number = value;
assert(i->number >= 0); assert(i->number >= 0);
@ -731,20 +727,6 @@ mod_dwarves_only(const unit * u, const region * r, skill_t sk, int value)
return -118; return -118;
} }
static void init_olditems(void)
{
item_t i;
for (i = 0; i != MAXITEMS; ++i) {
/* item is defined in XML file, but IT_XYZ enum still in use */
const item_type *itype = it_find(itemnames[i]);
if (itype) {
olditemtype[i] = itype;
}
}
}
static int heal(unit * user, int effect) static int heal(unit * user, int effect)
{ {
int req = unit_max_hp(user) * user->number - user->hp; int req = unit_max_hp(user) * user->number - user->hp;
@ -1006,7 +988,6 @@ void init_resources(void)
rt_register(r_unit); rt_register(r_unit);
/* alte typen registrieren: */ /* alte typen registrieren: */
init_olditems();
init_oldpotions(); init_oldpotions();
} }
@ -1211,7 +1192,6 @@ void test_clear_resources(void)
{ {
int i; int i;
memset((void *)olditemtype, 0, sizeof(olditemtype));
memset((void *)oldpotiontype, 0, sizeof(oldpotiontype)); memset((void *)oldpotiontype, 0, sizeof(oldpotiontype));
cb_foreach(&cb_items, "", 0, free_itype_cb, 0); cb_foreach(&cb_items, "", 0, free_itype_cb, 0);

View file

@ -291,7 +291,6 @@ extern "C" {
I_DOLPHIN, I_DOLPHIN,
I_RING_OF_NIMBLEFINGER, I_RING_OF_NIMBLEFINGER,
I_TROLLBELT, I_TROLLBELT,
I_PRESSCARD,
I_AURAKULUM, I_AURAKULUM,
I_SPHERE_OF_INVISIBILITY, I_SPHERE_OF_INVISIBILITY,
I_BAG_OF_HOLDING, I_BAG_OF_HOLDING,
@ -318,7 +317,6 @@ extern "C" {
R_DOLPHIN, R_DOLPHIN,
R_RING_OF_NIMBLEFINGER, R_RING_OF_NIMBLEFINGER,
R_TROLLBELT, R_TROLLBELT,
R_PRESSCARD,
R_AURAKULUM, R_AURAKULUM,
R_SPHERE_OF_INVISIBILITY, R_SPHERE_OF_INVISIBILITY,
R_BAG_OF_HOLDING, R_BAG_OF_HOLDING,
@ -335,11 +333,7 @@ extern "C" {
} resource_t; } resource_t;
extern const struct potion_type *oldpotiontype[]; extern const struct potion_type *oldpotiontype[];
extern const struct item_type *olditemtype[]; const struct resource_type *get_resourcetype(resource_t rt);
const struct resource_type *get_resourcetype(resource_t type);
int get_item(const struct unit *, item_t);
int set_item(struct unit *, item_t, int);
int get_money(const struct unit *); int get_money(const struct unit *);
int set_money(struct unit *, int); int set_money(struct unit *, int);

View file

@ -31,7 +31,7 @@ void test_change_item(CuTest * tc)
test_create_world(); test_create_world();
u = test_create_unit(0, 0); u = test_create_unit(0, 0);
test_uchange(tc, u, olditemtype[I_IRON]->rtype); test_uchange(tc, u, get_resourcetype(R_IRON));
} }
void test_change_person(CuTest * tc) void test_change_person(CuTest * tc)

View file

@ -723,7 +723,7 @@ int max_spellpoints(const region * r, const unit * u)
sk = eff_skill(u, SK_MAGIC, r); sk = eff_skill(u, SK_MAGIC, r);
msp = u_race(u)->maxaura * (pow(sk, potenz) / divisor + 1) + get_spchange(u); msp = u_race(u)->maxaura * (pow(sk, potenz) / divisor + 1) + get_spchange(u);
if (get_item(u, I_AURAKULUM) > 0) { if (i_get(u->items, it_find("aurafocus")) > 0) {
msp += use_item_aura(r, u); msp += use_item_aura(r, u);
} }
n = get_curseeffect(u->attribs, C_AURA, 0); n = get_curseeffect(u->attribs, C_AURA, 0);
@ -1022,7 +1022,7 @@ spellpower(region * r, unit * u, const spell * sp, int cast_level,
++force; ++force;
} }
if (get_item(u, I_RING_OF_POWER) > 0) if (i_get(u->items, it_find("rop")) > 0)
++force; ++force;
if (elf_power < 0) { if (elf_power < 0) {
elf_power = get_param_int(global.parameters, "rules.magic.elfpower", 0); elf_power = get_param_int(global.parameters, "rules.magic.elfpower", 0);
@ -1125,7 +1125,7 @@ double magic_resistance(unit * target)
} }
/* Unicorn +10 */ /* Unicorn +10 */
n = get_item(target, I_ELVENHORSE); n = i_get(target->items, it_find("elvenhorse"));
if (n) if (n)
probability += n * 0.1 / target->number; probability += n * 0.1 / target->number;

View file

@ -270,10 +270,12 @@ static int ridingcapacity(unit * u)
int walkingcapacity(const struct unit *u) int walkingcapacity(const struct unit *u)
{ {
int n, tmp, people, pferde_fuer_wagen; int n, people, pferde_fuer_wagen;
int wagen_ohne_pferde, wagen_mit_pferden, wagen_mit_trollen; int wagen_ohne_pferde, wagen_mit_pferden, wagen_mit_trollen;
int vehicles = 0, vcap = 0; int vehicles = 0, vcap = 0;
int animals = 0, acap = 0; int animals = 0, acap = 0;
const struct item_type *ihorse = it_find("horse");
const struct item_type *ibelt = it_find("trollbelt");
get_transporters(u->items, &animals, &acap, &vehicles, &vcap); get_transporters(u->items, &animals, &acap, &vehicles, &vcap);
@ -309,16 +311,20 @@ int walkingcapacity(const struct unit *u)
n += animals * acap; n += animals * acap;
n += people * personcapacity(u); n += people * personcapacity(u);
/* Goliathwasser */ /* Goliathwasser */
tmp = get_effect(u, oldpotiontype[P_STRONG]); if (ihorse) {
int tmp = get_effect(u, oldpotiontype[P_STRONG]);
if (tmp > 0) { if (tmp > 0) {
int horsecap = olditemtype[I_HORSE]->capacity; int horsecap = ihorse->capacity;
if (tmp > people) if (tmp > people) {
tmp = people; tmp = people;
}
n += tmp * (horsecap - personcapacity(u)); n += tmp * (horsecap - personcapacity(u));
} }
/* change_effect wird in ageing gemacht */ }
tmp = get_item(u, I_TROLLBELT); if (ibelt) {
int tmp = i_get(u->items, ibelt);
n += _min(people, tmp) * (STRENGTHMULTIPLIER - 1) * personcapacity(u); n += _min(people, tmp) * (STRENGTHMULTIPLIER - 1) * personcapacity(u);
}
return n; return n;
} }
@ -372,7 +378,7 @@ static int canwalk(unit * u)
bool canfly(unit * u) bool canfly(unit * u)
{ {
if (get_item(u, I_PEGASUS) >= u->number && effskill(u, SK_RIDING) >= 4) if (i_get(u->items, it_find("pegasus")) >= u->number && effskill(u, SK_RIDING) >= 4)
return true; return true;
if (fval(u_race(u), RCF_FLY)) if (fval(u_race(u), RCF_FLY))
@ -386,7 +392,7 @@ bool canfly(unit * u)
bool canswim(unit * u) bool canswim(unit * u)
{ {
if (get_item(u, I_DOLPHIN) >= u->number && effskill(u, SK_RIDING) >= 4) if (i_get(u->items, it_find("dolphin")) >= u->number && effskill(u, SK_RIDING) >= 4)
return true; return true;
if (u_race(u)->flags & RCF_FLY) if (u_race(u)->flags & RCF_FLY)
@ -860,7 +866,7 @@ static unit *bewegung_blockiert_von(unit * reisender, region * r)
if (!contact && guard) { if (!contact && guard) {
double prob = 0.3; /* 30% base chance */ double prob = 0.3; /* 30% base chance */
prob += 0.1 * (perception - eff_stealth(reisender, r)); prob += 0.1 * (perception - eff_stealth(reisender, r));
prob += 0.1 * _min(guard->number, get_item(guard, I_AMULET_OF_TRUE_SEEING)); prob += 0.1 * _min(guard->number, i_get(guard->items, it_find("aots")));
if (chance(prob)) { if (chance(prob)) {
return guard; return guard;
@ -1375,7 +1381,7 @@ static int movement_speed(unit * u)
} }
/* unicorn in inventory */ /* unicorn in inventory */
if (u->number <= get_item(u, I_FEENSTIEFEL)) { if (u->number <= i_get(u->items, it_find("fairyboot"))) {
mp *= 2; mp *= 2;
} }

View file

@ -39,8 +39,6 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
int get_resource(const unit * u, const resource_type * rtype) int get_resource(const unit * u, const resource_type * rtype)
{ {
const item_type *itype = resource2item(rtype);
assert(rtype); assert(rtype);
if (rtype->uget) { if (rtype->uget) {
/* this resource is probably special */ /* this resource is probably special */
@ -54,16 +52,13 @@ int get_resource(const unit * u, const resource_type * rtype)
if (i >= 0) if (i >= 0)
return i; return i;
} }
if (itype != NULL) { if (rtype->itype) {
if (itype == olditemtype[R_STONE] && (u_race(u)->flags & RCF_STONEGOLEM)) { if (rtype == rt_find("stone") && (u_race(u)->flags & RCF_STONEGOLEM)) {
return u->number * GOLEM_STONE; return u->number * GOLEM_STONE;
} else if (itype == olditemtype[R_IRON] && (u_race(u)->flags & RCF_IRONGOLEM)) { } else if (rtype->itype == it_find("iron") && (u_race(u)->flags & RCF_IRONGOLEM)) {
return u->number * GOLEM_IRON; return u->number * GOLEM_IRON;
} else { } else {
const item *i = *i_findc(&u->items, itype); return i_get(u->items, rtype->itype);
if (i)
return i->number;
return 0;
} }
} }
if (rtype == get_resourcetype(R_AURA)) if (rtype == get_resourcetype(R_AURA))

View file

@ -193,12 +193,6 @@ extern void add_raceprefix(const char *prefix)
/* "den Zwergen", "Halblingsparteien" */ /* "den Zwergen", "Halblingsparteien" */
void set_show_item(faction * f, item_t i)
{
attrib *a = a_add(&f->attribs, a_new(&at_showitem));
a->data.v = (void *)olditemtype[i];
}
bool r_insectstalled(const region * r) bool r_insectstalled(const region * r)
{ {
return fval(r->terrain, ARCTIC_REGION); return fval(r->terrain, ARCTIC_REGION);

View file

@ -57,10 +57,6 @@ extern "C" {
extern const struct unit *ucansee(const struct faction *f, extern const struct unit *ucansee(const struct faction *f,
const struct unit *u, const struct unit *x); const struct unit *u, const struct unit *x);
int hat_in_region(item_t itm, struct region *r, struct faction *f);
/* für fast_region und neuen CR: */
enum { enum {
see_none, see_none,
see_neighbour, see_neighbour,

View file

@ -131,9 +131,6 @@ typedef enum {
P_GROUP, P_GROUP,
P_FACTIONSTEALTH, P_FACTIONSTEALTH,
P_TREES, P_TREES,
P_XEPOTION,
P_XEBALLOON,
P_XELAEN,
P_ALLIANCE, P_ALLIANCE,
MAXPARAMS, MAXPARAMS,
NOPARAM = -1 NOPARAM = -1

View file

@ -303,13 +303,14 @@ int gift_items(unit * u, int flags)
if (flags & GIFT_PEASANTS) { if (flags & GIFT_PEASANTS) {
if (!fval(u->region->terrain, SEA_REGION)) { if (!fval(u->region->terrain, SEA_REGION)) {
if (itm->type == olditemtype[I_HORSE]) { if (itm->type == i_silver) {
rsethorses(r, rhorses(r) + itm->number);
itm->number = 0;
} else if (itm->type == i_silver) {
rsetmoney(r, rmoney(r) + itm->number); rsetmoney(r, rmoney(r) + itm->number);
itm->number = 0; itm->number = 0;
} }
else if (itm->type == it_find("horse")) {
rsethorses(r, rhorses(r) + itm->number);
itm->number = 0;
}
} }
} }
if (itm->number > 0 && (itm->type->flags & ITF_NOTLOST)) { if (itm->number > 0 && (itm->type->flags & ITF_NOTLOST)) {
@ -1210,23 +1211,17 @@ bool has_skill(const unit * u, skill_t sk)
static int item_modification(const unit * u, skill_t sk, int val) static int item_modification(const unit * u, skill_t sk, int val)
{ {
/* Presseausweis: *2 Spionage, 0 Tarnung */ if (sk == SK_STEALTH) {
if (sk == SK_SPY && get_item(u, I_PRESSCARD) >= u->number) {
val = val * 2;
} else if (sk == SK_STEALTH) {
#if NEWATSROI == 1 #if NEWATSROI == 1
if (get_item(u, I_RING_OF_INVISIBILITY) if (i_get(u->items, it_find("roi"))
+ 100 * get_item(u, I_SPHERE_OF_INVISIBILITY) >= u->number) { + 100 * i_get(u->items, it_find("sphereofinv")) >= u->number) {
val += ROIBONUS; val += ROIBONUS;
} }
#endif #endif
if (get_item(u, I_PRESSCARD) >= u->number) {
val = 0;
}
} }
#if NEWATSROI == 1 #if NEWATSROI == 1
if (sk == SK_PERCEPTION) { if (sk == SK_PERCEPTION) {
if (get_item(u, I_AMULET_OF_TRUE_SEEING) >= u->number) { if (i_get(u->items, it_find("aots")) >= u->number) {
val += ATSBONUS; val += ATSBONUS;
} }
} }
@ -1364,12 +1359,13 @@ int invisible(const unit * target, const unit * viewer)
return 0; return 0;
else { else {
int hidden = int hidden =
get_item(target, I_RING_OF_INVISIBILITY) + 100 * get_item(target, i_get(target->items, it_find("roi")) + 100 * i_get(target->items,
I_SPHERE_OF_INVISIBILITY); it_find("sphereofinv"));
if (hidden) { if (hidden) {
hidden = _min(hidden, target->number); hidden = _min(hidden, target->number);
if (viewer) if (viewer) {
hidden -= get_item(viewer, I_AMULET_OF_TRUE_SEEING); hidden -= i_get(viewer->items, it_find("aots"));
}
} }
return hidden; return hidden;
} }

View file

@ -3257,6 +3257,7 @@ static building *age_building(building * b)
{ {
const struct building_type *bt_blessed; const struct building_type *bt_blessed;
const struct curse_type *ct_astralblock; const struct curse_type *ct_astralblock;
const struct item_type *itype = it_find("elvenhorse");
bt_blessed = bt_find("blessedstonecircle"); bt_blessed = bt_find("blessedstonecircle");
ct_astralblock = ct_find("astralblock"); ct_astralblock = ct_find("astralblock");
@ -3268,7 +3269,7 @@ static building *age_building(building * b)
* *
* TODO: this would be nicer in a btype->age function, but we don't have it. * TODO: this would be nicer in a btype->age function, but we don't have it.
*/ */
if (ct_astralblock && bt_blessed && b->type == bt_blessed) { if (itype && ct_astralblock && bt_blessed && b->type == bt_blessed) {
region *r = b->region; region *r = b->region;
region *rt = r_standard_to_astral(r); region *rt = r_standard_to_astral(r);
unit *u, *mage = NULL; unit *u, *mage = NULL;
@ -3281,13 +3282,13 @@ static building *age_building(building * b)
int n, unicorns = 0; int n, unicorns = 0;
for (n = 0; n != u->number; ++n) { for (n = 0; n != u->number; ++n) {
if (chance(0.02)) { if (chance(0.02)) {
i_change(&u->items, olditemtype[I_ELVENHORSE], 1); i_change(&u->items, itype, 1);
++unicorns; ++unicorns;
} }
if (unicorns) { if (unicorns) {
ADDMSG(&u->faction->msgs, msg_message("scunicorn", ADDMSG(&u->faction->msgs, msg_message("scunicorn",
"unit amount rtype", "unit amount rtype",
u, unicorns, olditemtype[I_ELVENHORSE]->rtype)); u, unicorns, itype->rtype));
} }
} }
} }

View file

@ -81,7 +81,7 @@ static void eaten_by_monster(unit * u)
/* adjustment for smaller worlds */ /* adjustment for smaller worlds */
static double multi = 0.0; static double multi = 0.0;
int n = 0; int n = 0;
int horse = 0; int horse = -1;
if (multi == 0.0) { if (multi == 0.0) {
multi = RESOURCE_QUANTITY * newterrain(T_PLAIN)->size / 10000.0; multi = RESOURCE_QUANTITY * newterrain(T_PLAIN)->size / 10000.0;
@ -90,19 +90,18 @@ static void eaten_by_monster(unit * u)
switch (old_race(u_race(u))) { switch (old_race(u_race(u))) {
case RC_FIREDRAGON: case RC_FIREDRAGON:
n = rng_int() % 80 * u->number; n = rng_int() % 80 * u->number;
horse = get_item(u, I_HORSE);
break; break;
case RC_DRAGON: case RC_DRAGON:
n = rng_int() % 200 * u->number; n = rng_int() % 200 * u->number;
horse = get_item(u, I_HORSE);
break; break;
case RC_WYRM: case RC_WYRM:
n = rng_int() % 500 * u->number; n = rng_int() % 500 * u->number;
horse = get_item(u, I_HORSE);
break; break;
default: default:
n = rng_int() % (u->number / 20 + 1); n = rng_int() % (u->number / 20 + 1);
horse = 0;
} }
horse = horse ? i_get(u->items, it_find("horse")) : 0;
n = (int)(n * multi); n = (int)(n * multi);
if (n > 0) { if (n > 0) {
@ -116,7 +115,7 @@ static void eaten_by_monster(unit * u)
} }
} }
if (horse > 0) { if (horse > 0) {
set_item(u, I_HORSE, 0); i_change(&u->items, it_find("horse"), -horse);
ADDMSG(&u->region->msgs, msg_message("eathorse", "unit amount", u, horse)); ADDMSG(&u->region->msgs, msg_message("eathorse", "unit amount", u, horse));
} }
} }

View file

@ -48,22 +48,16 @@ static void oldfamiliars(unit * u)
equip_unit(u, get_equipment(fname)); equip_unit(u, get_equipment(fname));
} }
static void set_show_item(faction * f, item_t i)
{
attrib *a = a_add(&f->attribs, a_new(&at_showitem));
a->data.v = (void *)olditemtype[i];
}
static void equip_newunits(const struct equipment *eq, struct unit *u) static void equip_newunits(const struct equipment *eq, struct unit *u)
{ {
struct region *r = u->region; struct region *r = u->region;
switch (old_race(u_race(u))) { switch (old_race(u_race(u))) {
case RC_ELF: case RC_ELF:
set_show_item(u->faction, I_FEENSTIEFEL); set_show_item(u->faction, it_find("fairyboot"));
break; break;
case RC_GOBLIN: case RC_GOBLIN:
set_show_item(u->faction, I_RING_OF_INVISIBILITY); set_show_item(u->faction, it_find("roi"));
set_number(u, 10); set_number(u, 10);
break; break;
case RC_HUMAN: case RC_HUMAN:
@ -78,7 +72,7 @@ static void equip_newunits(const struct equipment *eq, struct unit *u)
} }
break; break;
case RC_CAT: case RC_CAT:
set_show_item(u->faction, I_RING_OF_INVISIBILITY); set_show_item(u->faction, it_find("roi"));
break; break;
case RC_AQUARIAN: case RC_AQUARIAN:
{ {

View file

@ -1079,8 +1079,12 @@ static void orc_growth(void)
int increase = 0; int increase = 0;
int num = get_cursedmen(u, c); int num = get_cursedmen(u, c);
double prob = curse_geteffect(c); double prob = curse_geteffect(c);
const item_type * it_chastity = it_find("ao_chastity");
for (n = (num - get_item(u, I_CHASTITY_BELT)); n > 0; n--) { if (it_chastity) {
num -= i_get(u->items, it_chastity);
}
for (n = num; n > 0; n--) {
if (chance(prob)) { if (chance(prob)) {
++increase; ++increase;
} }
@ -1176,18 +1180,18 @@ static void rotting_herbs(void)
rule_rot = rule_rot =
get_param_int(global.parameters, "rules.economy.herbrot", HERBROTCHANCE); get_param_int(global.parameters, "rules.economy.herbrot", HERBROTCHANCE);
} }
if (rule_rot == 0) if (rule_rot == 0) return;
return;
for (r = regions; r; r = r->next) { for (r = regions; r; r = r->next) {
unit *u; unit *u;
for (u = r->units; u; u = u->next) { for (u = r->units; u; u = u->next) {
const struct item_type *it_bag = it_find("magicherbbag");
item **itmp = &u->items; item **itmp = &u->items;
item *hbag = *i_find(itmp, olditemtype[I_SACK_OF_CONSERVATION]);
int rot_chance = rule_rot; int rot_chance = rule_rot;
if (hbag) if (it_bag && *i_find(itmp, it_bag)) {
rot_chance = (rot_chance * 2) / 5; rot_chance = (rot_chance * 2) / 5;
}
while (*itmp) { while (*itmp) {
item *itm = *itmp; item *itm = *itmp;
int n = itm->number; int n = itm->number;
@ -1196,7 +1200,7 @@ static void rotting_herbs(void)
double nv = normalvariate(k, k / 4); double nv = normalvariate(k, k / 4);
int inv = (int)nv; int inv = (int)nv;
int delta = _min(n, inv); int delta = _min(n, inv);
if (i_change(itmp, itm->type, -delta) == NULL) { if (!i_change(itmp, itm->type, -delta)) {
continue; continue;
} }
} }

View file

@ -547,18 +547,6 @@ void sparagraph(strlist ** SP, const char *s, int indent, char mark)
} }
} }
int hat_in_region(item_t it, region * r, faction * f)
{
unit *u;
for (u = r->units; u; u = u->next) {
if (u->faction == f && get_item(u, it) > 0) {
return 1;
}
}
return 0;
}
static void static void
nr_curses(FILE * F, const faction * viewer, const void *obj, objtype_t typ, nr_curses(FILE * F, const faction * viewer, const void *obj, objtype_t typ,
int indent) int indent)

View file

@ -1527,6 +1527,10 @@ static int count_healable(battle * b, fighter * df)
} }
return healable; return healable;
} }
static bool has_ao_healing(const unit *u) {
item *const* iter = i_findc(&u->items, it_find("ao_healing"));
return (*iter && (*iter)->number>0);
}
/* wiederbeleben */ /* wiederbeleben */
int sp_reanimate(struct castorder * co) int sp_reanimate(struct castorder * co)
@ -1539,7 +1543,7 @@ int sp_reanimate(struct castorder * co)
int healable, j = 0; int healable, j = 0;
double c = 0.50 + 0.02 * power; double c = 0.50 + 0.02 * power;
double k = EFFECT_HEALING_SPELL * power; double k = EFFECT_HEALING_SPELL * power;
bool use_item = get_item(mage, I_AMULET_OF_HEALING) > 0; bool use_item = has_ao_healing(mage);
message *msg; message *msg;
if (use_item) { if (use_item) {
@ -1658,7 +1662,7 @@ int sp_healing(struct castorder * co)
int healhp = (int)power * 200; int healhp = (int)power * 200;
quicklist *fgs; quicklist *fgs;
message *msg; message *msg;
bool use_item = get_item(mage, I_AMULET_OF_HEALING) > 0; bool use_item = has_ao_healing(mage);
/* bis zu 11 Personen pro Stufe (einen HP müssen sie ja noch /* bis zu 11 Personen pro Stufe (einen HP müssen sie ja noch
* haben, sonst wären sie tot) können geheilt werden */ * haben, sonst wären sie tot) können geheilt werden */

View file

@ -314,6 +314,7 @@ summary *make_summary(void)
region *r; region *r;
unit *u; unit *u;
summary *s = calloc(1, sizeof(summary)); summary *s = calloc(1, sizeof(summary));
const struct item_type *ihorse = it_find("horse");
for (f = factions; f; f = f->next) { for (f = factions; f; f = f->next) {
const struct locale *lang = f->locale; const struct locale *lang = f->locale;
@ -383,7 +384,7 @@ summary *make_summary(void)
if (u->flags & UFL_HERO) { if (u->flags & UFL_HERO) {
s->heroes += u->number; s->heroes += u->number;
} }
s->spielerpferde += get_item(u, I_HORSE); s->spielerpferde += i_get(u->items, ihorse);
s->playermoney += get_money(u); s->playermoney += get_money(u);
s->armed_men += armedmen(u, true); s->armed_men += armedmen(u, true);
for (itm = u->items; itm; itm = itm->next) { for (itm = u->items; itm; itm = itm->next) {
@ -395,7 +396,7 @@ summary *make_summary(void)
} }
} }
s->spielerpferde += get_item(u, I_HORSE); s->spielerpferde += i_get(u->items, ihorse);
for (sv = u->skills; sv != u->skills + u->skill_size; ++sv) { for (sv = u->skills; sv != u->skills + u->skill_size; ++sv) {
skill_t sk = sv->id; skill_t sk = sv->id;

View file

@ -136,11 +136,10 @@ void test_create_world(void)
get_or_create_locale("de"); get_or_create_locale("de");
init_resources(); init_resources();
assert(!olditemtype[I_HORSE]);
olditemtype[I_HORSE] = test_create_itemtype(names+0); test_create_itemtype(names+0);
olditemtype[I_IRON] = test_create_itemtype(names+4); test_create_itemtype(names+4);
olditemtype[I_STONE] = test_create_itemtype(names+6); test_create_itemtype(names+6);
t_plain = test_create_terrain("plain", LAND_REGION | FOREST_REGION | WALK_INTO | CAVALRY_REGION); t_plain = test_create_terrain("plain", LAND_REGION | FOREST_REGION | WALK_INTO | CAVALRY_REGION);
t_plain->size = 1000; t_plain->size = 1000;