mirror of
https://github.com/sheumann/hush.git
synced 2025-01-02 09:31:26 +00:00
hush: make pun_pipe loop clearer; fix "cmd | var=cmd
| cmd" handling
function old new delta free_strings - 38 +38 pseudo_exec_argv 161 171 +10 free_pipe 227 205 -22 ------------------------------------------------------------------------------ (add/remove: 1/0 grow/shrink: 1/1 up/down: 48/-22) Total: 26 bytes Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
This commit is contained in:
parent
6ac37da425
commit
889550b36b
44
shell/hush.c
44
shell/hush.c
@ -3713,11 +3713,17 @@ static NOINLINE void pseudo_exec_argv(nommu_save_t *nommu_save,
|
|||||||
{
|
{
|
||||||
char **new_env;
|
char **new_env;
|
||||||
|
|
||||||
/* Case when we are here: ... | var=val | ... */
|
|
||||||
if (!argv[assignment_cnt])
|
|
||||||
_exit(EXIT_SUCCESS);
|
|
||||||
|
|
||||||
new_env = expand_assignments(argv, assignment_cnt);
|
new_env = expand_assignments(argv, assignment_cnt);
|
||||||
|
|
||||||
|
if (!argv[assignment_cnt]) {
|
||||||
|
/* Case when we are here: ... | var=val | ...
|
||||||
|
* (note that we do not exit early, i.e., do not optimize out
|
||||||
|
* expand_assignments(): think about ... | var=`sleep 1` | ...
|
||||||
|
*/
|
||||||
|
free_strings(new_env);
|
||||||
|
_exit(EXIT_SUCCESS);
|
||||||
|
}
|
||||||
|
|
||||||
#if BB_MMU
|
#if BB_MMU
|
||||||
set_vars_and_save_old(new_env);
|
set_vars_and_save_old(new_env);
|
||||||
free(new_env); /* optional */
|
free(new_env); /* optional */
|
||||||
@ -3727,6 +3733,7 @@ static NOINLINE void pseudo_exec_argv(nommu_save_t *nommu_save,
|
|||||||
nommu_save->new_env = new_env;
|
nommu_save->new_env = new_env;
|
||||||
nommu_save->old_vars = set_vars_and_save_old(new_env);
|
nommu_save->old_vars = set_vars_and_save_old(new_env);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (argv_expanded) {
|
if (argv_expanded) {
|
||||||
argv = argv_expanded;
|
argv = argv_expanded;
|
||||||
} else {
|
} else {
|
||||||
@ -4145,8 +4152,9 @@ static int checkjobs_and_fg_shell(struct pipe* fg_pipe)
|
|||||||
static NOINLINE int run_pipe(struct pipe *pi)
|
static NOINLINE int run_pipe(struct pipe *pi)
|
||||||
{
|
{
|
||||||
static const char *const null_ptr = NULL;
|
static const char *const null_ptr = NULL;
|
||||||
int i;
|
|
||||||
int nextin;
|
int cmd_no;
|
||||||
|
int next_infd;
|
||||||
struct command *command;
|
struct command *command;
|
||||||
char **argv_expanded;
|
char **argv_expanded;
|
||||||
char **argv;
|
char **argv;
|
||||||
@ -4160,7 +4168,7 @@ static NOINLINE int run_pipe(struct pipe *pi)
|
|||||||
|
|
||||||
IF_HUSH_JOB(pi->pgrp = -1;)
|
IF_HUSH_JOB(pi->pgrp = -1;)
|
||||||
pi->stopped_cmds = 0;
|
pi->stopped_cmds = 0;
|
||||||
command = &(pi->cmds[0]);
|
command = &pi->cmds[0];
|
||||||
argv_expanded = NULL;
|
argv_expanded = NULL;
|
||||||
|
|
||||||
if (pi->num_cmds != 1
|
if (pi->num_cmds != 1
|
||||||
@ -4358,9 +4366,10 @@ static NOINLINE int run_pipe(struct pipe *pi)
|
|||||||
|
|
||||||
/* Going to fork a child per each pipe member */
|
/* Going to fork a child per each pipe member */
|
||||||
pi->alive_cmds = 0;
|
pi->alive_cmds = 0;
|
||||||
nextin = 0;
|
next_infd = 0;
|
||||||
|
|
||||||
for (i = 0; i < pi->num_cmds; i++) {
|
cmd_no = 0;
|
||||||
|
while (cmd_no < pi->num_cmds) {
|
||||||
struct fd_pair pipefds;
|
struct fd_pair pipefds;
|
||||||
#if !BB_MMU
|
#if !BB_MMU
|
||||||
volatile nommu_save_t nommu_save;
|
volatile nommu_save_t nommu_save;
|
||||||
@ -4369,7 +4378,8 @@ static NOINLINE int run_pipe(struct pipe *pi)
|
|||||||
nommu_save.argv = NULL;
|
nommu_save.argv = NULL;
|
||||||
nommu_save.argv_from_re_execing = NULL;
|
nommu_save.argv_from_re_execing = NULL;
|
||||||
#endif
|
#endif
|
||||||
command = &(pi->cmds[i]);
|
command = &pi->cmds[cmd_no];
|
||||||
|
cmd_no++;
|
||||||
if (command->argv) {
|
if (command->argv) {
|
||||||
debug_printf_exec(": pipe member '%s' '%s'...\n",
|
debug_printf_exec(": pipe member '%s' '%s'...\n",
|
||||||
command->argv[0], command->argv[1]);
|
command->argv[0], command->argv[1]);
|
||||||
@ -4380,7 +4390,7 @@ static NOINLINE int run_pipe(struct pipe *pi)
|
|||||||
/* pipes are inserted between pairs of commands */
|
/* pipes are inserted between pairs of commands */
|
||||||
pipefds.rd = 0;
|
pipefds.rd = 0;
|
||||||
pipefds.wr = 1;
|
pipefds.wr = 1;
|
||||||
if ((i + 1) < pi->num_cmds)
|
if (cmd_no < pi->num_cmds)
|
||||||
xpiped_pair(pipefds);
|
xpiped_pair(pipefds);
|
||||||
|
|
||||||
command->pid = BB_MMU ? fork() : vfork();
|
command->pid = BB_MMU ? fork() : vfork();
|
||||||
@ -4413,7 +4423,7 @@ static NOINLINE int run_pipe(struct pipe *pi)
|
|||||||
if (open(bb_dev_null, O_RDONLY))
|
if (open(bb_dev_null, O_RDONLY))
|
||||||
xopen("/", O_RDONLY);
|
xopen("/", O_RDONLY);
|
||||||
} else {
|
} else {
|
||||||
xmove_fd(nextin, 0);
|
xmove_fd(next_infd, 0);
|
||||||
}
|
}
|
||||||
xmove_fd(pipefds.wr, 1);
|
xmove_fd(pipefds.wr, 1);
|
||||||
if (pipefds.rd > 1)
|
if (pipefds.rd > 1)
|
||||||
@ -4460,12 +4470,12 @@ static NOINLINE int run_pipe(struct pipe *pi)
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
if (i)
|
if (cmd_no > 1)
|
||||||
close(nextin);
|
close(next_infd);
|
||||||
if ((i + 1) < pi->num_cmds)
|
if (cmd_no < pi->num_cmds)
|
||||||
close(pipefds.wr);
|
close(pipefds.wr);
|
||||||
/* Pass read (output) pipe end to next iteration */
|
/* Pass read (output) pipe end to next iteration */
|
||||||
nextin = pipefds.rd;
|
next_infd = pipefds.rd;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!pi->alive_cmds) {
|
if (!pi->alive_cmds) {
|
||||||
@ -7153,7 +7163,7 @@ int hush_main(int argc, char **argv)
|
|||||||
#endif
|
#endif
|
||||||
case 'n':
|
case 'n':
|
||||||
case 'x':
|
case 'x':
|
||||||
if (!set_mode('-', opt))
|
if (set_mode('-', opt) == 0) /* no error */
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
#ifndef BB_VER
|
#ifndef BB_VER
|
||||||
|
Loading…
Reference in New Issue
Block a user