avoiding a_select some more, and removing the unused compare-functions

This commit is contained in:
Enno Rehling 2006-02-26 11:12:25 +00:00
parent 5c474b9eb7
commit 23247f1831
6 changed files with 45 additions and 66 deletions

View file

@ -3628,9 +3628,19 @@ init_battle(region * r, battle **bp)
/* Fehler: "Die Einheit ist mit uns alliert" */ /* Fehler: "Die Einheit ist mit uns alliert" */
if (calm_ct) { if (calm_ct) {
variant var; attrib * a = a_find(u->attribs, &at_curse);
var.i = u2->faction->subscription; boolean calm = false;
if (curse_active(get_cursex(u->attribs, calm_ct, var, cmp_curseeffect_int))) { while (a && a->type==&at_curse) {
curse * c = (curse *)a->data.v;
if (c->type==calm_ct && c->effect.i==u2->faction->subscription) {
if (curse_active(c)) {
calm = true;
break;
}
}
a = a->next;
}
if (calm) {
cmistake(u, ord, 47, MSG_BATTLE); cmistake(u, ord, 47, MSG_BATTLE);
continue; continue;
} }

View file

@ -267,29 +267,6 @@ ct_find(const char *c)
* einen pointer auf die struct zurück. * einen pointer auf die struct zurück.
*/ */
typedef struct cid {
int id;
int id2;
} twoids;
boolean
cmp_curseeffect_vptr(const curse * c, variant var)
{
return (c->effect.v==var.v);
}
boolean
cmp_curseeffect_int(const curse * c, variant var)
{
return (c->effect.i==var.i);
}
boolean
cmp_cursedata_int(const curse * c, variant data)
{
return (c->data.i==data.i);
}
boolean boolean
cmp_curse(const attrib * a, const void * data) { cmp_curse(const attrib * a, const void * data) {
const curse * c = (const curse*)data; const curse * c = (const curse*)data;
@ -337,7 +314,6 @@ get_curse(attrib *ap, const curse_type * ctype)
a = a->nexttype; a = a->nexttype;
} }
} }
return NULL; return NULL;
} }
@ -358,17 +334,6 @@ remove_curse(attrib **ap, const curse *c)
if (a) a_remove(ap, a); if (a) a_remove(ap, a);
} }
void
remove_allcurse(attrib **ap, const void * data, boolean(*compare)(const attrib *, const void *))
{
attrib * a = a_select(*ap, data, compare);
while (a) {
attrib * next = a->next;
a_remove(ap, a);
a = a_select(next, data, compare);
}
}
/* gibt die allgemeine Stärke der Verzauberung zurück. id2 wird wie /* gibt die allgemeine Stärke der Verzauberung zurück. id2 wird wie
* oben benutzt. Dies ist nicht die Wirkung, sondern die Kraft und * oben benutzt. Dies ist nicht die Wirkung, sondern die Kraft und
* damit der gegen Antimagie wirkende Widerstand einer Verzauberung */ * damit der gegen Antimagie wirkende Widerstand einer Verzauberung */

View file

@ -311,9 +311,6 @@ extern int curse_age(struct attrib * a);
extern boolean cmp_curse(const attrib * a, const void * data); extern boolean cmp_curse(const attrib * a, const void * data);
extern boolean cmp_cursetype(const attrib * a, const void * data); extern boolean cmp_cursetype(const attrib * a, const void * data);
extern boolean cmp_curseeffect_vptr(const curse * c, variant data);
extern boolean cmp_curseeffect_int(const curse * c, variant data);
extern boolean cmp_cursedata_int(const curse * c, variant data);
extern void * resolve_curse(variant data); extern void * resolve_curse(variant data);
extern boolean is_cursed_with(attrib *ap, curse *c); extern boolean is_cursed_with(attrib *ap, curse *c);

View file

