* posix/regcomp.c (re_comp): Call __regfree on re_comp_buf.
authorRoland McGrath <roland@gnu.org>
Thu, 24 Oct 2002 00:22:27 +0000 (00:22 +0000)
committerRoland McGrath <roland@gnu.org>
Thu, 24 Oct 2002 00:22:27 +0000 (00:22 +0000)
(free_mem): New function.
* posix/Makefile (tests): Add bug-regex14.  Add bug-regex14-mem
if not cross compiling.
(generated): Add bug-regex14-mem and bug-regex14.mtrace.
(bug-regex14-ENV): Set.
(bug-regex14-mem): New target.
* posix/bug-regex14.c: New file.

* elf/Makefile ($(objpfx)librtld.map): Use temporary file for output
target, so we don't touch it when the link fails.

ChangeLog
elf/Makefile
posix/Makefile
posix/bug-regex14.c [new file with mode: 0644]
posix/regcomp.c

index c68f8a671e9035e4ee93213972329e3e1ef60fe8..6bac4d5f02e4dbc784a88163cba5529c68eec2eb 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,19 @@
+2002-10-24  Jakub Jelinek  <jakub@redhat.com>
+
+       * posix/regcomp.c (re_comp): Call __regfree on re_comp_buf.
+       (free_mem): New function.
+       * posix/Makefile (tests): Add bug-regex14.  Add bug-regex14-mem
+       if not cross compiling.
+       (generated): Add bug-regex14-mem and bug-regex14.mtrace.
+       (bug-regex14-ENV): Set.
+       (bug-regex14-mem): New target.
+       * posix/bug-regex14.c: New file.
+
 2002-10-23  Roland McGrath  <roland@redhat.com>
 
+       * elf/Makefile ($(objpfx)librtld.map): Use temporary file for output
+       target, so we don't touch it when the link fails.
+
        * libio/ftello.c (ftello): Use _IO_off64_t for type of POS.
        Check for the result overflowing off_t and fail with EOVERFLOW.
        * libio/ioftell.c (_IO_ftell): Likewise.
index f490b2587d5df892053bb2fa43bf7100da3678e1..015352275c8ce7ffc7ed8b25b5aac189e148a647 100644 (file)
@@ -188,8 +188,10 @@ $(objpfx)dl-allobjs.os: $(all-rtld-routines:%=$(objpfx)%.os)
 # for us.  Then we do the real link using rtld-libc.a instead of libc_pic.a.
 
 $(objpfx)librtld.map: $(objpfx)dl-allobjs.os $(common-objpfx)libc_pic.a
-       $(reloc-link) -o $@.o '-Wl,-(' $^ -lgcc '-Wl,-)' -Wl,-Map,$@
+       @-rm -f $@T
+       $(reloc-link) -o $@.o '-Wl,-(' $^ -lgcc '-Wl,-)' -Wl,-Map,$@T
        rm -f $@.o
+       mv -f $@T $@
 
 $(objpfx)librtld.mk: $(objpfx)librtld.map Makefile
        sed -n 's@^$(common-objpfx)\([^(]*\)(\(.*.os\))$$@\1 \2@p' $< | \
index 0062d982fbf07ee5f4cca6eea2bff9dd2f2a144b..37f6eccd19c193035ecb7d5cbd546cc93aa2c37a 100644 (file)
@@ -75,7 +75,7 @@ tests         := tstgetopt testfnm runtests runptests      \
                   tst-chmod bug-regex1 bug-regex2 bug-regex3 bug-regex4 \
                   tst-gnuglob tst-regex bug-regex5 bug-regex6 bug-regex7 \
                   bug-regex8 bug-regex9 bug-regex10 bug-regex11 bug-regex12 \
-                  bug-regex13
+                  bug-regex13 bug-regex14
 ifeq (yes,$(build-shared))
 test-srcs      := globtest
 tests           += wordexp-test tst-exec tst-spawn
@@ -89,7 +89,8 @@ before-compile        := testcases.h ptestcases.h
 # So they get cleaned up.
 generated := $(addprefix wordexp-test-result, 1 2 3 4 5 6 7 8 9 10) \
             annexc annexc.out wordexp-tst.out bug-regex2-mem \
-            bug-regex2.mtrace tst-getconf.out
+            bug-regex2.mtrace bug-regex14-mem bug-regex14.mtrace \
+            tst-getconf.out
 
 include ../Rules
 
