mirror of
https://github.com/TerryCavanagh/VVVVVV.git
synced 2025-01-24 09:49:46 +01:00
Clean up strcat()s/strcpy()s, EXCEPT for migrateSaveData()
strcat()s and strcpy()s have been replaced with SDL_snprintf() where possible, to clearly convey the intent of just building a string that looks a certain way, instead of spanning it out over multiple lines. Where there's not really a good way to avoid strcat()/strcpy() (e.g. in PLATFORM_getOSDirectory()), they will at least be replaced with SDL_strlcat() and SDL_strlcpy(), which are safer functions and are less likely to have issues with null termination. I decided not to bother with PLATFORM_migrateSaveData(), because it's going to be axed in 2.4 anyways.
This commit is contained in:
parent
ce2eba1649
commit
609ceb782c
1 changed files with 13 additions and 11 deletions
|
@ -47,13 +47,13 @@ int FILESYSTEM_init(char *argvZero, char* baseDir, char *assetsPath)
|
||||||
/* Determine the OS user directory */
|
/* Determine the OS user directory */
|
||||||
if (baseDir && baseDir[0] != '\0')
|
if (baseDir && baseDir[0] != '\0')
|
||||||
{
|
{
|
||||||
strcpy(output, baseDir);
|
|
||||||
|
|
||||||
/* We later append to this path and assume it ends in a slash */
|
/* We later append to this path and assume it ends in a slash */
|
||||||
if (SDL_strcmp(output + SDL_strlen(output) - SDL_strlen(pathSep), pathSep) != 0)
|
bool trailing_pathsep = SDL_strcmp(baseDir + SDL_strlen(baseDir) - SDL_strlen(pathSep), pathSep) == 0;
|
||||||
{
|
|
||||||
strcat(output, pathSep);
|
SDL_snprintf(output, sizeof(output), "%s%s",
|
||||||
}
|
baseDir,
|
||||||
|
!trailing_pathsep ? pathSep : ""
|
||||||
|
);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -97,12 +97,14 @@ int FILESYSTEM_init(char *argvZero, char* baseDir, char *assetsPath)
|
||||||
/* Mount the stock content last */
|
/* Mount the stock content last */
|
||||||
if (assetsPath)
|
if (assetsPath)
|
||||||
{
|
{
|
||||||
strcpy(output, assetsPath);
|
SDL_strlcpy(output, assetsPath, sizeof(output));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
strcpy(output, PHYSFS_getBaseDir());
|
SDL_snprintf(output, sizeof(output), "%s%s",
|
||||||
strcat(output, "data.zip");
|
PHYSFS_getBaseDir(),
|
||||||
|
"data.zip"
|
||||||
|
);
|
||||||
}
|
}
|
||||||
if (!PHYSFS_mount(output, NULL, 1))
|
if (!PHYSFS_mount(output, NULL, 1))
|
||||||
{
|
{
|
||||||
|
@ -350,9 +352,9 @@ void PLATFORM_getOSDirectory(char* output)
|
||||||
WCHAR utf16_path[MAX_PATH];
|
WCHAR utf16_path[MAX_PATH];
|
||||||
SHGetFolderPathW(NULL, CSIDL_PERSONAL, NULL, SHGFP_TYPE_CURRENT, utf16_path);
|
SHGetFolderPathW(NULL, CSIDL_PERSONAL, NULL, SHGFP_TYPE_CURRENT, utf16_path);
|
||||||
WideCharToMultiByte(CP_UTF8, 0, utf16_path, -1, output, MAX_PATH, NULL, NULL);
|
WideCharToMultiByte(CP_UTF8, 0, utf16_path, -1, output, MAX_PATH, NULL, NULL);
|
||||||
strcat(output, "\\VVVVVV\\");
|
SDL_strlcat(output, "\\VVVVVV\\", sizeof(output));
|
||||||
#else
|
#else
|
||||||
strcpy(output, PHYSFS_getPrefDir("distractionware", "VVVVVV"));
|
SDL_strlcpy(output, PHYSFS_getPrefDir("distractionware", "VVVVVV"), sizeof(output));
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue