the report's address list is now a quicklist. A bit faster perhaps, and less memory? One less reason to have the faction_list struct, at least.

This commit is contained in:
Enno Rehling 2011-02-24 22:29:21 -08:00
parent a538c52bc4
commit 831de3dd55
5 changed files with 40 additions and 22 deletions

View file

@ -63,6 +63,7 @@ without prior permission by the authors of Eressea.
#include <util/log.h>
#include <util/message.h>
#include <util/nrmessage.h>
#include <util/quicklist.h>
#include <libxml/encoding.h>
@ -959,11 +960,12 @@ show_active_spells(const region * r)
/* this is a copy of laws.c->find_address output changed. */
static void
cr_find_address(FILE * F, const faction * uf, const faction_list * addresses)
cr_find_address(FILE * F, const faction * uf, quicklist * addresses)
{
const faction_list * flist = addresses;
while (flist!=NULL) {
const faction * f = flist->data;
int i = 0;
quicklist * flist = addresses;
while (flist) {
const faction * f = (const faction *)ql_get(flist, i);
if (uf!=f) {
fprintf(F, "PARTEI %d\n", f->no);
fprintf(F, "\"%s\";Parteiname\n", f->name);
@ -974,7 +976,7 @@ cr_find_address(FILE * F, const faction * uf, const faction_list * addresses)
fprintf(F, "%d;alliance\n", f->alliance->id);
}
}
flist = flist->next;
ql_advance(&flist, &i, 1);
}
}
/* = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = */

View file

@ -76,6 +76,7 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
#include <util/log.h>
#include <util/message.h>
#include <util/nrmessage.h>
#include <util/quicklist.h>
#include <util/rng.h>
#include <libxml/encoding.h>
@ -1700,15 +1701,16 @@ rpline(FILE * F)
}
static void
list_address(FILE * F, const faction * uf, const faction_list * seenfactions)
list_address(FILE * F, const faction * uf, quicklist * seenfactions)
{
const faction_list *flist = seenfactions;
int qi = 0;
quicklist * flist = seenfactions;
centre(F, LOC(uf->locale, "nr_addresses"), false);
rnl(F);
while (flist!=NULL) {
const faction * f = flist->data;
const faction * f = (const faction *)ql_get(flist, qi);
if (!is_monsters(f)) {
char buf[8192];
char label = '-';
@ -1720,7 +1722,7 @@ list_address(FILE * F, const faction * uf, const faction_list * seenfactions)
rparagraph(F, buf, 4, 0, label);
}
flist = flist->next;
ql_advance(&flist, &qi, 1);
}
rnl(F);
rpline(F);

View file

@ -672,7 +672,8 @@ xml_region(report_context * ctx, seen_region * sr)
static xmlNodePtr
report_root(report_context * ctx)
{
const faction_list * address;
int qi;
quicklist * address;
region * r = ctx->first, * rend = ctx->last;
xml_context* xct = (xml_context*)ctx->userdata;
xmlNodePtr node, child, xmlReport = xmlNewNode(NULL, BAD_CAST "atlantis");
@ -697,9 +698,9 @@ report_root(report_context * ctx)
xmlNewTextChild(node, xct->ns_atl, BAD_CAST "time", (xmlChar *)zText);
xmlNewTextChild(node, xct->ns_atl, BAD_CAST "turn", (xmlChar *)itoab(turn, 10));
for (address=ctx->addresses;address;address=address->next) {
xmlAddChild(xmlReport, xml_faction(ctx, address->data));
for (qi=0,address=ctx->addresses;address;ql_advance(&address, &qi, 1)) {
faction * f = (faction *)ql_get(address, qi);
xmlAddChild(xmlReport, xml_faction(ctx, f));
}
for (;r!=rend;r=r->next) {

View file

@ -51,6 +51,7 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
#include <util/language.h>
#include <util/lists.h>
#include <util/log.h>
#include <util/quicklist.h>
/* libc includes */
#include <sys/stat.h>
@ -899,6 +900,15 @@ stealth_modifier(int seen_mode)
}
}
void transfer_seen(quicklist ** dst, faction_list ** src) {
while (*src) {
faction_list * flist = *src;
ql_set_insert(dst, flist->data);
free(flist);
*src = flist->next;
}
}
static void
get_addresses(report_context * ctx)
{
@ -906,18 +916,21 @@ get_addresses(report_context * ctx)
seen_region * sr = NULL;
region *r;
const faction * lastf = NULL;
faction_list * flist = ctx->f->seen_factions;
quicklist * flist = 0;
transfer_seen(&flist, &ctx->f->seen_factions);
ctx->f->seen_factions = NULL; /* do not delete it twice */
flist_add(&flist, ctx->f);
ql_push(&flist, ctx->f);
if (f_get_alliance(ctx->f)) {
faction_list * member = ctx->f->alliance->members;
for (;member;member=member->next) {
flist_add(&flist, member->data);
ql_set_insert(&flist, member->data);
}
}
/* find the first region that this faction can see */
for (r=ctx->first;sr==NULL && r!=ctx->last;r=r->next) {
sr = find_seen(ctx->seen, r);
}
@ -931,7 +944,7 @@ get_addresses(report_context * ctx)
faction * sf = visible_faction(ctx->f, u);
if (lastf!=sf) {
if (u->building || u->ship || (stealthmod>INT_MIN && cansee(ctx->f, r, u, stealthmod))) {
flist_add(&flist, sf);
ql_set_insert(&flist, sf);
lastf = sf;
}
}
@ -947,7 +960,7 @@ get_addresses(report_context * ctx)
unit * u2 = (unit*)a->data.v;
if (u2->faction==ctx->f) {
if (cansee_unit(u2, u, stealthmod)) {
flist_add(&flist, sf);
ql_set_insert(&flist, sf);
lastf = sf;
break;
}
@ -965,7 +978,7 @@ get_addresses(report_context * ctx)
boolean ballied = sf && sf!=ctx->f && sf!=lastf
&& !fval(u, UFL_ANON_FACTION) && cansee(ctx->f, r, u, stealthmod);
if (ballied || ALLIED(ctx->f, sf)) {
flist_add(&flist, sf);
ql_set_insert(&flist, sf);
lastf = sf;
}
}
@ -978,7 +991,7 @@ get_addresses(report_context * ctx)
faction *f2;
for (f2 = factions; f2; f2 = f2->next) {
if (f2->alliance == ctx->f->alliance) {
flist_add(&flist, f2);
ql_set_insert(&flist, f2);
}
}
}
@ -1393,7 +1406,7 @@ write_reports(faction * f, time_t ltime)
if (!gotit) {
log_warning(("No report for faction %s!\n", factionid(f)));
}
freelist(ctx.addresses);
ql_free(ctx.addresses);
seen_done(ctx.seen);
return 0;
}

View file

@ -83,7 +83,7 @@ extern const char * visibility[];
typedef struct report_context {
struct faction * f;
struct faction_list * addresses;
struct quicklist * addresses;
struct seen_region ** seen;
struct region * first, * last;
void * userdata;