- order in nr is now same as in template again.

- generation for list of reigons is getting slower, though
This commit is contained in:
Enno Rehling 2002-05-03 23:27:45 +00:00
parent 03a967c2c4
commit a79501bb78
2 changed files with 33 additions and 10 deletions

View file

@ -2470,7 +2470,6 @@ merian(FILE * out, faction * f)
#endif #endif
seen_region * seen; seen_region * seen;
seen_region * reuse; seen_region * reuse;
seen_region** append;
seen_region * last; seen_region * last;
#define MAXSEEHASH 4095 #define MAXSEEHASH 4095
@ -2554,18 +2553,43 @@ add_seen(const struct region * r, unsigned char mode, boolean dis)
{ {
seen_region * find = find_seen(r); seen_region * find = find_seen(r);
if (find==NULL) { if (find==NULL) {
seen_region * insert;
int index = abs((r->x & 0xffff) + ((r->y) << 16)) % MAXSEEHASH; int index = abs((r->x & 0xffff) + ((r->y) << 16)) % MAXSEEHASH;
if (!reuse) reuse = (seen_region*)calloc(1, sizeof(struct seen_region)); if (!reuse) reuse = (seen_region*)calloc(1, sizeof(struct seen_region));
*append = find = reuse; find = reuse;
reuse = reuse->next; reuse = reuse->next;
find->nextHash = seehash[index]; find->nextHash = seehash[index];
seehash[index] = find; seehash[index] = find;
find->r = r; find->r = r;
if (last) last->next = find;
find->next = NULL; for (insert=last;insert;insert=insert->next) {
find->prev = last; const region * rl;
seen_region * inext = insert->next;
for (rl=insert->r;rl && (!inext || rl!=inext->r);rl=rl->next) {
if (rl==r) break;
}
if (rl==r) break;
}
if (insert==0) {
for (insert=seen;insert!=last;insert=insert->next) {
const region * rl;
seen_region * inext = insert->next;
for (rl=insert->r;rl && (!inext || rl!=inext->r);rl=rl->next) {
if (rl==r) break;
}
if (rl==r) break;
}
if (insert==last) insert=0;
}
last = find; last = find;
append = &last->next; find->prev = insert;
if (insert!=0) {
find->next = insert->next;
insert->next = find;
} else {
find->next = seen;
seen = find;
}
} else if (find->mode >= mode) { } else if (find->mode >= mode) {
return false; return false;
} }
@ -2676,14 +2700,13 @@ prepare_report(faction * f)
{ {
region * r; region * r;
region * end = lastregion(f); region * end = lastregion(f);
seen_region ** append = &reuse;
append = &reuse;
memset(seehash, 0, sizeof(seehash));
while (*append) append = &(*append)->next; while (*append) append = &(*append)->next;
*append = seen; *append = seen;
memset(seehash, 0, sizeof(seehash));
seen = NULL; seen = NULL;
last = NULL; last = NULL;
append = &seen;
for (r = firstregion(f); r != end; r = r->next) { for (r = firstregion(f); r != end; r = r->next) {
attrib *ru; attrib *ru;
unit * u; unit * u;

View file

@ -865,7 +865,7 @@ use_tacticcrystal(region * r, unit * u, int amount, strlist * cmdstrings)
int power = 5; /* Widerstand gegen Antimagiesprüche, ist in diesem int power = 5; /* Widerstand gegen Antimagiesprüche, ist in diesem
Fall egal, da der curse für den Kampf gelten soll, Fall egal, da der curse für den Kampf gelten soll,
der vor den Antimagiezaubern passiert */ der vor den Antimagiezaubern passiert */
curse * c = create_curse(u, &u->attribs, ct_find("skill"), power, curse * c = create_curse(u, &u->attribs, ct_find("skillmod"), power,
duration, effect, u->number); duration, effect, u->number);
c->data = (void*)SK_TACTICS; c->data = (void*)SK_TACTICS;
unused(cmdstrings); unused(cmdstrings);