forked from github/server
reduce the footprint of nrmessage
This commit is contained in:
parent
3867388834
commit
ef74b8e759
4 changed files with 20 additions and 28 deletions
|
@ -512,17 +512,14 @@ static void report_crtypes(FILE * F, const struct locale *lang)
|
||||||
for (i = 0; i != MTMAXHASH; ++i) {
|
for (i = 0; i != MTMAXHASH; ++i) {
|
||||||
struct known_mtype *kmt;
|
struct known_mtype *kmt;
|
||||||
for (kmt = mtypehash[i]; kmt; kmt = kmt->nexthash) {
|
for (kmt = mtypehash[i]; kmt; kmt = kmt->nexthash) {
|
||||||
const struct nrmessage_type *nrt = nrt_find(kmt->mtype);
|
|
||||||
if (nrt) {
|
|
||||||
char buffer[DISPLAYSIZE];
|
char buffer[DISPLAYSIZE];
|
||||||
int hash = (int)kmt->mtype->key;
|
int hash = (int)kmt->mtype->key;
|
||||||
assert(hash > 0);
|
assert(hash > 0);
|
||||||
fprintf(F, "MESSAGETYPE %d\n", hash);
|
fprintf(F, "MESSAGETYPE %d\n", hash);
|
||||||
fputc('\"', F);
|
fputc('\"', F);
|
||||||
fputs(str_escape(nrt_string(nrt, lang), buffer, sizeof(buffer)), F);
|
fputs(str_escape(nrt_string(kmt->mtype, lang), buffer, sizeof(buffer)), F);
|
||||||
fputs("\";text\n", F);
|
fputs("\";text\n", F);
|
||||||
fprintf(F, "\"%s\";section\n", nrt_section(nrt));
|
fprintf(F, "\"%s\";section\n", nrt_section(kmt->mtype));
|
||||||
}
|
|
||||||
}
|
}
|
||||||
while (mtypehash[i]) {
|
while (mtypehash[i]) {
|
||||||
kmt = mtypehash[i];
|
kmt = mtypehash[i];
|
||||||
|
|
|
@ -723,7 +723,7 @@ rp_messages(struct stream *out, message_list * msgs, faction * viewer, int inden
|
||||||
struct mlist *m = msgs->begin;
|
struct mlist *m = msgs->begin;
|
||||||
while (m) {
|
while (m) {
|
||||||
/* messagetype * mt = m->type; */
|
/* messagetype * mt = m->type; */
|
||||||
if (!categorized || strcmp(nr_section(m->msg), section->name) == 0) {
|
if (!categorized || strcmp(nrt_section(m->msg->type), section->name) == 0) {
|
||||||
char lbuf[8192];
|
char lbuf[8192];
|
||||||
|
|
||||||
if (!k && categorized) {
|
if (!k && categorized) {
|
||||||
|
|
|
@ -30,17 +30,18 @@
|
||||||
#define NRT_MAXHASH 1021
|
#define NRT_MAXHASH 1021
|
||||||
static nrmessage_type *nrtypes[NRT_MAXHASH];
|
static nrmessage_type *nrtypes[NRT_MAXHASH];
|
||||||
|
|
||||||
const char *nrt_string(const struct nrmessage_type *nrt, const struct locale *lang)
|
const char *nrt_string(const struct message_type *mtype,
|
||||||
|
const struct locale *lang)
|
||||||
{
|
{
|
||||||
const char * str = locale_getstring(lang, nrt->mtype->name);
|
const char * str = locale_getstring(lang, mtype->name);
|
||||||
if (!str) {
|
if (!str) {
|
||||||
str = locale_getstring(default_locale, nrt->mtype->name);
|
str = locale_getstring(default_locale, mtype->name);
|
||||||
}
|
}
|
||||||
assert(str);
|
assert(str);
|
||||||
return str;
|
return str;
|
||||||
}
|
}
|
||||||
|
|
||||||
nrmessage_type *nrt_find(const struct message_type * mtype)
|
static nrmessage_type *nrt_find(const struct message_type * mtype)
|
||||||
{
|
{
|
||||||
nrmessage_type *found = NULL;
|
nrmessage_type *found = NULL;
|
||||||
unsigned int hash = mtype->key % NRT_MAXHASH;
|
unsigned int hash = mtype->key % NRT_MAXHASH;
|
||||||
|
@ -139,7 +140,7 @@ size_t size, const void *userdata)
|
||||||
|
|
||||||
if (nrt) {
|
if (nrt) {
|
||||||
const char *m =
|
const char *m =
|
||||||
translate(nrt_string(nrt, lang), userdata, nrt->vars, msg->parameters);
|
translate(nrt_string(msg->type, lang), userdata, nrt->vars, msg->parameters);
|
||||||
if (m) {
|
if (m) {
|
||||||
return str_strlcpy((char *)buffer, m, size);
|
return str_strlcpy((char *)buffer, m, size);
|
||||||
}
|
}
|
||||||
|
@ -152,14 +153,9 @@ size_t size, const void *userdata)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
const char *nr_section(const struct message *msg)
|
const char *nrt_section(const struct message_type * mtype)
|
||||||
{
|
|
||||||
nrmessage_type *nrt = nrt_find(msg->type);
|
|
||||||
return nrt ? nrt->section : NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
const char *nrt_section(const nrmessage_type * nrt)
|
|
||||||
{
|
{
|
||||||
|
nrmessage_type *nrt = nrt_find(mtype);
|
||||||
return nrt ? nrt->section : NULL;
|
return nrt ? nrt->section : NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -35,13 +35,12 @@ extern "C" {
|
||||||
void free_nrmesssages(void);
|
void free_nrmesssages(void);
|
||||||
|
|
||||||
void nrt_register(const struct message_type *mtype, const char *section);
|
void nrt_register(const struct message_type *mtype, const char *section);
|
||||||
struct nrmessage_type *nrt_find(const struct message_type *);
|
const char *nrt_string(const struct message_type *mtype,
|
||||||
const char *nrt_string(const struct nrmessage_type *nrt, const struct locale *lang);
|
const struct locale *lang);
|
||||||
const char *nrt_section(const struct nrmessage_type *nrt);
|
const char *nrt_section(const struct message_type *mtype);
|
||||||
|
|
||||||
size_t nr_render(const struct message *msg, const struct locale *lang,
|
size_t nr_render(const struct message *msg, const struct locale *lang,
|
||||||
char *buffer, size_t size, const void *userdata);
|
char *buffer, size_t size, const void *userdata);
|
||||||
const char *nr_section(const struct message *msg);
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue