add a string escaping function.

start some work on nrmessage.c.
This commit is contained in:
Enno Rehling 2018-05-17 16:53:56 +02:00
parent 35c3d4cda0
commit 9ca945cb2c
6 changed files with 82 additions and 25 deletions

View file

@ -3,7 +3,10 @@ msgstr "Rostiges Kettenhemd"
msgctxt "spellinfo" msgctxt "spellinfo"
msgid "destroy_magic" msgid "destroy_magic"
msgstr "Dieser Zauber ermöglicht dem Magier, Verzauberungen einer Einheit, eines Schiffes, Gebäudes oder auch der Region aufzulösen." msgstr ""
"Dieser Zauber ermöglicht dem Magier, Verzauberungen "
"einer Einheit, eines Schiffes, Gebäudes oder auch "
"der Region aufzulösen."
msgctxt "spell" msgctxt "spell"
msgid "shadowknights" msgid "shadowknights"

View file

@ -32,7 +32,10 @@ static nrmessage_type *nrtypes[NRT_MAXHASH];
const char *nrt_string(const struct nrmessage_type *type) const char *nrt_string(const struct nrmessage_type *type)
{ {
return type->string; if (type->string) {
return type->string;
}
return locale_get(type->lang, type->mtype->name);
} }
nrmessage_type *nrt_find(const struct locale * lang, nrmessage_type *nrt_find(const struct locale * lang,
@ -148,7 +151,7 @@ size_t size, const void *userdata)
if (nrt) { if (nrt) {
const char *m = const char *m =
translate(nrt->string, userdata, nrt->vars, msg->parameters); translate(nrt_string(nrt), userdata, nrt->vars, msg->parameters);
if (m) { if (m) {
return str_strlcpy((char *)buffer, m, size); return str_strlcpy((char *)buffer, m, size);
} }

View file

@ -270,3 +270,38 @@ void sbs_strcpy(struct sbstring *sbs, const char *str)
} }
sbs->end = sbs->begin + len; sbs->end = sbs->begin + len;
} }
char *str_unescape(char *str) {
char *read = str, *write = str;
while (*read) {
char * pos = strchr(read, '\\');
if (pos) {
size_t len = pos - read;
memmove(write, read, len);
write += len;
read += (len + 1);
switch (read[0]) {
case 'r':
*write++ = '\r';
break;
case 'n':
*write++ = '\n';
break;
case 't':
*write++ = '\t';
break;
default:
*write++ = read[0];
}
*write = 0;
++read;
}
else {
size_t len = strlen(read);
memmove(write, read, len);
write[len] = 0;
break;
}
}
return str;
}

View file

@ -26,13 +26,15 @@ extern "C" {
#endif #endif
void str_replace(char *buffer, size_t size, const char *tmpl, const char *var, const char *value); void str_replace(char *buffer, size_t size, const char *tmpl, const char *var, const char *value);
const char *str_escape(const char *str, char *buffer, size_t len);
unsigned int str_hash(const char *s); unsigned int str_hash(const char *s);
size_t str_slprintf(char * dst, size_t size, const char * format, ...); size_t str_slprintf(char * dst, size_t size, const char * format, ...);
size_t str_strlcpy(char *dst, const char *src, size_t len); size_t str_strlcpy(char *dst, const char *src, size_t len);
size_t str_strlcat(char *dst, const char *src, size_t len); size_t str_strlcat(char *dst, const char *src, size_t len);
char *str_strdup(const char *s); char *str_strdup(const char *s);
const char *str_escape(const char *str, char *buffer, size_t len);
char *str_unescape(char *str);
unsigned int jenkins_hash(unsigned int a); unsigned int jenkins_hash(unsigned int a);
unsigned int wang_hash(unsigned int a); unsigned int wang_hash(unsigned int a);

View file

@ -9,6 +9,19 @@
#include <string.h> #include <string.h>
#include "strings.h" #include "strings.h"
static void test_str_unescape(CuTest * tc)
{
char scratch[64];
strcpy(scratch, "1234 5678");
str_unescape(scratch);
CuAssertStrEquals(tc, "1234 5678", scratch);
strcpy(scratch, "\\\"\\\\\\n\\t\\r\\a");
str_unescape(scratch);
CuAssertStrEquals(tc, "\"\\\n\t\ra", scratch);
}
static void test_str_escape(CuTest * tc) static void test_str_escape(CuTest * tc)
{ {
char scratch[64]; char scratch[64];
@ -122,6 +135,7 @@ CuSuite *get_strings_suite(void)
CuSuite *suite = CuSuiteNew(); CuSuite *suite = CuSuiteNew();
SUITE_ADD_TEST(suite, test_str_hash); SUITE_ADD_TEST(suite, test_str_hash);
SUITE_ADD_TEST(suite, test_str_escape); SUITE_ADD_TEST(suite, test_str_escape);
SUITE_ADD_TEST(suite, test_str_unescape);
SUITE_ADD_TEST(suite, test_str_replace); SUITE_ADD_TEST(suite, test_str_replace);
SUITE_ADD_TEST(suite, test_str_slprintf); SUITE_ADD_TEST(suite, test_str_slprintf);
SUITE_ADD_TEST(suite, test_str_strlcat); SUITE_ADD_TEST(suite, test_str_strlcat);

View file

@ -10,12 +10,23 @@ This program may not be used, modified or distributed
without prior permission by the authors of Eressea. without prior permission by the authors of Eressea.
*/ */
#ifdef _MSC_VER
#include <platform.h> #include <platform.h>
#include <kernel/config.h> #endif
#include "xmlreader.h" #include "xmlreader.h"
#include "alchemy.h"
#include "guard.h"
#include "keyword.h"
#include "move.h"
#include "prefix.h"
#include "attributes/attributes.h"
#include "modules/score.h"
#include "kernel/building.h" #include "kernel/building.h"
#include "kernel/calendar.h"
#include "kernel/item.h" #include "kernel/item.h"
#include "kernel/messages.h" #include "kernel/messages.h"
#include "kernel/race.h" #include "kernel/race.h"
@ -27,26 +38,15 @@ without prior permission by the authors of Eressea.
#include "kernel/spell.h" #include "kernel/spell.h"
#include "kernel/spellbook.h" #include "kernel/spellbook.h"
#include "alchemy.h" #include "util/attrib.h"
#include "kernel/calendar.h" #include "util/crmessage.h"
#include "guard.h" #include "util/functions.h"
#include "keyword.h" #include "util/language.h"
#include "move.h" #include "util/log.h"
#include "prefix.h" #include "util/message.h"
#include "util/nrmessage.h"
#include <modules/score.h> #include "util/strings.h"
#include <attributes/attributes.h> #include "util/xml.h"
/* util includes */
#include <util/attrib.h>
#include <util/crmessage.h>
#include <util/functions.h>
#include <util/language.h>
#include <util/log.h>
#include <util/message.h>
#include <util/nrmessage.h>
#include <util/strings.h>
#include <util/xml.h>
/* libxml includes */ /* libxml includes */
#include <libxml/tree.h> #include <libxml/tree.h>