Next: , Previous: chroot invocation, Up: Modified command invocation


23.2 env: Run a command in a modified environment

env runs a command with a modified environment. Synopses:

     env [option]... [name=value]... [command [args]...]
     env

Operands of the form ‘variable=value’ set the environment variable variable to value value. value may be empty (‘variable=’). Setting a variable to an empty value is different from unsetting it. These operands are evaluated left-to-right, so if two operands mention the same variable the earlier is ignored.

Environment variable names can be empty, and can contain any characters other than ‘=’ and ASCII nul. However, it is wise to limit yourself to names that consist solely of underscores, digits, and ASCII letters, and that begin with a non-digit, as applications like the shell do not work well with other names.

The first operand that does not contain the character ‘=’ specifies the program to invoke; it is searched for according to the PATH environment variable. Any remaining arguments are passed as arguments to that program. The program should not be a special built-in utility (see Special built-in utilities).

Modifications to PATH take effect prior to searching for command. Use caution when reducing PATH; behavior is not portable when PATH is undefined or omits key directories such as /bin.

In the rare case that a utility contains a ‘=’ in the name, the only way to disambiguate it from a variable assignment is to use an intermediate command for command, and pass the problematic program name via args. For example, if ./prog= is an executable in the current PATH:

     env prog= true # runs 'true', with prog= in environment
     env ./prog= true # runs 'true', with ./prog= in environment
     env -- prog= true # runs 'true', with prog= in environment
     env sh -c '\prog= true' # runs 'prog=' with argument 'true'
     env sh -c 'exec "$@"' sh prog= true # also runs 'prog='

If no command name is specified following the environment specifications, the resulting environment is printed. This is like specifying the printenv program.

For some examples, suppose the environment passed to env contains ‘LOGNAME=rms’, ‘EDITOR=emacs’, and ‘PATH=.:/gnubin:/hacks’:

The program accepts the following options. Also see Common options. Options must precede operands.

-0
--null
Output a zero byte (ASCII nul) at the end of each line, rather than a newline. This option enables other programs to parse the output of env even when that output would contain data with embedded newlines.
-u name
--unset=name
Remove variable name from the environment, if it was in the environment.
-
-i
--ignore-environment
Start with an empty environment, ignoring the inherited environment.

Exit status:

     0   if no command is specified and the environment is output
     125 if env itself fails
     126 if command is found but cannot be invoked
     127 if command cannot be found
     the exit status of command otherwise