forked from github/server
SIMPLE_COMBAT enables new combat rules: - guard command shortens combat - combat in non-land is always short - ships take (rounds-1)*5% damage fixed a crash in xmlreader.
This commit is contained in:
parent
3b180b2980
commit
b116026d1d
2 changed files with 88 additions and 79 deletions
|
@ -1494,6 +1494,15 @@ do_combatmagic(battle *b, combatmagic_t was)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
combat_action(fighter * af, int turn)
|
||||||
|
{
|
||||||
|
#ifndef SIMPLE_COMBAT
|
||||||
|
af->action_counter++;
|
||||||
|
af->side->bf->lastturn = turn;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
do_combatspell(troop at)
|
do_combatspell(troop at)
|
||||||
|
@ -1565,10 +1574,7 @@ do_combatspell(troop at)
|
||||||
level = ((cspell_f)sp->sp_function)(fi, level, power, sp);
|
level = ((cspell_f)sp->sp_function)(fi, level, power, sp);
|
||||||
if (level > 0) {
|
if (level > 0) {
|
||||||
pay_spell(mage, sp, level, 1);
|
pay_spell(mage, sp, level, 1);
|
||||||
#ifndef SIMPLE_COMBAT
|
combat_action(at.fighter, b->turn);
|
||||||
at.fighter->action_counter++;
|
|
||||||
at.fighter->side->bf->lastturn = b->turn;
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1978,10 +1984,7 @@ attack(battle *b, troop ta, const att *a, int numattack)
|
||||||
af->catmsg += dead;
|
af->catmsg += dead;
|
||||||
if (!standard_attack && af->person[ta.index].last_action < b->turn) {
|
if (!standard_attack && af->person[ta.index].last_action < b->turn) {
|
||||||
af->person[ta.index].last_action = b->turn;
|
af->person[ta.index].last_action = b->turn;
|
||||||
#ifndef SIMPLE_COMBAT
|
combat_action(af, b->turn);
|
||||||
af->action_counter++;
|
|
||||||
af->side->bf->lastturn = b->turn;
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (standard_attack) {
|
if (standard_attack) {
|
||||||
|
@ -1996,10 +1999,7 @@ attack(battle *b, troop ta, const att *a, int numattack)
|
||||||
if (!td.fighter) return;
|
if (!td.fighter) return;
|
||||||
if (ta.fighter->person[ta.index].last_action < b->turn) {
|
if (ta.fighter->person[ta.index].last_action < b->turn) {
|
||||||
ta.fighter->person[ta.index].last_action = b->turn;
|
ta.fighter->person[ta.index].last_action = b->turn;
|
||||||
#ifndef SIMPLE_COMBAT
|
combat_action(ta.fighter, b->turn);
|
||||||
ta.fighter->action_counter++;
|
|
||||||
ta.fighter->side->bf->lastturn = b->turn;
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
reload = true;
|
reload = true;
|
||||||
if (hits(ta, td, wp)) {
|
if (hits(ta, td, wp)) {
|
||||||
|
@ -2026,10 +2026,7 @@ attack(battle *b, troop ta, const att *a, int numattack)
|
||||||
if (!td.fighter) return;
|
if (!td.fighter) return;
|
||||||
if(ta.fighter->person[ta.index].last_action < b->turn) {
|
if(ta.fighter->person[ta.index].last_action < b->turn) {
|
||||||
ta.fighter->person[ta.index].last_action = b->turn;
|
ta.fighter->person[ta.index].last_action = b->turn;
|
||||||
#ifndef SIMPLE_COMBAT
|
combat_action(ta.fighter, b->turn);
|
||||||
ta.fighter->action_counter++;
|
|
||||||
ta.fighter->side->bf->lastturn = b->turn;
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
if (hits(ta, td, NULL)) {
|
if (hits(ta, td, NULL)) {
|
||||||
terminate(td, ta, a->type, a->data.dice, false);
|
terminate(td, ta, a->type, a->data.dice, false);
|
||||||
|
@ -2040,10 +2037,7 @@ attack(battle *b, troop ta, const att *a, int numattack)
|
||||||
if (!td.fighter) return;
|
if (!td.fighter) return;
|
||||||
if(ta.fighter->person[ta.index].last_action < b->turn) {
|
if(ta.fighter->person[ta.index].last_action < b->turn) {
|
||||||
ta.fighter->person[ta.index].last_action = b->turn;
|
ta.fighter->person[ta.index].last_action = b->turn;
|
||||||
#ifndef SIMPLE_COMBAT
|
combat_action(ta.fighter, b->turn);
|
||||||
ta.fighter->action_counter++;
|
|
||||||
ta.fighter->side->bf->lastturn = b->turn;
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
if (hits(ta, td, NULL)) {
|
if (hits(ta, td, NULL)) {
|
||||||
int c = dice_rand(a->data.dice);
|
int c = dice_rand(a->data.dice);
|
||||||
|
@ -2062,10 +2056,7 @@ attack(battle *b, troop ta, const att *a, int numattack)
|
||||||
if (!td.fighter) return;
|
if (!td.fighter) return;
|
||||||
if(ta.fighter->person[ta.index].last_action < b->turn) {
|
if(ta.fighter->person[ta.index].last_action < b->turn) {
|
||||||
ta.fighter->person[ta.index].last_action = b->turn;
|
ta.fighter->person[ta.index].last_action = b->turn;
|
||||||
#ifndef SIMPLE_COMBAT
|
combat_action(ta.fighter, b->turn);
|
||||||
ta.fighter->action_counter++;
|
|
||||||
ta.fighter->side->bf->lastturn = b->turn;
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
if (hits(ta, td, NULL)) {
|
if (hits(ta, td, NULL)) {
|
||||||
drain_exp(td.fighter->unit, dice_rand(a->data.dice));
|
drain_exp(td.fighter->unit, dice_rand(a->data.dice));
|
||||||
|
@ -2076,10 +2067,7 @@ attack(battle *b, troop ta, const att *a, int numattack)
|
||||||
if (!td.fighter) return;
|
if (!td.fighter) return;
|
||||||
if(ta.fighter->person[ta.index].last_action < b->turn) {
|
if(ta.fighter->person[ta.index].last_action < b->turn) {
|
||||||
ta.fighter->person[ta.index].last_action = b->turn;
|
ta.fighter->person[ta.index].last_action = b->turn;
|
||||||
#ifndef SIMPLE_COMBAT
|
combat_action(ta.fighter, b->turn);
|
||||||
ta.fighter->action_counter++;
|
|
||||||
ta.fighter->side->bf->lastturn = b->turn;
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
if (hits(ta, td, NULL)) {
|
if (hits(ta, td, NULL)) {
|
||||||
dazzle(b, &td);
|
dazzle(b, &td);
|
||||||
|
@ -2090,10 +2078,7 @@ attack(battle *b, troop ta, const att *a, int numattack)
|
||||||
if (!td.fighter) return;
|
if (!td.fighter) return;
|
||||||
if(ta.fighter->person[ta.index].last_action < b->turn) {
|
if(ta.fighter->person[ta.index].last_action < b->turn) {
|
||||||
ta.fighter->person[ta.index].last_action = b->turn;
|
ta.fighter->person[ta.index].last_action = b->turn;
|
||||||
#ifndef SIMPLE_COMBAT
|
combat_action(ta.fighter, b->turn);
|
||||||
ta.fighter->action_counter++;
|
|
||||||
ta.fighter->side->bf->lastturn = b->turn;
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
if (td.fighter->unit->ship) {
|
if (td.fighter->unit->ship) {
|
||||||
td.fighter->unit->ship->damage += DAMAGE_SCALE * dice_rand(a->data.dice);
|
td.fighter->unit->ship->damage += DAMAGE_SCALE * dice_rand(a->data.dice);
|
||||||
|
@ -2212,11 +2197,29 @@ static int nextside = 0;
|
||||||
/** add a new army to the conflict
|
/** add a new army to the conflict
|
||||||
* beware: armies need to be added _at the beginning_ of the list because
|
* beware: armies need to be added _at the beginning_ of the list because
|
||||||
* otherwise join_allies() will get into trouble */
|
* otherwise join_allies() will get into trouble */
|
||||||
side *
|
static side *
|
||||||
make_side(battle * b, const faction * f, const group * g, unsigned int flags, const faction *stealthfaction)
|
make_side(battle * b, const faction * f, const group * g, unsigned int flags, const faction *stealthfaction)
|
||||||
{
|
{
|
||||||
side *s1 = calloc(sizeof(struct side), 1);
|
side *s1 = calloc(sizeof(struct side), 1);
|
||||||
bfaction * bf;
|
bfaction * bf;
|
||||||
|
unit * u;
|
||||||
|
|
||||||
|
#ifdef SIMPLE_COMBAT
|
||||||
|
if (!fval(b->region->terrain, LAND_REGION)) {
|
||||||
|
/* in ozeanregionen ist jeder kampf kurz */
|
||||||
|
flags |= SIDE_HASGUARDS;
|
||||||
|
} else {
|
||||||
|
for (u = b->region->units; u; u = u->next) {
|
||||||
|
if (getguard(u)) {
|
||||||
|
faction *fv = visible_faction(f, u);
|
||||||
|
if (alliedunit(u, fv, HELP_GUARD)) {
|
||||||
|
flags |= SIDE_HASGUARDS;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
s1->battle = b;
|
s1->battle = b;
|
||||||
s1->group = g;
|
s1->group = g;
|
||||||
|
@ -2413,9 +2416,10 @@ aftermath(battle * b)
|
||||||
for (s=b->sides;s;s=s->next) {
|
for (s=b->sides;s;s=s->next) {
|
||||||
int snumber = 0;
|
int snumber = 0;
|
||||||
fighter *df;
|
fighter *df;
|
||||||
#ifndef SIMPLE_COMBAT
|
|
||||||
boolean relevant = false; /* Kampf relevant für diese Partei? */
|
boolean relevant = false; /* Kampf relevant für diese Partei? */
|
||||||
|
#ifdef SIMPLE_COMBAT
|
||||||
|
if (fval(s, SIDE_HASGUARDS) == 0) relevant = true;
|
||||||
|
#else
|
||||||
if (s->bf->lastturn>1) {
|
if (s->bf->lastturn>1) {
|
||||||
relevant = true;
|
relevant = true;
|
||||||
} else if (s->bf->lastturn==1 && b->has_tactics_turn) {
|
} else if (s->bf->lastturn==1 && b->has_tactics_turn) {
|
||||||
|
@ -2436,9 +2440,19 @@ aftermath(battle * b)
|
||||||
int sum_hp = 0;
|
int sum_hp = 0;
|
||||||
int n;
|
int n;
|
||||||
|
|
||||||
|
for (n = 0; n != df->alive; ++n) {
|
||||||
|
if (df->person[n].hp > 0) {
|
||||||
|
sum_hp += df->person[n].hp;
|
||||||
|
}
|
||||||
|
}
|
||||||
snumber += du->number;
|
snumber += du->number;
|
||||||
#ifdef SIMPLE_COMBAT
|
#ifdef SIMPLE_COMBAT
|
||||||
if (battle_was_relevant) {
|
if (relevant) {
|
||||||
|
/* didn't have any help from the guards, so combat is long */
|
||||||
|
fset(du, UFL_NOTMOVING|UFL_LONGACTION);
|
||||||
|
}
|
||||||
|
if (sum_hp<du->hp) {
|
||||||
|
/* someone on the ship got damaged, damage the ship */
|
||||||
ship * sh = du->ship?du->ship:leftship(du);
|
ship * sh = du->ship?du->ship:leftship(du);
|
||||||
if (sh) fset(sh, SF_DAMAGED);
|
if (sh) fset(sh, SF_DAMAGED);
|
||||||
}
|
}
|
||||||
|
@ -2452,11 +2466,6 @@ aftermath(battle * b)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
for (n = 0; n != df->alive; ++n) {
|
|
||||||
if (df->person[n].hp > 0) {
|
|
||||||
sum_hp += df->person[n].hp;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (df->alive == du->number) {
|
if (df->alive == du->number) {
|
||||||
du->hp = sum_hp;
|
du->hp = sum_hp;
|
||||||
|
@ -2563,6 +2572,10 @@ aftermath(battle * b)
|
||||||
msg_release(seen);
|
msg_release(seen);
|
||||||
msg_release(unseen);
|
msg_release(unseen);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (battle_was_relevant) {
|
||||||
|
ship **sp = &r->ships;
|
||||||
|
|
||||||
/* Wir benutzen drifted, um uns zu merken, ob ein Schiff
|
/* Wir benutzen drifted, um uns zu merken, ob ein Schiff
|
||||||
* schonmal Schaden genommen hat. (moved und drifted
|
* schonmal Schaden genommen hat. (moved und drifted
|
||||||
* sollten in flags überführt werden */
|
* sollten in flags überführt werden */
|
||||||
|
@ -2587,15 +2600,15 @@ aftermath(battle * b)
|
||||||
|
|
||||||
if (du->ship) sh = du->ship; else sh = leftship(du);
|
if (du->ship) sh = du->ship; else sh = leftship(du);
|
||||||
|
|
||||||
if (sh && fval(sh, SF_DAMAGED) && b->turn+(b->has_tactics_turn?1:0)>2) {
|
if (sh && fval(sh, SF_DAMAGED)) {
|
||||||
damage_ship(sh, 0.20);
|
int n = b->turn - 1;
|
||||||
freset(sh, SF_DAMAGED);
|
if (n>0) {
|
||||||
|
damage_ship(sh, 0.05 * n);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (battle_was_relevant) {
|
|
||||||
ship **sp = &r->ships;
|
|
||||||
while (*sp) {
|
while (*sp) {
|
||||||
ship * sh = *sp;
|
ship * sh = *sp;
|
||||||
freset(sh, SF_DAMAGED);
|
freset(sh, SF_DAMAGED);
|
||||||
|
@ -2871,9 +2884,6 @@ make_fighter(battle * b, unit * u, side * s1, boolean attack)
|
||||||
|
|
||||||
assert(u->number);
|
assert(u->number);
|
||||||
if (fval(u, UFL_PARTEITARNUNG)!=0) flags |= SIDE_STEALTH;
|
if (fval(u, UFL_PARTEITARNUNG)!=0) flags |= SIDE_STEALTH;
|
||||||
#ifdef SIMPLE_COMBAT
|
|
||||||
if (attack) flags |= SIDE_HASGUARDS;
|
|
||||||
#endif
|
|
||||||
if (!init) {
|
if (!init) {
|
||||||
it_demonseye = it_find("demonseye");
|
it_demonseye = it_find("demonseye");
|
||||||
init=true;
|
init=true;
|
||||||
|
@ -2899,7 +2909,9 @@ make_fighter(battle * b, unit * u, side * s1, boolean attack)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* aliances are moved out of make_fighter and will be handled later */
|
/* aliances are moved out of make_fighter and will be handled later */
|
||||||
if (!s1) s1 = make_side(b, u->faction, g, flags, stealthfaction);
|
if (!s1) {
|
||||||
|
s1 = make_side(b, u->faction, g, flags, stealthfaction);
|
||||||
|
}
|
||||||
/* Zu diesem Zeitpunkt ist attacked noch 0, da die Einheit für noch
|
/* Zu diesem Zeitpunkt ist attacked noch 0, da die Einheit für noch
|
||||||
* keinen Kampf ausgewählt wurde (sonst würde ein fighter existieren) */
|
* keinen Kampf ausgewählt wurde (sonst würde ein fighter existieren) */
|
||||||
}
|
}
|
||||||
|
@ -3714,9 +3726,6 @@ init_battle(region * r, battle **bp)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
/* Ende Fehlerbehandlung */
|
/* Ende Fehlerbehandlung */
|
||||||
#ifdef SIMPLE_COMBAT
|
|
||||||
fset(u, UFL_LONGACTION);
|
|
||||||
#endif
|
|
||||||
if (b==NULL) {
|
if (b==NULL) {
|
||||||
unit * utmp;
|
unit * utmp;
|
||||||
for (utmp=r->units; utmp!=NULL; utmp=utmp->next) {
|
for (utmp=r->units; utmp!=NULL; utmp=utmp->next) {
|
||||||
|
|
|
@ -1721,7 +1721,7 @@ parse_messages(xmlDocPtr doc)
|
||||||
/* arguments */
|
/* arguments */
|
||||||
xpath->node = node;
|
xpath->node = node;
|
||||||
result = xmlXPathEvalExpression(BAD_CAST "type/arg", xpath);
|
result = xmlXPathEvalExpression(BAD_CAST "type/arg", xpath);
|
||||||
if (result->nodesetval->nodeNr>0) {
|
if (result->nodesetval && result->nodesetval->nodeNr>0) {
|
||||||
argv = malloc(sizeof(char*)*(result->nodesetval->nodeNr+1));
|
argv = malloc(sizeof(char*)*(result->nodesetval->nodeNr+1));
|
||||||
for (k=0;k!=result->nodesetval->nodeNr;++k) {
|
for (k=0;k!=result->nodesetval->nodeNr;++k) {
|
||||||
xmlNodePtr node = result->nodesetval->nodeTab[k];
|
xmlNodePtr node = result->nodesetval->nodeTab[k];
|
||||||
|
|
Loading…
Reference in a new issue