forked from github/server
add region_id to messages that include a region.
This commit is contained in:
parent
708abf4997
commit
9c71139bf4
3 changed files with 47 additions and 49 deletions
|
@ -298,35 +298,35 @@ static void cr_output_curses_compat(FILE *F, const faction * viewer, const void
|
|||
cr_output_curses(&strm, viewer, obj, typ);
|
||||
}
|
||||
|
||||
static int cr_unit(variant var, char *buffer, const void *userdata)
|
||||
static int cr_unit(variant var, const char *name, char *buffer, const void *userdata)
|
||||
{
|
||||
unit *u = (unit *)var.v;
|
||||
sprintf(buffer, "%d", u ? u->no : -1);
|
||||
sprintf(buffer, "%d;%s\n", u ? u->no : -1, name);
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int cr_ship(variant var, char *buffer, const void *userdata)
|
||||
static int cr_ship(variant var, const char *name, char *buffer, const void *userdata)
|
||||
{
|
||||
ship *u = (ship *)var.v;
|
||||
sprintf(buffer, "%d", u ? u->no : -1);
|
||||
sprintf(buffer, "%d;%s\n", u ? u->no : -1, name);
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int cr_building(variant var, char *buffer, const void *userdata)
|
||||
static int cr_building(variant var, const char *name, char *buffer, const void *userdata)
|
||||
{
|
||||
building *u = (building *)var.v;
|
||||
sprintf(buffer, "%d", u ? u->no : -1);
|
||||
sprintf(buffer, "%d;%s\n", u ? u->no : -1, name);
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int cr_faction(variant var, char *buffer, const void *userdata)
|
||||
static int cr_faction(variant var, const char *name, char *buffer, const void *userdata)
|
||||
{
|
||||
faction *f = (faction *)var.v;
|
||||
sprintf(buffer, "%d", f ? f->no : -1);
|
||||
sprintf(buffer, "%d;%s\n", f ? f->no : -1, name);
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int cr_region(variant var, char *buffer, const void *userdata)
|
||||
static int cr_region(variant var, const char *name, char *buffer, const void *userdata)
|
||||
{
|
||||
const faction *report = (const faction *)userdata;
|
||||
region *r = (region *)var.v;
|
||||
|
@ -335,60 +335,60 @@ static int cr_region(variant var, char *buffer, const void *userdata)
|
|||
int nx = r->x, ny = r->y;
|
||||
pnormalize(&nx, &ny, pl);
|
||||
adjust_coordinates(report, &nx, &ny, pl);
|
||||
sprintf(buffer, "%d %d %d", nx, ny, plane_id(pl));
|
||||
sprintf(buffer, "%d;%s_id\n%d %d %d;%s\n", r->uid, name, nx, ny, plane_id(pl), name);
|
||||
return 0;
|
||||
}
|
||||
return -1;
|
||||
}
|
||||
|
||||
static int cr_resource(variant var, char *buffer, const void *userdata)
|
||||
static int cr_resource(variant var, const char *name, char *buffer, const void *userdata)
|
||||
{
|
||||
const faction *report = (const faction *)userdata;
|
||||
const resource_type *r = (const resource_type *)var.v;
|
||||
if (r) {
|
||||
const char *key = resourcename(r, 0);
|
||||
sprintf(buffer, "\"%s\"",
|
||||
translate(key, LOC(report->locale, key)));
|
||||
sprintf(buffer, "\"%s\";%s\n",
|
||||
translate(key, LOC(report->locale, key)), name);
|
||||
return 0;
|
||||
}
|
||||
return -1;
|
||||
}
|
||||
|
||||
static int cr_race(variant var, char *buffer, const void *userdata)
|
||||
static int cr_race(variant var, const char *name, char *buffer, const void *userdata)
|
||||
{
|
||||
const faction *report = (const faction *)userdata;
|
||||
const struct race *rc = (const race *)var.v;
|
||||
const char *key = rc_name_s(rc, NAME_SINGULAR);
|
||||
sprintf(buffer, "\"%s\"",
|
||||
translate(key, LOC(report->locale, key)));
|
||||
sprintf(buffer, "\"%s\";%s\n",
|
||||
translate(key, LOC(report->locale, key)), name);
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int cr_alliance(variant var, char *buffer, const void *userdata)
|
||||
static int cr_alliance(variant var, const char *name, char *buffer, const void *userdata)
|
||||
{
|
||||
const alliance *al = (const alliance *)var.v;
|
||||
UNUSED_ARG(userdata);
|
||||
if (al != NULL) {
|
||||
sprintf(buffer, "%d", al->id);
|
||||
sprintf(buffer, "%d;%s\n", al->id, name);
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int cr_skill(variant var, char *buffer, const void *userdata)
|
||||
static int cr_skill(variant var, const char *name, char *buffer, const void *userdata)
|
||||
{
|
||||
const faction *f = (const faction *)userdata;
|
||||
skill_t sk = (skill_t)var.i;
|
||||
UNUSED_ARG(userdata);
|
||||
if (sk != NOSKILL)
|
||||
sprintf(buffer, "\"%s\"",
|
||||
sprintf(buffer, "\"%s\";%s\n",
|
||||
translate(mkname("skill", skillnames[sk]), skillname(sk,
|
||||
f->locale)));
|
||||
f->locale)), name);
|
||||
else
|
||||
strcpy(buffer, "\"\"");
|
||||
sprintf(buffer, "\"\";%s\n", name);
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int cr_order(variant var, char *buffer, const void *userdata)
|
||||
static int cr_order(variant var, const char *name, char *buffer, const void *userdata)
|
||||
{
|
||||
order *ord = (order *)var.v;
|
||||
const faction *f = (const faction *)userdata;
|
||||
|
@ -408,15 +408,14 @@ static int cr_order(variant var, char *buffer, const void *userdata)
|
|||
}
|
||||
*wp++ = r;
|
||||
}
|
||||
*wp++ = '\"';
|
||||
*wp++ = 0;
|
||||
sprintf(wp, "\";%s\n", name);
|
||||
}
|
||||
else
|
||||
strcpy(buffer, "\"\"");
|
||||
sprintf(buffer, "\"\";%s\n", name);
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int cr_resources(variant var, char *buffer, const void *userdata)
|
||||
static int cr_resources(variant var, const char *name, char *buffer, const void *userdata)
|
||||
{
|
||||
faction *f = (faction *)userdata;
|
||||
resource *rlist = (resource *)var.v;
|
||||
|
@ -437,12 +436,12 @@ static int cr_resources(variant var, char *buffer, const void *userdata)
|
|||
sprintf(wp, ", %d %s", rlist->number, translate(name,
|
||||
LOC(f->locale, name)));
|
||||
}
|
||||
strcat(wp, "\"");
|
||||
sprintf(wp, "\";%s\n", name);
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int cr_regions(variant var, char *buffer, const void *userdata)
|
||||
static int cr_regions(variant var, const char *name, char *buffer, const void *userdata)
|
||||
{
|
||||
faction *f = (faction *)userdata;
|
||||
const arg_regions *rdata = (const arg_regions *)var.v;
|
||||
|
@ -463,36 +462,36 @@ static int cr_regions(variant var, char *buffer, const void *userdata)
|
|||
z = plane_id(pl);
|
||||
wp += sprintf(wp, ", %d %d %d", nx, ny, z);
|
||||
}
|
||||
strcat(wp, "\"");
|
||||
wp += sprintf(wp, "\"%s\n", name);
|
||||
}
|
||||
else {
|
||||
strcpy(buffer, "\"\"");
|
||||
sprintf(buffer, "\"\";%s\n", name);
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int cr_spell(variant var, char *buffer, const void *userdata)
|
||||
static int cr_spell(variant var, const char *name, char *buffer, const void *userdata)
|
||||
{
|
||||
const faction *report = (const faction *)userdata;
|
||||
spell *sp = (spell *)var.v;
|
||||
if (sp != NULL) {
|
||||
sprintf(buffer, "\"%s\"", spell_name(mkname_spell(sp), report->locale));
|
||||
sprintf(buffer, "\"%s\";%s\n", spell_name(mkname_spell(sp), report->locale), name);
|
||||
}
|
||||
else {
|
||||
strcpy(buffer, "\"\"");
|
||||
sprintf(buffer, "\"\";%s\n", name);
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int cr_curse(variant var, char *buffer, const void *userdata)
|
||||
static int cr_curse(variant var, const char *name, char *buffer, const void *userdata)
|
||||
{
|
||||
const faction *report = (const faction *)userdata;
|
||||
const curse_type *ctype = (const curse_type *)var.v;
|
||||
if (ctype != NULL) {
|
||||
sprintf(buffer, "\"%s\"", curse_name(ctype, report->locale));
|
||||
sprintf(buffer, "\"%s\";%s\n", curse_name(ctype, report->locale), name);
|
||||
}
|
||||
else
|
||||
strcpy(buffer, "\"\"");
|
||||
sprintf(buffer, "\"\";%s\n", name);
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
|
|
@ -123,33 +123,32 @@ int cr_render(const message * msg, char *buffer, const void *userdata)
|
|||
continue; /* strcpy(c, (const char*)msg->locale_string(u->faction->locale, parameters[i])); */
|
||||
}
|
||||
else {
|
||||
if (crt->renderers[i](msg->parameters[i], c, userdata) != 0)
|
||||
if (crt->renderers[i](msg->parameters[i], msg->type->pnames[i], c, userdata) != 0)
|
||||
continue;
|
||||
}
|
||||
c += strlen(c);
|
||||
sprintf(c, ";%s\n", msg->type->pnames[i]);
|
||||
c += strlen(c);
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
int cr_string(variant var, char *buffer, const void *userdata)
|
||||
int cr_string(variant var, const char *name, char *buffer, const void *userdata)
|
||||
{
|
||||
sprintf(buffer, "\"%s\"", (const char *)var.v);
|
||||
sprintf(buffer, "\"%s\";%s", (const char *)var.v, name);
|
||||
UNUSED_ARG(userdata);
|
||||
return 0;
|
||||
}
|
||||
|
||||
int cr_int(variant var, char *buffer, const void *userdata)
|
||||
int cr_int(variant var, const char *name, char *buffer, const void *userdata)
|
||||
{
|
||||
sprintf(buffer, "%d", var.i);
|
||||
sprintf(buffer, "%d;%s", var.i, name);
|
||||
UNUSED_ARG(userdata);
|
||||
return 0;
|
||||
}
|
||||
|
||||
int cr_ignore(variant var, char *buffer, const void *userdata)
|
||||
int cr_ignore(variant var, const char *name, char *buffer, const void *userdata)
|
||||
{
|
||||
UNUSED_ARG(var);
|
||||
UNUSED_ARG(name);
|
||||
UNUSED_ARG(buffer);
|
||||
UNUSED_ARG(userdata);
|
||||
return -1;
|
||||
|
|
|
@ -12,13 +12,13 @@ extern "C" {
|
|||
|
||||
void crmessage_done(void);
|
||||
|
||||
typedef int(*tostring_f) (variant data, char *buffer, const void *userdata);
|
||||
typedef int(*tostring_f) (variant data, const char *name, char *buffer, const void *userdata);
|
||||
void tsf_register(const char *name, tostring_f fun);
|
||||
/* registers a new type->string-function */
|
||||
|
||||
int cr_string(variant v, char *buffer, const void *userdata);
|
||||
int cr_int(variant v, char *buffer, const void *userdata);
|
||||
int cr_ignore(variant v, char *buffer, const void *userdata);
|
||||
int cr_string(variant v, const char *name, char *buffer, const void *userdata);
|
||||
int cr_int(variant v, const char *name, char *buffer, const void *userdata);
|
||||
int cr_ignore(variant v, const char *name, char *buffer, const void *userdata);
|
||||
|
||||
void crt_register(const struct message_type *mtype);
|
||||
int cr_render(const struct message *msg, char *buffer,
|
||||
|
|
Loading…
Reference in a new issue