* version.h doesn't need an RCS ID
* compat.h does, add it to misc.c, always include it, move if NEED_COMPAT * major whitespace cleanup in sh.h
This commit is contained in:
		
							
								
								
									
										19
									
								
								compat.h
									
									
									
									
									
								
							
							
						
						
									
										19
									
								
								compat.h
									
									
									
									
									
								
							| @@ -1,5 +1,6 @@ | |||||||
| /* $MirOS: src/bin/mksh/compat.h,v 1.3 2006/08/18 18:59:49 tg Exp $ */ | #define MKSH_COMPAT_H_ID "$MirOS: src/bin/mksh/compat.h,v 1.4 2006/08/22 22:16:04 tg Exp $" | ||||||
|  |  | ||||||
|  | #ifdef NEED_COMPAT | ||||||
| /* Part I: extra headers */ | /* Part I: extra headers */ | ||||||
|  |  | ||||||
| #if defined(__sun__) || defined(__INTERIX) | #if defined(__sun__) || defined(__INTERIX) | ||||||
| @@ -39,7 +40,7 @@ | |||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #ifndef S_ISTXT | #ifndef S_ISTXT | ||||||
| #define	S_ISTXT	0001000			/* sticky bit */ | #define S_ISTXT 0001000 | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -55,13 +56,15 @@ size_t confstr(int, char *, size_t); | |||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #if defined(__gnu_linux__) || defined(__sun__) || defined(__CYGWIN__) | #if defined(__gnu_linux__) || defined(__sun__) || defined(__CYGWIN__) | ||||||
| #define	DEFFILEMODE	(S_IRUSR|S_IWUSR|S_IRGRP|S_IWGRP|S_IROTH|S_IWOTH) | #define DEFFILEMODE (S_IRUSR|S_IWUSR|S_IRGRP|S_IWGRP|S_IROTH|S_IWOTH) | ||||||
| mode_t	 getmode(const void *, mode_t); | mode_t getmode(const void *, mode_t); | ||||||
| void	*setmode(const char *); | void *setmode(const char *); | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #if defined(__INTERIX) | #ifdef __INTERIX | ||||||
| #define	makedev(x,y)	mkdev((x),(y)) | #define	makedev(x,y)	mkdev((x),(y)) | ||||||
| extern int   __cdecl	seteuid(uid_t); | extern int __cdecl seteuid(uid_t); | ||||||
| extern int   __cdecl	setegid(gid_t); | extern int __cdecl setegid(gid_t); | ||||||
|  | #endif | ||||||
|  |  | ||||||
| #endif | #endif | ||||||
|   | |||||||
							
								
								
									
										6
									
								
								misc.c
									
									
									
									
									
								
							
							
						
						
									
										6
									
								
								misc.c
									
									
									
									
									
								
							| @@ -3,8 +3,8 @@ | |||||||
|  |  | ||||||
| #include "sh.h" | #include "sh.h" | ||||||
|  |  | ||||||
| __RCSID("$MirOS: src/bin/mksh/misc.c,v 1.13 2006/08/09 20:44:15 tg Exp $" | __RCSID("$MirOS: src/bin/mksh/misc.c,v 1.14 2006/08/22 22:16:04 tg Exp $" | ||||||
| 	"\t" MKSH_SH_H_ID); | 	"\t" MKSH_SH_H_ID "\t" MKSH_COMPAT_H_ID); | ||||||
|  |  | ||||||
| short chtypes[UCHAR_MAX+1];	/* type bits for unsigned char */ | short chtypes[UCHAR_MAX+1];	/* type bits for unsigned char */ | ||||||
|  |  | ||||||
| @@ -13,7 +13,7 @@ static int do_gmatch(const unsigned char *, const unsigned char *, | |||||||
| static const unsigned char *cclass(const unsigned char *, int); | static const unsigned char *cclass(const unsigned char *, int); | ||||||
| static int parse_T(char *); | static int parse_T(char *); | ||||||
|  |  | ||||||
| static char	*do_phys_path(XString *, char *, const char *); | static char *do_phys_path(XString *, char *, const char *); | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * Fast character classes |  * Fast character classes | ||||||
|   | |||||||
							
								
								
									
										667
									
								
								sh.h
									
									
									
									
									
								
							
							
						
						
									
										667
									
								
								sh.h
									
									
									
									
									
								
							| @@ -8,7 +8,7 @@ | |||||||
| /*	$OpenBSD: c_test.h,v 1.4 2004/12/20 11:34:26 otto Exp $	*/ | /*	$OpenBSD: c_test.h,v 1.4 2004/12/20 11:34:26 otto Exp $	*/ | ||||||
| /*	$OpenBSD: tty.h,v 1.5 2004/12/20 11:34:26 otto Exp $	*/ | /*	$OpenBSD: tty.h,v 1.5 2004/12/20 11:34:26 otto Exp $	*/ | ||||||
|  |  | ||||||
| #define	MKSH_SH_H_ID	"$MirOS: src/bin/mksh/sh.h,v 1.35 2006/08/16 00:00:24 tg Exp $" | #define MKSH_SH_H_ID "$MirOS: src/bin/mksh/sh.h,v 1.36 2006/08/22 22:16:04 tg Exp $" | ||||||
|  |  | ||||||
| #include <sys/param.h> | #include <sys/param.h> | ||||||
|  |  | ||||||
| @@ -44,9 +44,8 @@ | |||||||
| #include <termios.h> | #include <termios.h> | ||||||
| #include <time.h> | #include <time.h> | ||||||
| #include <unistd.h> | #include <unistd.h> | ||||||
| #if defined(NEED_COMPAT) |  | ||||||
| #include "compat.h" | #include "compat.h" | ||||||
| #endif | #include "version.h" | ||||||
|  |  | ||||||
| /* some useful #defines */ | /* some useful #defines */ | ||||||
| #ifdef EXTERN | #ifdef EXTERN | ||||||
| @@ -71,7 +70,7 @@ typedef int32_t		Tflag; | |||||||
| #define	FDBASE		10	/* First file usable by Shell */ | #define	FDBASE		10	/* First file usable by Shell */ | ||||||
|  |  | ||||||
| /* Make MAGIC a char that might be printed to make bugs more obvious, but | /* Make MAGIC a char that might be printed to make bugs more obvious, but | ||||||
|  * not a char that is used often.  Also, can't use the high bit as it causes |  * not a char that is used often. Also, can't use the high bit as it causes | ||||||
|  * portability problems (calling strchr(x, 0x80|'x') is error prone). |  * portability problems (calling strchr(x, 0x80|'x') is error prone). | ||||||
|  */ |  */ | ||||||
| #define	MAGIC		(7)	/* prefix for *?[!{,} during expand */ | #define	MAGIC		(7)	/* prefix for *?[!{,} during expand */ | ||||||
| @@ -86,15 +85,15 @@ typedef int32_t		Tflag; | |||||||
| #define	_PATH_DEFPATH	"/bin:/usr/bin:/sbin:/usr/sbin" | #define	_PATH_DEFPATH	"/bin:/usr/bin:/sbin:/usr/sbin" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| EXTERN	char *	kshname;	/* $0 */ | EXTERN	char *kshname;		/* $0 */ | ||||||
| EXTERN	pid_t	kshpid;		/* $$, shell pid */ | EXTERN	pid_t kshpid;		/* $$, shell pid */ | ||||||
| EXTERN	pid_t	procpid;	/* pid of executing process */ | EXTERN	pid_t procpid;		/* pid of executing process */ | ||||||
| EXTERN	uid_t	ksheuid;	/* effective uid of shell */ | EXTERN	uid_t ksheuid;		/* effective uid of shell */ | ||||||
| EXTERN	uid_t	kshuid;		/* real uid of shell */ | EXTERN	uid_t kshuid;		/* real uid of shell */ | ||||||
| EXTERN	gid_t	kshegid;	/* effective gid of shell */ | EXTERN	gid_t kshegid;		/* effective gid of shell */ | ||||||
| EXTERN	gid_t	kshgid;		/* real gid of shell */ | EXTERN	gid_t kshgid;		/* real gid of shell */ | ||||||
| EXTERN	int	exstat;		/* exit status */ | EXTERN	int exstat;		/* exit status */ | ||||||
| EXTERN	int	subst_exstat;	/* exit status of last $(..)/`..` */ | EXTERN	int subst_exstat;	/* exit status of last $(..)/`..` */ | ||||||
| EXTERN	const char *safe_prompt; /* safe prompt if PS1 substitution fails */ | EXTERN	const char *safe_prompt; /* safe prompt if PS1 substitution fails */ | ||||||
|  |  | ||||||
| /* | /* | ||||||
| @@ -112,12 +111,12 @@ EXTERN	Area	aperm;		/* permanent object space */ | |||||||
|  * parsing & execution environment |  * parsing & execution environment | ||||||
|  */ |  */ | ||||||
| EXTERN	struct env { | EXTERN	struct env { | ||||||
| 	short	type;			/* environment type - see below */ | 	short type;			/* environment type - see below */ | ||||||
| 	short	flags;			/* EF_* */ | 	short flags;			/* EF_* */ | ||||||
| 	Area	area;			/* temporary allocation area */ | 	Area area;			/* temporary allocation area */ | ||||||
| 	struct	block *loc;		/* local variables and functions */ | 	struct block *loc;		/* local variables and functions */ | ||||||
| 	short  *savefd;			/* original redirected fds */ | 	short *savefd;			/* original redirected fds */ | ||||||
| 	struct	env *oenv;		/* link to previous environment */ | 	struct env *oenv;		/* link to previous environment */ | ||||||
| 	sigjmp_buf jbuf;		/* long jump back to env creator */ | 	sigjmp_buf jbuf;		/* long jump back to env creator */ | ||||||
| 	struct temp *temps;		/* temp files */ | 	struct temp *temps;		/* temp files */ | ||||||
| } *e; | } *e; | ||||||
| @@ -163,9 +162,9 @@ EXTERN	struct env { | |||||||
| #define OF_ANY		(OF_CMDLINE | OF_SET | OF_SPECIAL | OF_INTERNAL) | #define OF_ANY		(OF_CMDLINE | OF_SET | OF_SPECIAL | OF_INTERNAL) | ||||||
|  |  | ||||||
| struct option { | struct option { | ||||||
|     const char	*name;	/* long name of option */ | 	const char *name;	/* long name of option */ | ||||||
|     char	c;	/* character flag (if any) */ | 	char c;			/* character flag (if any) */ | ||||||
|     short	flags;	/* OF_* */ | 	short flags;		/* OF_* */ | ||||||
| }; | }; | ||||||
| extern const struct option options[]; | extern const struct option options[]; | ||||||
|  |  | ||||||
| @@ -225,13 +224,13 @@ enum temp_type { | |||||||
| 	TT_HIST_EDIT	/* temp file used for history editing (fc -e) */ | 	TT_HIST_EDIT	/* temp file used for history editing (fc -e) */ | ||||||
| }; | }; | ||||||
| typedef enum temp_type Temp_type; | typedef enum temp_type Temp_type; | ||||||
| /* temp/heredoc files.  The file is removed when the struct is freed. */ | /* temp/heredoc files. The file is removed when the struct is freed. */ | ||||||
| struct temp { | struct temp { | ||||||
| 	struct temp	*next; | 	struct temp *next; | ||||||
| 	struct shf	*shf; | 	struct shf *shf; | ||||||
| 	int		pid;		/* pid of process parsed here-doc */ | 	int pid;		/* pid of process parsed here-doc */ | ||||||
| 	Temp_type	type; | 	Temp_type type; | ||||||
| 	char		*name; | 	char *name; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| /* | /* | ||||||
| @@ -251,12 +250,12 @@ typedef void (*sig_t)(int); | |||||||
|  * trap handlers |  * trap handlers | ||||||
|  */ |  */ | ||||||
| typedef struct trap { | typedef struct trap { | ||||||
| 	int	signal;		/* signal number */ | 	int signal;		/* signal number */ | ||||||
| 	const char *name;	/* short name */ | 	const char *name;	/* short name */ | ||||||
| 	const char *mess;	/* descriptive name */ | 	const char *mess;	/* descriptive name */ | ||||||
| 	char   *trap;		/* trap command */ | 	char *trap;		/* trap command */ | ||||||
| 	volatile sig_atomic_t set; /* trap pending */ | 	volatile sig_atomic_t set; /* trap pending */ | ||||||
| 	int	flags;		/* TF_* */ | 	int flags;		/* TF_* */ | ||||||
| 	sig_t cursig;		/* current handler (valid if TF_ORIG_* set) */ | 	sig_t cursig;		/* current handler (valid if TF_ORIG_* set) */ | ||||||
| 	sig_t shtrap;		/* shell signal handler */ | 	sig_t shtrap;		/* shell signal handler */ | ||||||
| } Trap; | } Trap; | ||||||
| @@ -357,12 +356,12 @@ EXTERN Getopt user_opt;		/* parsing state for getopts builtin command */ | |||||||
|  |  | ||||||
| typedef int32_t Coproc_id; /* something that won't (realisticly) wrap */ | typedef int32_t Coproc_id; /* something that won't (realisticly) wrap */ | ||||||
| struct coproc { | struct coproc { | ||||||
| 	int	read;		/* pipe from co-process's stdout */ | 	int read;	/* pipe from co-process's stdout */ | ||||||
| 	int	readw;		/* other side of read (saved temporarily) */ | 	int readw;	/* other side of read (saved temporarily) */ | ||||||
| 	int	write;		/* pipe to co-process's stdin */ | 	int write;	/* pipe to co-process's stdin */ | ||||||
| 	Coproc_id id;		/* id of current output pipe */ | 	Coproc_id id;	/* id of current output pipe */ | ||||||
| 	int	njobs;		/* number of live jobs using output pipe */ | 	int njobs;	/* number of live jobs using output pipe */ | ||||||
| 	void    *job;           /* 0 or job of co-process using input pipe */ | 	void *job;	/* 0 or job of co-process using input pipe */ | ||||||
| }; | }; | ||||||
| EXTERN struct coproc coproc; | EXTERN struct coproc coproc; | ||||||
|  |  | ||||||
| @@ -458,32 +457,32 @@ struct shf { | |||||||
| extern struct shf shf_iob[]; | extern struct shf shf_iob[]; | ||||||
|  |  | ||||||
| struct table { | struct table { | ||||||
| 	Area   *areap;		/* area to allocate entries */ | 	Area *areap;		/* area to allocate entries */ | ||||||
| 	short	size, nfree;	/* hash size (always 2^^n), free entries */ | 	short size, nfree;	/* hash size (always 2^^n), free entries */ | ||||||
| 	struct	tbl **tbls;	/* hashed table items */ | 	struct tbl **tbls;	/* hashed table items */ | ||||||
| }; | }; | ||||||
|  |  | ||||||
| struct tbl {			/* table item */ | struct tbl {			/* table item */ | ||||||
| 	Tflag	flag;		/* flags */ | 	Tflag flag;		/* flags */ | ||||||
| 	int	type;		/* command type (see below), base (if INTEGER), | 	int type;		/* command type (see below), base (if INTEGER), | ||||||
| 				 * or offset from val.s of value (if EXPORT) */ | 				 * or offset from val.s of value (if EXPORT) */ | ||||||
| 	Area	*areap;		/* area to allocate from */ | 	Area *areap;		/* area to allocate from */ | ||||||
| 	union { | 	union { | ||||||
| 		char *s;	/* string */ | 		char *s;	/* string */ | ||||||
| 		long i;		/* integer */ | 		long i;		/* integer */ | ||||||
| 		int (*f)(char **);	/* int function */ | 		int (*f)(char **);	/* int function */ | ||||||
| 		struct op *t;	/* "function" tree */ | 		struct op *t;	/* "function" tree */ | ||||||
| 	} val;			/* value */ | 	} val;			/* value */ | ||||||
| 	int	index;		/* index for an array */ | 	int index;		/* index for an array */ | ||||||
| 	union { | 	union { | ||||||
| 	    int	field;		/* field with for -L/-R/-Z */ | 		int field;	/* field with for -L/-R/-Z */ | ||||||
| 	    int errno_;		/* CEXEC/CTALIAS */ | 		int errno_;	/* CEXEC/CTALIAS */ | ||||||
| 	} u2; | 	} u2; | ||||||
| 	union { | 	union { | ||||||
| 		struct tbl *array;	/* array values */ | 		struct tbl *array;	/* array values */ | ||||||
| 		char *fpath;		/* temporary path to undef function */ | 		char *fpath;	/* temporary path to undef function */ | ||||||
| 	} u; | 	} u; | ||||||
| 	char	name[4];	/* name -- variable length */ | 	char name[4];		/* name -- variable length */ | ||||||
| }; | }; | ||||||
|  |  | ||||||
| /* common flag bits */ | /* common flag bits */ | ||||||
| @@ -518,7 +517,7 @@ struct tbl {			/* table item */ | |||||||
| #define SPEC_BI		BIT(12)	/* a POSIX special builtin */ | #define SPEC_BI		BIT(12)	/* a POSIX special builtin */ | ||||||
| #define REG_BI		BIT(13)	/* a POSIX regular builtin */ | #define REG_BI		BIT(13)	/* a POSIX regular builtin */ | ||||||
| /* Attributes that can be set by the user (used to decide if an unset param | /* Attributes that can be set by the user (used to decide if an unset param | ||||||
|  * should be repoted by set/typeset).  Does not include ARRAY or LOCAL. |  * should be repoted by set/typeset). Does not include ARRAY or LOCAL. | ||||||
|  */ |  */ | ||||||
| #define USERATTRIB	(EXPORT|INTEGER|RDONLY|LJUST|RJUST|ZEROFIL\ | #define USERATTRIB	(EXPORT|INTEGER|RDONLY|LJUST|RJUST|ZEROFIL\ | ||||||
| 			 |LCASEV|UCASEV_AL|INT_U|INT_L) | 			 |LCASEV|UCASEV_AL|INT_U|INT_L) | ||||||
| @@ -547,7 +546,7 @@ struct tbl {			/* table item */ | |||||||
| #define AI_ARGV(a, i)	((i) == 0 ? (a).argv[0] : (a).argv[(i) - (a).skip]) | #define AI_ARGV(a, i)	((i) == 0 ? (a).argv[0] : (a).argv[(i) - (a).skip]) | ||||||
| #define AI_ARGC(a)	((a).argc_ - (a).skip) | #define AI_ARGC(a)	((a).argc_ - (a).skip) | ||||||
|  |  | ||||||
| /* Argument info.  Used for $#, $* for shell, functions, includes, etc. */ | /* Argument info. Used for $#, $* for shell, functions, includes, etc. */ | ||||||
| struct arg_info { | struct arg_info { | ||||||
| 	int flags;	/* AF_* */ | 	int flags;	/* AF_* */ | ||||||
| 	char **argv; | 	char **argv; | ||||||
| @@ -559,17 +558,16 @@ struct arg_info { | |||||||
|  * activation record for function blocks |  * activation record for function blocks | ||||||
|  */ |  */ | ||||||
| struct block { | struct block { | ||||||
| 	Area	area;		/* area to allocate things */ | 	Area area;		/* area to allocate things */ | ||||||
| 	/*struct arg_info argi;*/ | 	char **argv; | ||||||
| 	char	**argv; | 	int argc; | ||||||
| 	int	argc; | 	int flags;		/* see BF_* */ | ||||||
| 	int	flags;		/* see BF_* */ | 	struct table vars;	/* local variables */ | ||||||
| 	struct	table vars;	/* local variables */ | 	struct table funs;	/* local functions */ | ||||||
| 	struct	table funs;	/* local functions */ | 	Getopt getopts_state; | ||||||
| 	Getopt	getopts_state; | 	char *error;		/* error handler */ | ||||||
| 	char *	error;		/* error handler */ | 	char *exit;		/* exit handler */ | ||||||
| 	char *	exit;		/* exit handler */ | 	struct block *next;	/* enclosing block */ | ||||||
| 	struct	block *next;	/* enclosing block */ |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| /* Values for struct block.flags */ | /* Values for struct block.flags */ | ||||||
| @@ -591,8 +589,8 @@ EXTERN	struct table keywords;	/* keywords */ | |||||||
| EXTERN	struct table homedirs;	/* homedir() cache */ | EXTERN	struct table homedirs;	/* homedir() cache */ | ||||||
|  |  | ||||||
| struct builtin { | struct builtin { | ||||||
| 	const char   *name; | 	const char *name; | ||||||
| 	int  (*func)(char **); | 	int (*func)(char **); | ||||||
| }; | }; | ||||||
|  |  | ||||||
| extern const struct builtin shbuiltins [], kshbuiltins []; | extern const struct builtin shbuiltins [], kshbuiltins []; | ||||||
| @@ -630,21 +628,21 @@ EXTERN int current_lineno;	/* LINENO value */ | |||||||
|  * Description of a command or an operation on commands. |  * Description of a command or an operation on commands. | ||||||
|  */ |  */ | ||||||
| struct op { | struct op { | ||||||
| 	short	type;			/* operation type, see below */ | 	short type;			/* operation type, see below */ | ||||||
| 	union { /* WARNING: newtp(), tcopy() use evalflags = 0 to clear union */ | 	union { /* WARNING: newtp(), tcopy() use evalflags = 0 to clear union */ | ||||||
| 		short	evalflags;	/* TCOM: arg expansion eval() flags */ | 		short evalflags;	/* TCOM: arg expansion eval() flags */ | ||||||
| 		short	ksh_func;	/* TFUNC: function x (vs x()) */ | 		short ksh_func;		/* TFUNC: function x (vs x()) */ | ||||||
| 	} u; | 	} u; | ||||||
| 	char  **args;			/* arguments to a command */ | 	char **args;			/* arguments to a command */ | ||||||
| 	char  **vars;			/* variable assignments */ | 	char **vars;			/* variable assignments */ | ||||||
| 	struct ioword	**ioact;	/* IO actions (eg, < > >>) */ | 	struct ioword **ioact;		/* IO actions (eg, < > >>) */ | ||||||
| 	struct op *left, *right;	/* descendents */ | 	struct op *left, *right;	/* descendents */ | ||||||
| 	char   *str;			/* word for case; identifier for for, | 	char *str;			/* word for case; identifier for for, | ||||||
| 					 * select, and functions; | 					 * select, and functions; | ||||||
| 					 * path to execute for TEXEC; | 					 * path to execute for TEXEC; | ||||||
| 					 * time hook for TCOM. | 					 * time hook for TCOM. | ||||||
| 					 */ | 					 */ | ||||||
| 	int	lineno;			/* TCOM/TFUNC: LINENO for this */ | 	int lineno;			/* TCOM/TFUNC: LINENO for this */ | ||||||
| }; | }; | ||||||
|  |  | ||||||
| /* Tree.type values */ | /* Tree.type values */ | ||||||
| @@ -748,7 +746,7 @@ struct ioword { | |||||||
|  * indicating how the arguments have been munged are kept in t->vars[]. |  * indicating how the arguments have been munged are kept in t->vars[]. | ||||||
|  * The contents of t->vars[] are stuffed strings (so they can be treated |  * The contents of t->vars[] are stuffed strings (so they can be treated | ||||||
|  * like all other t->vars[]) in which the second character is the one that |  * like all other t->vars[]) in which the second character is the one that | ||||||
|  * is examined.  The DB_* defines are the values for these second characters. |  * is examined. The DB_* defines are the values for these second characters. | ||||||
|  */ |  */ | ||||||
| #define DB_NORM	1		/* normal argument */ | #define DB_NORM	1		/* normal argument */ | ||||||
| #define DB_OR	2		/* || -> -o conversion */ | #define DB_OR	2		/* || -> -o conversion */ | ||||||
| @@ -759,9 +757,9 @@ struct ioword { | |||||||
| #define X_EXTRA		8	/* this many extra bytes in X string */ | #define X_EXTRA		8	/* this many extra bytes in X string */ | ||||||
|  |  | ||||||
| typedef struct XString { | typedef struct XString { | ||||||
| 	char   *end, *beg;	/* end, begin of string */ | 	char *end, *beg;	/* end, begin of string */ | ||||||
| 	size_t	len;		/* length */ | 	size_t len;		/* length */ | ||||||
| 	Area	*areap;		/* area to allocate/free from */ | 	Area *areap;		/* area to allocate/free from */ | ||||||
| } XString; | } XString; | ||||||
|  |  | ||||||
| typedef char *XStringP; | typedef char *XStringP; | ||||||
| @@ -780,9 +778,9 @@ typedef char *XStringP; | |||||||
|  |  | ||||||
| /* check if there are at least n bytes left */ | /* check if there are at least n bytes left */ | ||||||
| #define	XcheckN(xs, xp, n) do { \ | #define	XcheckN(xs, xp, n) do { \ | ||||||
| 		    int more = ((xp) + (n)) - (xs).end; \ | 			int more = ((xp) + (n)) - (xs).end; \ | ||||||
| 		    if (more > 0) \ | 			if (more > 0) \ | ||||||
| 			xp = Xcheck_grow_(&xs, xp, more); \ | 				xp = Xcheck_grow_(&xs, xp, more); \ | ||||||
| 		} while (0) | 		} while (0) | ||||||
|  |  | ||||||
| /* check for overflow, expand string */ | /* check for overflow, expand string */ | ||||||
| @@ -803,15 +801,15 @@ typedef char *XStringP; | |||||||
| #define	Xsavepos(xs, xp) ((xp) - (xs).beg) | #define	Xsavepos(xs, xp) ((xp) - (xs).beg) | ||||||
| #define	Xrestpos(xs, xp, n) ((xs).beg + (n)) | #define	Xrestpos(xs, xp, n) ((xs).beg + (n)) | ||||||
|  |  | ||||||
| char *	Xcheck_grow_(XString *, char *, unsigned); | char *Xcheck_grow_(XString *, char *, unsigned); | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * expandable vector of generic pointers |  * expandable vector of generic pointers | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| typedef struct XPtrV { | typedef struct XPtrV { | ||||||
| 	void  **cur;		/* next avail pointer */ | 	void **cur;		/* next avail pointer */ | ||||||
| 	void  **beg, **end;	/* begin, end of vector */ | 	void **beg, **end;	/* begin, end of vector */ | ||||||
| } XPtrV; | } XPtrV; | ||||||
|  |  | ||||||
| #define	XPinit(x, n) do { \ | #define	XPinit(x, n) do { \ | ||||||
| @@ -825,7 +823,7 @@ typedef struct XPtrV { | |||||||
| 			if ((x).cur >= (x).end) { \ | 			if ((x).cur >= (x).end) { \ | ||||||
| 				int n = XPsize(x); \ | 				int n = XPsize(x); \ | ||||||
| 				(x).beg = (void**) aresize((void*) (x).beg, \ | 				(x).beg = (void**) aresize((void*) (x).beg, \ | ||||||
| 						   sizeofN(void*, n*2), ATEMP); \ | 				    sizeofN(void*, n*2), ATEMP); \ | ||||||
| 				(x).cur = (x).beg + n; \ | 				(x).cur = (x).beg + n; \ | ||||||
| 				(x).end = (x).cur + n; \ | 				(x).end = (x).cur + n; \ | ||||||
| 			} \ | 			} \ | ||||||
| @@ -899,9 +897,9 @@ struct source { | |||||||
| #define STBRACE		12	/* parsing ${..[#%]..} */ | #define STBRACE		12	/* parsing ${..[#%]..} */ | ||||||
|  |  | ||||||
| typedef union { | typedef union { | ||||||
| 	int	i; | 	int i; | ||||||
| 	char   *cp; | 	char *cp; | ||||||
| 	char  **wp; | 	char **wp; | ||||||
| 	struct op *o; | 	struct op *o; | ||||||
| 	struct ioword *iop; | 	struct ioword *iop; | ||||||
| } YYSTYPE; | } YYSTYPE; | ||||||
| @@ -957,262 +955,261 @@ EXTERN	char	ident [IDENT+1]; | |||||||
|  |  | ||||||
| #define HISTORYSIZE	500	/* size of saved history */ | #define HISTORYSIZE	500	/* size of saved history */ | ||||||
|  |  | ||||||
| EXTERN	char  **history;	/* saved commands */ | EXTERN	char **history;	/* saved commands */ | ||||||
| EXTERN	char  **histptr;	/* last history item */ | EXTERN	char **histptr;	/* last history item */ | ||||||
| EXTERN	int	histsize;	/* history size */ | EXTERN	int histsize;	/* history size */ | ||||||
|  |  | ||||||
| /* alloc.c */ | /* alloc.c */ | ||||||
| Area *	ainit(Area *); | Area *ainit(Area *); | ||||||
| void	afreeall(Area *); | void afreeall(Area *); | ||||||
| void *	alloc(size_t, Area *); | void *alloc(size_t, Area *); | ||||||
| void *	aresize(void *, size_t, Area *); | void *aresize(void *, size_t, Area *); | ||||||
| void	afree(void *, Area *); | void afree(void *, Area *); | ||||||
| /* edit.c */ | /* edit.c */ | ||||||
| void	x_init(void); | void x_init(void); | ||||||
| int	x_read(char *, size_t); | int x_read(char *, size_t); | ||||||
| int	x_bind(const char *, const char *, int, int); | int x_bind(const char *, const char *, int, int); | ||||||
| /* eval.c */ | /* eval.c */ | ||||||
| char *	substitute(const char *, int); | char *substitute(const char *, int); | ||||||
| char **	eval(char **, int); | char **eval(char **, int); | ||||||
| char *	evalstr(char *cp, int); | char *evalstr(char *cp, int); | ||||||
| char *	evalonestr(char *cp, int); | char *evalonestr(char *cp, int); | ||||||
| char	*debunk(char *, const char *, size_t); | char *debunk(char *, const char *, size_t); | ||||||
| void	expand(char *, XPtrV *, int); | void expand(char *, XPtrV *, int); | ||||||
| int	glob_str(char *, XPtrV *, int); | int glob_str(char *, XPtrV *, int); | ||||||
| /* exec.c */ | /* exec.c */ | ||||||
| int	execute(struct op * volatile, volatile int); | int execute(struct op * volatile, volatile int); | ||||||
| int	shcomexec(char **); | int shcomexec(char **); | ||||||
| struct tbl * findfunc(const char *, unsigned int, int); | struct tbl *findfunc(const char *, unsigned int, int); | ||||||
| int	define(const char *, struct op *); | int define(const char *, struct op *); | ||||||
| void	builtin(const char *, int (*)(char **)); | void builtin(const char *, int (*)(char **)); | ||||||
| struct tbl *	findcom(const char *, int); | struct tbl *findcom(const char *, int); | ||||||
| void	flushcom(int); | void flushcom(int); | ||||||
| char *	search(const char *, const char *, int, int *); | char *search(const char *, const char *, int, int *); | ||||||
| int	search_access(const char *, int, int *); | int search_access(const char *, int, int *); | ||||||
| int	pr_menu(char *const *); | int pr_menu(char *const *); | ||||||
| int	pr_list(char *const *); | int pr_list(char *const *); | ||||||
| /* expr.c */ | /* expr.c */ | ||||||
| int	evaluate(const char *, long *, int, bool); | int evaluate(const char *, long *, int, bool); | ||||||
| int	v_evaluate(struct tbl *, const char *, volatile int, bool); | int v_evaluate(struct tbl *, const char *, volatile int, bool); | ||||||
| /* funcs.c */ | /* funcs.c */ | ||||||
| int	c_hash(char **); | int c_hash(char **); | ||||||
| int	c_cd(char **); | int c_cd(char **); | ||||||
| int	c_pwd(char **); | int c_pwd(char **); | ||||||
| int	c_print(char **); | int c_print(char **); | ||||||
| int	c_whence(char **); | int c_whence(char **); | ||||||
| int	c_command(char **); | int c_command(char **); | ||||||
| int	c_typeset(char **); | int c_typeset(char **); | ||||||
| int	c_alias(char **); | int c_alias(char **); | ||||||
| int	c_unalias(char **); | int c_unalias(char **); | ||||||
| int	c_let(char **); | int c_let(char **); | ||||||
| int	c_jobs(char **); | int c_jobs(char **); | ||||||
| int	c_fgbg(char **); | int c_fgbg(char **); | ||||||
| int	c_kill(char **); | int c_kill(char **); | ||||||
| void	getopts_reset(int); | void getopts_reset(int); | ||||||
| int	c_getopts(char **); | int c_getopts(char **); | ||||||
| int	c_bind(char **); | int c_bind(char **); | ||||||
| int	c_label(char **); | int c_label(char **); | ||||||
| int	c_shift(char **); | int c_shift(char **); | ||||||
| int	c_umask(char **); | int c_umask(char **); | ||||||
| int	c_dot(char **); | int c_dot(char **); | ||||||
| int	c_wait(char **); | int c_wait(char **); | ||||||
| int	c_read(char **); | int c_read(char **); | ||||||
| int	c_eval(char **); | int c_eval(char **); | ||||||
| int	c_trap(char **); | int c_trap(char **); | ||||||
| int	c_brkcont(char **); | int c_brkcont(char **); | ||||||
| int	c_exitreturn(char **); | int c_exitreturn(char **); | ||||||
| int	c_set(char **); | int c_set(char **); | ||||||
| int	c_unset(char **); | int c_unset(char **); | ||||||
| int	c_ulimit(char **); | int c_ulimit(char **); | ||||||
| int	c_times(char **); | int c_times(char **); | ||||||
| int	timex(struct op *, int); | int timex(struct op *, int); | ||||||
| void	timex_hook(struct op *, char ** volatile *); | void timex_hook(struct op *, char ** volatile *); | ||||||
| int	c_exec(char **); | int c_exec(char **); | ||||||
| int	c_builtin(char **); | int c_builtin(char **); | ||||||
| int	c_test(char **); | int c_test(char **); | ||||||
| /* histrap.c */ | /* histrap.c */ | ||||||
| void	init_histvec(void); | void init_histvec(void); | ||||||
| void	hist_init(Source *); | void hist_init(Source *); | ||||||
| void	hist_finish(void); | void hist_finish(void); | ||||||
| void	histsave(int, const char *, int); | void histsave(int, const char *, int); | ||||||
| int	c_fc(char **); | int c_fc(char **); | ||||||
| void	sethistsize(int); | void sethistsize(int); | ||||||
| void	sethistfile(const char *); | void sethistfile(const char *); | ||||||
| char **	histpos(void); | char **histpos(void); | ||||||
| int	histnum(int); | int histnum(int); | ||||||
| int	findhist(int, int, const char *, int); | int findhist(int, int, const char *, int); | ||||||
| int	findhistrel(const char *); | int findhistrel(const char *); | ||||||
| char  **hist_get_newest(int); | char **hist_get_newest(int); | ||||||
| void	inittraps(void); | void inittraps(void); | ||||||
| void	alarm_init(void); | void alarm_init(void); | ||||||
| Trap *	gettrap(const char *, int); | Trap *gettrap(const char *, int); | ||||||
| void	trapsig(int); | void trapsig(int); | ||||||
| void	intrcheck(void); | void intrcheck(void); | ||||||
| int	fatal_trap_check(void); | int fatal_trap_check(void); | ||||||
| int	trap_pending(void); | int trap_pending(void); | ||||||
| void	runtraps(int intr); | void runtraps(int intr); | ||||||
| void	runtrap(Trap *); | void runtrap(Trap *); | ||||||
| void	cleartraps(void); | void cleartraps(void); | ||||||
| void	restoresigs(void); | void restoresigs(void); | ||||||
| void	settrap(Trap *, char *); | void settrap(Trap *, char *); | ||||||
| int	block_pipe(void); | int block_pipe(void); | ||||||
| void	restore_pipe(int); | void restore_pipe(int); | ||||||
| int	setsig(Trap *, sig_t, int); | int setsig(Trap *, sig_t, int); | ||||||
| void	setexecsig(Trap *, int); | void setexecsig(Trap *, int); | ||||||
| /* jobs.c */ | /* jobs.c */ | ||||||
| void	j_init(int); | void j_init(int); | ||||||
| void	j_exit(void); | void j_exit(void); | ||||||
| void	j_change(void); | void j_change(void); | ||||||
| int	exchild(struct op *, int, int); | int exchild(struct op *, int, int); | ||||||
| void	startlast(void); | void startlast(void); | ||||||
| int	waitlast(void); | int waitlast(void); | ||||||
| int	waitfor(const char *, int *); | int waitfor(const char *, int *); | ||||||
| int	j_kill(const char *, int); | int j_kill(const char *, int); | ||||||
| int	j_resume(const char *, int); | int j_resume(const char *, int); | ||||||
| int	j_jobs(const char *, int, int); | int j_jobs(const char *, int, int); | ||||||
| int	j_njobs(void); | int j_njobs(void); | ||||||
| void	j_notify(void); | void j_notify(void); | ||||||
| pid_t	j_async(void); | pid_t j_async(void); | ||||||
| int	j_stopped_running(void); | int j_stopped_running(void); | ||||||
| /* lex.c */ | /* lex.c */ | ||||||
| int	yylex(int); | int yylex(int); | ||||||
| void	yyerror(const char *, ...) | void yyerror(const char *, ...) | ||||||
| 	    __attribute__((__noreturn__, __format__ (printf, 1, 2))); |     __attribute__((__noreturn__, __format__ (printf, 1, 2))); | ||||||
| Source * pushs(int, Area *); | Source *pushs(int, Area *); | ||||||
| void	set_prompt(int, Source *); | void set_prompt(int, Source *); | ||||||
| void	pprompt(const char *, int); | void pprompt(const char *, int); | ||||||
| int	promptlen(const char *); | int promptlen(const char *); | ||||||
| /* main.c */ | /* main.c */ | ||||||
| int	include(const char *, int, char **, int); | int include(const char *, int, char **, int); | ||||||
| int	command(const char *); | int command(const char *); | ||||||
| int	shell(Source *volatile, int volatile); | int shell(Source *volatile, int volatile); | ||||||
| void	unwind(int) __attribute__((__noreturn__)); | void unwind(int) __attribute__((__noreturn__)); | ||||||
| void	newenv(int); | void newenv(int); | ||||||
| void	quitenv(struct shf *); | void quitenv(struct shf *); | ||||||
| void	cleanup_parents_env(void); | void cleanup_parents_env(void); | ||||||
| void	cleanup_proc_env(void); | void cleanup_proc_env(void); | ||||||
| void	errorf(const char *, ...) | void errorf(const char *, ...) | ||||||
| 	    __attribute__((__noreturn__, __format__ (printf, 1, 2))); |     __attribute__((__noreturn__, __format__ (printf, 1, 2))); | ||||||
| void	warningf(int, const char *, ...) | void warningf(int, const char *, ...) | ||||||
| 	    __attribute__((__format__ (printf, 2, 3))); |     __attribute__((__format__ (printf, 2, 3))); | ||||||
| void	bi_errorf(const char *, ...) | void bi_errorf(const char *, ...) | ||||||
| 	    __attribute__((__format__ (printf, 1, 2))); |     __attribute__((__format__ (printf, 1, 2))); | ||||||
| void	internal_errorf(int, const char *, ...) | void internal_errorf(int, const char *, ...) | ||||||
| 	    __attribute__((__format__ (printf, 2, 3))); |     __attribute__((__format__ (printf, 2, 3))); | ||||||
| void	error_prefix(int); | void error_prefix(int); | ||||||
| void	shellf(const char *, ...) | void shellf(const char *, ...) | ||||||
| 	    __attribute__((__format__ (printf, 1, 2))); |     __attribute__((__format__ (printf, 1, 2))); | ||||||
| void	shprintf(const char *, ...) | void shprintf(const char *, ...) | ||||||
| 	    __attribute__((__format__ (printf, 1, 2))); |     __attribute__((__format__ (printf, 1, 2))); | ||||||
| int	can_seek(int); | int can_seek(int); | ||||||
| void	initio(void); | void initio(void); | ||||||
| int	ksh_dup2(int, int, int); | int ksh_dup2(int, int, int); | ||||||
| int	savefd(int); | int savefd(int); | ||||||
| void	restfd(int, int); | void restfd(int, int); | ||||||
| void	openpipe(int *); | void openpipe(int *); | ||||||
| void	closepipe(int *); | void closepipe(int *); | ||||||
| int	check_fd(char *, int, const char **); | int check_fd(char *, int, const char **); | ||||||
| void	coproc_init(void); | void coproc_init(void); | ||||||
| void	coproc_read_close(int); | void coproc_read_close(int); | ||||||
| void	coproc_readw_close(int); | void coproc_readw_close(int); | ||||||
| void	coproc_write_close(int); | void coproc_write_close(int); | ||||||
| int	coproc_getfd(int, const char **); | int coproc_getfd(int, const char **); | ||||||
| void	coproc_cleanup(int); | void coproc_cleanup(int); | ||||||
| struct temp *maketemp(Area *, Temp_type, struct temp **); | struct temp *maketemp(Area *, Temp_type, struct temp **); | ||||||
| unsigned int	hash(const char *); | unsigned int hash(const char *); | ||||||
| void		ktinit(struct table *, Area *, int); | void ktinit(struct table *, Area *, int); | ||||||
| struct tbl *	ktsearch(struct table *, const char *, unsigned int); | struct tbl *ktsearch(struct table *, const char *, unsigned int); | ||||||
| struct tbl *	ktenter(struct table *, const char *, unsigned int); | struct tbl *ktenter(struct table *, const char *, unsigned int); | ||||||
| void		ktdelete(struct tbl *); | void ktdelete(struct tbl *); | ||||||
| void		ktwalk(struct tstate *, struct table *); | void ktwalk(struct tstate *, struct table *); | ||||||
| struct tbl *	ktnext(struct tstate *); | struct tbl *ktnext(struct tstate *); | ||||||
| struct tbl **	ktsort(struct table *); | struct tbl **ktsort(struct table *); | ||||||
| /* misc.c */ | /* misc.c */ | ||||||
| void	setctypes(const char *, int); | void setctypes(const char *, int); | ||||||
| void	initctypes(void); | void initctypes(void); | ||||||
| char *	ulton(unsigned long, int); | char *ulton(unsigned long, int); | ||||||
| char *	str_save(const char *, Area *); | char *str_save(const char *, Area *); | ||||||
| char *	str_nsave(const char *, int, Area *); | char *str_nsave(const char *, int, Area *); | ||||||
| int	option(const char *); | int option(const char *); | ||||||
| char *	getoptions(void); | char *getoptions(void); | ||||||
| void	change_flag(enum sh_flag, int, int); | void change_flag(enum sh_flag, int, int); | ||||||
| int	parse_args(char **, int, int *); | int parse_args(char **, int, int *); | ||||||
| int	getn(const char *, int *); | int getn(const char *, int *); | ||||||
| int	bi_getn(const char *, int *); | int bi_getn(const char *, int *); | ||||||
| int	gmatchx(const char *, const char *, int); | int gmatchx(const char *, const char *, int); | ||||||
| int	has_globbing(const char *, const char *); | int has_globbing(const char *, const char *); | ||||||
| const unsigned char *pat_scan(const unsigned char *, const unsigned char *, | const unsigned char *pat_scan(const unsigned char *, const unsigned char *, int); | ||||||
|     int); | void qsortp(void **, size_t, int (*)(void *, void *)); | ||||||
| void	qsortp(void **, size_t, int (*)(void *, void *)); | int xstrcmp(void *, void *); | ||||||
| int	xstrcmp(void *, void *); | void ksh_getopt_reset(Getopt *, int); | ||||||
| void	ksh_getopt_reset(Getopt *, int); | int ksh_getopt(char **, Getopt *, const char *); | ||||||
| int	ksh_getopt(char **, Getopt *, const char *); | void print_value_quoted(const char *); | ||||||
| void	print_value_quoted(const char *); | void print_columns(struct shf *, int, char *(*)(void *, int, char *, int), | ||||||
| void	print_columns(struct shf *, int, char *(*)(void *, int, char *, int), |  | ||||||
|     void *, int, int prefcol); |     void *, int, int prefcol); | ||||||
| int	strip_nuls(char *, int); | int strip_nuls(char *, int); | ||||||
| int	blocking_read(int, char *, int); | int blocking_read(int, char *, int); | ||||||
| int	reset_nonblock(int); | int reset_nonblock(int); | ||||||
| char	*ksh_get_wd(char *, int); | char *ksh_get_wd(char *, int); | ||||||
| int	make_path(const char *, const char *, char **, XString *, int *); | int make_path(const char *, const char *, char **, XString *, int *); | ||||||
| void	simplify_path(char *); | void simplify_path(char *); | ||||||
| char	*get_phys_path(const char *); | char *get_phys_path(const char *); | ||||||
| void	set_current_wd(char *); | void set_current_wd(char *); | ||||||
| /* shf.c */ | /* shf.c */ | ||||||
| struct shf *shf_open(const char *, int, int, int); | struct shf *shf_open(const char *, int, int, int); | ||||||
| struct shf *shf_fdopen(int, int, struct shf *); | struct shf *shf_fdopen(int, int, struct shf *); | ||||||
| struct shf *shf_reopen(int, int, struct shf *); | struct shf *shf_reopen(int, int, struct shf *); | ||||||
| struct shf *shf_sopen(char *, int, int, struct shf *); | struct shf *shf_sopen(char *, int, int, struct shf *); | ||||||
| int	shf_close(struct shf *); | int shf_close(struct shf *); | ||||||
| int	shf_fdclose(struct shf *); | int shf_fdclose(struct shf *); | ||||||
| char *	shf_sclose(struct shf *); | char *shf_sclose(struct shf *); | ||||||
| int	shf_flush(struct shf *); | int shf_flush(struct shf *); | ||||||
| int	shf_read(char *, int, struct shf *); | int shf_read(char *, int, struct shf *); | ||||||
| char *	shf_getse(char *, int, struct shf *); | char *shf_getse(char *, int, struct shf *); | ||||||
| int	shf_getchar(struct shf *s); | int shf_getchar(struct shf *s); | ||||||
| int	shf_ungetc(int, struct shf *); | int shf_ungetc(int, struct shf *); | ||||||
| int	shf_putchar(int, struct shf *); | int shf_putchar(int, struct shf *); | ||||||
| int	shf_puts(const char *, struct shf *); | int shf_puts(const char *, struct shf *); | ||||||
| int	shf_write(const char *, int, struct shf *); | int shf_write(const char *, int, struct shf *); | ||||||
| int	shf_fprintf(struct shf *, const char *, ...); | int shf_fprintf(struct shf *, const char *, ...); | ||||||
| int	shf_snprintf(char *, int, const char *, ...); | int shf_snprintf(char *, int, const char *, ...); | ||||||
| char *	shf_smprintf(const char *, ...); | char *shf_smprintf(const char *, ...); | ||||||
| int	shf_vfprintf(struct shf *, const char *, va_list); | int shf_vfprintf(struct shf *, const char *, va_list); | ||||||
| /* syn.c */ | /* syn.c */ | ||||||
| void	initkeywords(void); | void initkeywords(void); | ||||||
| struct op * compile(Source *); | struct op *compile(Source *); | ||||||
| /* tree.c */ | /* tree.c */ | ||||||
| int	fptreef(struct shf *, int, const char *, ...); | int fptreef(struct shf *, int, const char *, ...); | ||||||
| char *	snptreef(char *, int, const char *, ...); | char *snptreef(char *, int, const char *, ...); | ||||||
| struct op *	tcopy(struct op *, Area *); | struct op *tcopy(struct op *, Area *); | ||||||
| char *	wdcopy(const char *, Area *); | char *wdcopy(const char *, Area *); | ||||||
| char *	wdscan(const char *, int); | char *wdscan(const char *, int); | ||||||
| char *	wdstrip(const char *); | char *wdstrip(const char *); | ||||||
| void	tfree(struct op *, Area *); | void tfree(struct op *, Area *); | ||||||
| /* var.c */ | /* var.c */ | ||||||
| void	newblock(void); | void newblock(void); | ||||||
| void	popblock(void); | void popblock(void); | ||||||
| void	initvar(void); | void initvar(void); | ||||||
| struct tbl *	global(const char *); | struct tbl *global(const char *); | ||||||
| struct tbl *	local(const char *, bool); | struct tbl *local(const char *, bool); | ||||||
| char *	str_val(struct tbl *); | char *str_val(struct tbl *); | ||||||
| long	intval(struct tbl *); | long intval(struct tbl *); | ||||||
| int	setstr(struct tbl *, const char *, int); | int setstr(struct tbl *, const char *, int); | ||||||
| struct tbl *setint_v(struct tbl *, struct tbl *, bool); | struct tbl *setint_v(struct tbl *, struct tbl *, bool); | ||||||
| void	setint(struct tbl *, long); | void setint(struct tbl *, long); | ||||||
| int	getint(struct tbl *, long *, bool); | int getint(struct tbl *, long *, bool); | ||||||
| struct tbl *	typeset(const char *, Tflag, Tflag, int, int); | struct tbl *typeset(const char *, Tflag, Tflag, int, int); | ||||||
| void	unset(struct tbl *, int); | void unset(struct tbl *, int); | ||||||
| char  * skip_varname(const char *, int); | char *skip_varname(const char *, int); | ||||||
| char	*skip_wdvarname(const char *, int); | char *skip_wdvarname(const char *, int); | ||||||
| int	is_wdvarname(const char *, int); | int is_wdvarname(const char *, int); | ||||||
| int	is_wdvarassign(const char *); | int is_wdvarassign(const char *); | ||||||
| char **	makenv(void); | char **makenv(void); | ||||||
| void	change_random(void); | void change_random(void); | ||||||
| int	array_ref_len(const char *); | int array_ref_len(const char *); | ||||||
| char *	arrayname(const char *); | char *arrayname(const char *); | ||||||
| void    set_array(const char *, int, char **); | void set_array(const char *, int, char **); | ||||||
| int	eaccess(const char *, int); | int eaccess(const char *, int); | ||||||
|  |  | ||||||
| enum Test_op { | enum Test_op { | ||||||
| 	TO_NONOP = 0,	/* non-operator */ | 	TO_NONOP = 0,	/* non-operator */ | ||||||
| @@ -1247,30 +1244,28 @@ typedef enum Test_meta Test_meta; | |||||||
|  |  | ||||||
| typedef struct test_env Test_env; | typedef struct test_env Test_env; | ||||||
| struct test_env { | struct test_env { | ||||||
| 	int	flags;		/* TEF_* */ | 	int flags;		/* TEF_* */ | ||||||
| 	union { | 	union { | ||||||
| 		char	**wp;		/* used by ptest_* */ | 		char **wp;	/* used by ptest_* */ | ||||||
| 		XPtrV	*av;		/* used by dbtestp_* */ | 		XPtrV *av;	/* used by dbtestp_* */ | ||||||
| 	} pos; | 	} pos; | ||||||
| 	char **wp_end;			/* used by ptest_* */ | 	char **wp_end;		/* used by ptest_* */ | ||||||
| 	int	(*isa)(Test_env *, Test_meta); | 	int (*isa)(Test_env *, Test_meta); | ||||||
| 	const char *(*getopnd) (Test_env *, Test_op, int); | 	const char *(*getopnd) (Test_env *, Test_op, int); | ||||||
| 	int	(*eval)(Test_env *, Test_op, const char *, const char *, int); | 	int (*eval)(Test_env *, Test_op, const char *, const char *, int); | ||||||
| 	void	(*error)(Test_env *, int, const char *); | 	void (*error)(Test_env *, int, const char *); | ||||||
| }; | }; | ||||||
|  |  | ||||||
| Test_op	test_isop(Test_meta, const char *); | Test_op	test_isop(Test_meta, const char *); | ||||||
| int     test_eval(Test_env *, Test_op, const char *, const char *, int); | int test_eval(Test_env *, Test_op, const char *, const char *, int); | ||||||
| int	test_parse(Test_env *); | int test_parse(Test_env *); | ||||||
|  |  | ||||||
| EXTERN int		tty_fd I__(-1);	/* dup'd tty file descriptor */ | EXTERN int tty_fd I__(-1);	/* dup'd tty file descriptor */ | ||||||
| EXTERN int		tty_devtty;	/* true if tty_fd is from /dev/tty */ | EXTERN int tty_devtty;		/* true if tty_fd is from /dev/tty */ | ||||||
| EXTERN struct termios	tty_state;	/* saved tty state */ | EXTERN struct termios tty_state;	/* saved tty state */ | ||||||
|  |  | ||||||
| extern void	tty_init(int); | extern void tty_init(int); | ||||||
| extern void	tty_close(void); | extern void tty_close(void); | ||||||
|  |  | ||||||
| #include "version.h" |  | ||||||
|  |  | ||||||
| /* be sure not to interfere with anyone else's idea about EXTERN */ | /* be sure not to interfere with anyone else's idea about EXTERN */ | ||||||
| #ifdef EXTERN_DEFINED | #ifdef EXTERN_DEFINED | ||||||
| @@ -1283,9 +1278,9 @@ extern void	tty_close(void); | |||||||
| #if defined(__gnu_linux__) || defined(__INTERIX) || defined(__sun__) \ | #if defined(__gnu_linux__) || defined(__INTERIX) || defined(__sun__) \ | ||||||
|     || (defined(__NetBSD__) && (__NetBSD_Version__ < 106020000)) \ |     || (defined(__NetBSD__) && (__NetBSD_Version__ < 106020000)) \ | ||||||
|     || defined(__CYGWIN__) |     || defined(__CYGWIN__) | ||||||
| #define	HAVE_ARC4RANDOM	0 | #define HAVE_ARC4RANDOM 0 | ||||||
| #else | #else | ||||||
| #define	HAVE_ARC4RANDOM	1 | #define HAVE_ARC4RANDOM 1 | ||||||
| #endif | #endif | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user