diff options
| author | Russ Allbery <eagle@eyrie.org> | 2016-01-17 19:43:13 -0800 | 
|---|---|---|
| committer | Russ Allbery <eagle@eyrie.org> | 2016-01-17 19:43:13 -0800 | 
| commit | cf5297c4ec8815ecc7f5139ef05b9867843db2f7 (patch) | |
| tree | fef6ba149883530c7e7fba771be6ac2e59c4dfe9 /portable/setenv.c | |
| parent | 7e03241ce323be7447b085a8e7b07b78c770b0dc (diff) | |
| parent | 4b3f858ef567c0d12511e7fea2a56f08f2729635 (diff) | |
Merge tag 'upstream/1.3' into debian/master
Upstream version 1.3
Diffstat (limited to 'portable/setenv.c')
| -rw-r--r-- | portable/setenv.c | 24 | 
1 files changed, 9 insertions, 15 deletions
| diff --git a/portable/setenv.c b/portable/setenv.c index 472282a..f1f6db4 100644 --- a/portable/setenv.c +++ b/portable/setenv.c @@ -26,6 +26,7 @@   * the system version.   */  #if TESTING +# undef setenv  # define setenv test_setenv  int test_setenv(const char *, const char *, int);  #endif @@ -34,29 +35,22 @@ int  setenv(const char *name, const char *value, int overwrite)  {      char *envstring; -    size_t size; +    /* Do nothing if not overwriting and the variable is already set. */      if (!overwrite && getenv(name) != NULL)          return 0;      /* -     * Allocate memory for the environment string.  We intentionally don't use -     * the xmalloc family of allocation routines here, since the intention is -     * to provide a replacement for the standard library function that sets -     * errno and returns in the event of a memory allocation failure. -     */ -    size = strlen(name) + 1 + strlen(value) + 1; -    envstring = malloc(size); -    if (envstring == NULL) -        return -1; - -    /*       * Build the environment string and add it to the environment using       * putenv.  Systems without putenv lose, but XPG4 requires it. +     * +     * We intentionally don't use the xmalloc family of allocation routines +     * here, since the intention is to provide a replacement for the standard +     * library function that sets errno and returns in the event of a memory +     * allocation failure.       */ -    strlcpy(envstring, name, size); -    strlcat(envstring, "=", size); -    strlcat(envstring, value, size); +    if (asprintf(&envstring, "%s=%s", name, value) < 0) +        return -1;      return putenv(envstring);      /* | 
