summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Berthold Stoeger <bstoeger@mail.tuwien.ac.at>2017-11-18 10:55:01 +0100
committerGravatar Lubomir I. Ivanov <neolit123@gmail.com>2017-11-22 19:22:29 +0100
commit04f38d61d7b707c3ee29e00002380d596658395e (patch)
treecc6c2ecc100a86241cffc8b4b619c10a2aec73e1
parent7a99d7e5c3b297b543a9ce1ab36e337c1a8e0bf0 (diff)
downloadsubsurface-04f38d61d7b707c3ee29e00002380d596658395e.tar.gz
Clean up system_default_filename()
In the old implementation there were two static C-style strings, filename and path, which were initialized to NULL and filled on first call of the function (i.e. singletons). There is no sense in having two static variables indicating whether this function was called previously. Moreover, there is no point in remembering filename accross function calls, because it is not used once path is set to a non-NULL value. Therefore, make the filename variable non-static and calculate it only on first invocation (as indicated by a NULL path). Moreover, free() the filename variable after its use to fix a memory leak of the old code. The windows code is slightly different in that the temporary filename is not dynamically allocated. Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
-rw-r--r--core/linux.c11
-rw-r--r--core/macos.c11
-rw-r--r--core/windows.c9
3 files changed, 14 insertions, 17 deletions
diff --git a/core/linux.c b/core/linux.c
index da96ecb49..2f8d9d832 100644
--- a/core/linux.c
+++ b/core/linux.c
@@ -83,18 +83,17 @@ const char *system_default_directory(void)
const char *system_default_filename(void)
{
- static char *filename = NULL;
- if (!filename) {
+ static const char *path = NULL;
+ if (!path) {
const char *user = getenv("LOGNAME");
if (same_string(user, ""))
user = "username";
- filename = calloc(strlen(user) + 5, 1);
+ char *filename = calloc(strlen(user) + 5, 1);
strcat(filename, user);
strcat(filename, ".xml");
- }
- static const char *path = NULL;
- if (!path)
path = system_default_path_append(filename);
+ free(filename);
+ }
return path;
}
diff --git a/core/macos.c b/core/macos.c
index b16225c78..37bbd5d25 100644
--- a/core/macos.c
+++ b/core/macos.c
@@ -81,18 +81,17 @@ const char *system_default_directory(void)
const char *system_default_filename(void)
{
- static char *filename = NULL;
- if (!filename) {
+ static const char *path = NULL;
+ if (!path) {
const char *user = getenv("LOGNAME");
if (same_string(user, ""))
user = "username";
- filename = calloc(strlen(user) + 5, 1);
+ char *filename = calloc(strlen(user) + 5, 1);
strcat(filename, user);
strcat(filename, ".xml");
- }
- static const char *path = NULL;
- if (!path)
path = system_default_path_append(filename);
+ free(filename);
+ }
return path;
}
diff --git a/core/windows.c b/core/windows.c
index 029c3516e..f0b9eb22c 100644
--- a/core/windows.c
+++ b/core/windows.c
@@ -103,17 +103,16 @@ const char *system_default_directory(void)
*/
const char *system_default_filename(void)
{
- static wchar_t filename[UNLEN + 5] = { 0 };
- if (!*filename) {
+ static const char *path = NULL;
+ if (!path) {
wchar_t username[UNLEN + 1] = { 0 };
DWORD username_len = UNLEN + 1;
GetUserNameW(username, &username_len);
+ wchar_t filename[UNLEN + 5] = { 0 };
wcscat(filename, username);
wcscat(filename, L".xml");
- }
- static const char *path = NULL;
- if (!path)
path = system_default_path_append(filename);
+ }
return path;
}