xref: /titanic_44/usr/src/lib/libshell/i386/include/ast/shell.h (revision 0a0e9771ca0211c15f3ac4466b661c145feeb9e4)
1 
2 /* : : generated by proto : : */
3 /***********************************************************************
4 *                                                                      *
5 *               This software is part of the ast package               *
6 *          Copyright (c) 1982-2008 AT&T Intellectual Property          *
7 *                      and is licensed under the                       *
8 *                  Common Public License, Version 1.0                  *
9 *                    by AT&T Intellectual Property                     *
10 *                                                                      *
11 *                A copy of the License is available at                 *
12 *            http://www.opensource.org/licenses/cpl1.0.txt             *
13 *         (with md5 checksum 059e8cd6165cb4c31e351f2b69388fd9)         *
14 *                                                                      *
15 *              Information and Software Systems Research               *
16 *                            AT&T Research                             *
17 *                           Florham Park NJ                            *
18 *                                                                      *
19 *                  David Korn <dgk@research.att.com>                   *
20 *                                                                      *
21 ***********************************************************************/
22 
23 #ifndef SH_INTERACTIVE
24 #if !defined(__PROTO__)
25 #include <prototyped.h>
26 #endif
27 #if !defined(__LINKAGE__)
28 #define __LINKAGE__		/* 2004-08-11 transition */
29 #endif
30 
31 /*
32  * David Korn
33  * AT&T Labs
34  *
35  * Interface definitions for shell command language
36  *
37  */
38 
39 #include	<ast.h>
40 #include	<cdt.h>
41 #ifdef _SH_PRIVATE
42 #   include	"name.h"
43 #else
44 #   include	<nval.h>
45 #endif /* _SH_PRIVATE */
46 
47 #define SH_VERSION	20071012
48 
49 #undef NOT_USED
50 #define NOT_USED(x)	(&x,1)
51 
52 /* options */
53 typedef struct
54 {
55 	unsigned long v[4];
56 }
57 Shopt_t;
58 
59 typedef struct Shell_s Shell_t;
60 
61 typedef void	(*Shinit_f) __PROTO__((Shell_t*, int));
62 typedef int	(*Shwait_f) __PROTO__((int, long, int));
63 
64 union Shnode_u;
65 typedef union Shnode_u Shnode_t;
66 
67 #define SH_CFLAG	0
68 #define SH_HISTORY	1	/* used also as a state */
69 #define	SH_ERREXIT	2	/* used also as a state */
70 #define	SH_VERBOSE	3	/* used also as a state */
71 #define SH_MONITOR	4	/* used also as a state */
72 #define	SH_INTERACTIVE	5	/* used also as a state */
73 #define	SH_RESTRICTED	6
74 #define	SH_XTRACE	7
75 #define	SH_KEYWORD	8
76 #define SH_NOUNSET	9
77 #define SH_NOGLOB	10
78 #define SH_ALLEXPORT	11
79 #define SH_PFSH		12
80 #define SH_IGNOREEOF	13
81 #define SH_NOCLOBBER	14
82 #define SH_MARKDIRS	15
83 #define SH_BGNICE	16
84 #define SH_VI		17
85 #define SH_VIRAW	18
86 #define	SH_TFLAG	19
87 #define SH_TRACKALL	20
88 #define	SH_SFLAG	21
89 #define	SH_NOEXEC	22
90 #define SH_GMACS	24
91 #define SH_EMACS	25
92 #define SH_PRIVILEGED	26
93 #define SH_SUBSHARE	27	/* subshell shares state with parent */
94 #define SH_NOLOG	28
95 #define SH_NOTIFY	29
96 #define SH_DICTIONARY	30
97 #define SH_PIPEFAIL	32
98 #define SH_GLOBSTARS	33
99 #define SH_XARGS	34
100 #define SH_RC		35
101 #define SH_SHOWME	36
102 
103 /*
104  * passed as flags to builtins in Nambltin_t struct when BLT_OPTIM is on
105  */
106 #define SH_BEGIN_OPTIM	0x1
107 #define SH_END_OPTIM	0x2
108 
109 /* The following type is used for error messages */
110 
111 /* error messages */
112 extern __MANGLE__ const char	e_defpath[];
113 extern __MANGLE__ const char	e_found[];
114 extern __MANGLE__ const char	e_nospace[];
115 extern __MANGLE__ const char	e_format[];
116 extern __MANGLE__ const char 	e_number[];
117 extern __MANGLE__ const char	e_restricted[];
118 extern __MANGLE__ const char	e_recursive[];
119 extern __MANGLE__ char		e_version[];
120 
121 typedef struct sh_scope
122 {
123 	struct sh_scope	*par_scope;
124 	int		argc;
125 	char		**argv;
126 	char		*cmdname;
127 	char		*filename;
128 	char		*funname;
129 	int		lineno;
130 	Dt_t		*var_tree;
131 	struct sh_scope	*self;
132 } Shscope_t;
133 
134 /*
135  * Saves the state of the shell
136  */
137 
138 struct Shell_s
139 {
140 	Shopt_t		options;	/* set -o options */
141 	Dt_t		*var_tree;	/* for shell variables */
142 	Dt_t		*fun_tree;	/* for shell functions */
143 	Dt_t		*alias_tree;	/* for alias names */
144 	Dt_t		*bltin_tree;    /* for builtin commands */
145 	Shscope_t	*topscope;	/* pointer to top-level scope */
146 	int		inlineno;	/* line number of current input file */
147 	int		exitval;	/* most recent exit value */
148 	unsigned char	trapnote;	/* set when trap/signal is pending */
149 	char		subshell;	/* set for virtual subshell */
150 	char		shcomp;		/* set when runing shcomp */
151 #ifdef _SH_PRIVATE
152 	_SH_PRIVATE
153 #endif /* _SH_PRIVATE */
154 };
155 
156 /* flags for sh_parse */
157 #define SH_NL		1	/* Treat new-lines as ; */
158 #define SH_EOF		2	/* EOF causes syntax error */
159 
160 /* symbolic values for sh_iogetiop */
161 #define SH_IOCOPROCESS	(-2)
162 #define SH_IOHISTFILE	(-3)
163 
164 #include	<cmd.h>
165 
166 /* symbolic value for sh_fdnotify */
167 #define SH_FDCLOSE	(-1)
168 
169 #undef getenv			/* -lshell provides its own */
170 
171 #if defined(__EXPORT__) && defined(_DLL)
172 #   ifdef _BLD_shell
173 #undef __MANGLE__
174 #define __MANGLE__ __LINKAGE__ __EXPORT__
175 #   endif /* _BLD_shell */
176 #endif /* _DLL */
177 
178 extern __MANGLE__ Dt_t		*sh_bltin_tree __PROTO__((void));
179 extern __MANGLE__ void		sh_subfork __PROTO__((void));
180 extern __MANGLE__ Shell_t		*sh_init __PROTO__((int,char*[],Shinit_f));
181 extern __MANGLE__ int		sh_reinit __PROTO__((char*[]));
182 extern __MANGLE__ int 		sh_eval __PROTO__((Sfio_t*,int));
183 extern __MANGLE__ void 		sh_delay __PROTO__((double));
184 extern __MANGLE__ __V_		*sh_parse __PROTO__((Shell_t*, Sfio_t*,int));
185 extern __MANGLE__ int 		sh_trap __PROTO__((const char*,int));
186 extern __MANGLE__ int 		sh_fun __PROTO__((Namval_t*,Namval_t*, char*[]));
187 extern __MANGLE__ int 		sh_funscope __PROTO__((int,char*[],int(*)(__V_*),__V_*,int));
188 extern __MANGLE__ Sfio_t		*sh_iogetiop __PROTO__((int,int));
189 extern __MANGLE__ int		sh_main __PROTO__((int, char*[], Shinit_f));
190 extern __MANGLE__ int		sh_run __PROTO__((int, char*[]));
191 extern __MANGLE__ void		sh_menu __PROTO__((Sfio_t*, int, char*[]));
192 extern __MANGLE__ Namval_t		*sh_addbuiltin __PROTO__((const char*, int(*)(int, char*[],__V_*), __V_*));
193 extern __MANGLE__ char		*sh_fmtq __PROTO__((const char*));
194 extern __MANGLE__ char		*sh_fmtqf __PROTO__((const char*, int, int));
195 extern __MANGLE__ Sfdouble_t	sh_strnum __PROTO__((const char*, char**, int));
196 extern __MANGLE__ int		sh_access __PROTO__((const char*,int));
197 extern __MANGLE__ int 		sh_close __PROTO__((int));
198 extern __MANGLE__ int 		sh_dup __PROTO__((int));
199 extern __MANGLE__ void 		sh_exit __PROTO__((int));
200 extern __MANGLE__ int		sh_fcntl __PROTO__((int, int, ...));
201 extern __MANGLE__ Sfio_t		*sh_fd2sfio __PROTO__((int));
202 extern __MANGLE__ int		(*sh_fdnotify __PROTO__((int(*)(int,int)))) __PROTO__((int,int));
203 extern __MANGLE__ Shell_t		*sh_getinterp __PROTO__((void));
204 extern __MANGLE__ int		sh_open __PROTO__((const char*, int, ...));
205 extern __MANGLE__ int		sh_openmax __PROTO__((void));
206 extern __MANGLE__ Sfio_t		*sh_pathopen __PROTO__((const char*));
207 extern __MANGLE__ ssize_t 		sh_read __PROTO__((int, __V_*, size_t));
208 extern __MANGLE__ ssize_t 		sh_write __PROTO__((int, const __V_*, size_t));
209 extern __MANGLE__ off_t		sh_seek __PROTO__((int, off_t, int));
210 extern __MANGLE__ int 		sh_pipe __PROTO__((int[]));
211 extern __MANGLE__ mode_t 		sh_umask __PROTO__((mode_t));
212 extern __MANGLE__ __V_		*sh_waitnotify __PROTO__((Shwait_f));
213 extern __MANGLE__ Shscope_t	*sh_getscope __PROTO__((int,int));
214 extern __MANGLE__ Shscope_t	*sh_setscope __PROTO__((Shscope_t*));
215 extern __MANGLE__ void		sh_sigcheck __PROTO__((void));
216 extern __MANGLE__ unsigned long	sh_isoption __PROTO__((int));
217 extern __MANGLE__ unsigned long	sh_onoption __PROTO__((int));
218 extern __MANGLE__ unsigned long	sh_offoption __PROTO__((int));
219 extern __MANGLE__ int 		sh_waitsafe __PROTO__((void));
220 extern __MANGLE__ int		sh_exec __PROTO__((const Shnode_t*,int));
221 
222 #if SHOPT_DYNAMIC
223     extern __MANGLE__ __V_		**sh_getliblist __PROTO__((void));
224 #endif /* SHOPT_DYNAMIC */
225 
226 /*
227  * direct access to sh is obsolete, use sh_getinterp() instead
228  */
229 #if !defined(_SH_PRIVATE) && defined(__IMPORT__) && !defined(_BLD_shell)
230 	extern __MANGLE__ __IMPORT__  Shell_t sh;
231 #else
232 	extern __MANGLE__ Shell_t sh;
233 #endif
234 
235 #ifdef _DLL
236 #undef __MANGLE__
237 #define __MANGLE__ __LINKAGE__
238 #endif /* _DLL */
239 
240 #ifndef _SH_PRIVATE
241 #   define access(a,b)	sh_access(a,b)
242 #   define close(a)	sh_close(a)
243 #   define exit(a)	sh_exit(a)
244 #   define fcntl(a,b,c)	sh_fcntl(a,b,c)
245 #   define pipe(a)	sh_pipe(a)
246 #   define read(a,b,c)	sh_read(a,b,c)
247 #   define write(a,b,c)	sh_write(a,b,c)
248 #   define umask(a)	sh_umask(a)
249 #   define dup		sh_dup
250 #   if _lib_lseek64
251 #	define open64	sh_open
252 #	define lseek64	sh_seek
253 #   else
254 #	define open	sh_open
255 #	define lseek	sh_seek
256 #   endif
257 #endif /* !_SH_PRIVATE */
258 
259 #define SH_SIGSET	4
260 #define SH_EXITSIG	0400	/* signal exit bit */
261 #define SH_EXITMASK	(SH_EXITSIG-1)	/* normal exit status bits */
262 #define SH_RUNPROG	-1022	/* needs to be negative and < 256 */
263 
264 #endif /* SH_INTERACTIVE */
265