More regex memory leak fixes and tests.
authorUlrich Drepper <drepper@gmail.com>
Tue, 12 Oct 2010 02:46:44 +0000 (22:46 -0400)
committerUlrich Drepper <drepper@gmail.com>
Tue, 12 Oct 2010 02:46:44 +0000 (22:46 -0400)
ChangeLog
posix/bug-regex31.c
posix/bug-regex31.input [new file with mode: 0644]
posix/regcomp.c

index ee11d29..2192364 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,12 @@
 2010-10-11  Ulrich Drepper  <drepper@gmail.com>
 
+       * posix/bug-regex31.c: Rewrite to run multiple tests from stdin.
+       * posix/bug-regex31.input: New file.
+
+       [BZ #12078]
+       * posix/regcomp.c (parse_branch): Free memory when allocation failed.
+       (parse_sub_exp): Fix last change, use postorder.
+
        * posix/bug-regex31.c: New file.
        * posix/Makefile: Add rules to build and run bug-regex31.
 
index 2d5d669..974e860 100644 (file)
@@ -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;
 }
diff --git a/posix/bug-regex31.input b/posix/bug-regex31.input
new file mode 100644 (file)
index 0000000..eea961c
--- /dev/null
@@ -0,0 +1,3 @@
+([0]
+([0]a
+([0]([0])
index 9f5ca2c..4ee7b90 100644 (file)
@@ -2164,12 +2164,15 @@ parse_branch (re_string_t *regexp, regex_t *preg, re_token_t *token,
        }
       if (tree != NULL && exp != NULL)
        {
-         tree = create_tree (dfa, tree, exp, CONCAT);
-         if (tree == NULL)
+         bin_tree_t *newtree = create_tree (dfa, tree, exp, CONCAT);
+         if (newtree == NULL)
            {
+             postorder (exp, free_tree, NULL);
+             postorder (tree, free_tree, NULL);
              *err = REG_ESPACE;
              return NULL;
            }
+         tree = newtree;
        }
       else if (tree == NULL)
        tree = exp;
@@ -2420,7 +2423,7 @@ parse_sub_exp (re_string_t *regexp, regex_t *preg, re_token_t *token,
       if (BE (*err == REG_NOERROR && token->type != OP_CLOSE_SUBEXP, 0))
        {
          if (tree != NULL)
-           free_tree (NULL, tree);
+           postorder (tree, free_tree, NULL);
          *err = REG_EPAREN;
        }
       if (BE (*err != REG_NOERROR, 0))