Index: busybox-1.4.2/editors/awk.c =================================================================== --- busybox-1.4.2.orig/editors/awk.c 2007-06-04 13:21:32.083099296 +0200 +++ busybox-1.4.2/editors/awk.c 2007-06-04 13:21:35.202625056 +0200 @@ -2639,14 +2639,13 @@ int awk_main(int argc, char **argv) { - unsigned opt; - char *opt_F, *opt_v, *opt_W; int i, j, flen; var *v; var tv; char **envp; char *vnames = (char *)vNames; /* cheat */ char *vvalues = (char *)vValues; + int c; /* Undo busybox.c, or else strtod may eat ','! This breaks parsing: * $1,$2 == '$1,' '$2', NOT '$1' ',' '$2' */ @@ -2694,40 +2693,54 @@ free(s); } - opt = getopt32(argc, argv, "F:v:f:W:", &opt_F, &opt_v, &programname, &opt_W); - argv += optind; - argc -= optind; - if (opt & 0x1) setvar_s(V[FS], opt_F); // -F - if (opt & 0x2) if (!is_assignment(opt_v)) bb_show_usage(); // -v - if (opt & 0x4) { // -f - char *s = s; /* die, gcc, die */ - FILE *from_file = afopen(programname, "r"); - /* one byte is reserved for some trick in next_token */ - if (fseek(from_file, 0, SEEK_END) == 0) { - flen = ftell(from_file); - s = xmalloc(flen + 4); - fseek(from_file, 0, SEEK_SET); - i = 1 + fread(s + 1, 1, flen, from_file); - } else { - for (i = j = 1; j > 0; i += j) { - s = xrealloc(s, i + 4096); - j = fread(s + i, 1, 4094, from_file); + programname = NULL; + while((c = getopt(argc, argv, "F:v:f:W:")) != EOF) { + switch (c) { + case 'F': + setvar_s(V[FS], optarg); + break; + case 'v': + if (! is_assignment(optarg)) + bb_show_usage(); + break; + case 'f': { + FILE *F = afopen(programname = optarg, "r"); + char *s = NULL; + /* one byte is reserved for some trick in next_token */ + if (fseek(F, 0, SEEK_END) == 0) { + flen = ftell(F); + s = (char *)xmalloc(flen+4); + fseek(F, 0, SEEK_SET); + i = 1 + fread(s+1, 1, flen, F); + } else { + for (i=j=1; j>0; i+=j) { + s = (char *)xrealloc(s, i+4096); + j = fread(s+i, 1, 4094, F); + } + } + s[i] = '\0'; + fclose(F); + parse_program(s+1); + free(s); + break; } + case 'W': + bb_error_msg("Warning: unrecognized option '-W %s' ignored\n", optarg); + break; + + default: + bb_show_usage(); } - s[i] = '\0'; - fclose(from_file); - parse_program(s + 1); - free(s); - } else { // no -f: take program from 1st parameter - if (!argc) - bb_show_usage(); + } + argc -= optind; + argv += optind; + + if (!programname) { programname = "cmd. line"; parse_program(*argv++); argc--; } - if (opt & 0x8) // -W - bb_error_msg("warning: unrecognized option '-W %s' ignored", opt_W); - + /* fill in ARGV array */ setvar_i(V[ARGC], argc + 1); setari_u(V[ARGV], 0, "awk");