- Beim Versteienrn und anderen Zaubern treten Fehler auf, wenn force==0
This commit is contained in:
Enno Rehling 2004-06-26 17:38:29 +00:00
parent a8ed2663ef
commit 4b3f794d4c

View file

@ -179,7 +179,7 @@ sp_versteinern(fighter * fi, int level, double power, spell * sp)
sprintf(buf, "%s zaubert %s", unitname(fi->unit), sprintf(buf, "%s zaubert %s", unitname(fi->unit),
spell_name(sp, default_locale)); spell_name(sp, default_locale));
force = lovar(get_force(power,0)); force = lovar(get_force(power, 0));
enemies = count_enemies(b, fi->side, minrow, maxrow); enemies = count_enemies(b, fi->side, minrow, maxrow);
if (!enemies) { if (!enemies) {
@ -190,7 +190,7 @@ sp_versteinern(fighter * fi, int level, double power, spell * sp)
scat(":"); scat(":");
battlerecord(b, buf); battlerecord(b, buf);
do { while (force && stoned < enemies) {
troop dt = select_enemy(b, fi, minrow, maxrow); troop dt = select_enemy(b, fi, minrow, maxrow);
fighter * df = dt.fighter; fighter * df = dt.fighter;
unit * du = df->unit; unit * du = df->unit;
@ -204,7 +204,7 @@ sp_versteinern(fighter * fi, int level, double power, spell * sp)
dt.fighter->person[(df->alive - df->removed)] = p; dt.fighter->person[(df->alive - df->removed)] = p;
} }
--force; --force;
} while (force && stoned < enemies); }
sprintf(buf, "%d Personen %s versteinert.", sprintf(buf, "%d Personen %s versteinert.",
stoned, stoned == 1 ? "wurde" : "wurden"); stoned, stoned == 1 ? "wurde" : "wurden");
@ -250,7 +250,7 @@ sp_stun(fighter * fi, int level, double power, spell * sp)
battlerecord(b, buf); battlerecord(b, buf);
stunned = 0; stunned = 0;
do { while (force && stunned < enemies) {
troop dt = select_enemy(b, fi, minrow, maxrow); troop dt = select_enemy(b, fi, minrow, maxrow);
fighter * df = dt.fighter; fighter * df = dt.fighter;
unit * du = df->unit; unit * du = df->unit;
@ -260,7 +260,7 @@ sp_stun(fighter * fi, int level, double power, spell * sp)
df->person[dt.index].flags |= FL_STUNNED; df->person[dt.index].flags |= FL_STUNNED;
++stunned; ++stunned;
} }
} while (force && stunned < enemies); }
sprintf(buf, "%d Krieger %s für einen Moment benommen.", sprintf(buf, "%d Krieger %s für einen Moment benommen.",
stunned, stunned == 1 ? "ist" : "sind"); stunned, stunned == 1 ? "ist" : "sind");
@ -393,7 +393,7 @@ sp_sleep(fighter * fi, int level, double power, spell * sp)
scat(":"); scat(":");
battlerecord(b, buf); battlerecord(b, buf);
do { while (force && enemies) {
dt = select_enemy(b, fi, minrow, maxrow); dt = select_enemy(b, fi, minrow, maxrow);
assert(dt.fighter); assert(dt.fighter);
du = dt.fighter->unit; du = dt.fighter->unit;
@ -403,7 +403,7 @@ sp_sleep(fighter * fi, int level, double power, spell * sp)
--enemies; --enemies;
} }
--force; --force;
} while (force && enemies); }
sprintf(buf, "%d Krieger %s in Schlaf versetzt.", sprintf(buf, "%d Krieger %s in Schlaf versetzt.",
k, k == 1 ? "wurde" : "wurden"); k, k == 1 ? "wurde" : "wurden");
@ -467,7 +467,7 @@ sp_speed(fighter * fi, int level, double power, spell * sp)
* die Gefahr eine Endlosschleife*/ * die Gefahr eine Endlosschleife*/
allies *= 2; allies *= 2;
do { while (force && allies) {
troop dt = select_ally_in_row(fi, minrow, maxrow); troop dt = select_ally_in_row(fi, minrow, maxrow);
fighter *df = dt.fighter; fighter *df = dt.fighter;
--allies; --allies;
@ -479,7 +479,7 @@ sp_speed(fighter * fi, int level, double power, spell * sp)
--force; --force;
} }
} }
} while (force && allies); }
sprintf(buf, "%d Krieger %s magisch beschleunigt.", sprintf(buf, "%d Krieger %s magisch beschleunigt.",
targets, targets == 1 ? "wurde" : "wurden"); targets, targets == 1 ? "wurde" : "wurden");
@ -539,7 +539,7 @@ sp_mindblast(fighter * fi, int level, double power, spell * sp)
scat(":"); scat(":");
battlerecord(b, buf); battlerecord(b, buf);
do { while (force && enemies) {
dt = select_enemy(b, fi, minrow, maxrow); dt = select_enemy(b, fi, minrow, maxrow);
assert(dt.fighter); assert(dt.fighter);
du = dt.fighter->unit; du = dt.fighter->unit;
@ -559,7 +559,7 @@ sp_mindblast(fighter * fi, int level, double power, spell * sp)
++k; ++k;
} }
--force; --force;
} while (force && enemies); }
sprintf(buf, "%d Krieger %s Erinnerungen", k, k == 1 ? "verliert" : "verlieren"); sprintf(buf, "%d Krieger %s Erinnerungen", k, k == 1 ? "verliert" : "verlieren");
@ -613,12 +613,12 @@ sp_dragonodem(fighter * fi, int level, double power, spell * sp)
at.fighter = fi; at.fighter = fi;
at.index = 0; at.index = 0;
do { while (force && killed < enemies) {
dt = select_enemy(b, fi, minrow, maxrow); dt = select_enemy(b, fi, minrow, maxrow);
assert(dt.fighter); assert(dt.fighter);
--force; --force;
killed += terminate(dt, at, AT_COMBATSPELL, damage, false); killed += terminate(dt, at, AT_COMBATSPELL, damage, false);
} while (force && killed < enemies); }
sprintf(buf, "%d Personen %s getötet", sprintf(buf, "%d Personen %s getötet",
killed, killed == 1 ? "wurde" : "wurden"); killed, killed == 1 ? "wurde" : "wurden");
@ -662,12 +662,12 @@ sp_immolation(fighter * fi, int level, double power, spell * sp)
at.fighter = fi; at.fighter = fi;
at.index = 0; at.index = 0;
do { while (force && killed < enemies) {
dt = select_enemy(b, fi, minrow, maxrow); dt = select_enemy(b, fi, minrow, maxrow);
assert(dt.fighter); assert(dt.fighter);
--force; --force;
killed += terminate(dt, at, AT_COMBATSPELL, damage, false); killed += terminate(dt, at, AT_COMBATSPELL, damage, false);
} while (force && killed < enemies); }
sprintf(buf, "%d Personen %s getötet", sprintf(buf, "%d Personen %s getötet",
killed, killed == 1 ? "wurde" : "wurden"); killed, killed == 1 ? "wurde" : "wurden");
@ -711,7 +711,7 @@ sp_drainodem(fighter * fi, int level, double power, spell * sp)
at.fighter = fi; at.fighter = fi;
at.index = 0; at.index = 0;
do { while (force && drained < enemies) {
dt = select_enemy(b, fi, minrow, maxrow); dt = select_enemy(b, fi, minrow, maxrow);
assert(dt.fighter); assert(dt.fighter);
if (hits(at, dt, NULL)) { if (hits(at, dt, NULL)) {
@ -720,7 +720,7 @@ sp_drainodem(fighter * fi, int level, double power, spell * sp)
} }
killed += terminate(dt, at, AT_COMBATSPELL, damage, false); killed += terminate(dt, at, AT_COMBATSPELL, damage, false);
--force; --force;
} while (force && drained < enemies); }
sprintf(buf, "%d Person%s wurde ihre Lebenskraft entzogen", sprintf(buf, "%d Person%s wurde ihre Lebenskraft entzogen",
drained, drained == 1 ? " wurde" : "en wurden"); drained, drained == 1 ? " wurde" : "en wurden");
@ -1079,7 +1079,7 @@ sp_hero(fighter * fi, int level, double power, spell * sp)
* die Gefahr eine Endlosschleife*/ * die Gefahr eine Endlosschleife*/
allies *= 2; allies *= 2;
do { while (force && allies) {
troop dt = select_ally_in_row(fi, minrow, maxrow); troop dt = select_ally_in_row(fi, minrow, maxrow);
fighter *df = dt.fighter; fighter *df = dt.fighter;
--allies; --allies;
@ -1092,7 +1092,7 @@ sp_hero(fighter * fi, int level, double power, spell * sp)
--force; --force;
} }
} }
} while (force && allies); }
sprintf(buf, "%d Krieger %s moralisch gestärkt", sprintf(buf, "%d Krieger %s moralisch gestärkt",
targets, targets == 1 ? "wurde" : "wurden"); targets, targets == 1 ? "wurde" : "wurden");
@ -1139,7 +1139,7 @@ sp_berserk(fighter * fi, int level, double power, spell * sp)
* die Gefahr eine Endlosschleife*/ * die Gefahr eine Endlosschleife*/
allies *= 2; allies *= 2;
do { while (force && allies) {
troop dt = select_ally_in_row(fi, minrow, maxrow); troop dt = select_ally_in_row(fi, minrow, maxrow);
fighter *df = dt.fighter; fighter *df = dt.fighter;
--allies; --allies;
@ -1153,7 +1153,7 @@ sp_berserk(fighter * fi, int level, double power, spell * sp)
--force; --force;
} }
} }
} while (force && allies); }
sprintf(buf, "%d Krieger %s in Blutrausch versetzt", sprintf(buf, "%d Krieger %s in Blutrausch versetzt",
targets, targets == 1 ? "wurde" : "wurden"); targets, targets == 1 ? "wurde" : "wurden");
@ -1192,7 +1192,7 @@ sp_frighten(fighter * fi, int level, double power, spell * sp)
scat(":"); scat(":");
battlerecord(b, buf); battlerecord(b, buf);
do { while (force && enemies) {
troop dt = select_enemy(b, fi, minrow, maxrow); troop dt = select_enemy(b, fi, minrow, maxrow);
fighter *df = dt.fighter; fighter *df = dt.fighter;
--enemies; --enemies;
@ -1211,7 +1211,7 @@ sp_frighten(fighter * fi, int level, double power, spell * sp)
targets++; targets++;
} }
--force; --force;
} while (force && enemies); }
sprintf(buf, "%d Krieger %s eingeschüchtert", sprintf(buf, "%d Krieger %s eingeschüchtert",
targets, targets == 1 ? "wurde" : "wurden"); targets, targets == 1 ? "wurde" : "wurden");
@ -1299,7 +1299,7 @@ sp_windshield(fighter * fi, int level, double power, spell * sp)
return 0; return 0;
} }
do { while (force && enemies) {
troop dt = select_enemy(b, fi, minrow, maxrow); troop dt = select_enemy(b, fi, minrow, maxrow);
fighter *df = dt.fighter; fighter *df = dt.fighter;
--enemies; --enemies;
@ -1313,7 +1313,7 @@ sp_windshield(fighter * fi, int level, double power, spell * sp)
df->person[dt.index].attack -= at_malus; df->person[dt.index].attack -= at_malus;
--force; --force;
} }
} while (force && enemies); }
scat(": "); scat(": ");
scat("Ein Sturm kommt auf und die Schützen können kaum noch zielen."); scat("Ein Sturm kommt auf und die Schützen können kaum noch zielen.");