@ -40,6 +40,7 @@ extern "C" {
#define RF_MIGRATION (1<<10) #define RF_MIGRATION (1<<10)
#define RF_UNUSED_1 (1<<11) #define RF_UNUSED_1 (1<<11)
#define RF_ORCIFIED (1<<12) #define RF_ORCIFIED (1<<12)
#define RF_CURSED (1<<13)
#define RF_COMBATDEBUG (1<<14) #define RF_COMBATDEBUG (1<<14)

View file

@ -1067,6 +1067,8 @@ att_modification(const unit *u, skill_t sk)
int result = 0; int result = 0;
static boolean init = false; static boolean init = false;
static const curse_type * skillmod_ct, * gbdream_ct, * worse_ct; static const curse_type * skillmod_ct, * gbdream_ct, * worse_ct;
curse * c;
if (!init) { if (!init) {
init = true; init = true;
skillmod_ct = ct_find("skillmod"); skillmod_ct = ct_find("skillmod");
@ -1074,33 +1076,41 @@ att_modification(const unit *u, skill_t sk)
worse_ct = ct_find("worse"); worse_ct = ct_find("worse");
} }
result += curse_geteffect(get_curse(u->attribs, worse_ct)); c = get_curse(u->attribs, worse_ct);
if (c!=NULL) result += curse_geteffect(c);
if (skillmod_ct) { if (skillmod_ct) {
curse * c; attrib * a = a_find(u->attribs, &at_curse);
variant var; while (a && a->type==&at_curse) {
var.i = sk; curse * c = (curse *)a->data.v;
c = get_cursex(u->attribs, skillmod_ct, var, cmp_cursedata_int); if (c->type==skillmod_ct && c->data.i==sk) {
result += curse_geteffect(c); result += curse_geteffect(c);
break;
}
a = a->next;
}
} }
/* TODO hier kann nicht mit get/iscursed gearbeitet werden, da nur der /* TODO hier kann nicht mit get/iscursed gearbeitet werden, da nur der
* jeweils erste vom Typ C_GBDREAM zurückgegen wird, wir aber alle * jeweils erste vom Typ C_GBDREAM zurückgegen wird, wir aber alle
* durchsuchen und aufaddieren müssen */ * durchsuchen und aufaddieren müssen */
a = a_select(u->region->attribs, gbdream_ct, cmp_cursetype); a = a_find(u->region->attribs, &at_curse);
while (a) { while (a && a->type==&at_curse) {
curse * c = (curse*)a->data.v; curse * c = (curse*)a->data.v;
if (c->type==gbdream_ct) {
int mod = curse_geteffect(c); int mod = curse_geteffect(c);
unit * mage = c->magician; unit * mage = c->magician;
/* wir suchen jeweils den größten Bonus und den größten Malus */ /* wir suchen jeweils den größten Bonus und den größten Malus */
if (mod>0 && (mage==NULL || alliedunit(mage, u->faction, HELP_GUARD))) if (mod>bonus) {
{ if (mage==NULL || alliedunit(mage, u->faction, HELP_GUARD)) {
if (mod > bonus ) bonus = mod; bonus = mod;
} else if (mod < 0 &&
(mage == NULL || !alliedunit(mage, u->faction, HELP_GUARD)))
{
if (mod < malus ) malus = mod;
} }
a = a_select(a->next, gbdream_ct, cmp_cursetype); } else if (mod < malus) {
if (mage == NULL || !alliedunit(mage, u->faction, HELP_GUARD)) {
malus = mod;
}
}
}
a = a->next;
} }
result = result + bonus + malus; result = result + bonus + malus;

View file

@ -4066,10 +4066,6 @@ sp_rallypeasantmob(castorder *co)
unit *mage = co->magician.u; unit *mage = co->magician.u;
int cast_level = co->level; int cast_level = co->level;
/* TODO
remove_allcurse(&r->attribs, C_RIOT, 0);
*/
for (u = r->units; u; u = un){ for (u = r->units; u; u = un){
un = u->next; un = u->next;
if (u->faction->no == MONSTER_FACTION && u->race == new_race[RC_PEASANT]){ if (u->faction->no == MONSTER_FACTION && u->race == new_race[RC_PEASANT]){