ash: cleanup part 2.5

This commit is contained in:
Denis Vlasenko 2007-02-23 21:10:23 +00:00
parent a89150733a
commit 2de3d9fbee

View File

@ -66,6 +66,15 @@
#endif #endif
/* ============ Misc helpers */
#define xbarrier() do { __asm__ __volatile__ ("": : :"memory"); } while (0)
/* C99 say: "char" declaration may be signed or unsigned default */
#define signed_char2int(sc) ((int)((signed char)sc))
/* ============ Shell options */ /* ============ Shell options */
static const char *const optletters_optnames[] = { static const char *const optletters_optnames[] = {
@ -192,13 +201,11 @@ static volatile sig_atomic_t pendingsigs;
* much more efficient and portable. (But hacking the kernel is so much * much more efficient and portable. (But hacking the kernel is so much
* more fun than worrying about efficiency and portability. :-)) * more fun than worrying about efficiency and portability. :-))
*/ */
#define xbarrier() ({ __asm__ __volatile__ ("": : :"memory"); })
#define INT_OFF \ #define INT_OFF \
({ \ do { \
suppressint++; \ suppressint++; \
xbarrier(); \ xbarrier(); \
0; \ } while (0)
})
/* /*
* Called to raise an exception. Since C doesn't include exceptions, we * Called to raise an exception. Since C doesn't include exceptions, we
@ -263,38 +270,37 @@ force_int_on(void)
#define FORCE_INT_ON force_int_on() #define FORCE_INT_ON force_int_on()
#else #else
#define INT_ON \ #define INT_ON \
({ \ do { \
xbarrier(); \ xbarrier(); \
if (--suppressint == 0 && intpending) raise_interrupt(); \ if (--suppressint == 0 && intpending) \
0; \ raise_interrupt(); \
}) } while (0)
#define FORCE_INT_ON \ #define FORCE_INT_ON \
({ \ do { \
xbarrier(); \ xbarrier(); \
suppressint = 0; \ suppressint = 0; \
if (intpending) raise_interrupt(); \ if (intpending) \
0; \ raise_interrupt(); \
}) } while (0)
#endif /* ASH_OPTIMIZE_FOR_SIZE */ #endif /* ASH_OPTIMIZE_FOR_SIZE */
#define SAVE_INT(v) ((v) = suppressint) #define SAVE_INT(v) ((v) = suppressint)
#define RESTORE_INT(v) \ #define RESTORE_INT(v) \
({ \ do { \
xbarrier(); \ xbarrier(); \
suppressint = (v); \ suppressint = (v); \
if (suppressint == 0 && intpending) raise_interrupt(); \ if (suppressint == 0 && intpending) \
0; \ raise_interrupt(); \
}) } while (0)
#define EXSIGON \ #define EXSIGON \
({ \ do { \
exsig++; \ exsig++; \
xbarrier(); \ xbarrier(); \
if (pendingsigs) \ if (pendingsigs) \
raise_exception(EXSIG); \ raise_exception(EXSIG); \
0; \ } while (0)
})
/* EXSIG is turned off by evalbltin(). */ /* EXSIG is turned off by evalbltin(). */
/* /*
@ -406,7 +412,7 @@ out2str(const char *p)
} }
/* ============ Parsing structures */ /* ============ Parser structures */
/* control characters in argument strings */ /* control characters in argument strings */
#define CTLESC '\201' /* escape next character */ #define CTLESC '\201' /* escape next character */
@ -436,6 +442,8 @@ out2str(const char *p)
#define VSTRIMLEFTMAX 0x9 /* ${var##pattern} */ #define VSTRIMLEFTMAX 0x9 /* ${var##pattern} */
#define VSLENGTH 0xa /* ${#var} */ #define VSLENGTH 0xa /* ${#var} */
static const char dolatstr[] = { CTLVAR, VSNORMAL|VSQUOTE, '@', '=', '\0' };
#define NCMD 0 #define NCMD 0
#define NPIPE 1 #define NPIPE 1
#define NREDIR 2 #define NREDIR 2
@ -1364,18 +1372,22 @@ _STPUTC(int c, char *p)
#define STARTSTACKSTR(p) ((p) = stackblock()) #define STARTSTACKSTR(p) ((p) = stackblock())
#define STPUTC(c, p) ((p) = _STPUTC((c), (p))) #define STPUTC(c, p) ((p) = _STPUTC((c), (p)))
#define CHECKSTRSPACE(n, p) \ #define CHECKSTRSPACE(n, p) \
({ \ do { \
char *q = (p); \ char *q = (p); \
size_t l = (n); \ size_t l = (n); \
size_t m = sstrend - q; \ size_t m = sstrend - q; \
if (l > m) \ if (l > m) \
(p) = makestrspace(l, q); \ (p) = makestrspace(l, q); \
0; \ } while (0)
})
#define USTPUTC(c, p) (*p++ = (c)) #define USTPUTC(c, p) (*p++ = (c))
#define STACKSTRNUL(p) ((p) == sstrend ? (p = growstackstr(), *p = '\0') : (*p = '\0')) #define STACKSTRNUL(p) \
do { \
if ((p) == sstrend) \
p = growstackstr(); \
*p = '\0'; \
} while (0)
#define STUNPUTC(p) (--p) #define STUNPUTC(p) (--p)
#define STTOPC(p) p[-1] #define STTOPC(p) (p[-1])
#define STADJUST(amount, p) (p += (amount)) #define STADJUST(amount, p) (p += (amount))
#define grabstackstr(p) stalloc((char *)(p) - (char *)stackblock()) #define grabstackstr(p) stalloc((char *)(p) - (char *)stackblock())
@ -1519,6 +1531,29 @@ nextopt(const char *optstring)
} }
/* ============ Math support definitions */
#if ENABLE_ASH_MATH_SUPPORT_64
typedef int64_t arith_t;
#define arith_t_type long long
#else
typedef long arith_t;
#define arith_t_type long
#endif
#if ENABLE_ASH_MATH_SUPPORT
static arith_t dash_arith(const char *);
static arith_t arith(const char *expr, int *perrcode);
#endif
#if ENABLE_ASH_RANDOM_SUPPORT
static unsigned long rseed;
#ifndef DYNAMIC_VAR
#define DYNAMIC_VAR
#endif
#endif
/* ============ Shell variables */ /* ============ Shell variables */
/* flags */ /* flags */
@ -1533,7 +1568,7 @@ nextopt(const char *optstring)
#define VNOSAVE 0x100 /* when text is on the heap before setvareq */ #define VNOSAVE 0x100 /* when text is on the heap before setvareq */
#ifdef DYNAMIC_VAR #ifdef DYNAMIC_VAR
# define VDYNAMIC 0x200 /* dynamic variable */ # define VDYNAMIC 0x200 /* dynamic variable */
# else #else
# define VDYNAMIC 0 # define VDYNAMIC 0
#endif #endif
@ -2401,12 +2436,6 @@ pwdcmd(int argc, char **argv)
#define IBUFSIZ (BUFSIZ + 1) #define IBUFSIZ (BUFSIZ + 1)
#define basebuf bb_common_bufsiz1 /* buffer for top level input file */ #define basebuf bb_common_bufsiz1 /* buffer for top level input file */
/* shell.h */
static const char spcstr[] = " ";
static const char dolatstr[] = { CTLVAR, VSNORMAL|VSQUOTE, '@', '=', '\0' };
/* Syntax classes */ /* Syntax classes */
#define CWORD 0 /* character is nothing special */ #define CWORD 0 /* character is nothing special */
#define CNL 1 /* newline character */ #define CNL 1 /* newline character */
@ -2435,77 +2464,72 @@ static const char dolatstr[] = { CTLVAR, VSNORMAL|VSQUOTE, '@', '=', '\0' };
#define PEOA_OR_PEOF PEOF #define PEOA_OR_PEOF PEOF
#endif #endif
/* C99 say: "char" declaration may be signed or unsigned default */
#define SC2INT(chr2may_be_negative_int) (int)((signed char)chr2may_be_negative_int)
/* /*
* is_special(c) evaluates to 1 for c in "!#$*-0123456789?@"; 0 otherwise * is_special(c) evaluates to 1 for c in "!#$*-0123456789?@"; 0 otherwise
* (assuming ascii char codes, as the original implementation did) * (assuming ascii char codes, as the original implementation did)
*/ */
#define is_special(c) \ #define is_special(c) \
( (((unsigned int)c) - 33 < 32) \ ((((unsigned int)c) - 33 < 32) \
&& ((0xc1ff920dUL >> (((unsigned int)c) - 33)) & 1)) && ((0xc1ff920dUL >> (((unsigned int)c) - 33)) & 1))
#if ENABLE_ASH_OPTIMIZE_FOR_SIZE
#define USE_SIT_FUNCTION
#endif
/* number syntax index */ /* number syntax index */
#define BASESYNTAX 0 /* not in quotes */ #define BASESYNTAX 0 /* not in quotes */
#define DQSYNTAX 1 /* in double quotes */ #define DQSYNTAX 1 /* in double quotes */
#define SQSYNTAX 2 /* in single quotes */ #define SQSYNTAX 2 /* in single quotes */
#define ARISYNTAX 3 /* in arithmetic */ #define ARISYNTAX 3 /* in arithmetic */
#if ENABLE_ASH_OPTIMIZE_FOR_SIZE
#define USE_SIT_FUNCTION
#endif
#if ENABLE_ASH_MATH_SUPPORT #if ENABLE_ASH_MATH_SUPPORT
static const char S_I_T[][4] = { static const char S_I_T[][4] = {
#if ENABLE_ASH_ALIAS #if ENABLE_ASH_ALIAS
{CSPCL, CIGN, CIGN, CIGN}, /* 0, PEOA */ { CSPCL, CIGN, CIGN, CIGN }, /* 0, PEOA */
#endif #endif
{CSPCL, CWORD, CWORD, CWORD}, /* 1, ' ' */ { CSPCL, CWORD, CWORD, CWORD }, /* 1, ' ' */
{CNL, CNL, CNL, CNL}, /* 2, \n */ { CNL, CNL, CNL, CNL }, /* 2, \n */
{CWORD, CCTL, CCTL, CWORD}, /* 3, !*-/:=?[]~ */ { CWORD, CCTL, CCTL, CWORD }, /* 3, !*-/:=?[]~ */
{CDQUOTE, CENDQUOTE, CWORD, CWORD}, /* 4, '"' */ { CDQUOTE, CENDQUOTE, CWORD, CWORD }, /* 4, '"' */
{CVAR, CVAR, CWORD, CVAR}, /* 5, $ */ { CVAR, CVAR, CWORD, CVAR }, /* 5, $ */
{CSQUOTE, CWORD, CENDQUOTE, CWORD}, /* 6, "'" */ { CSQUOTE, CWORD, CENDQUOTE, CWORD }, /* 6, "'" */
{CSPCL, CWORD, CWORD, CLP}, /* 7, ( */ { CSPCL, CWORD, CWORD, CLP }, /* 7, ( */
{CSPCL, CWORD, CWORD, CRP}, /* 8, ) */ { CSPCL, CWORD, CWORD, CRP }, /* 8, ) */
{CBACK, CBACK, CCTL, CBACK}, /* 9, \ */ { CBACK, CBACK, CCTL, CBACK }, /* 9, \ */
{CBQUOTE, CBQUOTE, CWORD, CBQUOTE}, /* 10, ` */ { CBQUOTE, CBQUOTE, CWORD, CBQUOTE }, /* 10, ` */
{CENDVAR, CENDVAR, CWORD, CENDVAR}, /* 11, } */ { CENDVAR, CENDVAR, CWORD, CENDVAR }, /* 11, } */
#ifndef USE_SIT_FUNCTION #ifndef USE_SIT_FUNCTION
{CENDFILE, CENDFILE, CENDFILE, CENDFILE}, /* 12, PEOF */ { CENDFILE, CENDFILE, CENDFILE, CENDFILE }, /* 12, PEOF */
{CWORD, CWORD, CWORD, CWORD}, /* 13, 0-9A-Za-z */ { CWORD, CWORD, CWORD, CWORD }, /* 13, 0-9A-Za-z */
{CCTL, CCTL, CCTL, CCTL} /* 14, CTLESC ... */ { CCTL, CCTL, CCTL, CCTL } /* 14, CTLESC ... */
#endif #endif
}; };
#else #else
static const char S_I_T[][3] = { static const char S_I_T[][3] = {
#if ENABLE_ASH_ALIAS #if ENABLE_ASH_ALIAS
{CSPCL, CIGN, CIGN}, /* 0, PEOA */ { CSPCL, CIGN, CIGN }, /* 0, PEOA */
#endif #endif
{CSPCL, CWORD, CWORD}, /* 1, ' ' */ { CSPCL, CWORD, CWORD }, /* 1, ' ' */
{CNL, CNL, CNL}, /* 2, \n */ { CNL, CNL, CNL }, /* 2, \n */
{CWORD, CCTL, CCTL}, /* 3, !*-/:=?[]~ */ { CWORD, CCTL, CCTL }, /* 3, !*-/:=?[]~ */
{CDQUOTE, CENDQUOTE, CWORD}, /* 4, '"' */ { CDQUOTE, CENDQUOTE, CWORD }, /* 4, '"' */
{CVAR, CVAR, CWORD}, /* 5, $ */ { CVAR, CVAR, CWORD }, /* 5, $ */
{CSQUOTE, CWORD, CENDQUOTE}, /* 6, "'" */ { CSQUOTE, CWORD, CENDQUOTE }, /* 6, "'" */
{CSPCL, CWORD, CWORD}, /* 7, ( */ { CSPCL, CWORD, CWORD }, /* 7, ( */
{CSPCL, CWORD, CWORD}, /* 8, ) */ { CSPCL, CWORD, CWORD }, /* 8, ) */
{CBACK, CBACK, CCTL}, /* 9, \ */ { CBACK, CBACK, CCTL }, /* 9, \ */
{CBQUOTE, CBQUOTE, CWORD}, /* 10, ` */ { CBQUOTE, CBQUOTE, CWORD }, /* 10, ` */
{CENDVAR, CENDVAR, CWORD}, /* 11, } */ { CENDVAR, CENDVAR, CWORD }, /* 11, } */
#ifndef USE_SIT_FUNCTION #ifndef USE_SIT_FUNCTION
{CENDFILE, CENDFILE, CENDFILE}, /* 12, PEOF */ { CENDFILE, CENDFILE, CENDFILE }, /* 12, PEOF */
{CWORD, CWORD, CWORD}, /* 13, 0-9A-Za-z */ { CWORD, CWORD, CWORD }, /* 13, 0-9A-Za-z */
{CCTL, CCTL, CCTL} /* 14, CTLESC ... */ { CCTL, CCTL, CCTL } /* 14, CTLESC ... */
#endif #endif
}; };
#endif /* ASH_MATH_SUPPORT */ #endif /* ASH_MATH_SUPPORT */
#ifdef USE_SIT_FUNCTION #ifdef USE_SIT_FUNCTION
#define U_C(c) ((unsigned char)(c))
static int static int
SIT(int c, int syntax) SIT(int c, int syntax)
{ {
@ -2535,9 +2559,13 @@ SIT(int c, int syntax)
indx = 0; indx = 0;
else else
#endif #endif
if (U_C(c) >= U_C(CTLESC) && U_C(c) <= U_C(CTLQUOTEMARK)) #define U_C(c) ((unsigned char)(c))
if ((unsigned char)c >= (unsigned char)(CTLESC)
&& (unsigned char)c <= (unsigned char)(CTLQUOTEMARK)
) {
return CCTL; return CCTL;
else { } else {
s = strchr(spec_symbls, c); s = strchr(spec_symbls, c);
if (s == NULL || *s == '\0') if (s == NULL || *s == '\0')
return CWORD; return CWORD;
@ -2546,9 +2574,7 @@ SIT(int c, int syntax)
return S_I_T[indx][syntax]; return S_I_T[indx][syntax];
} }
#else /* USE_SIT_FUNCTION */ #else /* !USE_SIT_FUNCTION */
#define SIT(c, syntax) S_I_T[(int)syntax_index_table[((int)c)+SYNBASE]][syntax]
#if ENABLE_ASH_ALIAS #if ENABLE_ASH_ALIAS
#define CSPCL_CIGN_CIGN_CIGN 0 #define CSPCL_CIGN_CIGN_CIGN 0
@ -2847,32 +2873,11 @@ static const char syntax_index_table[258] = {
/* 257 127 */ CWORD_CWORD_CWORD_CWORD, /* 257 127 */ CWORD_CWORD_CWORD_CWORD,
}; };
#define SIT(c, syntax) (S_I_T[(int)syntax_index_table[((int)c)+SYNBASE]][syntax])
#endif /* USE_SIT_FUNCTION */ #endif /* USE_SIT_FUNCTION */
/* exec.h */
#if ENABLE_ASH_MATH_SUPPORT_64
typedef int64_t arith_t;
#define arith_t_type long long
#else
typedef long arith_t;
#define arith_t_type long
#endif
#if ENABLE_ASH_MATH_SUPPORT
static arith_t dash_arith(const char *);
static arith_t arith(const char *expr, int *perrcode);
#endif
#if ENABLE_ASH_RANDOM_SUPPORT
static unsigned long rseed;
# ifndef DYNAMIC_VAR
# define DYNAMIC_VAR
# endif
#endif
/* main.h */ /* main.h */
static void readcmdfile(char *); static void readcmdfile(char *);
@ -4244,10 +4249,10 @@ cmdlist(union node *np, int sep)
{ {
for (; np; np = np->narg.next) { for (; np; np = np->narg.next) {
if (!sep) if (!sep)
cmdputs(spcstr); cmdputs(" ");
cmdtxt(np); cmdtxt(np);
if (sep && np->narg.next) if (sep && np->narg.next)
cmdputs(spcstr); cmdputs(" ");
} }
} }
@ -4810,7 +4815,7 @@ memtodest(const char *p, size_t len, int syntax, int quotes)
q = makestrspace(len * 2, q); q = makestrspace(len * 2, q);
while (len--) { while (len--) {
int c = SC2INT(*p++); int c = signed_char2int(*p++);
if (!c) if (!c)
continue; continue;
if (quotes && (SIT(c, syntax) == CCTL || SIT(c, syntax) == CBACK)) if (quotes && (SIT(c, syntax) == CCTL || SIT(c, syntax) == CBACK))
@ -5477,7 +5482,7 @@ varvalue(char *name, int varflags, int flags)
goto param; goto param;
/* fall through */ /* fall through */
case '*': case '*':
sep = ifsset() ? SC2INT(ifsval()[0]) : ' '; sep = ifsset() ? signed_char2int(ifsval()[0]) : ' ';
if (quotes && (SIT(sep, syntax) == CCTL || SIT(sep, syntax) == CBACK)) if (quotes && (SIT(sep, syntax) == CCTL || SIT(sep, syntax) == CBACK))
sepq = 1; sepq = 1;
param: param:
@ -8510,7 +8515,7 @@ preadbuffer(void)
#endif #endif
popstring(); popstring();
if (--parsenleft >= 0) if (--parsenleft >= 0)
return SC2INT(*parsenextc++); return signed_char2int(*parsenextc++);
} }
if (parsenleft == EOF_NLEFT || parsefile->buf == NULL) if (parsenleft == EOF_NLEFT || parsefile->buf == NULL)
return PEOF; return PEOF;
@ -8563,25 +8568,20 @@ preadbuffer(void)
*q = savec; *q = savec;
return SC2INT(*parsenextc++); return signed_char2int(*parsenextc++);
} }
#define pgetc_as_macro() (--parsenleft >= 0? SC2INT(*parsenextc++) : preadbuffer()) #define pgetc_as_macro() (--parsenleft >= 0? signed_char2int(*parsenextc++) : preadbuffer())
#if ENABLE_ASH_OPTIMIZE_FOR_SIZE
#define pgetc_macro() pgetc()
static int static int
pgetc(void) pgetc(void)
{ {
return pgetc_as_macro(); return pgetc_as_macro();
} }
#if ENABLE_ASH_OPTIMIZE_FOR_SIZE
#define pgetc_macro() pgetc()
#else #else
#define pgetc_macro() pgetc_as_macro() #define pgetc_macro() pgetc_as_macro()
static int
pgetc(void)
{
return pgetc_macro();
}
#endif #endif
/* /*
@ -8810,6 +8810,7 @@ setinputstring(char *string)
* *
* Routines to check for mail. * Routines to check for mail.
*/ */
#if ENABLE_ASH_MAIL #if ENABLE_ASH_MAIL
#define MAXMBOXES 10 #define MAXMBOXES 10
@ -8870,6 +8871,7 @@ changemail(const char *val)
{ {
mail_var_path_changed++; mail_var_path_changed++;
} }
#endif /* ASH_MAIL */ #endif /* ASH_MAIL */
@ -9133,7 +9135,7 @@ showvars(const char *sep_prefix, int on, int off)
ep = listvars(on, off, &epend); ep = listvars(on, off, &epend);
qsort(ep, epend - ep, sizeof(char *), vpcmp); qsort(ep, epend - ep, sizeof(char *), vpcmp);
sep = *sep_prefix ? spcstr : sep_prefix; sep = *sep_prefix ? " " : sep_prefix;
for (; ep < epend; ep++) { for (; ep < epend; ep++) {
const char *p; const char *p;
@ -10991,9 +10993,8 @@ readcmdfile(char *name)
} }
/* ============ redir.c */ /* ============ redir.c
*
/*
* Code for dealing with input/output redirection. * Code for dealing with input/output redirection.
*/ */