diff options
author | Ulrich Drepper <drepper@gmail.com> | 2010-10-11 22:46:44 -0400 |
---|---|---|
committer | Ulrich Drepper <drepper@gmail.com> | 2010-10-11 22:46:44 -0400 |
commit | e9b9cbf5e9bdcda6f0b50456658bac748202dd70 (patch) | |
tree | f7c25be42fb102aa3f4d7d611e14ac6d84b82eca /posix/bug-regex31.c | |
parent | ef06edbee6463061a7f3dcbd2f56a625b41a4810 (diff) | |
download | glibc-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.c | 34 |
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 (®ex, "([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 (®ex, 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; } |