Add no-FPU ColdFire math_private.h.
[glibc.git] / posix / bug-getopt4.c
blob0956ca57fb2af7f03b3be092211c1ab2155ee025
1 /* BZ 11041 */
2 #include <getopt.h>
3 #include <unistd.h>
4 #include <stdio.h>
6 static const struct option opts[] =
8 { "alpha", optional_argument, NULL, 'a' },
9 { NULL, 0, NULL, 0 }
12 static int
13 one_test (const char *fmt, int argc, char *argv[], int n, int expected[n])
15 optind = 1;
17 int res = 0;
18 for (int i = 0; i < n; ++i)
20 rewind (stderr);
21 if (ftruncate (fileno (stderr), 0) != 0)
23 puts ("cannot truncate file");
24 return 1;
27 int c = getopt_long (argc, argv, fmt, opts, NULL);
28 if (c != expected[i])
30 printf ("%s: format '%s' test %d failed: expected '%c', got '%c'\n",
31 argv[0], fmt, i, expected[i], c);
32 res = 1;
34 else if (optarg != NULL)
36 printf ("%s: format '%s' test %d failed: optarg is \"%s\", not NULL\n",
37 argv[0], fmt, i, optarg);
38 res = 1;
40 if (ftell (stderr) != 0)
42 printf ("%s: format '%s' test %d failed: printed to stderr\n",
43 argv[0], fmt, i);
44 res = 1;
48 return res;
52 static int
53 do_test (void)
55 char *fname = tmpnam (NULL);
56 if (fname == NULL)
58 puts ("cannot generate name for temporary file");
59 return 1;
62 if (freopen (fname, "w+", stderr) == NULL)
64 puts ("cannot redirect stderr");
65 return 1;
68 remove (fname);
70 int ret = one_test ("W;", 2,
71 (char *[2]) { (char *) "bug-getopt4a", (char *) "--a" },
72 1, (int [1]) { 'a' });
74 ret |= one_test ("W;", 3,
75 (char *[3]) { (char *) "bug-getopt4b", (char *) "-W",
76 (char *) "a" },
77 1, (int [1]) { 'a' });
79 if (ret == 0)
80 puts ("all OK");
82 return ret;
85 #define TEST_FUNCTION do_test ()
86 #include "../test-skeleton.c"