mangle.c (write_discriminator): Use `_0' for discriminator 1, not `_'.
authorJakub Jelinek <jakub@redhat.com>
Fri, 23 Mar 2001 22:12:55 +0000 (23:12 +0100)
committerJakub Jelinek <jakub@gcc.gnu.org>
Fri, 23 Mar 2001 22:12:55 +0000 (23:12 +0100)
* mangle.c (write_discriminator): Use `_0' for discriminator 1,
not `_'.

* cp-demangle.c (demangle_discriminator): `_0' is discriminator #1,
`_' not followed by a digit is invalid.

From-SVN: r40795

gcc/cp/ChangeLog
gcc/cp/mangle.c
libiberty/ChangeLog
libiberty/cp-demangle.c

index 2881da6ab5ef0ee6bd948ce121ac36e6bdff8fc9..5f63a6785cf672854090e2b6793572548a4d806b 100644 (file)
@@ -1,3 +1,8 @@
+2001-03-23  Jakub Jelinek  <jakub@redhat.com>
+
+       * mangle.c (write_discriminator): Use `_0' for discriminator 1,
+       not `_'.
+
 2001-03-23  Jakub Jelinek  <jakub@redhat.com>
 
        * decl.c (local_names): Define.
index a908640088ef3c4f83b2da7a7a60d24d3a769da1..e2641a74c6e229efc6f8d2423b5c7e4b2635bca4 100644 (file)
@@ -1196,10 +1196,7 @@ write_discriminator (discriminator)
   if (discriminator > 0)
     {
       write_char ('_');
-      /* The number is omitted for discriminator == 1.  Beyond 1, the
-        numbering starts at 0.  */
-      if (discriminator > 1)
-       write_unsigned_number (discriminator - 2);
+      write_unsigned_number (discriminator - 1);
     }
 }
 
index 0e937d2cfb3227804b4640bd1d223715deb923a5..7a1e8268551c7e0f788eb54a216700c772f215fe 100644 (file)
@@ -1,3 +1,8 @@
+2001-03-23  Jakub Jelinek  <jakub@redhat.com>
+
+       * cp-demangle.c (demangle_discriminator): `_0' is discriminator #1,
+       `_' not followed by a digit is invalid.
+
 2001-03-22  Jim Blandy  <jimb@redhat.com>
 
        * cp-demangle.c (string_list_delete): Use dyn_string_delete
index b8255b3a26c9e283c95c3d4fb0de9e9e98689d60..8419eef34259093a916bdeb5bf0628a4f3a1456b 100644 (file)
@@ -3446,15 +3446,11 @@ demangle_discriminator (dm, suppress_first)
            /* Write the discriminator.  The mangled number is two
               less than the discriminator ordinal, counting from
               zero.  */
-           RETURN_IF_ERROR (int_to_dyn_string (discriminator + 2, 
+           RETURN_IF_ERROR (int_to_dyn_string (discriminator + 1,
                                                (dyn_string_t) dm->result));
        }
       else
-       {
-         if (flag_verbose)
-           /* A missing digit correspond to one.  */
-           RETURN_IF_ERROR (result_add_char (dm, '1'));
-       }
+       return STATUS_ERROR;
       if (flag_verbose)
        RETURN_IF_ERROR (result_add_char (dm, ']'));
     }