diff options
author | Jay Satiro <raysatiro@yahoo.com> | 2020-01-29 03:23:55 -0500 |
---|---|---|
committer | Jay Satiro <raysatiro@yahoo.com> | 2020-02-12 18:37:31 -0500 |
commit | 9dc350b60c1345aea548847de414c55468a4d123 (patch) | |
tree | 0f2b5f439f83ab148dcb158e2d63342d752a8658 /src/tool_homedir.c | |
parent | 39d5621cbd81ff456d295af7c648a31215958c93 (diff) | |
download | curl-9dc350b60c1345aea548847de414c55468a4d123.tar.gz |
tool_homedir: Change GetEnv() to use libcurl's curl_getenv()
- Deduplicate GetEnv() code.
- On Windows change ultimate call to use Windows API
GetEnvironmentVariable() instead of C runtime getenv().
Prior to this change both libcurl and the tool had their own GetEnv
which over time diverged. Now the tool's GetEnv is a wrapper around
curl_getenv (libcurl API function which is itself a wrapper around
libcurl's GetEnv).
Furthermore this change fixes a bug in that Windows API
GetEnvironmentVariable() is called instead of C runtime getenv() to get
the environment variable since some changes aren't always visible to the
latter.
Reported-by: Christoph M. Becker
Fixes https://github.com/curl/curl/issues/4774
Closes https://github.com/curl/curl/pull/4863
Diffstat (limited to 'src/tool_homedir.c')
-rw-r--r-- | src/tool_homedir.c | 55 |
1 files changed, 24 insertions, 31 deletions
diff --git a/src/tool_homedir.c b/src/tool_homedir.c index 6bc69551e..e4ea97d38 100644 --- a/src/tool_homedir.c +++ b/src/tool_homedir.c @@ -25,38 +25,23 @@ # include <pwd.h> #endif +#include <curl/mprintf.h> + #include "tool_homedir.h" #include "memdebug.h" /* keep this as LAST include */ -static char *GetEnv(const char *variable, char do_expand) +static char *GetEnv(const char *variable) { - char *env = NULL; -#ifdef WIN32 - char buf1[1024], buf2[1024]; - DWORD rc; + char *dupe, *env; - /* Don't use getenv(); it doesn't find variable added after program was - * started. Don't accept truncated results (i.e. rc >= sizeof(buf1)). */ + env = curl_getenv(variable); + if(!env) + return NULL; - rc = GetEnvironmentVariableA(variable, buf1, sizeof(buf1)); - if(rc > 0 && rc < sizeof(buf1)) { - env = buf1; - variable = buf1; - } - if(do_expand && strchr(variable, '%')) { - /* buf2 == variable if not expanded */ - rc = ExpandEnvironmentStringsA(variable, buf2, sizeof(buf2)); - if(rc > 0 && rc < sizeof(buf2) && - !strchr(buf2, '%')) /* no vars still unexpanded */ - env = buf2; - } -#else - (void)do_expand; - /* no length control */ - env = getenv(variable); -#endif - return (env && env[0]) ? strdup(env) : NULL; + dupe = strdup(env); + curl_free(env); + return dupe; } /* return the home directory of the current user as an allocated string */ @@ -64,11 +49,11 @@ char *homedir(void) { char *home; - home = GetEnv("CURL_HOME", FALSE); + home = GetEnv("CURL_HOME"); if(home) return home; - home = GetEnv("HOME", FALSE); + home = GetEnv("HOME"); if(home) return home; @@ -86,10 +71,18 @@ char *homedir(void) } #endif /* PWD-stuff */ #ifdef WIN32 - home = GetEnv("APPDATA", TRUE); - if(!home) - home = GetEnv("%USERPROFILE%\\Application Data", TRUE); /* Normally only - on Win-2K/XP */ + home = GetEnv("APPDATA"); + if(!home) { + char *env = GetEnv("USERPROFILE"); + if(env) { + char *path = curl_maprintf("%s\\Application Data", env); + if(path) { + home = strdup(path); + curl_free(path); + } + free(env); + } + } #endif /* WIN32 */ return home; } |