mirror of
https://github.com/sheumann/hush.git
synced 2025-01-08 18:30:27 +00:00
ash: remove last "signed char"; make SIT() clearer. -12 bytes
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
This commit is contained in:
parent
0337e038a9
commit
76bc2d6deb
127
shell/ash.c
127
shell/ash.c
@ -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;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user