forked from github/server
eliminate unnecessary strncpy use.
This commit is contained in:
parent
47c8b20f68
commit
d71d5e413a
4 changed files with 30 additions and 15 deletions
|
@ -413,7 +413,8 @@ void nr_spell_syntax(struct stream *out, spellbook_entry * sbe, const struct loc
|
|||
}
|
||||
else {
|
||||
char substr[32];
|
||||
strncpy(substr, syntaxp, cstr - syntaxp);
|
||||
assert(sizeof(substr) > (cstr - syntaxp));
|
||||
memcpy(substr, syntaxp, cstr - syntaxp);
|
||||
substr[cstr - syntaxp] = 0;
|
||||
locp = LOC(lang, mkname("spellpar", substr));
|
||||
syntaxp = substr + 1;
|
||||
|
|
|
@ -849,10 +849,6 @@ const struct unit * u, struct skill * sv, int *dh, int days)
|
|||
|
||||
void split_paragraph(strlist ** SP, const char *s, unsigned int indent, unsigned int width, char mark)
|
||||
{
|
||||
|
||||
/* Die Liste SP wird mit dem String s aufgefuellt, mit indent und einer
|
||||
* mark, falls angegeben. SP wurde also auf 0 gesetzt vor dem Aufruf.
|
||||
* Vgl. spunit (). */
|
||||
bool firstline;
|
||||
static char buf[REPORTWIDTH + 1]; // FIXME: static buffer, artificial limit
|
||||
size_t len = strlen(s);
|
||||
|
@ -883,7 +879,7 @@ void split_paragraph(strlist ** SP, const char *s, unsigned int indent, unsigned
|
|||
if (!cut) {
|
||||
cut = s + _min(len, REPORTWIDTH);
|
||||
}
|
||||
strncpy(buf + indent, s, cut - s);
|
||||
memcpy(buf + indent, s, cut - s);
|
||||
buf[indent + (cut - s)] = 0;
|
||||
addstrlist(SP, buf); // TODO: too much string copying, cut out this function
|
||||
while (*cut == ' ') {
|
||||
|
|
|
@ -101,16 +101,23 @@ locale *get_or_create_locale(const char *name)
|
|||
void make_locales(const char *str)
|
||||
{
|
||||
const char *tok = str;
|
||||
while (*tok) {
|
||||
char zText[32];
|
||||
while (*tok && *tok != ',')
|
||||
++tok;
|
||||
strncpy(zText, str, tok - str);
|
||||
zText[tok - str] = 0;
|
||||
get_or_create_locale(zText);
|
||||
if (*tok) {
|
||||
str = ++tok;
|
||||
while (tok) {
|
||||
char zText[16];
|
||||
size_t len;
|
||||
|
||||
tok = strchr(str, ',');
|
||||
if (tok) {
|
||||
len = tok - str;
|
||||
assert(sizeof(zText) > len);
|
||||
memcpy(zText, str, len);
|
||||
str = tok + 1;
|
||||
}
|
||||
else {
|
||||
len = strlen(str);
|
||||
memcpy(zText, str, len);
|
||||
}
|
||||
zText[len] = 0;
|
||||
get_or_create_locale(zText);
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -16,9 +16,20 @@ static void test_language(CuTest *tc)
|
|||
test_cleanup();
|
||||
}
|
||||
|
||||
static void test_make_locales(CuTest *tc)
|
||||
{
|
||||
test_setup();
|
||||
make_locales("aa,bb,cc");
|
||||
CuAssertPtrNotNull(tc, get_locale("aa"));
|
||||
CuAssertPtrNotNull(tc, get_locale("bb"));
|
||||
CuAssertPtrNotNull(tc, get_locale("cc"));
|
||||
test_cleanup();
|
||||
}
|
||||
|
||||
CuSuite *get_language_suite(void)
|
||||
{
|
||||
CuSuite *suite = CuSuiteNew();
|
||||
SUITE_ADD_TEST(suite, test_language);
|
||||
SUITE_ADD_TEST(suite, test_make_locales);
|
||||
return suite;
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue