hush: reduce #ifdef forest a bit, rename handle_dollar -> parse_dollar
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
This commit is contained in:
parent
5ae8f1cdbe
commit
2e48d536ce
45
shell/hush.c
45
shell/hush.c
@ -50,6 +50,7 @@
|
|||||||
*
|
*
|
||||||
* Bash compat TODO:
|
* Bash compat TODO:
|
||||||
* redirection of stdout+stderr: &> and >&
|
* redirection of stdout+stderr: &> and >&
|
||||||
|
* subst operator: ${var/[/]expr/expr}
|
||||||
* brace expansion: one/{two,three,four}
|
* brace expansion: one/{two,three,four}
|
||||||
* reserved words: function select
|
* reserved words: function select
|
||||||
* advanced test: [[ ]]
|
* advanced test: [[ ]]
|
||||||
@ -1830,6 +1831,7 @@ static void o_addstr(o_string *o, const char *str)
|
|||||||
{
|
{
|
||||||
o_addblock(o, str, strlen(str));
|
o_addblock(o, str, strlen(str));
|
||||||
}
|
}
|
||||||
|
|
||||||
#if !BB_MMU
|
#if !BB_MMU
|
||||||
static void nommu_addchr(o_string *o, int ch)
|
static void nommu_addchr(o_string *o, int ch)
|
||||||
{
|
{
|
||||||
@ -2618,7 +2620,7 @@ static NOINLINE int expand_vars_to_list(o_string *output, int n, char *arg, char
|
|||||||
|
|
||||||
/* lookup the variable in question */
|
/* lookup the variable in question */
|
||||||
if (isdigit(var[0])) {
|
if (isdigit(var[0])) {
|
||||||
/* handle_dollar() should have vetted var for us */
|
/* parse_dollar() should have vetted var for us */
|
||||||
i = xatoi_u(var);
|
i = xatoi_u(var);
|
||||||
if (i < G.global_argc)
|
if (i < G.global_argc)
|
||||||
val = G.global_argv[i];
|
val = G.global_argv[i];
|
||||||
@ -4545,11 +4547,11 @@ static void debug_print_tree(struct pipe *pi, int lvl)
|
|||||||
fprintf(stderr, " group %s: (argv=%p)%s%s\n",
|
fprintf(stderr, " group %s: (argv=%p)%s%s\n",
|
||||||
CMDTYPE[command->cmd_type],
|
CMDTYPE[command->cmd_type],
|
||||||
argv
|
argv
|
||||||
#if !BB_MMU
|
# if !BB_MMU
|
||||||
, " group_as_string:", command->group_as_string
|
, " group_as_string:", command->group_as_string
|
||||||
#else
|
# else
|
||||||
, "", ""
|
, "", ""
|
||||||
#endif
|
# endif
|
||||||
);
|
);
|
||||||
debug_print_tree(command->group, lvl+1);
|
debug_print_tree(command->group, lvl+1);
|
||||||
prn++;
|
prn++;
|
||||||
@ -5988,18 +5990,18 @@ static int add_till_closing_bracket(o_string *dest, struct in_str *input, unsign
|
|||||||
|
|
||||||
/* Return code: 0 for OK, 1 for syntax error */
|
/* Return code: 0 for OK, 1 for syntax error */
|
||||||
#if BB_MMU
|
#if BB_MMU
|
||||||
#define handle_dollar(as_string, dest, input) \
|
#define parse_dollar(as_string, dest, input) \
|
||||||
handle_dollar(dest, input)
|
parse_dollar(dest, input)
|
||||||
#define as_string NULL
|
#define as_string NULL
|
||||||
#endif
|
#endif
|
||||||
static int handle_dollar(o_string *as_string,
|
static int parse_dollar(o_string *as_string,
|
||||||
o_string *dest,
|
o_string *dest,
|
||||||
struct in_str *input)
|
struct in_str *input)
|
||||||
{
|
{
|
||||||
int ch = i_peek(input); /* first character after the $ */
|
int ch = i_peek(input); /* first character after the $ */
|
||||||
unsigned char quote_mask = dest->o_escape ? 0x80 : 0;
|
unsigned char quote_mask = dest->o_escape ? 0x80 : 0;
|
||||||
|
|
||||||
debug_printf_parse("handle_dollar entered: ch='%c'\n", ch);
|
debug_printf_parse("parse_dollar entered: ch='%c'\n", ch);
|
||||||
if (isalpha(ch)) {
|
if (isalpha(ch)) {
|
||||||
ch = i_getch(input);
|
ch = i_getch(input);
|
||||||
nommu_addchr(as_string, ch);
|
nommu_addchr(as_string, ch);
|
||||||
@ -6047,7 +6049,7 @@ static int handle_dollar(o_string *as_string,
|
|||||||
if (!strchr(_SPECIAL_VARS_STR, ch) && !isalnum(ch)) { /* not one of those */
|
if (!strchr(_SPECIAL_VARS_STR, ch) && !isalnum(ch)) { /* not one of those */
|
||||||
bad_dollar_syntax:
|
bad_dollar_syntax:
|
||||||
syntax_error_unterm_str("${name}");
|
syntax_error_unterm_str("${name}");
|
||||||
debug_printf_parse("handle_dollar return 1: unterminated ${name}\n");
|
debug_printf_parse("parse_dollar return 1: unterminated ${name}\n");
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
ch |= quote_mask;
|
ch |= quote_mask;
|
||||||
@ -6129,13 +6131,11 @@ static int handle_dollar(o_string *as_string,
|
|||||||
if (!BB_MMU)
|
if (!BB_MMU)
|
||||||
pos = dest->length;
|
pos = dest->length;
|
||||||
add_till_closing_bracket(dest, input, ')' | DOUBLE_CLOSE_CHAR_FLAG);
|
add_till_closing_bracket(dest, input, ')' | DOUBLE_CLOSE_CHAR_FLAG);
|
||||||
#if !BB_MMU
|
|
||||||
if (as_string) {
|
if (as_string) {
|
||||||
o_addstr(as_string, dest->data + pos);
|
o_addstr(as_string, dest->data + pos);
|
||||||
o_addchr(as_string, ')');
|
o_addchr(as_string, ')');
|
||||||
o_addchr(as_string, ')');
|
o_addchr(as_string, ')');
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
o_addchr(dest, SPECIAL_VAR_SYMBOL);
|
o_addchr(dest, SPECIAL_VAR_SYMBOL);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -6146,12 +6146,10 @@ static int handle_dollar(o_string *as_string,
|
|||||||
if (!BB_MMU)
|
if (!BB_MMU)
|
||||||
pos = dest->length;
|
pos = dest->length;
|
||||||
add_till_closing_bracket(dest, input, ')');
|
add_till_closing_bracket(dest, input, ')');
|
||||||
#if !BB_MMU
|
|
||||||
if (as_string) {
|
if (as_string) {
|
||||||
o_addstr(as_string, dest->data + pos);
|
o_addstr(as_string, dest->data + pos);
|
||||||
o_addchr(as_string, ')');
|
o_addchr(as_string, ')');
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
o_addchr(dest, SPECIAL_VAR_SYMBOL);
|
o_addchr(dest, SPECIAL_VAR_SYMBOL);
|
||||||
# endif
|
# endif
|
||||||
break;
|
break;
|
||||||
@ -6174,7 +6172,7 @@ static int handle_dollar(o_string *as_string,
|
|||||||
default:
|
default:
|
||||||
o_addQchr(dest, '$');
|
o_addQchr(dest, '$');
|
||||||
}
|
}
|
||||||
debug_printf_parse("handle_dollar return 0\n");
|
debug_printf_parse("parse_dollar return 0\n");
|
||||||
return 0;
|
return 0;
|
||||||
#undef as_string
|
#undef as_string
|
||||||
}
|
}
|
||||||
@ -6237,9 +6235,9 @@ static int parse_stream_dquoted(o_string *as_string,
|
|||||||
goto again;
|
goto again;
|
||||||
}
|
}
|
||||||
if (ch == '$') {
|
if (ch == '$') {
|
||||||
if (handle_dollar(as_string, dest, input) != 0) {
|
if (parse_dollar(as_string, dest, input) != 0) {
|
||||||
debug_printf_parse("parse_stream_dquoted return 1: "
|
debug_printf_parse("parse_stream_dquoted return 1: "
|
||||||
"handle_dollar returned non-0\n");
|
"parse_dollar returned non-0\n");
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
goto again;
|
goto again;
|
||||||
@ -6602,9 +6600,9 @@ static struct pipe *parse_stream(char **pstring,
|
|||||||
#endif
|
#endif
|
||||||
break;
|
break;
|
||||||
case '$':
|
case '$':
|
||||||
if (handle_dollar(&ctx.as_string, &dest, input) != 0) {
|
if (parse_dollar(&ctx.as_string, &dest, input) != 0) {
|
||||||
debug_printf_parse("parse_stream parse error: "
|
debug_printf_parse("parse_stream parse error: "
|
||||||
"handle_dollar returned non-0\n");
|
"parse_dollar returned non-0\n");
|
||||||
goto parse_error;
|
goto parse_error;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -6630,19 +6628,16 @@ static struct pipe *parse_stream(char **pstring,
|
|||||||
break;
|
break;
|
||||||
#if ENABLE_HUSH_TICK
|
#if ENABLE_HUSH_TICK
|
||||||
case '`': {
|
case '`': {
|
||||||
#if !BB_MMU
|
unsigned pos;
|
||||||
int pos;
|
|
||||||
#endif
|
|
||||||
o_addchr(&dest, SPECIAL_VAR_SYMBOL);
|
o_addchr(&dest, SPECIAL_VAR_SYMBOL);
|
||||||
o_addchr(&dest, '`');
|
o_addchr(&dest, '`');
|
||||||
#if !BB_MMU
|
|
||||||
pos = dest.length;
|
pos = dest.length;
|
||||||
#endif
|
|
||||||
add_till_backquote(&dest, input);
|
add_till_backquote(&dest, input);
|
||||||
#if !BB_MMU
|
# if !BB_MMU
|
||||||
o_addstr(&ctx.as_string, dest.data + pos);
|
o_addstr(&ctx.as_string, dest.data + pos);
|
||||||
o_addchr(&ctx.as_string, '`');
|
o_addchr(&ctx.as_string, '`');
|
||||||
#endif
|
# endif
|
||||||
o_addchr(&dest, SPECIAL_VAR_SYMBOL);
|
o_addchr(&dest, SPECIAL_VAR_SYMBOL);
|
||||||
//debug_printf_subst("SUBST RES3 '%s'\n", dest.data + pos);
|
//debug_printf_subst("SUBST RES3 '%s'\n", dest.data + pos);
|
||||||
break;
|
break;
|
||||||
|
Loading…
Reference in New Issue
Block a user