diff options
| author | Jörg Frings-Fürst <debian@jff.email> | 2025-03-22 18:00:25 +0100 | 
|---|---|---|
| committer | Jörg Frings-Fürst <debian@jff.email> | 2025-03-22 18:00:25 +0100 | 
| commit | 0737819efdd0bae112d16d874cac7e747e43cd08 (patch) | |
| tree | 98a9ac84f7f347ae530c14852c68870682f3d04c /tests/unsetenv.c | |
| parent | 163a663518f33bab48b28431972e580b366b4d49 (diff) | |
| parent | e670957a8693f860cf7d77fed4ce6b4b056a8083 (diff) | |
Merge branch 'release/debian/1.3-1'debian/1.3-1
Diffstat (limited to 'tests/unsetenv.c')
| -rw-r--r-- | tests/unsetenv.c | 32 | 
1 files changed, 30 insertions, 2 deletions
| diff --git a/tests/unsetenv.c b/tests/unsetenv.c index d8ada2aa..5e989968 100644 --- a/tests/unsetenv.c +++ b/tests/unsetenv.c @@ -57,7 +57,6 @@ int  unsetenv (const char *name)  {    size_t len; -  char **ep;    if (name == NULL || *name == '\0' || strchr (name, '=') != NULL)      { @@ -67,9 +66,37 @@ unsetenv (const char *name)    len = strlen (name); +#if HAVE_DECL__PUTENV /* native Windows */ +  /* The Microsoft documentation +     <https://learn.microsoft.com/en-us/cpp/c-runtime-library/reference/putenv-wputenv> +     says: +       "Don't change an environment entry directly: instead, +        use _putenv or _wputenv to change it." +     Note: Microsoft's _putenv updates not only the contents of _environ but +     also the contents of _wenviron, so that both are in kept in sync. + +     The way to remove an environment variable is to pass to _putenv a string +     of the form "NAME=".  (NB: This is a different convention than with glibc +     putenv, which expects a string of the form "NAME"!)  */ +  { +    int putenv_result; +    char *name_ = malloc (len + 2); +    if (name_ == NULL) +      return -1; +    memcpy (name_, name, len); +    name_[len] = '='; +    name_[len + 1] = 0; +    putenv_result = _putenv (name_); +    /* In this particular case it is OK to free() the argument passed to +       _putenv.  */ +    free (name_); +    return putenv_result; +  } +#else +    LOCK; -  ep = __environ; +  char **ep = __environ;    while (*ep != NULL)      if (!strncmp (*ep, name, len) && (*ep)[len] == '=')        { @@ -87,6 +114,7 @@ unsetenv (const char *name)    UNLOCK;    return 0; +#endif  }  #ifdef _LIBC | 
