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)