SETENV(3C) Standard C Library Functions SETENV(3C)
NAME
setenv - add or change environment variable
SYNOPSIS
#include <stdlib.h>
int setenv(
const char *envname,
const char *envval,
int overwrite);
DESCRIPTION
The
setenv() function updates or adds a variable in the environment
of the calling process. The
envname argument points to a string
containing the name of an environment variable to be added or
altered. The environment variable is set to the value to which
envval points. The function fails if
envname points to a string which
contains an '=' character. If the environment variable named by
envname already exists and the value of
overwrite is non-zero, the
function returns successfully and the environment is updated. If the
environment variable named by
envname already exists and the value of
overwrite is zero, the function returns successfully and the
environment remains unchanged.
If the application modifies
environ or the pointers to which it
points, the behavior of
setenv() is undefined. The
setenv() function
updates the list of pointers to which
environ points.
The strings described by
envname and
envval are copied by this
function.
RETURN VALUES
Upon successful completion, 0 is returned. Otherwise, -1 is returned,
errno set to indicate the error, and the environment is left
unchanged.
ERRORS
The
setenv() function will fail if:
EINVAL The
envname argument is a null pointer, points to an empty
string, or points to a string containing an '=' character.
ENOMEM Insufficient memory was available to add a variable or its
value to the environment.
ATTRIBUTES
See
attributes(7) for descriptions of the following attributes:
+--------------------+-----------------+
| ATTRIBUTE TYPE | ATTRIBUTE VALUE |
+--------------------+-----------------+
|Interface Stability | Standard |
+--------------------+-----------------+
|MT-Level | MT-Safe |
+--------------------+-----------------+
SEE ALSO
getenv(3C),
unsetenv(3C),
attributes(7),
standards(7) March 31, 2002 SETENV(3C)