refresh all package patches in the buildroot using quilt
[openwrt-10.03/.git] / package / busybox / patches / 400-revert_awk_getopt.patch
1 Index: busybox-1.4.2/editors/awk.c
2 ===================================================================
3 --- busybox-1.4.2.orig/editors/awk.c    2007-06-04 13:21:32.083099296 +0200
4 +++ busybox-1.4.2/editors/awk.c 2007-06-04 13:21:35.202625056 +0200
5 @@ -2639,14 +2639,13 @@
6  
7  int awk_main(int argc, char **argv)
8  {
9 -       unsigned opt;
10 -       char *opt_F, *opt_v, *opt_W;
11         int i, j, flen;
12         var *v;
13         var tv;
14         char **envp;
15         char *vnames = (char *)vNames; /* cheat */
16         char *vvalues = (char *)vValues;
17 +       int c;
18  
19         /* Undo busybox.c, or else strtod may eat ','! This breaks parsing:
20          * $1,$2 == '$1,' '$2', NOT '$1' ',' '$2' */
21 @@ -2694,40 +2693,54 @@
22                 free(s);
23         }
24  
25 -       opt = getopt32(argc, argv, "F:v:f:W:", &opt_F, &opt_v, &programname, &opt_W);
26 -       argv += optind;
27 -       argc -= optind;
28 -       if (opt & 0x1) setvar_s(V[FS], opt_F); // -F
29 -       if (opt & 0x2) if (!is_assignment(opt_v)) bb_show_usage(); // -v
30 -       if (opt & 0x4) { // -f
31 -               char *s = s; /* die, gcc, die */
32 -               FILE *from_file = afopen(programname, "r");
33 -               /* one byte is reserved for some trick in next_token */
34 -               if (fseek(from_file, 0, SEEK_END) == 0) {
35 -                       flen = ftell(from_file);
36 -                       s = xmalloc(flen + 4);
37 -                       fseek(from_file, 0, SEEK_SET);
38 -                       i = 1 + fread(s + 1, 1, flen, from_file);
39 -               } else {
40 -                       for (i = j = 1; j > 0; i += j) {
41 -                               s = xrealloc(s, i + 4096);
42 -                               j = fread(s + i, 1, 4094, from_file);
43 +       programname = NULL;
44 +       while((c = getopt(argc, argv, "F:v:f:W:")) != EOF) {
45 +               switch (c) {
46 +                       case 'F':
47 +                               setvar_s(V[FS], optarg);
48 +                               break;
49 +                       case 'v':
50 +                               if (! is_assignment(optarg))
51 +                                       bb_show_usage();
52 +                               break;
53 +                       case 'f': {
54 +                               FILE *F = afopen(programname = optarg, "r");
55 +                               char *s = NULL;
56 +                               /* one byte is reserved for some trick in next_token */
57 +                               if (fseek(F, 0, SEEK_END) == 0) {
58 +                                       flen = ftell(F);
59 +                                       s = (char *)xmalloc(flen+4);
60 +                                       fseek(F, 0, SEEK_SET);
61 +                                       i = 1 + fread(s+1, 1, flen, F);
62 +                               } else {
63 +                                       for (i=j=1; j>0; i+=j) {
64 +                                               s = (char *)xrealloc(s, i+4096);
65 +                                               j = fread(s+i, 1, 4094, F);
66 +                                       }
67 +                               }
68 +                               s[i] = '\0';
69 +                               fclose(F);
70 +                               parse_program(s+1);
71 +                               free(s);
72 +                               break;
73                         }
74 +                       case 'W':
75 +                               bb_error_msg("Warning: unrecognized option '-W %s' ignored\n", optarg);
76 +                               break;
77 +
78 +                       default:
79 +                               bb_show_usage();
80                 }
81 -               s[i] = '\0';
82 -               fclose(from_file);
83 -               parse_program(s + 1);
84 -               free(s);
85 -       } else { // no -f: take program from 1st parameter
86 -               if (!argc)
87 -                       bb_show_usage();
88 +       }
89 +       argc -= optind;
90 +       argv += optind;
91 +
92 +       if (!programname) {
93                 programname = "cmd. line";
94                 parse_program(*argv++);
95                 argc--;
96         }
97 -       if (opt & 0x8) // -W
98 -               bb_error_msg("warning: unrecognized option '-W %s' ignored", opt_W);
99 -
100 +       
101         /* fill in ARGV array */
102         setvar_i(V[ARGC], argc + 1);
103         setari_u(V[ARGV], 0, "awk");