about summary refs log tree commit diff
path: root/posix/bug-regex31.c
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@gmail.com>2010-10-11 22:46:44 -0400
committerUlrich Drepper <drepper@gmail.com>2010-10-11 22:46:44 -0400
commite9b9cbf5e9bdcda6f0b50456658bac748202dd70 (patch)
treef7c25be42fb102aa3f4d7d611e14ac6d84b82eca /posix/bug-regex31.c
parentef06edbee6463061a7f3dcbd2f56a625b41a4810 (diff)
downloadglibc-e9b9cbf5e9bdcda6f0b50456658bac748202dd70.tar.gz
glibc-e9b9cbf5e9bdcda6f0b50456658bac748202dd70.tar.xz
glibc-e9b9cbf5e9bdcda6f0b50456658bac748202dd70.zip
More regex memory leak fixes and tests.
Diffstat (limited to 'posix/bug-regex31.c')
-rw-r--r--posix/bug-regex31.c34
1 files changed, 27 insertions, 7 deletions
diff --git a/posix/bug-regex31.c b/posix/bug-regex31.c
index 2d5d6695d4..974e8603b9 100644
--- a/posix/bug-regex31.c
+++ b/posix/bug-regex31.c
@@ -3,14 +3,34 @@
 #include <stdio.h>
 #include <sys/types.h>
 
-int main()
+int
+main (void)
 {
- regex_t regex;
- int rc;
-
   mtrace ();
 
- if ((rc = regcomp (&regex, "([0]", REG_EXTENDED)))
-   printf ("Error %d (expected)\n", rc);
- return 0;
+  int res = 0;
+  char *buf = NULL;
+  size_t len = 0;
+  while (! feof (stdin))
+    {
+      ssize_t n = getline (&buf, &len, stdin);
+      if (n <= 0)
+	break;
+      if (buf[n - 1] == '\n')
+	buf[n - 1] = '\0';
+
+      regex_t regex;
+      int rc = regcomp (&regex, buf, REG_EXTENDED);
+      if (rc != 0)
+	printf ("%s: Error %d (expected)\n", buf, rc);
+      else
+	{
+	  printf ("%s: succeeded !\n", buf);
+	  res = 1;
+	}
+    }
+
+  free (buf);
+
+  return 0;
 }