xmlreport (WIP):

- buildings are done
- unit.faction.rel
This commit is contained in:
Enno Rehling 2008-06-07 09:55:57 +00:00
parent 6e5d930778
commit 8b242c0b33
6 changed files with 157 additions and 71 deletions

View File

@ -177,7 +177,7 @@ print_items(FILE * F, item * items, const struct locale * lang)
} }
static void static void
print_curses(FILE * F, const faction * viewer, const void * obj, typ_t typ) cr_output_curses(FILE * F, const faction * viewer, const void * obj, typ_t typ)
{ {
boolean header = false; boolean header = false;
attrib *a = NULL; attrib *a = NULL;
@ -563,26 +563,19 @@ cr_output_messages(FILE * F, message_list *msgs, faction * f)
static void static void
cr_output_building(FILE * F, building * b, const unit * owner, int fno, faction *f) cr_output_building(FILE * F, building * b, const unit * owner, int fno, faction *f)
{ {
const char * bname; const char * bname, * billusion;
static const struct building_type * bt_illusion;
const building_type * type = b->type;
if (!bt_illusion) bt_illusion = bt_find("illusion");
fprintf(F, "BURG %d\n", b->no); fprintf(F, "BURG %d\n", b->no);
if (b->type==bt_illusion) { report_building(b, &bname, &billusion);
const attrib * a = a_findc(b->attribs, &at_icastle); if (billusion) {
if (a!=NULL) { fprintf(F, "\"%s\";Typ\n", add_translation(billusion, LOC(f->locale, billusion)));
type = ((icastle_data*)a->data.v)->type; if (owner && owner->faction==f) {
}
bname = buildingtype(b->type, b, b->size);
if (owner!=NULL && owner->faction==f) {
fprintf(F, "\"%s\";wahrerTyp\n", add_translation(bname, LOC(f->locale, bname))); fprintf(F, "\"%s\";wahrerTyp\n", add_translation(bname, LOC(f->locale, bname)));
} }
} else {
fprintf(F, "\"%s\";Typ\n", add_translation(bname, LOC(f->locale, bname)));
} }
bname = buildingtype(type, b, b->size);
fprintf(F, "\"%s\";Typ\n", add_translation(bname, LOC(f->locale, bname)));
fprintf(F, "\"%s\";Name\n", b->name); fprintf(F, "\"%s\";Name\n", b->name);
if (b->display && b->display[0]) if (b->display && b->display[0])
fprintf(F, "\"%s\";Beschr\n", b->display); fprintf(F, "\"%s\";Beschr\n", b->display);
@ -594,7 +587,7 @@ cr_output_building(FILE * F, building * b, const unit * owner, int fno, faction
fprintf(F, "%d;Partei\n", fno); fprintf(F, "%d;Partei\n", fno);
if (b->besieged) if (b->besieged)
fprintf(F, "%d;Belagerer\n", b->besieged); fprintf(F, "%d;Belagerer\n", b->besieged);
print_curses(F, f, b, TYP_BUILDING); cr_output_curses(F, f, b, TYP_BUILDING);
} }
/* = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = */ /* = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = */
@ -637,7 +630,7 @@ cr_output_ship(FILE * F, const ship * sh, const unit * u, int fcaptain, const fa
if (w != NODIRECTION) if (w != NODIRECTION)
fprintf(F, "%d;Kueste\n", w); fprintf(F, "%d;Kueste\n", w);
print_curses(F, f, sh, TYP_SHIP); cr_output_curses(F, f, sh, TYP_SHIP);
} }
static void static void
@ -913,7 +906,7 @@ cr_output_unit(FILE * F, const region * r,
fprintf(F, "%d;%s\n", in, add_translation(ic, locale_string(f->locale, ic))); fprintf(F, "%d;%s\n", in, add_translation(ic, locale_string(f->locale, ic)));
} }
print_curses(F, f, u, TYP_UNIT); cr_output_curses(F, f, u, TYP_UNIT);
} }
/* = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = */ /* = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = */
@ -1218,7 +1211,7 @@ cr_output_region(FILE * F, report_context * ctx, seen_region * sr)
if (r->land) { if (r->land) {
print_items(F, r->land->items, f->locale); print_items(F, r->land->items, f->locale);
} }
print_curses(F, f, r, TYP_REGION); cr_output_curses(F, f, r, TYP_REGION);
cr_borders(ctx->seen, r, f, sr->mode, F); cr_borders(ctx->seen, r, f, sr->mode, F);
if (sr->mode==see_unit && r->planep==get_astralplane() && !is_cursed(r->attribs, C_ASTRALBLOCK, 0)) if (sr->mode==see_unit && r->planep==get_astralplane() && !is_cursed(r->attribs, C_ASTRALBLOCK, 0))
{ {

View File

@ -214,7 +214,7 @@ rparagraph(FILE *F, const char *str, ptrdiff_t indent, int hanging_indent, char
} }
static void static void
report_spell(FILE * F, spell *sp, const struct locale * lang) nr_spell(FILE * F, spell *sp, const struct locale * lang)
{ {
int bytes, k, itemanz, costtyp; int bytes, k, itemanz, costtyp;
int dh = 0; int dh = 0;
@ -535,7 +535,7 @@ hat_in_region(item_t it, region * r, faction * f)
} }
static void static void
print_curses(FILE *F, const faction *viewer, const void * obj, typ_t typ, int indent) nr_curses(FILE *F, const faction *viewer, const void * obj, typ_t typ, int indent)
{ {
attrib *a = NULL; attrib *a = NULL;
int self = 0; int self = 0;
@ -651,7 +651,7 @@ rps_nowrap(FILE * F, const char *s)
} }
static void static void
report_unit(FILE * F, const faction * f, const unit * u, int indent, int mode) nr_unit(FILE * F, const faction * f, const unit * u, int indent, int mode)
{ {
attrib *a_otherfaction; attrib *a_otherfaction;
char marker; char marker;
@ -686,7 +686,7 @@ report_unit(FILE * F, const faction * f, const unit * u, int indent, int mode)
rparagraph(F, buf, indent, 0, marker); rparagraph(F, buf, indent, 0, marker);
if (!isbattle) { if (!isbattle) {
print_curses(F, f, u, TYP_UNIT, indent); nr_curses(F, f, u, TYP_UNIT, indent);
} }
} }
@ -1105,7 +1105,7 @@ describe(FILE * F, const seen_region * sr, faction * f)
n = 0; n = 0;
/* Wirkungen permanenter Sprüche */ /* Wirkungen permanenter Sprüche */
print_curses(F, f, r, TYP_REGION,0); nr_curses(F, f, r, TYP_REGION,0);
/* Produktionsreduktion */ /* Produktionsreduktion */
a = a_find(r->attribs, &at_reduceproduction); a = a_find(r->attribs, &at_reduceproduction);
@ -1709,7 +1709,7 @@ list_address(FILE * F, const faction * uf, const faction_list * seenfactions)
} }
static void static void
report_ship(FILE * F, const seen_region * sr, const ship * sh, const faction * f, const unit * captain) nr_ship(FILE * F, const seen_region * sr, const ship * sh, const faction * f, const unit * captain)
{ {
const region * r = sr->r; const region * r = sr->r;
char buffer[8192], * bufp = buffer; char buffer[8192], * bufp = buffer;
@ -1766,11 +1766,11 @@ report_ship(FILE * F, const seen_region * sr, const ship * sh, const faction * f
*bufp = 0; *bufp = 0;
rparagraph(F, buffer, 2, 0, 0); rparagraph(F, buffer, 2, 0, 0);
print_curses(F, f, sh, TYP_SHIP, 4); nr_curses(F, f, sh, TYP_SHIP, 4);
} }
static void static void
report_building(FILE *F, const seen_region * sr, const building * b, const faction * f) nr_building(FILE *F, const seen_region * sr, const building * b, const faction * f)
{ {
region * r = sr->r; region * r = sr->r;
int i, bytes; int i, bytes;
@ -1897,7 +1897,7 @@ report_building(FILE *F, const seen_region * sr, const building * b, const facti
if (sr->mode<see_lighthouse) return; if (sr->mode<see_lighthouse) return;
print_curses(F, f, b, TYP_BUILDING, 4); nr_curses(F, f, b, TYP_BUILDING, 4);
} }
int int
@ -2114,7 +2114,7 @@ report_plaintext(const char * filename, report_context * ctx, const char * chars
centre(F, LOC(f->locale, "section_newspells"), true); centre(F, LOC(f->locale, "section_newspells"), true);
while (a && a->type==&at_reportspell) { while (a && a->type==&at_reportspell) {
spell *sp = (spell *)a->data.v; spell *sp = (spell *)a->data.v;
report_spell(F, sp, f->locale); nr_spell(F, sp, f->locale);
a = a->next; a = a->next;
} }
} }
@ -2228,13 +2228,13 @@ report_plaintext(const char * filename, report_context * ctx, const char * chars
u = r->units; u = r->units;
while (b) { while (b) {
while (b && (!u || u->building!=b)) { while (b && (!u || u->building!=b)) {
report_building(F, sr, b, f); nr_building(F, sr, b, f);
b = b->next; b = b->next;
} }
if (b) { if (b) {
report_building(F, sr, b, f); nr_building(F, sr, b, f);
while (u && u->building==b) { while (u && u->building==b) {
report_unit(F, f, u, 6, sr->mode); nr_unit(F, f, u, 6, sr->mode);
u = u->next; u = u->next;
} }
b = b->next; b = b->next;
@ -2243,20 +2243,20 @@ report_plaintext(const char * filename, report_context * ctx, const char * chars
while (u && !u->ship) { while (u && !u->ship) {
if (stealthmod>INT_MIN) { if (stealthmod>INT_MIN) {
if (u->faction == f || cansee(f, r, u, stealthmod)) { if (u->faction == f || cansee(f, r, u, stealthmod)) {
report_unit(F, f, u, 4, sr->mode); nr_unit(F, f, u, 4, sr->mode);
} }
} }
u = u->next; u = u->next;
} }
while (sh) { while (sh) {
while (sh && (!u || u->ship!=sh)) { while (sh && (!u || u->ship!=sh)) {
report_ship(F, sr, sh, f, NULL); nr_ship(F, sr, sh, f, NULL);
sh = sh->next; sh = sh->next;
} }
if (sh) { if (sh) {
report_ship(F, sr, sh, f, u); nr_ship(F, sr, sh, f, u);
while (u && u->ship==sh) { while (u && u->ship==sh) {
report_unit(F, f, u, 6, sr->mode); nr_unit(F, f, u, 6, sr->mode);
u = u->next; u = u->next;
} }
sh = sh->next; sh = sh->next;

View File

@ -113,8 +113,48 @@ xml_i(double number)
return (const xmlChar *)buffer; return (const xmlChar *)buffer;
} }
static const xmlChar *
xml_ref_unit(const unit * u)
{
static char idbuf[20];
snprintf(idbuf, sizeof(idbuf), "unit_%d", u->no);
return (const xmlChar *)idbuf;
}
static const xmlChar *
xml_ref_faction(const faction * f)
{
static char idbuf[20];
snprintf(idbuf, sizeof(idbuf), "fctn_%d", f->no);
return (const xmlChar *)idbuf;
}
static const xmlChar *
xml_ref_building(const building * b)
{
static char idbuf[20];
snprintf(idbuf, sizeof(idbuf), "bldg_%d", b->no);
return (const xmlChar *)idbuf;
}
static const xmlChar *
xml_ref_ship(const ship * sh)
{
static char idbuf[20];
snprintf(idbuf, sizeof(idbuf), "shp_%d", sh->no);
return (const xmlChar *)idbuf;
}
static const xmlChar *
xml_ref_region(const region * r)
{
static char idbuf[20];
snprintf(idbuf, sizeof(idbuf), "rgn_%d", r->uid);
return (const xmlChar *)idbuf;
}
static xmlNodePtr static xmlNodePtr
report_inventory(report_context * ctx, item * items, unit * u) xml_inventory(report_context * ctx, item * items, unit * u)
{ {
xml_context* xct = (xml_context*)ctx->userdata; xml_context* xct = (xml_context*)ctx->userdata;
xmlNodePtr node = xmlNewNode(xct->ns_atl, BAD_CAST "items"); xmlNodePtr node = xmlNewNode(xct->ns_atl, BAD_CAST "items");
@ -138,19 +178,22 @@ xml_unit(report_context * ctx, unit * u, int mode)
{ {
xml_context* xct = (xml_context*)ctx->userdata; xml_context* xct = (xml_context*)ctx->userdata;
xmlNodePtr node = xmlNewNode(xct->ns_atl, BAD_CAST "unit"); xmlNodePtr node = xmlNewNode(xct->ns_atl, BAD_CAST "unit");
char idbuffer[20];
static const curse_type * itemcloak_ct = 0; static const curse_type * itemcloak_ct = 0;
static boolean init = false; static boolean init = false;
xmlNodePtr child; xmlNodePtr child;
snprintf(idbuffer, sizeof(idbuffer), "unit_%d", u->no); xmlNewNsProp(node, xct->ns_xml, XML_XML_ID, xml_ref_unit(u));
xmlNewNsProp(node, xct->ns_xml, XML_XML_ID, (xmlChar *)idbuffer);
xmlNewNsProp(node, xct->ns_atl, BAD_CAST "key", BAD_CAST itoa36(u->no)); xmlNewNsProp(node, xct->ns_atl, BAD_CAST "key", BAD_CAST itoa36(u->no));
xmlNewTextChild(node, xct->ns_atl, BAD_CAST "name", (const xmlChar *)u->name); xmlNewTextChild(node, xct->ns_atl, BAD_CAST "name", (const xmlChar *)u->name);
snprintf(idbuffer, sizeof(idbuffer), "faction_%d", u->faction->no);
child = xmlNewNode(xct->ns_atl, BAD_CAST "faction"); child = xmlNewNode(xct->ns_atl, BAD_CAST "faction");
xmlNewNsProp(child, xct->ns_atl, BAD_CAST "ref", (xmlChar *)idbuffer); if (ctx->f == u->faction || omniscient(ctx->f)) {
xmlNewNsProp(child, xct->ns_atl, BAD_CAST "rel", BAD_CAST "true");
xmlNewNsProp(child, xct->ns_atl, BAD_CAST "ref", xml_ref_faction(u->faction));
} else {
const faction * sf = visible_faction(ctx->f, u);
xmlNewNsProp(child, xct->ns_atl, BAD_CAST "ref", xml_ref_faction(sf));
}
xmlAddChild(node, child); xmlAddChild(node, child);
if (!init) { if (!init) {
@ -184,7 +227,7 @@ xml_unit(report_context * ctx, unit * u, int mode)
} }
if (show) { if (show) {
xmlAddChild(node, report_inventory(ctx, show, u)); xmlAddChild(node, xml_inventory(ctx, show, u));
} }
} }
@ -192,7 +235,7 @@ xml_unit(report_context * ctx, unit * u, int mode)
} }
static xmlNodePtr static xmlNodePtr
report_link(report_context * ctx, const xmlChar * role, const xmlChar * ref) xml_link(report_context * ctx, const xmlChar * role, const xmlChar * ref)
{ {
xml_context* xct = (xml_context*)ctx->userdata; xml_context* xct = (xml_context*)ctx->userdata;
xmlNodePtr node = xmlNewNode(xct->ns_atl, BAD_CAST "link"); xmlNodePtr node = xmlNewNode(xct->ns_atl, BAD_CAST "link");
@ -228,35 +271,59 @@ xml_resources(report_context * ctx, const seen_region * sr)
} }
static xmlNodePtr static xmlNodePtr
report_faction(report_context * ctx, faction * f) xml_faction(report_context * ctx, faction * f)
{ {
xml_context* xct = (xml_context*)ctx->userdata; xml_context* xct = (xml_context*)ctx->userdata;
xmlNodePtr node = xmlNewNode(xct->ns_atl, BAD_CAST "faction"); xmlNodePtr node = xmlNewNode(xct->ns_atl, BAD_CAST "faction");
char faction_id[20];
snprintf(faction_id, sizeof(faction_id), "faction_%d", f->no); xmlNewNsProp(node, xct->ns_xml, XML_XML_ID, xml_ref_faction(f));
xmlNewNsProp(node, xct->ns_xml, XML_XML_ID, (xmlChar *)faction_id);
xmlNewNsProp(node, xct->ns_atl, BAD_CAST "key", BAD_CAST itoa36(f->no)); xmlNewNsProp(node, xct->ns_atl, BAD_CAST "key", BAD_CAST itoa36(f->no));
xmlNewTextChild(node, xct->ns_atl, BAD_CAST "name", (const xmlChar *)f->name); xmlNewTextChild(node, xct->ns_atl, BAD_CAST "name", (const xmlChar *)f->name);
if (ctx->f==f) { if (ctx->f==f) {
xmlAddChild(node, report_link(ctx, BAD_CAST "race", BAD_CAST f->race->_name[0])); xmlAddChild(node, xml_link(ctx, BAD_CAST "race", BAD_CAST f->race->_name[0]));
if (f->items) xmlAddChild(node, report_inventory(ctx, f->items, NULL)); if (f->items) xmlAddChild(node, xml_inventory(ctx, f->items, NULL));
} }
return node; return node;
} }
static xmlNodePtr static xmlNodePtr
xml_building(report_context * ctx, seen_region * sr, building * b) xml_building(report_context * ctx, seen_region * sr, const building * b, const unit * owner)
{ {
xml_context* xct = (xml_context*)ctx->userdata; xml_context* xct = (xml_context*)ctx->userdata;
xmlNodePtr node = xmlNewNode(xct->ns_atl, BAD_CAST "building"); xmlNodePtr node = xmlNewNode(xct->ns_atl, BAD_CAST "building");
char idbuf[20]; xmlNodePtr child;
const char * bname, * billusion;
snprintf(idbuf, sizeof(idbuf), "bldg_%d", b->no); xmlNewNsProp(node, xct->ns_xml, XML_XML_ID, xml_ref_building(b));
xmlNewNsProp(node, xct->ns_xml, XML_XML_ID, (xmlChar *)idbuf);
xmlNewNsProp(node, xct->ns_atl, BAD_CAST "key", BAD_CAST itoa36(b->no)); xmlNewNsProp(node, xct->ns_atl, BAD_CAST "key", BAD_CAST itoa36(b->no));
xmlNewTextChild(node, xct->ns_atl, BAD_CAST "name", (const xmlChar *)b->name); xmlNewTextChild(node, xct->ns_atl, BAD_CAST "name", (const xmlChar *)b->name);
xmlNewTextChild(node, xct->ns_atl, BAD_CAST "size", (const xmlChar *)itoab(b->size, 10));
if (b->display && b->display[0]) {
xmlNewTextChild(node, xct->ns_atl, BAD_CAST "descr", (const xmlChar *)b->display);
}
if (b->besieged) {
xmlNewTextChild(node, xct->ns_atl, BAD_CAST "siege", (const xmlChar *)itoab(b->besieged, 10));
}
if (owner) xml_link(ctx, BAD_CAST "owner", xml_ref_unit(owner));
report_building(b, &bname, &billusion);
if (owner && owner->faction==ctx->f) {
child = xmlNewNode(xct->ns_atl, BAD_CAST "type");
xmlNewNsProp(child, xct->ns_atl, BAD_CAST "rel", BAD_CAST "true");
xmlNewNsProp(child, xct->ns_atl, BAD_CAST "ref", (const xmlChar *)bname);
xmlAddChild(node, child);
if (billusion) {
child = xmlNewNode(xct->ns_atl, BAD_CAST "type");
xmlNewNsProp(child, xct->ns_atl, BAD_CAST "rel", BAD_CAST "illusion");
xmlNewNsProp(child, xct->ns_atl, BAD_CAST "ref", (const xmlChar *)billusion);
xmlAddChild(node, child);
}
} else {
child = xmlNewNode(xct->ns_atl, BAD_CAST "type");
xmlNewNsProp(child, xct->ns_atl, BAD_CAST "ref", (const xmlChar *)(billusion?billusion:bname));
xmlAddChild(node, child);
}
return node; return node;
} }
@ -266,31 +333,30 @@ xml_ship(report_context * ctx, seen_region * sr, ship * sh)
{ {
xml_context* xct = (xml_context*)ctx->userdata; xml_context* xct = (xml_context*)ctx->userdata;
xmlNodePtr node = xmlNewNode(xct->ns_atl, BAD_CAST "ship"); xmlNodePtr node = xmlNewNode(xct->ns_atl, BAD_CAST "ship");
char idbuf[20];
snprintf(idbuf, sizeof(idbuf), "ship_%d", sh->no); xmlNewNsProp(node, xct->ns_xml, XML_XML_ID, xml_ref_ship(sh));
xmlNewNsProp(node, xct->ns_xml, XML_XML_ID, (xmlChar *)idbuf);
xmlNewNsProp(node, xct->ns_atl, BAD_CAST "key", BAD_CAST itoa36(sh->no)); xmlNewNsProp(node, xct->ns_atl, BAD_CAST "key", BAD_CAST itoa36(sh->no));
xmlNewTextChild(node, xct->ns_atl, BAD_CAST "name", (const xmlChar *)sh->name); xmlNewTextChild(node, xct->ns_atl, BAD_CAST "name", (const xmlChar *)sh->name);
if (sh->display && sh->display[0]) {
xmlNewTextChild(node, xct->ns_atl, BAD_CAST "descr", (const xmlChar *)sh->display);
}
return node; return node;
} }
static xmlNodePtr static xmlNodePtr
report_region(report_context * ctx, seen_region * sr) xml_region(report_context * ctx, seen_region * sr)
{ {
xml_context* xct = (xml_context*)ctx->userdata; xml_context* xct = (xml_context*)ctx->userdata;
const region * r = sr->r; const region * r = sr->r;
xmlNodePtr node = xmlNewNode(xct->ns_atl, BAD_CAST "region"); xmlNodePtr node = xmlNewNode(xct->ns_atl, BAD_CAST "region");
xmlNodePtr child; xmlNodePtr child;
char region_id[20];
int stealthmod = stealth_modifier(sr->mode); int stealthmod = stealth_modifier(sr->mode);
unit * u; unit * u;
ship * sh = r->ships; ship * sh = r->ships;
building * b = r->buildings; building * b = r->buildings;
sprintf(region_id, "region_%u", r->uid); xmlNewNsProp(node, xct->ns_xml, XML_XML_ID, xml_ref_region(r));
xmlNewNsProp(node, xct->ns_xml, XML_XML_ID, BAD_CAST region_id);
child = xmlNewNode(xct->ns_atl, BAD_CAST "coordinate"); child = xmlNewNode(xct->ns_atl, BAD_CAST "coordinate");
xmlNewNsProp(child, xct->ns_atl, BAD_CAST "x", xml_i(region_x(r, ctx->f))); xmlNewNsProp(child, xct->ns_atl, BAD_CAST "x", xml_i(region_x(r, ctx->f)));
@ -307,7 +373,7 @@ report_region(report_context * ctx, seen_region * sr)
if (r->land!=NULL) { if (r->land!=NULL) {
child = xmlNewTextChild(node, xct->ns_atl, BAD_CAST "name", (const xmlChar *)r->land->name); child = xmlNewTextChild(node, xct->ns_atl, BAD_CAST "name", (const xmlChar *)r->land->name);
if (r->land->items) { if (r->land->items) {
xmlAddChild(node, report_inventory(ctx, r->land->items, NULL)); xmlAddChild(node, xml_inventory(ctx, r->land->items, NULL));
} }
} }
xmlAddChild(node, xml_resources(ctx, sr)); xmlAddChild(node, xml_resources(ctx, sr));
@ -325,12 +391,12 @@ report_region(report_context * ctx, seen_region * sr)
u = r->units; u = r->units;
while (b) { while (b) {
while (b && (!u || u->building!=b)) { while (b && (!u || u->building!=b)) {
child = xml_building(ctx, sr, b); child = xml_building(ctx, sr, b, NULL);
xmlAddChild(node, child); xmlAddChild(node, child);
b = b->next; b = b->next;
} }
if (b) { if (b) {
child = xml_building(ctx, sr, b); child = xml_building(ctx, sr, b, u);
xmlAddChild(node, child); xmlAddChild(node, child);
while (u && u->building==b) { while (u && u->building==b) {
xmlAddChild(child, xml_unit(ctx, u, sr->mode)); xmlAddChild(child, xml_unit(ctx, u, sr->mode));
@ -379,12 +445,12 @@ report_root(report_context * ctx)
xmlSetNs(xmlReport, xct->ns_atl); xmlSetNs(xmlReport, xct->ns_atl);
for (address=ctx->addresses;address;address=address->next) { for (address=ctx->addresses;address;address=address->next) {
xmlAddChild(xmlReport, report_faction(ctx, address->data)); xmlAddChild(xmlReport, xml_faction(ctx, address->data));
} }
for (;r!=rend;r=r->next) { for (;r!=rend;r=r->next) {
seen_region * sr = find_seen(ctx->seen, r); seen_region * sr = find_seen(ctx->seen, r);
if (sr!=NULL) xmlAddChild(xmlReport, report_region(ctx, sr)); if (sr!=NULL) xmlAddChild(xmlReport, xml_region(ctx, sr));
} }
return xmlReport; return xmlReport;
}; };

View File

@ -295,6 +295,32 @@ report_resource(resource_report * result, const char * name, int number, int lev
result->level = level; result->level = level;
} }
void
report_building(const struct building * b, const char ** name, const char ** illusion)
{
static int init;
static const struct building_type * bt_illusion;
if (name) {
*name = buildingtype(b->type, b, b->size);
}
if (illusion) {
*illusion = NULL;
if (!init) {
bt_illusion = bt_find("illusion");
init = 1;
}
if (bt_illusion && b->type==bt_illusion) {
const attrib * a = a_findc(b->attribs, &at_icastle);
if (a!=NULL) {
icastle_data * icastle = (icastle_data*)a->data.v;
*illusion = buildingtype(icastle->type, b, b->size);
}
}
}
}
int int
report_resources(const seen_region * sr, resource_report * result, int size, const faction * viewer) report_resources(const seen_region * sr, resource_report * result, int size, const faction * viewer)
{ {

View File

@ -123,6 +123,7 @@ extern const char * report_kampfstatus(const struct unit * u, const struct local
int report_resources(const struct seen_region * sr, struct resource_report * result, int size, const struct faction * viewer); int report_resources(const struct seen_region * sr, struct resource_report * result, int size, const struct faction * viewer);
int report_items(const struct item * items, struct item * result, int size, const struct unit * owner, const struct faction * viewer); int report_items(const struct item * items, struct item * result, int size, const struct unit * owner, const struct faction * viewer);
void report_item(const struct unit * owner, const struct item * i, const struct faction * viewer, const char ** name, const char ** basename, int * number, boolean singular); void report_item(const struct unit * owner, const struct item * i, const struct faction * viewer, const char ** name, const char ** basename, int * number, boolean singular);
void report_building(const struct building * b, const char ** btype, const char ** billusion);
extern size_t f_regionid(const struct region * r, const struct faction * f, char * buffer, size_t size); extern size_t f_regionid(const struct region * r, const struct faction * f, char * buffer, size_t size);

View File

@ -108,7 +108,7 @@ attrib_type at_wdwpyramid = {
/* ----------------------------------------------------------------------- */ /* ----------------------------------------------------------------------- */
static void static void
report_spell(unit * mage, region * r, message * msg) nr_spell(unit * mage, region * r, message * msg)
{ {
r_addmessage(r, NULL, msg); r_addmessage(r, NULL, msg);
if (mage && mage->region!=r) { if (mage && mage->region!=r) {
@ -1977,7 +1977,7 @@ sp_holyground(castorder *co)
double power = co->force; double power = co->force;
curse * c; curse * c;
message * msg = msg_message("sp_holyground_effect", "mage region", mage, r); message * msg = msg_message("sp_holyground_effect", "mage region", mage, r);
report_spell(mage, r, msg); nr_spell(mage, r, msg);
msg_release(msg); msg_release(msg);
if (!ctype) ctype = ct_find("holyground"); if (!ctype) ctype = ct_find("holyground");
@ -2082,7 +2082,7 @@ sp_drought(castorder *co)
/* melden, 1x pro Partei */ /* melden, 1x pro Partei */
msg = msg_message("sp_drought_effect", "mage region", mage, r); msg = msg_message("sp_drought_effect", "mage region", mage, r);
report_spell(mage, r, msg); nr_spell(mage, r, msg);
msg_release(msg); msg_release(msg);
/* Wenn schon Duerre herrscht, dann setzen wir nur den Power-Level /* Wenn schon Duerre herrscht, dann setzen wir nur den Power-Level
@ -4015,7 +4015,7 @@ sp_raisepeasantmob(castorder *co)
create_curse(mage, &r->attribs, ct_find("riotzone"), cast_level, duration, anteil, 0); create_curse(mage, &r->attribs, ct_find("riotzone"), cast_level, duration, anteil, 0);
msg = msg_message("sp_raisepeasantmob_effect", "mage region", mage, r); msg = msg_message("sp_raisepeasantmob_effect", "mage region", mage, r);
report_spell(mage, r, msg); nr_spell(mage, r, msg);
msg_release(msg); msg_release(msg);
return cast_level; return cast_level;
@ -4802,7 +4802,7 @@ sp_icastle(castorder *co)
co->order)); co->order));
msg = msg_message("sp_icastle_effect", "region", r); msg = msg_message("sp_icastle_effect", "region", r);
report_spell(mage, r, msg); nr_spell(mage, r, msg);
msg_release(msg); msg_release(msg);
return cast_level; return cast_level;