forked from github/server
- removing cruft
- fixing print_fighters() since list is not ordered by status anymore
This commit is contained in:
parent
573d283e92
commit
34fce9b8a7
4 changed files with 61 additions and 213 deletions
|
@ -404,15 +404,14 @@ hpflee(int status)
|
||||||
return 0.0;
|
return 0.0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int
|
static int
|
||||||
get_unitrow(const fighter * af)
|
get_row(const side * s, int row)
|
||||||
{
|
{
|
||||||
boolean counted[MAXSIDES];
|
boolean counted[MAXSIDES];
|
||||||
int enemyfront = 0;
|
int enemyfront = 0;
|
||||||
int line, result;
|
int line, result;
|
||||||
int retreat = 0;
|
int retreat = 0;
|
||||||
int size[NUMROWS];
|
int size[NUMROWS];
|
||||||
int row = statusrow(af->status);
|
|
||||||
int front = 0;
|
int front = 0;
|
||||||
|
|
||||||
memset(counted, 0, sizeof(counted));
|
memset(counted, 0, sizeof(counted));
|
||||||
|
@ -420,17 +419,19 @@ get_unitrow(const fighter * af)
|
||||||
for (line=FIRST_ROW;line!=NUMROWS;++line) {
|
for (line=FIRST_ROW;line!=NUMROWS;++line) {
|
||||||
int si;
|
int si;
|
||||||
/* how many enemies are there in the first row? */
|
/* how many enemies are there in the first row? */
|
||||||
for (si=0;af->side->enemies[si];++si) {
|
for (si=0;s->enemies[si];++si) {
|
||||||
side *s = af->side->enemies[si];
|
side *se = s->enemies[si];
|
||||||
if (s->size[line]>0) {
|
if (se->size[line]>0) {
|
||||||
int ai;
|
int ai;
|
||||||
enemyfront += s->size[line]; /* - s->nonblockers[line] (nicht, weil angreifer) */
|
enemyfront += se->size[line]; /* - s->nonblockers[line] (nicht, weil angreifer) */
|
||||||
for (ai=0;s->enemies[ai];++ai) {
|
for (ai=0;se->enemies[ai];++ai) {
|
||||||
side * ally = s->enemies[ai];
|
side * ally = se->enemies[ai];
|
||||||
if (!counted[ally->index] && !enemy(ally, af->side)) {
|
if (!counted[ally->index] && !enemy(ally, s)) {
|
||||||
int i;
|
int i;
|
||||||
counted[ally->index] = true;
|
counted[ally->index] = true;
|
||||||
for (i=0;i!=NUMROWS;++i) size[i] += ally->size[i] - ally->nonblockers[i];
|
for (i=0;i!=NUMROWS;++i) {
|
||||||
|
size[i] += ally->size[i] - ally->nonblockers[i];
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -453,17 +454,11 @@ get_unitrow(const fighter * af)
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if 0
|
int
|
||||||
static int
|
get_unitrow(const fighter * af)
|
||||||
sort_fighterrow(fighter ** elem1, fighter ** elem2)
|
|
||||||
{
|
{
|
||||||
int a, b;
|
return get_row(af->side, statusrow(af->status));
|
||||||
|
|
||||||
a = get_unitrow(*elem1);
|
|
||||||
b = get_unitrow(*elem2);
|
|
||||||
return (a < b) ? -1 : ((a == b) ? 0 : 1);
|
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
reportcasualties(battle * b, fighter * fig, int dead)
|
reportcasualties(battle * b, fighter * fig, int dead)
|
||||||
|
@ -1320,7 +1315,7 @@ select_opponent(battle * b, troop at, int minrow, int maxrow)
|
||||||
* cvector *fgs=fighters(b,af,FIGHT_ROW,BEHIND_ROW, FS_HELP|FS_ENEMY);
|
* cvector *fgs=fighters(b,af,FIGHT_ROW,BEHIND_ROW, FS_HELP|FS_ENEMY);
|
||||||
* fighter *fig;
|
* fighter *fig;
|
||||||
*
|
*
|
||||||
* Optional: Verwirbeln. Vorsicht: Aufwendig!
|
* Optional: Verwirbeln. Vorsicht: Aufwändig!
|
||||||
* v_scramble(fgs->begin, fgs->end);
|
* v_scramble(fgs->begin, fgs->end);
|
||||||
*
|
*
|
||||||
* for (fig = fgs->begin; fig != fgs->end; ++fig) {
|
* for (fig = fgs->begin; fig != fgs->end; ++fig) {
|
||||||
|
@ -2654,23 +2649,25 @@ battle_punit(unit * u, battle * b)
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
print_fighters(battle * b, fighter * fighters)
|
print_fighters(battle * b, const side * s)
|
||||||
{
|
{
|
||||||
fighter *df;
|
fighter *df;
|
||||||
int lastrow = -1;
|
int row;
|
||||||
|
|
||||||
for (df=fighters; df; df=df->next) {
|
for (row=1;row!=NUMROWS;++row) {
|
||||||
unit *du = df->unit;
|
int unitrow = get_row(s, row);
|
||||||
|
|
||||||
int row = get_unitrow(df);
|
for (df=s->fighters; df; df=df->next) {
|
||||||
|
unit *du = df->unit;
|
||||||
|
int thisrow = statusrow(df->unit->status);
|
||||||
|
|
||||||
if (row != lastrow) {
|
if (row == thisrow) {
|
||||||
message * m = msg_message("battle::row_header", "row", row);
|
message * m = msg_message("battle::row_header", "row", unitrow);
|
||||||
message_all(b, m);
|
message_all(b, m);
|
||||||
msg_release(m);
|
msg_release(m);
|
||||||
lastrow = row;
|
}
|
||||||
|
battle_punit(du, b);
|
||||||
}
|
}
|
||||||
battle_punit(du, b);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2794,7 +2791,7 @@ print_stats(battle * b)
|
||||||
}
|
}
|
||||||
battledebug(buf);
|
battledebug(buf);
|
||||||
}
|
}
|
||||||
print_fighters(b, s->fighters);
|
print_fighters(b, s);
|
||||||
}
|
}
|
||||||
|
|
||||||
battlerecord(b, " ");
|
battlerecord(b, " ");
|
||||||
|
@ -3787,65 +3784,6 @@ battle_stats(FILE * F, battle * b)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/** randomly shuffle an array of fighters.
|
|
||||||
* for correctness, see Donald E. Knuth, The Art of Computer Programming
|
|
||||||
*/
|
|
||||||
#if 0
|
|
||||||
static void
|
|
||||||
shuffle_fighters(fighter ** fighters, int n)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
for (i=0;i!=n;++i) {
|
|
||||||
int j = i + (rng_int() % (n-i));
|
|
||||||
fighter * fig = fighters[i];
|
|
||||||
fighters[i] = fighters[j];
|
|
||||||
fighters[j] = fig;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
|
||||||
sort_fighters(fighter ** fighters, int * rows, int N)
|
|
||||||
{
|
|
||||||
unsigned int n = N, i = n/2, parent, child;
|
|
||||||
int tr;
|
|
||||||
fighter * tf;
|
|
||||||
|
|
||||||
for (;;) {
|
|
||||||
if (i > 0) {
|
|
||||||
i--;
|
|
||||||
tr = rows[i];
|
|
||||||
tf = fighters[i];
|
|
||||||
} else {
|
|
||||||
n--;
|
|
||||||
if (n == 0) return;
|
|
||||||
tr = rows[n];
|
|
||||||
tf = fighters[n];
|
|
||||||
rows[n] = rows[0];
|
|
||||||
fighters[n] = fighters[0];
|
|
||||||
}
|
|
||||||
|
|
||||||
parent = i;
|
|
||||||
child = i*2 + 1;
|
|
||||||
|
|
||||||
while (child < n) {
|
|
||||||
if (child + 1 < n && rows[child + 1] > rows[child]) {
|
|
||||||
child++;
|
|
||||||
}
|
|
||||||
if (rows[child] > tr) {
|
|
||||||
rows[parent] = rows[child];
|
|
||||||
fighters[parent] = fighters[child];
|
|
||||||
parent = child;
|
|
||||||
child = parent*2 + 1;
|
|
||||||
} else {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
rows[parent] = tr;
|
|
||||||
fighters[parent] = tf;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/** execute one round of attacks
|
/** execute one round of attacks
|
||||||
* fig->fighting is used to determine who attacks, not fig->alive, since
|
* fig->fighting is used to determine who attacks, not fig->alive, since
|
||||||
* the latter may be influenced by attacks that already took place.
|
* the latter may be influenced by attacks that already took place.
|
||||||
|
@ -4033,35 +3971,6 @@ do_battle(void)
|
||||||
/* PRECOMBATSPELLS */
|
/* PRECOMBATSPELLS */
|
||||||
do_combatmagic(b, DO_PRECOMBATSPELL);
|
do_combatmagic(b, DO_PRECOMBATSPELL);
|
||||||
|
|
||||||
/* Nun erstellen wir eine Liste von allen Kämpfern, die wir
|
|
||||||
* dann scramblen. Zuerst werden sie wild gemischt, und dann wird (stabil)
|
|
||||||
* nach der Kampfreihe sortiert */
|
|
||||||
|
|
||||||
/* das ist wahrscheinlich alles nicht wichtig, sondern uralt */
|
|
||||||
#if 0
|
|
||||||
b->fighters = malloc(sizeof(fighter*)*b->nfighters);
|
|
||||||
for (i=0, s=b->sides; s; s=s->next) {
|
|
||||||
fighter * fig;
|
|
||||||
for (fig=s->fighters; fig; fig=fig->next) {
|
|
||||||
b->fighters[i++] = fig;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
assert(i<=b->nfighters);
|
|
||||||
shuffle_fighters(b->fighters, b->nfighters);
|
|
||||||
#endif
|
|
||||||
/*
|
|
||||||
rows = malloc(sizeof(int)*b->nfighters);
|
|
||||||
for (i=0;i!=b->nfighters;++i) {
|
|
||||||
rows[i] = get_unitrow(b->fighters[i]);
|
|
||||||
}
|
|
||||||
sort_fighters(b->fighters, rows, b->nfighters);
|
|
||||||
free(rows);
|
|
||||||
|
|
||||||
for (s = b->sides; s; s = s->next) {
|
|
||||||
v_sort(s->fighters.begin, s->fighters.end, (v_sort_fun) sort_fighterrow);
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
print_stats(b); /* gibt die Kampfaufstellung aus */
|
print_stats(b); /* gibt die Kampfaufstellung aus */
|
||||||
printf("%s (%d, %d) : ", rname(r, NULL), r->x, r->y);
|
printf("%s (%d, %d) : ", rname(r, NULL), r->x, r->y);
|
||||||
|
|
||||||
|
|
|
@ -58,9 +58,6 @@ extern "C" {
|
||||||
bfaction * factions;
|
bfaction * factions;
|
||||||
int nfactions;
|
int nfactions;
|
||||||
int nfighters;
|
int nfighters;
|
||||||
#if 0
|
|
||||||
struct fighter ** fighters;
|
|
||||||
#endif
|
|
||||||
struct side * sides;
|
struct side * sides;
|
||||||
int nsides;
|
int nsides;
|
||||||
cvector meffects;
|
cvector meffects;
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
/* vi: set ts=2:
|
/* vi: set ts=2:
|
||||||
*
|
*
|
||||||
*
|
*
|
||||||
* Eressea PB(E)M host Copyright (C) 1998-2003
|
* Eressea PB(E)M host Copyright (C) 1998-2003
|
||||||
* Christian Schlittchen (corwin@amber.kn-bremen.de)
|
* Christian Schlittchen (corwin@amber.kn-bremen.de)
|
||||||
* Katja Zedel (katze@felidae.kn-bremen.de)
|
* Katja Zedel (katze@felidae.kn-bremen.de)
|
||||||
* Henning Peters (faroul@beyond.kn-bremen.de)
|
* Henning Peters (faroul@beyond.kn-bremen.de)
|
||||||
|
@ -31,124 +31,70 @@
|
||||||
void
|
void
|
||||||
cv_init(cvector * cv)
|
cv_init(cvector * cv)
|
||||||
{
|
{
|
||||||
cv->begin = 0;
|
cv->begin = 0;
|
||||||
cv->end = 0;
|
cv->end = 0;
|
||||||
cv->space = 0;
|
cv->space = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
cvector *
|
cvector *
|
||||||
cv_kill(cvector * cv)
|
cv_kill(cvector * cv)
|
||||||
{
|
{
|
||||||
if (cv->begin) free(cv->begin);
|
if (cv->begin) free(cv->begin);
|
||||||
cv_init(cv);
|
cv_init(cv);
|
||||||
return cv;
|
return cv;
|
||||||
}
|
}
|
||||||
|
|
||||||
size_t
|
size_t
|
||||||
cv_size(cvector * cv)
|
cv_size(cvector * cv)
|
||||||
{
|
{
|
||||||
return cv->end - cv->begin;
|
return cv->end - cv->begin;
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
cv_reserve(cvector * cv, size_t size)
|
cv_reserve(cvector * cv, size_t size)
|
||||||
{
|
{
|
||||||
size_t count = cv->end - cv->begin;
|
size_t count = cv->end - cv->begin;
|
||||||
cv->begin = realloc(cv->begin, size * sizeof(void *));
|
cv->begin = realloc(cv->begin, size * sizeof(void *));
|
||||||
|
|
||||||
cv->space = size;
|
cv->space = size;
|
||||||
cv->end = cv->begin + count;
|
cv->end = cv->begin + count;
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
cv_pushback(cvector * cv, void *u)
|
cv_pushback(cvector * cv, void *u)
|
||||||
{
|
{
|
||||||
if (cv->space == cv_size(cv))
|
if (cv->space == cv_size(cv))
|
||||||
cv_reserve(cv, cv->space ? cv->space * 2 : 2);
|
cv_reserve(cv, cv->space ? cv->space * 2 : 2);
|
||||||
*(cv->end++) = u;
|
*(cv->end++) = u;
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
v_sort(void **begin, void **end, int (__cdecl * compare) (const void *, const void *))
|
|
||||||
{
|
|
||||||
qsort(begin, end - begin, sizeof(void *), compare);
|
|
||||||
}
|
|
||||||
|
|
||||||
void **
|
|
||||||
v_find(void **begin, void **end, void *item)
|
|
||||||
{
|
|
||||||
void **it;
|
|
||||||
|
|
||||||
for (it = begin; it != end; ++it)
|
|
||||||
if (*it == item)
|
|
||||||
return it;
|
|
||||||
return it;
|
|
||||||
}
|
|
||||||
|
|
||||||
void **
|
|
||||||
v_findx(void **begin, void **end, void *item, int (__cdecl * cmp) (void *, void *))
|
|
||||||
{
|
|
||||||
void **it;
|
|
||||||
|
|
||||||
for (it = begin; it != end; ++it)
|
|
||||||
if (cmp(*it, item))
|
|
||||||
return it;
|
|
||||||
return it;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
__cv_scramblecmp(const void *p1, const void *p2)
|
__cv_scramblecmp(const void *p1, const void *p2)
|
||||||
{
|
{
|
||||||
return *((long *) p1) - *((long *) p2);
|
return *((long *) p1) - *((long *) p2);
|
||||||
}
|
}
|
||||||
|
|
||||||
#define addptr(p,i) ((void *)(((char *)p) + i))
|
#define addptr(p,i) ((void *)(((char *)p) + i))
|
||||||
|
|
||||||
void
|
/** randomly shuffle an array
|
||||||
|
* for correctness, see Donald E. Knuth, The Art of Computer Programming
|
||||||
|
*/
|
||||||
|
static void
|
||||||
__cv_scramble(void *v1, size_t n, size_t width)
|
__cv_scramble(void *v1, size_t n, size_t width)
|
||||||
{
|
{
|
||||||
size_t i;
|
size_t i;
|
||||||
static size_t s = 0;
|
void * temp = malloc(width);
|
||||||
static void *v = 0;
|
for (i=0;i!=n;++i) {
|
||||||
|
size_t j = i + (rng_int() % (n-i));
|
||||||
if (n * (width + 4) > s) {
|
memcpy(temp, addptr(v1, i*width), width);
|
||||||
s = n * (width + 4);
|
memcpy(addptr(v1, i*width), addptr(v1, j*width), width);
|
||||||
v = (void *) realloc(v, s);
|
memcpy(addptr(v1, j*width), temp, width);
|
||||||
}
|
}
|
||||||
for (i = 0; i != n; i++) {
|
free(temp);
|
||||||
*(long *) addptr(v, i * (width + 4)) = rng_int();
|
|
||||||
memcpy(addptr(v, i * (width + 4) + 4), addptr(v1, i * width), width);
|
|
||||||
}
|
|
||||||
|
|
||||||
qsort(v, n, width + 4, __cv_scramblecmp);
|
|
||||||
|
|
||||||
for (i = 0; i != n; i++)
|
|
||||||
memcpy(addptr(v1, i * width), addptr(v, i * (width + 4) + 4), width);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
v_scramble(void **begin, void **end)
|
v_scramble(void **begin, void **end)
|
||||||
{
|
{
|
||||||
__cv_scramble(begin, end - begin, sizeof(void *));
|
__cv_scramble(begin, end - begin, sizeof(void *));
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
cv_mergeunique(cvector * c, const cvector * a, const cvector * b, int (__cdecl * keyfun) (const void *))
|
|
||||||
{
|
|
||||||
void **ai, **bi;
|
|
||||||
|
|
||||||
assert(cv_size(c) == 0);
|
|
||||||
|
|
||||||
for (ai = a->begin, bi = b->begin; ai != a->end || bi != b->end;) {
|
|
||||||
int ak = (ai == a->end) ? INT_MAX : keyfun(*ai);
|
|
||||||
int bk = (bi == b->end) ? INT_MAX : keyfun(*bi);
|
|
||||||
int nk = (ak < bk) ? ak : bk;
|
|
||||||
|
|
||||||
cv_pushback(c, (ak == nk) ? (*ai) : (*bi));
|
|
||||||
while (ai != a->end && keyfun(*ai) == nk)
|
|
||||||
++ai;
|
|
||||||
while (bi != b->end && keyfun(*bi) == nk)
|
|
||||||
++bi;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -40,11 +40,7 @@ cvector *cv_kill(cvector * cv);
|
||||||
size_t cv_size(cvector * cv);
|
size_t cv_size(cvector * cv);
|
||||||
void cv_reserve(cvector * cv, size_t size);
|
void cv_reserve(cvector * cv, size_t size);
|
||||||
void cv_pushback(cvector * cv, void *u);
|
void cv_pushback(cvector * cv, void *u);
|
||||||
void v_sort(void **begin, void **end, int (__cdecl * compare) (const void *, const void *));
|
|
||||||
extern void **v_find(void **begin, void **end, void *);
|
|
||||||
extern void **v_findx(void **begin, void **end, void *, int (__cdecl * cmp) (void *, void *));
|
|
||||||
void v_scramble(void **begin, void **end);
|
void v_scramble(void **begin, void **end);
|
||||||
void cv_mergeunique(cvector * c, const cvector * a, const cvector * b, int (__cdecl * keyfun) (const void *));
|
|
||||||
|
|
||||||
#define cv_remove(c, i) { void** x = v_find((c)->begin, (c)->end, (i)); if (x) { *x = *(c)->end; (c)->end--; } }
|
#define cv_remove(c, i) { void** x = v_find((c)->begin, (c)->end, (i)); if (x) { *x = *(c)->end; (c)->end--; } }
|
||||||
#define cv_foreach(item, vector) \
|
#define cv_foreach(item, vector) \
|
||||||
|
|
Loading…
Reference in a new issue