diff options
author | Bernhard Reutner-Fischer | 2006-08-20 17:35:13 +0000 |
---|---|---|
committer | Bernhard Reutner-Fischer | 2006-08-20 17:35:13 +0000 |
commit | d591a360d39f9bca3479b913fe4c5773965d18cf (patch) | |
tree | 994b43e608bc4640dff7d1bd333938229b874d82 /shell/lash.c | |
parent | 13068a4fdbe558daea85820fec663db3536aacff (diff) | |
download | busybox-d591a360d39f9bca3479b913fe4c5773965d18cf.zip busybox-d591a360d39f9bca3479b913fe4c5773965d18cf.tar.gz |
- merge -r15463:15564 from busybox_scratch branch through these changesets:
------------------------------------------------------------------------
r15465 | aldot | 2006-06-21 20:48:06 +0200 (Wed, 21 Jun 2006) | 3 lines
- use CONFIG_BUSYBOX_EXEC_PATH as before it one was broken by a recent revert.
- use xchdir() since all is invain if it fails there anyways, supposedly
------------------------------------------------------------------------
r15466 | aldot | 2006-06-21 20:55:16 +0200 (Wed, 21 Jun 2006) | 2 lines
- adjust docs to take CONFIG_BUSYBOX_EXEC_PATH into account.
------------------------------------------------------------------------
r15467 | aldot | 2006-06-21 21:31:24 +0200 (Wed, 21 Jun 2006) | 18 lines
- partial fallout of my TREE_USED touchup against gcc-4.2: rip unused vars, save
s 144 bytes
text data bss dec hex filename
862434 10156 645924 1518514 172bb2 busybox.old
862322 10156 645892 1518370 172b22 busybox
function old new delta
z_len 4 - -4
textend 4 - -4
part_nb 4 - -4
insize 4 - -4
ifile_size 4 - -4
do_link 4 - -4
new_text 70 60 -10
ipaddr_list_link 33 23 -10
gzip_main 898 822 -76
------------------------------------------------------------------------------
(add/remove: 0/6 grow/shrink: 0/3 up/down: 0/-120) Total: -120 bytes
------------------------------------------------------------------------
r15468 | aldot | 2006-06-21 21:43:05 +0200 (Wed, 21 Jun 2006) | 19 lines
- remove useless global exports
function old new delta
rpm_main 940 1601 +661
rpm_getstring 107 112 +5
rpm_getint 148 153 +5
loop_through_files 103 106 +3
fileaction_dobackup 115 113 -2
fileaction_list 5 - -5
rpm_getcount 42 - -42
extract_cpio_gz 161 - -161
rpm_gettags 504 - -504
------------------------------------------------------------------------------
(add/remove: 0/4 grow/shrink: 4/1 up/down: 674/-714) Total: -40 bytes
text data bss dec hex filename
862322 10156 645892 1518370 172b22 busybox.old
862290 10156 645892 1518338 172b02 busybox
------------------------------------------------------------------------
r15555 | aldot | 2006-06-30 14:10:11 +0200 (Fri, 30 Jun 2006) | 22 lines
- shrink syslog a little bit, move a big buffer (for 'line') off the bss, fold s
emaphore stuff into single caller manually.
stats:
function old new delta
logMessage 395 427 +32
message 1245 1257 +12
opts - 4 +4
small 1 - -1
local_logging 4 - -4
doRemoteLog 4 - -4
circular_logging 4 - -4
syslogd_main 1299 1285 -14
static.res 36 16 -20
.rodata 186650 186586 -64
static.line 1025 - -1025
------------------------------------------------------------------------------
(add/remove: 1/5 grow/shrink: 2/3 up/down: 48/-1136) Total: -1088 bytes
cow@s37:~/src/busybox_scratch$ size sysklogd/syslogd.o{.orig,}
text data bss dec hex filename
3723 348 5242 9313 2461 sysklogd/syslogd.o.orig
3697 348 4188 8233 2029 sysklogd/syslogd.o
==============================================================================
Overall bloatcheck for the changeset mentioned above:
function old new delta
rpm_main 953 1608 +655
logMessage 395 427 +32
message 1245 1257 +12
opts - 4 +4
rpm_getstring 107 110 +3
rpm_getint 148 151 +3
loop_through_files 103 104 +1
small 1 - -1
fileaction_dobackup 115 113 -2
z_len 4 - -4
textend 4 - -4
part_nb 4 - -4
local_logging 4 - -4
insize 4 - -4
ifile_size 4 - -4
do_link 4 - -4
doRemoteLog 4 - -4
circular_logging 4 - -4
fileaction_list 5 - -5
new_text 70 60 -10
ipaddr_list_link 33 23 -10
clear_bufs 31 21 -10
syslogd_main 1287 1273 -14
builtin_help 190 176 -14
static.res 36 16 -20
builtin_source 229 199 -30
rpm_getcount 42 - -42
gzip_main 842 786 -56
.rodata 227176 227112 -64
lash_main 609 527 -82
busy_loop 3883 3739 -144
extract_cpio_gz 155 - -155
rpm_gettags 501 - -501
static.line 1025 - -1025
------------------------------------------------------------------------------
(add/remove: 1/15 grow/shrink: 6/12 up/down: 710/-2221) Total: -1511 bytes
Diffstat (limited to 'shell/lash.c')
-rw-r--r-- | shell/lash.c | 126 |
1 files changed, 54 insertions, 72 deletions
diff --git a/shell/lash.c b/shell/lash.c index eae949e..fd6bea1 100644 --- a/shell/lash.c +++ b/shell/lash.c @@ -54,6 +54,9 @@ enum { ELSE_EXP_CONTEXT = 0x10 }; +#define LASH_OPT_DONE (1) +#define LASH_OPT_SAW_QUOTE (2) + #ifdef CONFIG_LASH_PIPE_N_REDIRECTS struct redir_struct { enum redir_type type; /* type of redirection */ @@ -154,7 +157,7 @@ static int shell_context; /* Type prompt trigger (PS1 or PS2) */ /* Globals that are static to this file */ static const char *cwd; -static char *local_pending_command = NULL; +static char *local_pending_command; static struct jobset job_list = { NULL, NULL }; static int argc; static char **argv; @@ -176,7 +179,7 @@ static inline void debug_printf(const char *format, ...) va_end(args); } #else -static inline void debug_printf(const char *format, ...) { } +static inline void debug_printf(const char ATTRIBUTE_UNUSED *format, ...) { } #endif /* @@ -304,12 +307,12 @@ static int builtin_fg_bg(struct child_prog *child) } /* built-in 'help' handler */ -static int builtin_help(struct child_prog *dummy) +static int builtin_help(struct child_prog ATTRIBUTE_UNUSED *dummy) { struct built_in_command *x; - printf("\nBuilt-in commands:\n"); - printf("-------------------\n"); + printf("\nBuilt-in commands:\n" + "-------------------\n"); for (x = bltins; x->cmd; x++) { if (x->descr==NULL) continue; @@ -320,7 +323,7 @@ static int builtin_help(struct child_prog *dummy) continue; printf("%s\t%s\n", x->cmd, x->descr); } - printf("\n\n"); + putchar('\n'); return EXIT_SUCCESS; } @@ -343,7 +346,7 @@ static int builtin_jobs(struct child_prog *child) /* built-in 'pwd' handler */ -static int builtin_pwd(struct child_prog *dummy) +static int builtin_pwd(struct child_prog ATTRIBUTE_UNUSED *dummy) { cwd = xgetcwd((char *)cwd); if (!cwd) @@ -386,7 +389,7 @@ static int builtin_export(struct child_prog *child) /* built-in 'read VAR' handler */ static int builtin_read(struct child_prog *child) { - int res = 0, len, newlen; + int res = 0, len; char *s; char string[MAX_READ]; @@ -397,16 +400,16 @@ static int builtin_read(struct child_prog *child) string[len++] = '='; string[len] = '\0'; fgets(&string[len], sizeof(string) - len, stdin); /* read string */ - newlen = strlen(string); - if(newlen > len) - string[--newlen] = '\0'; /* chomp trailing newline */ + res = strlen(string); + if (res > len) + string[--res] = '\0'; /* chomp trailing newline */ /* ** string should now contain "VAR=<value>" ** copy it (putenv() won't do that, so we must make sure ** the string resides in a static buffer!) */ res = -1; - if((s = strdup(string))) + if ((s = strdup(string))) res = putenv(s); if (res) bb_perror_msg("read"); @@ -423,12 +426,8 @@ static int builtin_source(struct child_prog *child) FILE *input; int status; - if (child->argv[1] == NULL) - return EXIT_FAILURE; - - input = fopen(child->argv[1], "r"); + input = bb_wfopen(child->argv[1], "r"); if (!input) { - printf( "Couldn't open file '%s'\n", child->argv[1]); return EXIT_FAILURE; } @@ -635,7 +634,7 @@ static inline void setup_prompt_string(char **prompt_str) if (shell_context == 0) { free(PS1); PS1=xmalloc(strlen(cwd)+4); - sprintf(PS1, "%s %s", cwd, ( geteuid() != 0 ) ? "$ ":"# "); + sprintf(PS1, "%s %c ", cwd, ( geteuid() != 0 ) ? '$': '#'); *prompt_str = PS1; } else { *prompt_str = PS2; @@ -688,20 +687,18 @@ static int get_command(FILE * source, char *command) static char * strsep_space( char *string, int * ix) { - char *token; - /* Short circuit the trivial case */ if ( !string || ! string[*ix]) return NULL; /* Find the end of the token. */ - while( string[*ix] && !isspace(string[*ix]) ) { + while (string[*ix] && !isspace(string[*ix]) ) { (*ix)++; } /* Find the end of any whitespace trailing behind * the token and let that be part of the token */ - while( string[*ix] && isspace(string[*ix]) ) { + while (string[*ix] && (isspace)(string[*ix]) ) { (*ix)++; } @@ -710,9 +707,7 @@ static char * strsep_space( char *string, int * ix) return NULL; } - token = xstrndup(string, *ix); - - return token; + return xstrndup(string, *ix); } static int expand_arguments(char *command) @@ -721,7 +716,7 @@ static int expand_arguments(char *command) expand_t expand_result; char *tmpcmd, *cmd, *cmd_copy; char *src, *dst, *var; - const char *out_of_space = "out of space during expansion"; + const char * const out_of_space = "out of space during expansion"; int flags = GLOB_NOCHECK #ifdef GLOB_BRACE | GLOB_BRACE @@ -846,7 +841,7 @@ static int expand_arguments(char *command) num_skip_chars=1; } else { src=dst+1; - while(isalnum(*src) || *src=='_') src++; + while((isalnum)(*src) || *src=='_') src++; } if (src == NULL) { src = dst+dstlen; @@ -890,10 +885,9 @@ static int parse_command(char **command_ptr, struct job *job, int *inbg) char *command; char *return_command = NULL; char *src, *buf; - int argc_l = 0; - int done = 0; + int argc_l; + int flag; int argv_alloced; - int saw_quote = 0; char quote = '\0'; struct child_prog *prog; #ifdef CONFIG_LASH_PIPE_N_REDIRECTS @@ -902,8 +896,7 @@ static int parse_command(char **command_ptr, struct job *job, int *inbg) #endif /* skip leading white space */ - while (**command_ptr && isspace(**command_ptr)) - (*command_ptr)++; + *command_ptr = skip_whitespace(*command_ptr); /* this handles empty lines or leading '#' characters */ if (!**command_ptr || (**command_ptr == '#')) { @@ -937,9 +930,10 @@ static int parse_command(char **command_ptr, struct job *job, int *inbg) prog->argv = xmalloc(sizeof(*prog->argv) * argv_alloced); prog->argv[0] = job->cmdbuf; + flag = argc_l = 0; buf = command; src = *command_ptr; - while (*src && !done) { + while (*src && !(flag & LASH_OPT_DONE)) { if (quote == *src) { quote = '\0'; } else if (quote) { @@ -960,7 +954,7 @@ static int parse_command(char **command_ptr, struct job *job, int *inbg) *src == ']') *buf++ = '\\'; *buf++ = *src; } else if (isspace(*src)) { - if (*prog->argv[argc_l] || saw_quote) { + if (*prog->argv[argc_l] || flag & LASH_OPT_SAW_QUOTE) { buf++, argc_l++; /* +1 here leaves room for the NULL which ends argv */ if ((argc_l + 1) == argv_alloced) { @@ -970,21 +964,21 @@ static int parse_command(char **command_ptr, struct job *job, int *inbg) argv_alloced); } prog->argv[argc_l] = buf; - saw_quote = 0; + flag ^= LASH_OPT_SAW_QUOTE; } } else switch (*src) { case '"': case '\'': quote = *src; - saw_quote = 1; + flag |= LASH_OPT_SAW_QUOTE; break; case '#': /* comment */ if (*(src-1)== '$') *buf++ = *src; else - done = 1; + flag |= LASH_OPT_DONE; break; #ifdef CONFIG_LASH_PIPE_N_REDIRECTS @@ -1027,8 +1021,7 @@ static int parse_command(char **command_ptr, struct job *job, int *inbg) /* This isn't POSIX sh compliant. Oh well. */ chptr = src; - while (isspace(*chptr)) - chptr++; + chptr = skip_whitespace(chptr); if (!*chptr) { bb_error_msg("file name expected after %c", *(src-1)); @@ -1047,13 +1040,10 @@ static int parse_command(char **command_ptr, struct job *job, int *inbg) case '|': /* pipe */ /* finish this command */ - if (*prog->argv[argc_l] || saw_quote) + if (*prog->argv[argc_l] || flag & LASH_OPT_SAW_QUOTE) argc_l++; if (!argc_l) { - bb_error_msg("empty command in pipe"); - free_job(job); - job->num_progs=0; - return 1; + goto empty_command_in_pipe; } prog->argv[argc_l] = NULL; @@ -1073,10 +1063,10 @@ static int parse_command(char **command_ptr, struct job *job, int *inbg) prog->argv[0] = ++buf; src++; - while (*src && isspace(*src)) - src++; + src = skip_whitespace(src); if (!*src) { +empty_command_in_pipe: bb_error_msg("empty command in pipe"); free_job(job); job->num_progs=0; @@ -1090,9 +1080,10 @@ static int parse_command(char **command_ptr, struct job *job, int *inbg) #ifdef CONFIG_LASH_JOB_CONTROL case '&': /* background */ *inbg = 1; + /* fallthrough */ #endif case ';': /* multiple commands */ - done = 1; + flag |= LASH_OPT_DONE; return_command = *command_ptr + (src - *command_ptr) + 1; break; @@ -1113,7 +1104,7 @@ static int parse_command(char **command_ptr, struct job *job, int *inbg) src++; } - if (*prog->argv[argc_l] || saw_quote) { + if (*prog->argv[argc_l] || flag & LASH_OPT_SAW_QUOTE) { argc_l++; } if (!argc_l) { @@ -1295,7 +1286,7 @@ static int run_command(struct job *newjob, int inbg, int outpipe[2]) signal(SIGTTOU, SIG_DFL); signal(SIGCHLD, SIG_DFL); - // Close all open filehandles. + /* Close all open filehandles. */ while(close_me_list) close((long)llist_pop(&close_me_list)); if (outpipe[1]!=-1) { @@ -1512,14 +1503,13 @@ static inline void setup_job_control(void) int lash_main(int argc_l, char **argv_l) { - int opt, interactive=FALSE; + unsigned long opt; FILE *input = stdin; argc = argc_l; argv = argv_l; /* These variables need re-initializing when recursing */ last_jobid = 0; - local_pending_command = NULL; close_me_list = NULL; job_list.head = NULL; job_list.fg = NULL; @@ -1532,27 +1522,18 @@ int lash_main(int argc_l, char **argv_l) llist_add_to(&close_me_list, (void *)(long)fileno(prof_input)); /* Now run the file */ busy_loop(prof_input); - fclose(prof_input); + bb_fclose_nonstdin(prof_input); llist_pop(&close_me_list); } } - while ((opt = getopt(argc_l, argv_l, "cxi")) > 0) { - switch (opt) { - case 'c': - input = NULL; - if (local_pending_command != 0) - bb_error_msg_and_die("multiple -c arguments"); - local_pending_command = xstrdup(argv[optind]); - optind++; - argv = argv+optind; - break; - case 'i': - interactive++; - break; - default: - bb_show_usage(); - } + opt = bb_getopt_ulflags(argc_l, argv_l, "+ic:", &local_pending_command); +#define LASH_OPT_i (1<<0) +#define LASH_OPT_c (1<<2) + if (opt & LASH_OPT_c) { + input = NULL; + optind++; + argv += optind; } /* A shell is interactive if the `-i' flag was given, or if all of * the following conditions are met: @@ -1564,14 +1545,15 @@ int lash_main(int argc_l, char **argv_l) if (argv[optind]==NULL && input==stdin && isatty(STDIN_FILENO) && isatty(STDOUT_FILENO)) { - interactive++; + opt |= LASH_OPT_i; } setup_job_control(); - if (interactive) { + if (opt & LASH_OPT_i) { /* Looks like they want an interactive shell */ if (!ENABLE_FEATURE_SH_EXTRA_QUIET) { - printf( "\n\n%s Built-in shell (lash)\n", BB_BANNER); - printf( "Enter 'help' for a list of built-in commands.\n\n"); + printf("\n\n%s Built-in shell (lash)\n" + "Enter 'help' for a list of built-in commands.\n\n", + BB_BANNER); } } else if (!local_pending_command && argv[optind]) { //printf( "optind=%d argv[optind]='%s'\n", optind, argv[optind]); |