about summary refs log tree commit diff
path: root/argp/bug-argp2.c
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@redhat.com>2010-04-04 11:28:36 -0700
committerUlrich Drepper <drepper@redhat.com>2010-04-04 11:28:36 -0700
commit7ebaec64a0171a54dbe9aedd95497b130458060e (patch)
tree0ec932906dcba4070448a29c9e686cb5d56e08e8 /argp/bug-argp2.c
parent8c6de69d00c6be60657ca0d763dda803172c6aab (diff)
downloadglibc-7ebaec64a0171a54dbe9aedd95497b130458060e.tar.gz
glibc-7ebaec64a0171a54dbe9aedd95497b130458060e.tar.xz
glibc-7ebaec64a0171a54dbe9aedd95497b130458060e.zip
Add test case for last argp bug.
Diffstat (limited to 'argp/bug-argp2.c')
-rw-r--r--argp/bug-argp2.c55
1 files changed, 55 insertions, 0 deletions
diff --git a/argp/bug-argp2.c b/argp/bug-argp2.c
new file mode 100644
index 0000000000..133e5cf6e8
--- /dev/null
+++ b/argp/bug-argp2.c
@@ -0,0 +1,55 @@
+#include <argp.h>
+#include <stdio.h>
+#include <stdlib.h>
+
+static struct argp_option argp_options[] = {
+  { "dstaddr", 'd', "ADDR", 0,
+    "set destination (peer) address to ADDR" },
+  { "peer", 'p', "ADDR", OPTION_ALIAS },
+  { NULL }
+};
+
+static error_t parse_opt (int key, char *arg, struct argp_state *state);
+
+static struct argp argp =
+{
+  argp_options, parse_opt
+};
+
+static int cnt;
+
+static int
+do_test (int argc, char *argv[])
+{
+  int remaining;
+  argp_parse (&argp, argc, argv, 0, &remaining, NULL);
+  return cnt != 4;
+}
+
+static error_t
+parse_opt (int key, char *arg, struct argp_state *state)
+{
+  switch (key)
+  {
+  case 'd':
+  case 'p':
+    printf ("got '%c' with argument '%s'\n", key, arg);
+    ++cnt;
+    break;
+  case 0:
+  case ARGP_KEY_END:
+  case ARGP_KEY_NO_ARGS:
+  case ARGP_KEY_INIT:
+  case ARGP_KEY_SUCCESS:
+  case ARGP_KEY_FINI:
+    // Ignore.
+    return ARGP_ERR_UNKNOWN;
+  default:
+    printf ("invalid key '%x'\n", key);
+    exit (1);
+  }
+  return 0;
+}
+
+#define TEST_FUNCTION do_test (argc, argv)
+#include "../test-skeleton.c"