master
 1/* Copyright (C) 1991-2025 Free Software Foundation, Inc.
 2   This file is part of the GNU C Library.
 3
 4   The GNU C Library is free software; you can redistribute it and/or
 5   modify it under the terms of the GNU Lesser General Public
 6   License as published by the Free Software Foundation; either
 7   version 2.1 of the License, or (at your option) any later version.
 8
 9   The GNU C Library is distributed in the hope that it will be useful,
10   but WITHOUT ANY WARRANTY; without even the implied warranty of
11   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
12   Lesser General Public License for more details.
13
14   You should have received a copy of the GNU Lesser General Public
15   License along with the GNU C Library; if not, see
16   <https://www.gnu.org/licenses/>.  */
17
18#ifndef	_WORDEXP_H
19#define	_WORDEXP_H	1
20
21#include <features.h>
22#define __need_size_t
23#include <stddef.h>
24
25__BEGIN_DECLS
26
27/* Bits set in the FLAGS argument to `wordexp'.  */
28enum
29  {
30    WRDE_DOOFFS = (1 << 0),	/* Insert PWORDEXP->we_offs NULLs.  */
31    WRDE_APPEND = (1 << 1),	/* Append to results of a previous call.  */
32    WRDE_NOCMD = (1 << 2),	/* Don't do command substitution.  */
33    WRDE_REUSE = (1 << 3),	/* Reuse storage in PWORDEXP.  */
34    WRDE_SHOWERR = (1 << 4),	/* Don't redirect stderr to /dev/null.  */
35    WRDE_UNDEF = (1 << 5),	/* Error for expanding undefined variables.  */
36    __WRDE_FLAGS = (WRDE_DOOFFS | WRDE_APPEND | WRDE_NOCMD
37		    | WRDE_REUSE | WRDE_SHOWERR | WRDE_UNDEF)
38  };
39
40/* Structure describing a word-expansion run.  */
41typedef struct
42  {
43    size_t we_wordc;		/* Count of words matched.  */
44    char **we_wordv;		/* List of expanded words.  */
45    size_t we_offs;		/* Slots to reserve in `we_wordv'.  */
46  } wordexp_t;
47
48/* Possible nonzero return values from `wordexp'.  */
49enum
50  {
51#ifdef __USE_XOPEN
52    WRDE_NOSYS = -1,		/* Never used since we support `wordexp'.  */
53#endif
54    WRDE_NOSPACE = 1,		/* Ran out of memory.  */
55    WRDE_BADCHAR,		/* A metachar appears in the wrong place.  */
56    WRDE_BADVAL,		/* Undefined var reference with WRDE_UNDEF.  */
57    WRDE_CMDSUB,		/* Command substitution with WRDE_NOCMD.  */
58    WRDE_SYNTAX			/* Shell syntax error.  */
59  };
60
61/* Do word expansion of WORDS into PWORDEXP.  */
62extern int wordexp (const char *__restrict __words,
63		    wordexp_t *__restrict __pwordexp, int __flags);
64
65/* Free the storage allocated by a `wordexp' call.  */
66extern void wordfree (wordexp_t *__wordexp) __THROW;
67
68__END_DECLS
69
70#endif /* wordexp.h  */