aboutsummaryrefslogtreecommitdiff
path: root/coreutils-5.3.0-bin/man/cat1p/env.1p.txt
blob: 119f6c4a6f9d760649aeccd5a599feb2478c3e6d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
env(P)                                                   env(P)





NAME
       env - set the environment for command invocation

SYNOPSIS
       env [-i][name=value]...  [utility [argument...]]

DESCRIPTION
       The  env  utility  shall obtain the current environment,
       modify it according to its arguments,  then  invoke  the
       utility  named  by the utility operand with the modified
       environment.

       Optional arguments shall be passed to utility.

       If no utility operand is specified, the resulting  envi-
       ronment  shall  be  written to the standard output, with
       one name= value pair per line.

OPTIONS
       The env utility shall conform to  the  Base  Definitions
       volume  of  IEEE Std 1003.1-2001,  Section 12.2, Utility
       Syntax Guidelines.

       The following options shall be supported:

       -i     Invoke utility with exactly the environment spec-
              ified by the arguments; the inherited environment
              shall be ignored completely.


OPERANDS
       The following operands shall be supported:

       name=value
              Arguments of the form name=  value  shall  modify
              the  execution  environment,  and shall be placed
              into the inherited environment before the utility
              is invoked.

       utility
              The  name  of  the  utility to be invoked. If the
              utility operand names any of the special built-in
              utilities  in  Special  Built-In  Utilities , the
              results are undefined.

       argument
              A string to pass as an argument for  the  invoked
              utility.


STDIN
       Not used.

INPUT FILES
       None.

ENVIRONMENT VARIABLES
       The  following  environment  variables  shall affect the
       execution of env:

       LANG   Provide a default value for the internationaliza-
              tion  variables  that are unset or null. (See the
              Base Definitions volume of  IEEE Std 1003.1-2001,
              Section  8.2,  Internationalization Variables for
              the precedence of internationalization  variables
              used  to  determine  the  values  of locale cate-
              gories.)

       LC_ALL If set to a non-empty string value, override  the
              values  of  all  the  other  internationalization
              variables.

       LC_CTYPE
              Determine the locale for  the  interpretation  of
              sequences  of  bytes  of  text data as characters
              (for example, single-byte as  opposed  to  multi-
              byte characters in arguments).

       LC_MESSAGES
              Determine  the  locale  that  should  be  used to
              affect the format and contents of diagnostic mes-
              sages written to standard error.

       NLSPATH
              Determine  the  location  of message catalogs for
              the processing of LC_MESSAGES .

       PATH   Determine  the  location  of  the   utility,   as
              described  in  the  Base  Definitions  volume  of
              IEEE Std 1003.1-2001,  Chapter   8,   Environment
              Variables.  If PATH is specified as a name= value
              operand to env, the value given shall be used  in
              the search for utility.


ASYNCHRONOUS EVENTS
       Default.

STDOUT
       If  no  utility  operand  is specified, each name= value
       pair in the resulting environment shall  be  written  in
       the form:


              "%s=%s\n", <name>, <value>

       If  the  utility  operand  is specified, the env utility
       shall not write to standard output.

STDERR
       The standard error shall be  used  only  for  diagnostic
       messages.

OUTPUT FILES
       None.

EXTENDED DESCRIPTION
       None.

EXIT STATUS
       If  utility  is invoked, the exit status of env shall be
       the exit status of utility; otherwise, the  env  utility
       shall exit with one of the following values:

           0  The env utility completed successfully.

       1-125  An error occurred in the env utility.

         126  The  utility  specified  by utility was found but
              could not be invoked.

         127  The utility specified by  utility  could  not  be
              found.


CONSEQUENCES OF ERRORS
       Default.

       The following sections are informative.

APPLICATION USAGE
       The command, env, nice, nohup, time, and xargs utilities
       have been specified to use exit code  127  if  an  error
       occurs  so that applications can distinguish "failure to
       find a utility" from "invoked  utility  exited  with  an
       error  indication".  The value 127 was chosen because it
       is not commonly used for other meanings; most  utilities
       use  small  values for "normal error conditions" and the
       values above 128 can be confused with termination due to
       receipt of a signal. The value 126 was chosen in a simi-
       lar manner to indicate that the utility could be  found,
       but  not  invoked. Some scripts produce meaningful error
       messages differentiating the 126 and 127 cases. The dis-
       tinction  between  exit  codes  126  and 127 is based on
       KornShell practice that uses 127 when  all  attempts  to
       exec  the  utility fail with [ENOENT], and uses 126 when
       any attempt to exec the utility fails for any other rea-
       son.

       Historical  implementations  of  the env utility use the
       execvp() or execlp() functions  defined  in  the  System
       Interfaces  volume of IEEE Std 1003.1-2001 to invoke the
       specified utility; this provides better performance  and
       keeps  users  from having to escape characters with spe-
       cial meaning to the shell. Therefore,  shell  functions,
       special  built-ins, and built-ins that are only provided
       by the shell are not found.

EXAMPLES
       The following command:


              env -i PATH=/mybin mygrep xyz myfile

       invokes the command mygrep with a new PATH value as  the
       only  entry  in  its  environment. In this case, PATH is
       used to locate mygrep, which then must reside in /mybin.

RATIONALE
       As with all other utilities that invoke other utilities,
       this volume of IEEE Std 1003.1-2001 only specifies  what
       env  does with standard input, standard output, standard
       error, input files, and output files. If  a  utility  is
       executed,  it is not constrained by the specification of
       input and output by env.

       The -i option was added to allow  the  functionality  of
       the  withdrawn  - option in a manner compatible with the
       Utility Syntax Guidelines.

       Some have suggested that env is redundant since the same
       effect is achieved by:


              name=value ... utility [ argument ... ]

       The  example  is  equivalent  to env when an environment
       variable is being added to the environment of  the  com-
       mand,  but  not when the environment is being set to the
       given value. The env utility also writes out the current
       environment  if invoked without arguments. There is suf-
       ficient functionality beyond what the  example  provides
       to justify inclusion of env.

FUTURE DIRECTIONS
       None.

SEE ALSO
       Parameters and Variables , Special Built-In Utilities

COPYRIGHT
       Portions  of  this  text are reprinted and reproduced in
       electronic form from  IEEE  Std  1003.1,  2003  Edition,
       Standard  for Information Technology -- Portable Operat-
       ing System Interface (POSIX), The Open Group Base Speci-
       fications Issue 6, Copyright (C) 2001-2003 by the Insti-
       tute of Electrical and Electronics  Engineers,  Inc  and
       The  Open Group. In the event of any discrepancy between
       this version and the original IEEE and  The  Open  Group
       Standard,  the original IEEE and The Open Group Standard
       is the referee document. The original  Standard  can  be
       obtained        online        at        http://www.open-
       group.org/unix/online.html .



POSIX                         2003                       env(P)