ash: remove last "signed char"; make SIT() clearer. -12 bytes

Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
This commit is contained in:
Denys Vlasenko 2009-11-29 01:37:46 +01:00
parent 0337e038a9
commit 76bc2d6deb

View File

@ -2621,50 +2621,54 @@ pwdcmd(int argc UNUSED_PARAM, char **argv UNUSED_PARAM)
#endif #endif
#if ENABLE_SH_MATH_SUPPORT #if ENABLE_SH_MATH_SUPPORT
static const uint8_t S_I_T[][4] = { # define SIT_ITEM(a,b,c,d) (a | (b << 4) | (c << 8) | (d << 12))
# if ENABLE_ASH_ALIAS static const uint16_t S_I_T[] =
{ CSPCL, CIGN, CIGN, CIGN }, /* 0, PEOA */
# endif
{ CSPCL, CWORD, CWORD, CWORD }, /* 1, ' ' */
{ CNL, CNL, CNL, CNL }, /* 2, \n */
{ CWORD, CCTL, CCTL, CWORD }, /* 3, !*-/:=?[]~ */
{ CDQUOTE, CENDQUOTE, CWORD, CWORD }, /* 4, '"' */
{ CVAR, CVAR, CWORD, CVAR }, /* 5, $ */
{ CSQUOTE, CWORD, CENDQUOTE, CWORD }, /* 6, "'" */
{ CSPCL, CWORD, CWORD, CLP }, /* 7, ( */
{ CSPCL, CWORD, CWORD, CRP }, /* 8, ) */
{ CBACK, CBACK, CCTL, CBACK }, /* 9, \ */
{ CBQUOTE, CBQUOTE, CWORD, CBQUOTE }, /* 10, ` */
{ CENDVAR, CENDVAR, CWORD, CENDVAR }, /* 11, } */
# ifndef USE_SIT_FUNCTION
{ CENDFILE, CENDFILE, CENDFILE, CENDFILE }, /* 12, PEOF */
{ CWORD, CWORD, CWORD, CWORD }, /* 13, 0-9A-Za-z */
{ CCTL, CCTL, CCTL, CCTL } /* 14, CTLESC ... */
# endif
};
#else #else
static const uint8_t S_I_T[][3] = { # define SIT_ITEM(a,b,c,d) (a | (b << 4) | (c << 8))
static const uint16_t S_I_T[] =
#endif
{
#if ENABLE_ASH_ALIAS #if ENABLE_ASH_ALIAS
{ CSPCL, CIGN, CIGN }, /* 0, PEOA */ SIT_ITEM(CSPCL , CIGN , CIGN , CIGN ), /* 0, PEOA */
#endif #endif
{ CSPCL, CWORD, CWORD }, /* 1, ' ' */ SIT_ITEM(CSPCL , CWORD , CWORD, CWORD ), /* 1, ' ' */
{ CNL, CNL, CNL }, /* 2, \n */ SIT_ITEM(CNL , CNL , CNL , CNL ), /* 2, \n */
{ CWORD, CCTL, CCTL }, /* 3, !*-/:=?[]~ */ SIT_ITEM(CWORD , CCTL , CCTL , CWORD ), /* 3, !*-/:=?[]~ */
{ CDQUOTE, CENDQUOTE, CWORD }, /* 4, '"' */ SIT_ITEM(CDQUOTE , CENDQUOTE, CWORD, CWORD ), /* 4, '"' */
{ CVAR, CVAR, CWORD }, /* 5, $ */ SIT_ITEM(CVAR , CVAR , CWORD, CVAR ), /* 5, $ */
{ CSQUOTE, CWORD, CENDQUOTE }, /* 6, "'" */ SIT_ITEM(CSQUOTE , CWORD , CENDQUOTE, CWORD), /* 6, "'" */
{ CSPCL, CWORD, CWORD }, /* 7, ( */ SIT_ITEM(CSPCL , CWORD , CWORD, CLP ), /* 7, ( */
{ CSPCL, CWORD, CWORD }, /* 8, ) */ SIT_ITEM(CSPCL , CWORD , CWORD, CRP ), /* 8, ) */
{ CBACK, CBACK, CCTL }, /* 9, \ */ SIT_ITEM(CBACK , CBACK , CCTL , CBACK ), /* 9, \ */
{ CBQUOTE, CBQUOTE, CWORD }, /* 10, ` */ SIT_ITEM(CBQUOTE , CBQUOTE , CWORD, CBQUOTE), /* 10, ` */
{ CENDVAR, CENDVAR, CWORD }, /* 11, } */ SIT_ITEM(CENDVAR , CENDVAR , CWORD, CENDVAR), /* 11, } */
#ifndef USE_SIT_FUNCTION #ifndef USE_SIT_FUNCTION
{ CENDFILE, CENDFILE, CENDFILE }, /* 12, PEOF */ SIT_ITEM(CENDFILE, CENDFILE , CENDFILE, CENDFILE),/* 12, PEOF */
{ CWORD, CWORD, CWORD }, /* 13, 0-9A-Za-z */ SIT_ITEM(CWORD , CWORD , CWORD, CWORD ), /* 13, 0-9A-Za-z */
{ CCTL, CCTL, CCTL } /* 14, CTLESC ... */ SIT_ITEM(CCTL , CCTL , CCTL , CCTL ) /* 14, CTLESC ... */
#endif #endif
#undef SIT_ITEM
};
/* Constants below must match table above */
enum {
#if ENABLE_ASH_ALIAS
CSPCL_CIGN_CIGN_CIGN , /* 0 */
#endif
CSPCL_CWORD_CWORD_CWORD , /* 1 */
CNL_CNL_CNL_CNL , /* 2 */
CWORD_CCTL_CCTL_CWORD , /* 3 */
CDQUOTE_CENDQUOTE_CWORD_CWORD , /* 4 */
CVAR_CVAR_CWORD_CVAR , /* 5 */
CSQUOTE_CWORD_CENDQUOTE_CWORD , /* 6 */
CSPCL_CWORD_CWORD_CLP , /* 7 */
CSPCL_CWORD_CWORD_CRP , /* 8 */
CBACK_CBACK_CCTL_CBACK , /* 9 */
CBQUOTE_CBQUOTE_CWORD_CBQUOTE , /* 10 */
CENDVAR_CENDVAR_CWORD_CENDVAR , /* 11 */
CENDFILE_CENDFILE_CENDFILE_CENDFILE, /* 12 */
CWORD_CWORD_CWORD_CWORD , /* 13 */
CCTL_CCTL_CCTL_CCTL , /* 14 */
}; };
#endif /* SH_MATH_SUPPORT */
/* c in SIT(c, syntax) must be an *unsigned char* or PEOA or PEOF, /* c in SIT(c, syntax) must be an *unsigned char* or PEOA or PEOF,
* caller must ensure proper cast on it if c is *char_ptr! * caller must ensure proper cast on it if c is *char_ptr!
@ -2714,45 +2718,12 @@ SIT(int c, int syntax)
} }
indx = syntax_index_table[s - spec_symbls]; indx = syntax_index_table[s - spec_symbls];
} }
return S_I_T[indx][syntax]; return (S_I_T[indx] >> (syntax*4)) & 0xf;
} }
#else /* !USE_SIT_FUNCTION */ #else /* !USE_SIT_FUNCTION */
# if ENABLE_ASH_ALIAS static const uint8_t syntax_index_table[] = {
# define CSPCL_CIGN_CIGN_CIGN 0
# define CSPCL_CWORD_CWORD_CWORD 1
# define CNL_CNL_CNL_CNL 2
# define CWORD_CCTL_CCTL_CWORD 3
# define CDQUOTE_CENDQUOTE_CWORD_CWORD 4
# define CVAR_CVAR_CWORD_CVAR 5
# define CSQUOTE_CWORD_CENDQUOTE_CWORD 6
# define CSPCL_CWORD_CWORD_CLP 7
# define CSPCL_CWORD_CWORD_CRP 8
# define CBACK_CBACK_CCTL_CBACK 9
# define CBQUOTE_CBQUOTE_CWORD_CBQUOTE 10
# define CENDVAR_CENDVAR_CWORD_CENDVAR 11
# define CENDFILE_CENDFILE_CENDFILE_CENDFILE 12
# define CWORD_CWORD_CWORD_CWORD 13
# define CCTL_CCTL_CCTL_CCTL 14
# else
# define CSPCL_CWORD_CWORD_CWORD 0
# define CNL_CNL_CNL_CNL 1
# define CWORD_CCTL_CCTL_CWORD 2
# define CDQUOTE_CENDQUOTE_CWORD_CWORD 3
# define CVAR_CVAR_CWORD_CVAR 4
# define CSQUOTE_CWORD_CENDQUOTE_CWORD 5
# define CSPCL_CWORD_CWORD_CLP 6
# define CSPCL_CWORD_CWORD_CRP 7
# define CBACK_CBACK_CCTL_CBACK 8
# define CBQUOTE_CBQUOTE_CWORD_CBQUOTE 9
# define CENDVAR_CENDVAR_CWORD_CENDVAR 10
# define CENDFILE_CENDFILE_CENDFILE_CENDFILE 11
# define CWORD_CWORD_CWORD_CWORD 12
# define CCTL_CCTL_CCTL_CCTL 13
# endif
static const uint8_t syntax_index_table[258] = {
/* BASESYNTAX_DQSYNTAX_SQSYNTAX_ARISYNTAX */ /* BASESYNTAX_DQSYNTAX_SQSYNTAX_ARISYNTAX */
/* 0 */ CWORD_CWORD_CWORD_CWORD, /* 0 */ CWORD_CWORD_CWORD_CWORD,
/* 1 */ CWORD_CWORD_CWORD_CWORD, /* 1 */ CWORD_CWORD_CWORD_CWORD,
@ -3016,9 +2987,9 @@ static const uint8_t syntax_index_table[258] = {
/* PEOF */ CENDFILE_CENDFILE_CENDFILE_CENDFILE, /* PEOF */ CENDFILE_CENDFILE_CENDFILE_CENDFILE,
}; };
# define SIT(c, syntax) (S_I_T[syntax_index_table[c]][syntax]) # define SIT(c, syntax) ((S_I_T[syntax_index_table[c]] >> (syntax*4)) & 0xf)
#endif /* USE_SIT_FUNCTION */ #endif /* !USE_SIT_FUNCTION */
/* ============ Alias handling */ /* ============ Alias handling */
@ -10437,7 +10408,7 @@ noexpand(const char *text)
continue; continue;
if (c == CTLESC) if (c == CTLESC)
text++; text++;
else if (SIT((signed char)c, BASESYNTAX) == CCTL) else if (SIT(c, BASESYNTAX) == CCTL)
return 0; return 0;
} }
return 1; return 1;
@ -11398,8 +11369,10 @@ parsebackq: {
continue; continue;
} }
if (pc != '\\' && pc != '`' && pc != '$' if (pc != '\\' && pc != '`' && pc != '$'
&& (!dblquote || pc != '"')) && (!dblquote || pc != '"')
) {
STPUTC('\\', pout); STPUTC('\\', pout);
}
if (pc <= 255 /* not PEOA or PEOF */) { if (pc <= 255 /* not PEOA or PEOF */) {
break; break;
} }