Patch from Shaun Jackman to detect "name=value" variable assignments. Random
cleanup at the end by me to make some unrelated #ifdefs go away...
This commit is contained in:
parent
f946379599
commit
68286770b6
19
shell/lash.c
19
shell/lash.c
@ -1182,9 +1182,12 @@ static int parse_command(char **command_ptr, struct job *job, int *inbg)
|
|||||||
static int pseudo_exec(struct child_prog *child)
|
static int pseudo_exec(struct child_prog *child)
|
||||||
{
|
{
|
||||||
struct built_in_command *x;
|
struct built_in_command *x;
|
||||||
#ifdef CONFIG_FEATURE_SH_STANDALONE_SHELL
|
|
||||||
char *name;
|
/* Check if the command sets an environment variable. */
|
||||||
#endif
|
if( strchr(child->argv[0], '=') != NULL ) {
|
||||||
|
child->argv[1] = child->argv[0];
|
||||||
|
_exit(builtin_export(child));
|
||||||
|
}
|
||||||
|
|
||||||
/* Check if the command matches any of the non-forking builtins.
|
/* Check if the command matches any of the non-forking builtins.
|
||||||
* Depending on context, this might be redundant. But it's
|
* Depending on context, this might be redundant. But it's
|
||||||
@ -1204,7 +1207,7 @@ static int pseudo_exec(struct child_prog *child)
|
|||||||
_exit (x->function(child));
|
_exit (x->function(child));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#ifdef CONFIG_FEATURE_SH_STANDALONE_SHELL
|
|
||||||
/* Check if the command matches any busybox internal
|
/* Check if the command matches any busybox internal
|
||||||
* commands ("applets") here. Following discussions from
|
* commands ("applets") here. Following discussions from
|
||||||
* November 2000 on busybox@busybox.net, don't use
|
* November 2000 on busybox@busybox.net, don't use
|
||||||
@ -1216,17 +1219,15 @@ static int pseudo_exec(struct child_prog *child)
|
|||||||
* /bin/foo invocation will fork and exec /bin/foo, even if
|
* /bin/foo invocation will fork and exec /bin/foo, even if
|
||||||
* /bin/foo is a symlink to busybox.
|
* /bin/foo is a symlink to busybox.
|
||||||
*/
|
*/
|
||||||
name = child->argv[0];
|
|
||||||
|
|
||||||
{
|
if (ENABLE_FEATURE_SH_STANDALONE_SHELL) {
|
||||||
char **argv_l = child->argv;
|
char **argv_l = child->argv;
|
||||||
int argc_l;
|
int argc_l;
|
||||||
|
|
||||||
for(argc_l=0;*argv_l!=NULL; argv_l++, argc_l++);
|
for(argc_l=0; *argv_l; argv_l++, argc_l++);
|
||||||
optind = 1;
|
optind = 1;
|
||||||
run_applet_by_name(name, argc_l, child->argv);
|
run_applet_by_name(child->argv[0], argc_l, child->argv);
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
execvp(child->argv[0], child->argv);
|
execvp(child->argv[0], child->argv);
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user