cp-demangle.c (cplus_demangle_v3): Check that it's a v3 mangled name before allocatin...
authorJason Merrill <jason@redhat.com>
Tue, 5 Dec 2000 17:29:12 +0000 (12:29 -0500)
committerJason Merrill <jason@gcc.gnu.org>
Tue, 5 Dec 2000 17:29:12 +0000 (12:29 -0500)
        * cp-demangle.c (cplus_demangle_v3): Check that it's a v3 mangled
        name before allocating the dyn_string.

From-SVN: r38043

libiberty/ChangeLog
libiberty/cp-demangle.c

index 9a5a13f..0656e8c 100644 (file)
@@ -1,3 +1,8 @@
+2000-12-05  Jason Merrill  <jason@redhat.com>
+
+       * cp-demangle.c (cplus_demangle_v3): Check that it's a v3 mangled
+       name before allocating the dyn_string.
+
 2000-12-04  Jason Merrill  <jason@redhat.com>
 
        * cp-demangle.c: s/new_abi/v3/.
index 5787f74..1cc4847 100644 (file)
@@ -3600,10 +3600,18 @@ char *
 cplus_demangle_v3 (mangled)
      const char* mangled;
 {
+  dyn_string_t demangled;
+  status_t status;
+
+  /* If this isn't a mangled name, don't pretend to demangle it.  */
+  if (strncmp (mangled, "_Z", 2) != 0)
+    return NULL;
+
   /* Create a dyn_string to hold the demangled name.  */
-  dyn_string_t demangled = dyn_string_new (0);
+  demangled = dyn_string_new (0);
   /* Attempt the demangling.  */
-  status_t status = cp_demangle ((char *) mangled, demangled);
+  status = cp_demangle ((char *) mangled, demangled);
+
   if (STATUS_NO_ERROR (status))
     /* Demangling succeeded.  */
     {