antimagiekristallfix

This commit is contained in:
Katja Zedel 2002-04-06 20:45:55 +00:00
parent 41f17d9df7
commit f2f09674cf
5 changed files with 94 additions and 39 deletions

View file

@ -554,6 +554,10 @@ create_curse(unit *magician, attrib **ap, curse_t id, int id2, int vigour,
int duration, int effect, int men)
{
curse *c;
/* die Kraft eines Spruchs darf nicht 0 sein*/
assert(vigour >= 0);
c = get_curse(*ap, id, id2);
if(c && (c->flag & CURSE_ONLYONE)){
@ -709,6 +713,9 @@ is_cursed(attrib *ap, curse_t id, int id2)
if (c->flag & CURSE_ISNEW)
return false;
if (c->vigour <= 0)
return false;
return true;
}

View file

@ -805,22 +805,44 @@ use_antimagiccrystal(region * r, unit * mage, int amount, strlist * cmdstrings)
{
int i;
for (i=0;i!=amount;++i) {
int effect, power, duration = 2;
int effect, force, duration = 2;
spell *sp = find_spellbyid(SPL_ANTIMAGICZONE);
attrib ** ap = &r->attribs;
unused(cmdstrings);
/* Reduziert die Stärke jedes Spruchs um effect */
effect = sp->level*4; /* Stufe 5 =~ 15 */
effect = sp->level;
/* Hält Sprüche bis zu einem summierten Gesamtlevel von power aus.
* Jeder Zauber reduziert die 'Lebenskraft' (vigour) der Antimagiezone
* um seine Stufe */
power = sp->level * 20; /* Stufe 5 =~ 100 */
force = sp->level * 20; /* Stufe 5 =~ 100 */
power = destroy_curse(&r->attribs, effect, power, NULL);
/* Regionszauber auflösen */
while (*ap && force > 0) {
curse * c;
attrib * a = *ap;
if (!fval(a->type, ATF_CURSE)) {
do { ap = &(*ap)->next; } while (*ap && a->type==(*ap)->type);
continue;
}
c = (curse*)a->data.v;
if(power) {
create_curse(mage, &r->attribs, C_ANTIMAGICZONE, 0, power, duration, effect, 0);
/* Immunität prüfen */
if (c->flag & CURSE_IMMUN) {
do { ap = &(*ap)->next; } while (*ap && a->type==(*ap)->type);
continue;
}
force = destr_curse(c, effect, force);
if(c->vigour <= 0) {
a_remove(ap, a);
}
if(*ap) ap = &(*ap)->next;
}
if(force) {
create_curse(mage, &r->attribs, C_ANTIMAGICZONE, 0, force, duration, effect, 0);
}
}

View file

@ -332,6 +332,43 @@ magicanalyse_ship(ship *sh, unit *mage, int force)
/* ------------------------------------------------------------- */
/* Antimagie - curse auflösen */
/* ------------------------------------------------------------- */
/* Wenn der Curse schwächer ist als der cast_level, dann wird er
* aufgelöst, bzw seine Kraft (vigour) auf 0 gesetzt.
* Ist der cast_level zu gering, hat die Antimagie nur mit einer Chance
* von 100-20*Stufenunterschied % eine Wirkung auf den Curse. Dann wird
* die Kraft des Curse um die halbe Stärke der Antimagie reduziert.
* Zurückgegeben wird der noch unverbrauchte Rest von force.
*/
int
destr_curse(curse* c, int cast_level, int force)
{
if (cast_level < c->vigour) { /* Zauber ist nicht stark genug */
int chance;
/* pro Stufe Unterschied -20% */
chance = (10 + (cast_level - c->vigour)*2);
if(rand()%10 >= chance){
force -= c->vigour;
if (c->type->change_vigour){
c->type->change_vigour(c, -(cast_level+1/2));
} else {
c->vigour -= cast_level+1/2;
}
}
} else { /* Zauber ist stärker als curse */
if (force >= c->vigour){ /* reicht die Kraft noch aus? */
force -= c->vigour;
if (c->type->change_vigour){
c->type->change_vigour(c, -c->vigour);
} else {
c->vigour = 0;
}
}
}
return force;
}
int
destroy_curse(attrib **alist, int cast_level, int force,
const curse_type * ctype)
@ -355,29 +392,19 @@ destroy_curse(attrib **alist, int cast_level, int force,
continue;
}
if(!ctype || c->type==ctype) { /* wirkt auf alle */
if (cast_level < c->vigour) { /* Zauber ist nicht stark genug */
int chance;
/* pro Stufe Unterschied -20% */
chance = (10 + (cast_level - c->vigour)*2);
if(rand()%10 >= chance){
if (c->type->change_vigour)
c->type->change_vigour(c, -2);
force -= c->vigour;
c->vigour -= 2;
if(c->vigour <= 0) {
a_remove(alist, a);
}
succ = cast_level;
}
} else { /* Zauber ist stärker als curse */
if (force >= c->vigour){ /* reicht die Kraft noch aus? */
force -= c->vigour;
if (c->type->change_vigour)
c->type->change_vigour(c, -c->vigour);
a_remove(alist, a);
succ = cast_level;
}
/* Wenn kein spezieller cursetyp angegeben ist, soll die Antimagie
* auf alle Verzauberungen wirken. Ansonsten prüfe, ob der Curse vom
* richtigen Typ ist. */
if(!ctype || c->type==ctype) {
int n;
n = destr_curse(c, cast_level, force);
if (n != force){
assert(n<force); /* force darf sich nur vermindert haben */
succ = cast_level;
force = n;
}
if(c->vigour <= 0) {
a_remove(ap, a);
}
}
if(*ap) ap = &(*ap)->next;

View file

@ -213,7 +213,8 @@ int use_item_power(struct region * r, struct unit * u);
int use_item_regeneration(struct region * r, struct unit * u);
void showspells(struct region *r, struct unit *u);
int sp_antimagiczone(struct castorder *co);
int destroy_curse(struct attrib **alist, int cast_level, int force, const struct curse_type * ctype);
int destr_curse(struct curse* c, int cast_level, int force);
/* Kampfzauber */

View file

@ -3,19 +3,17 @@ ifndef ERESSEA
export ERESSEA=$(PWD)
endif
# CONVERT_TRIGGERS = 1
# Hier definieren, damit nicht '@gcc'
CC = gcc -DNEW_RESOURCEGROWTH
#CC = gcc -DNEW_RESOURCEGROWTH
CC = gcc-3.0 -D_GNU_SOURCE
DEPEND = @gcc-3.0 -MM -MG -r
AR = ar
CTAGS = ctags
CC = gcc
LD = gcc
CTAGS = ctags-exuberant
LD = gcc-3.0
INSTALL = cp
CFLAGS += -DNEW_RESOURCEGROWTH
# CFLAGS += -Wshadow
CFLAGS += -minline-all-stringops
# Ps = 0 -> Normal (default)
# Ps = 1 -> Bold