import less(1)
[unleashed/tickless.git] / share / man / man3c / wordexp.3c
blobee5eff5b30f63ae4742c5581b91692fe90fbdd60
1 '\" te
2 .\" Copyright (c) 1992, X/Open Company Limited. All Rights Reserved.  Portions Copyright (c) 2003, Sun Microsystems, Inc.  All Rights Reserved.
3 .\" Sun Microsystems, Inc. gratefully acknowledges The Open Group for permission to reproduce portions of its copyrighted documentation. Original documentation from The Open Group can be obtained online at
4 .\" http://www.opengroup.org/bookstore/.
5 .\" The Institute of Electrical and Electronics Engineers and The Open Group, have given us permission to reprint portions of their documentation. In the following statement, the phrase "this text" refers to portions of the system documentation. Portions of this text are reprinted and reproduced in electronic form in the Sun OS Reference Manual, from IEEE Std 1003.1, 2004 Edition, Standard for Information Technology -- Portable Operating System Interface (POSIX), The Open Group Base Specifications Issue 6, Copyright (C) 2001-2004 by the Institute of Electrical and Electronics Engineers, Inc and The Open Group. In the event of any discrepancy between these versions 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.opengroup.org/unix/online.html.
6 .\"  This notice shall appear on any product containing this material.
7 .\" The contents of this file are subject to the terms of the Common Development and Distribution License (the "License").  You may not use this file except in compliance with the License.
8 .\" You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE or http://www.opensolaris.org/os/licensing.  See the License for the specific language governing permissions and limitations under the License.
9 .\" When distributing Covered Code, include this CDDL HEADER in each file and include the License file at usr/src/OPENSOLARIS.LICENSE.  If applicable, add the following below this CDDL HEADER, with the fields enclosed by brackets "[]" replaced with your own identifying information: Portions Copyright [yyyy] [name of copyright owner]
10 .TH WORDEXP 3C "Nov 1, 2003"
11 .SH NAME
12 wordexp, wordfree \- perform word expansions
13 .SH SYNOPSIS
14 .LP
15 .nf
16 #include <wordexp.h>
18 \fBint\fR \fBwordexp\fR(\fBconst char *restrict\fR \fIwords\fR, \fBwordexp_t *restrict\fR \fIpwordexp\fR,
19      \fBint\fR \fIflags\fR);
20 .fi
22 .LP
23 .nf
24 \fBvoid\fR \fBwordfree\fR(\fBwordexp_t *\fR\fIpwordexp\fR);
25 .fi
27 .SH DESCRIPTION
28 .sp
29 .LP
30 The \fBwordexp()\fR function performs word expansions, subject to quoting, and
31 places the list of expanded words into the structure pointed to by
32 \fIpwordexp\fR.
33 .sp
34 .LP
35 The \fBwordfree()\fR function frees any memory allocated by \fBwordexp()\fR
36 associated with \fIpwordexp\fR.
37 .SS "\fIwords\fR Argument"
38 .sp
39 .LP
40 The \fIwords\fR argument is a pointer to a string containing one or more words
41 to be expanded. The expansions will be the same as would be performed by the
42 shell if \fIwords\fR were the part of a command line representing the arguments
43 to a utility. Therefore, \fIwords\fR must not contain an unquoted \fBNEWLINE\fR
44 or any of the unquoted shell special characters:
45 .sp
46 .LP
47 \fB |   &   ;   <   >\fR
48 .sp
49 .LP
50 except in the context of command substitution. It also must not contain
51 unquoted parentheses or braces, except in the context of command or variable
52 substitution. If the argument \fIwords\fR contains an unquoted comment
53 character (number sign) that is the beginning of a token, \fBwordexp()\fR may
54 treat the comment character as a regular character, or may interpret it as a
55 comment indicator and ignore the remainder of \fIwords\fR.
56 .SS "\fIpwordexp\fR Argument"
57 .sp
58 .LP
59 The structure type \fBwordexp_t\fR is defined in the header <\fBwordexp.h\fR>
60 and includes at least the following members:
61 .sp
62 .ne 2
63 .na
64 \fB\fBsize_t we_wordc\fR\fR
65 .ad
66 .RS 19n
67 Count of words matched by \fIwords\fR.
68 .RE
70 .sp
71 .ne 2
72 .na
73 \fB\fBchar **we_wordv\fR\fR
74 .ad
75 .RS 19n
76 Pointer to list of expanded words.
77 .RE
79 .sp
80 .ne 2
81 .na
82 \fB\fBsize_t we_offs\fR\fR
83 .ad
84 .RS 19n
85 Slots to reserve at the beginning of \fIpwordexp\(mi>\fR\fBwe_wordv\fR.
86 .RE
88 .sp
89 .LP
90 The \fBwordexp()\fR function stores the number of generated words into
91 \fIpwordexp\(mi>\fR\fBwe_wordc\fR and a pointer to a list of pointers to words
92 in \fIpwordexp\(mi>\fR\fBwe_wordv.\fR Each individual field created during
93 field splitting is a separate word in the \fIpwordexp\(mi>\fR\fBwe_wordv\fR
94 list.  The words are in order. The first pointer after the last word pointer
95 will be a null pointer.
96 .sp
97 .LP
98 It is the caller's responsibility to allocate the storage pointed to by
99 \fIpwordexp\fR. The \fBwordexp()\fR function allocates other space as needed,
100 including memory pointed to by \fIpwordexp\(mi>\fR\fBwe_wordv\fR. The
101 \fBwordfree()\fR function frees any memory associated with \fIpwordexp\fR from
102 a previous call to \fBwordexp()\fR.
103 .SS "\fIflags\fR Argument"
106 The \fIflags\fR argument is used to control the behavior of \fBwordexp()\fR.
107 The value of \fIflags\fR is the bitwise inclusive \fBOR\fR of zero or more of
108 the following constants, which are defined in \fB<wordexp.h>\fR:
110 .ne 2
112 \fB\fBWRDE_APPEND\fR\fR
114 .RS 16n
115 Append words generated to the ones from a previous call to \fBwordexp()\fR.
119 .ne 2
121 \fB\fBWRDE_DOOFFS\fR\fR
123 .RS 16n
124 Make use of \fIpwordexp\(mi>\fR\fBwe_offs.\fR If this flag is set,
125 \fIpwordexp\(mi>\fR\fBwe_offs\fR is used to specify how many \fINULL\fR
126 pointers to add to the beginning of \fIpwordexp\(mi>\fR\fBwe_wordv.\fR In other
127 words, \fIpwordexp\(mi>\fR\fBwe_wordv\fR will point to
128 \fIpwordexp\(mi>\fR\fBwe_offs\fR \fINULL\fR pointers, followed by
129 \fIpwordexp\(mi>\fR\fBwe_wordc\fR word pointers, followed by a \fINULL\fR
130 pointer.
134 .ne 2
136 \fB\fBWRDE_NOCMD\fR\fR
138 .RS 16n
139 Fail if command substitution is requested.
143 .ne 2
145 \fB\fBWRDE_REUSE\fR\fR
147 .RS 16n
148 The \fIpwordexp\fR argument was passed to a previous successful call to
149 \fBwordexp()\fR, and has not been passed to \fBwordfree()\fR. The result will
150 be the same as if the application had called \fBwordfree()\fR and then called
151 \fBwordexp()\fR without \fBWRDE_REUSE\fR.
155 .ne 2
157 \fB\fBWRDE_SHOWERR\fR\fR
159 .RS 16n
160 Do not redirect \fBstderr\fR to \fB/dev/null\fR.
164 .ne 2
166 \fB\fBWRDE_UNDEF\fR\fR
168 .RS 16n
169 Report error on an attempt to expand an undefined shell variable.
174 The \fBWRDE_APPEND\fR flag can be used to append a new set of words to those
175 generated by a previous call to \fBwordexp()\fR. The following rules apply when
176 two or more calls to \fBwordexp()\fR are made with the same value of
177 \fIpwordexp\fR and without intervening calls to \fBwordfree()\fR:
178 .RS +4
181 The first such call must not set \fBWRDE_APPEND\fR. All subsequent calls
182 must set it.
184 .RS +4
187 All of the calls must set \fBWRDE_DOOFFS\fR, or all must not set it.
189 .RS +4
192 After the second and each subsequent call, \fIpwordexp\(mi>\fR\fBwe_wordv\fR
193 will point to a list containing the following:
194 .RS +4
197 zero or more \fINULL\fR pointers, as specified by \fBWRDE_DOOFFS\fR and
198 \fIpwordexp\(mi>\fR\fBwe_offs.\fR
200 .RS +4
203 pointers to the words that were in the \fIpwordexp\(mi>\fR\fBwe_wordv\fR
204 list before the call, in the same order as before.
206 .RS +4
209 pointers to the new words generated by the latest call, in the specified
210 order.
213 .RS +4
216 The count returned in \fIpwordexp\(mi>\fR\fBwe_wordc\fR will be the total
217 number of words from all of the calls.
219 .RS +4
222 The application can change any of the fields after a call to
223 \fBwordexp()\fR, but if it does it must reset them to the original value before
224 a subsequent call, using the same \fIpwordexp\fR value, to \fBwordfree()\fR or
225 \fBwordexp()\fR with the \fBWRDE_APPEND\fR or \fBWRDE_REUSE\fR flag.
229 If \fIwords\fR contains an unquoted:
232 \fBNEWLINE\fR \fB|   &   ;   <   >   (   )   {   }\fR
235 in an inappropriate context, \fBwordexp()\fR will fail, and the number of
236 expanded words will be zero.
239 Unless \fBWRDE_SHOWERR\fR is set in \fIflags\fR, \fBwordexp()\fR will redirect
240 \fBstderr\fR to \fB/dev/null\fR for any utilities executed as a result of
241 command substitution while expanding \fIwords\fR.
244 If \fBWRDE_SHOWERR\fR is set, \fBwordexp()\fR may write messages to
245 \fIstderr\fR if syntax errors are detected while expanding \fIwords\fR. If
246 \fBWRDE_DOOFFS\fR is set, then \fIpwordexp\(mi>\fR\fB we_offs\fR must have the
247 same value for each \fBwordexp()\fR call and \fBwordfree()\fR call using a
248 given \fIpwordexp\fR.
251 The following constants are defined as error return values:
253 .ne 2
255 \fB\fBWRDE_BADCHAR\fR\fR
257 .RS 16n
258 One of the unquoted characters:
260 \fBNEWLINE\fR \fB|   &   ;   <   >   (   )   {   }\fR
262 appears in \fIwords\fR in an inappropriate context.
266 .ne 2
268 \fB\fBWRDE_BADVAL\fR\fR
270 .RS 16n
271 Reference to undefined shell variable when \fBWRDE_UNDEF\fR is set in
272 \fIflags\fR.
276 .ne 2
278 \fB\fBWRDE_CMDSUB\fR\fR
280 .RS 16n
281 Command substitution requested when \fBWRDE_NOCMD\fR was set in flags.
285 .ne 2
287 \fB\fBWRDE_NOSPACE\fR\fR
289 .RS 16n
290 Attempt to allocate memory failed.
294 .ne 2
296 \fB\fBWRDE_SYNTAX\fR\fR
298 .RS 16n
299 Shell syntax error, such as unbalanced parentheses or unterminated string.
302 .SH RETURN VALUES
305 On successful completion, \fBwordexp()\fR returns \fB0\fR.
308 Otherwise, a non-zero value as described in \fB<wordexp.h>\fR is returned to
309 indicate an error.  If \fBwordexp()\fR returns the value \fBWRDE_NOSPACE\fR,
310 then \fIpwordexp\(mi>\fR\fBwe_wordc\fR and \fIpwordexp\(mi>\fR\fBwe_wordv\fR
311 will be updated to reflect any words that were successfully expanded. In other
312 cases, they will not be modified.
315 The \fBwordfree()\fR function returns no value.
316 .SH ERRORS
319 No errors are defined.
320 .SH USAGE
323 This function is intended to be used by an application that wants to do all of
324 the shell's expansions on a word or words obtained from a user. For example, if
325 the application prompts for a filename (or list of filenames) and then uses
326 \fBwordexp()\fR to process the input, the user could respond with anything that
327 would be valid as input to the shell.
330 The \fBWRDE_NOCMD\fR flag is provided for applications that, for security or
331 other reasons, want to prevent a user from executing shell command. Disallowing
332 unquoted shell special characters also prevents unwanted side effects such as
333 executing a command or writing a file.
334 .SH ATTRIBUTES
337 See \fBattributes\fR(5) for descriptions of the following attributes:
342 box;
343 c | c
344 l | l .
345 ATTRIBUTE TYPE  ATTRIBUTE VALUE
347 Interface Stability     Standard
349 MT-Level        MT-Safe
352 .SH SEE ALSO
355 \fBfnmatch\fR(3C), \fBglob\fR(3C), \fBattributes\fR(5), \fBstandards\fR(5)