@@ -149,7 +150,7 @@ endif
 # XXX Please note that for now we ignore the result of this test.
 tests: $(objpfx)annexc.out
 ifeq (no,$(cross-compiling))
-tests:$(objpfx)bug-regex2-mem $(objpfx)tst-getconf.out
+tests:$(objpfx)bug-regex2-mem $(objpfx)bug-regex14-mem $(objpfx)tst-getconf.out
 endif
 
 $(objpfx)annexc.out: $(objpfx)annexc
@@ -165,6 +166,11 @@ bug-regex2-ENV = MALLOC_TRACE=$(objpfx)bug-regex2.mtrace
 $(objpfx)bug-regex2-mem: $(objpfx)bug-regex2.out
        $(common-objpfx)malloc/mtrace $(objpfx)bug-regex2.mtrace > $@
 
+bug-regex14-ENV = MALLOC_TRACE=$(objpfx)bug-regex14.mtrace
+
+$(objpfx)bug-regex14-mem: $(objpfx)bug-regex14.out
+       $(common-objpfx)malloc/mtrace $(objpfx)bug-regex14.mtrace > $@
+
 $(objpfx)tst-getconf.out: tst-getconf.sh $(objpfx)getconf
        $(SHELL) -e $< $(common-objpfx) $(elf-objpfx) $(rtld-installed-name)
 
diff --git a/posix/bug-regex14.c b/posix/bug-regex14.c
new file mode 100644 (file)
index 0000000..91ff32a
--- /dev/null
@@ -0,0 +1,54 @@
+/* Tests re_comp and re_exec.
+   Copyright (C) 2002 Free Software Foundation, Inc.
+   This file is part of the GNU C Library.
+   Contributed by Isamu Hasegawa <isamu@yamato.ibm.com>, 2002.
+
+   The GNU C Library is free software; you can redistribute it and/or
+   modify it under the terms of the GNU Lesser General Public
+   License as published by the Free Software Foundation; either
+   version 2.1 of the License, or (at your option) any later version.
+
+   The GNU C Library is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+   Lesser General Public License for more details.
+
+   You should have received a copy of the GNU Lesser General Public
+   License along with the GNU C Library; if not, write to the Free
+   Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
+   02111-1307 USA.  */
+
+#define _REGEX_RE_COMP
+#include <sys/types.h>
+#include <mcheck.h>
+#include <regex.h>
+#include <stdio.h>
+#include <stdlib.h>
+
+int
+main (void)
+{
+  const char *err;
+  size_t i;
+  int ret = 0;
+
+  mtrace ();
+
+  for (i = 0; i < 100; ++i)
+    {
+      err = re_comp ("a t.st");
+      if (err)
+       {
+         printf ("re_comp failed: %s\n", err);
+         ret = 1;
+       }
+
+      if (! re_exec ("This is a test."))
+       {
+         printf ("re_exec failed\n");
+         ret = 1;
+       }
+    }
+
+  return ret;
+}
index 497d1301dff5a914d65a91cf89f6cfb740b700ed..9bb06aa7bf99750fa2d80b62e4b0a592a93b5f6e 100644 (file)
@@ -653,6 +653,7 @@ re_comp (s)
      const char *s;
 {
   reg_errcode_t ret;
+  char *fastmap;
 
   if (!s)
     {
@@ -661,7 +662,17 @@ re_comp (s)
       return 0;
     }
 
-  if (!re_comp_buf.buffer)
+  if (re_comp_buf.buffer)
+    {
+      fastmap = re_comp_buf.fastmap;
+      re_comp_buf.fastmap = NULL;
+      __regfree (&re_comp_buf);
+      re_comp_buf.buffer = NULL;
+      re_comp_buf.allocated = 0;
+      re_comp_buf.fastmap = fastmap;
+    }
+
+  if (re_comp_buf.fastmap == NULL)
     {
       re_comp_buf.fastmap = (char *) malloc (SBC_MAX);
       if (re_comp_buf.fastmap == NULL)
@@ -683,6 +694,16 @@ re_comp (s)
   /* Yes, we're discarding `const' here if !HAVE_LIBINTL.  */
   return (char *) gettext (__re_error_msgid + __re_error_msgid_idx[(int) ret]);
 }
+
+#ifdef _LIBC
+static void __attribute__ ((unused))
+free_mem (void)
+{
+  __regfree (&re_comp_buf);
+}
+text_set_element (__libc_subfreeres, free_mem);
+#endif
+
 #endif /* _REGEX_RE_COMP */
 \f
 /* Internal entry point.