mirror of
https://github.com/ddnet/ddnet.git
synced 2024-11-19 14:38:18 +00:00
Merge pull request #2032 from heinrich5991/pr_positional
Allow translations to reorder string substitutions
This commit is contained in:
commit
508f56f25f
|
@ -100,7 +100,7 @@ void dbg_msg(const char *sys, const char *fmt, ...)
|
||||||
|
|
||||||
va_start(args, fmt);
|
va_start(args, fmt);
|
||||||
#if defined(CONF_FAMILY_WINDOWS)
|
#if defined(CONF_FAMILY_WINDOWS)
|
||||||
_vsnprintf(msg, sizeof(str)-len, fmt, args);
|
_vsprintf_p(msg, sizeof(str)-len, fmt, args);
|
||||||
#else
|
#else
|
||||||
vsnprintf(msg, sizeof(str)-len, fmt, args);
|
vsnprintf(msg, sizeof(str)-len, fmt, args);
|
||||||
#endif
|
#endif
|
||||||
|
@ -1472,7 +1472,7 @@ int fs_storage_path(const char *appname, char *path, int max)
|
||||||
char *home = getenv("APPDATA");
|
char *home = getenv("APPDATA");
|
||||||
if(!home)
|
if(!home)
|
||||||
return -1;
|
return -1;
|
||||||
_snprintf(path, max, "%s/%s", home, appname);
|
str_format(path, max, "%s/%s", home, appname);
|
||||||
return 0;
|
return 0;
|
||||||
#else
|
#else
|
||||||
char *home = getenv("HOME");
|
char *home = getenv("HOME");
|
||||||
|
@ -1484,25 +1484,25 @@ int fs_storage_path(const char *appname, char *path, int max)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
#if defined(CONF_PLATFORM_MACOSX)
|
#if defined(CONF_PLATFORM_MACOSX)
|
||||||
snprintf(path, max, "%s/Library/Application Support/%s", home, appname);
|
str_format(path, max, "%s/Library/Application Support/%s", home, appname);
|
||||||
return 0;
|
return 0;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* old folder location */
|
/* old folder location */
|
||||||
snprintf(path, max, "%s/.%s", home, appname);
|
str_format(path, max, "%s/.%s", home, appname);
|
||||||
for(i = strlen(home)+2; path[i]; i++)
|
for(i = strlen(home)+2; path[i]; i++)
|
||||||
path[i] = tolower(path[i]);
|
path[i] = tolower(path[i]);
|
||||||
|
|
||||||
if(!xdgdatahome)
|
if(!xdgdatahome)
|
||||||
{
|
{
|
||||||
/* use default location */
|
/* use default location */
|
||||||
snprintf(xdgpath, max, "%s/.local/share/%s", home, appname);
|
str_format(xdgpath, max, "%s/.local/share/%s", home, appname);
|
||||||
for(i = strlen(home)+14; xdgpath[i]; i++)
|
for(i = strlen(home)+14; xdgpath[i]; i++)
|
||||||
xdgpath[i] = tolower(xdgpath[i]);
|
xdgpath[i] = tolower(xdgpath[i]);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
snprintf(xdgpath, max, "%s/%s", xdgdatahome, appname);
|
str_format(xdgpath, max, "%s/%s", xdgdatahome, appname);
|
||||||
for(i = strlen(xdgdatahome)+1; xdgpath[i]; i++)
|
for(i = strlen(xdgdatahome)+1; xdgpath[i]; i++)
|
||||||
xdgpath[i] = tolower(xdgpath[i]);
|
xdgpath[i] = tolower(xdgpath[i]);
|
||||||
}
|
}
|
||||||
|
@ -1515,7 +1515,7 @@ int fs_storage_path(const char *appname, char *path, int max)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
snprintf(path, max, "%s", xdgpath);
|
str_format(path, max, "%s", xdgpath);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
#endif
|
#endif
|
||||||
|
@ -1774,7 +1774,7 @@ void str_format(char *buffer, int buffer_size, const char *format, ...)
|
||||||
#if defined(CONF_FAMILY_WINDOWS)
|
#if defined(CONF_FAMILY_WINDOWS)
|
||||||
va_list ap;
|
va_list ap;
|
||||||
va_start(ap, format);
|
va_start(ap, format);
|
||||||
_vsnprintf(buffer, buffer_size, format, ap);
|
_vsprintf_p(buffer, buffer_size, format, ap);
|
||||||
va_end(ap);
|
va_end(ap);
|
||||||
#else
|
#else
|
||||||
va_list ap;
|
va_list ap;
|
||||||
|
|
|
@ -40,3 +40,24 @@ TEST(Str, Endswith)
|
||||||
EXPECT_EQ(str_endswith(ABCDEFG, DEFG) - ABCDEFG,
|
EXPECT_EQ(str_endswith(ABCDEFG, DEFG) - ABCDEFG,
|
||||||
str_length(ABCDEFG) - str_length(DEFG));
|
str_length(ABCDEFG) - str_length(DEFG));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TEST(StrFormat, Positional)
|
||||||
|
{
|
||||||
|
char aBuf[256];
|
||||||
|
|
||||||
|
// normal
|
||||||
|
str_format(aBuf, sizeof(aBuf), "%s %s", "first", "second");
|
||||||
|
EXPECT_STREQ(aBuf, "first second");
|
||||||
|
|
||||||
|
// normal with positional arguments
|
||||||
|
str_format(aBuf, sizeof(aBuf), "%1$s %2$s", "first", "second");
|
||||||
|
EXPECT_STREQ(aBuf, "first second");
|
||||||
|
|
||||||
|
// reverse
|
||||||
|
str_format(aBuf, sizeof(aBuf), "%2$s %1$s", "first", "second");
|
||||||
|
EXPECT_STREQ(aBuf, "second first");
|
||||||
|
|
||||||
|
// duplicate
|
||||||
|
str_format(aBuf, sizeof(aBuf), "%1$s %1$s %2$d %1$s %2$d", "str", 1);
|
||||||
|
EXPECT_STREQ(aBuf, "str str 1 str 1");
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue