OSDN Git Service

* verify.cc (_Jv_BytecodeVerifier::require_array_type): Special
authortromey <tromey@138bc75d-0d04-0410-961f-82ee72b054a4>
Tue, 20 Nov 2001 00:38:40 +0000 (00:38 +0000)
committertromey <tromey@138bc75d-0d04-0410-961f-82ee72b054a4>
Tue, 20 Nov 2001 00:38:40 +0000 (00:38 +0000)
case for boolean arrays.

* verify.cc (_Jv_BytecodeVerifier::compute_jump): Put PC into
error message.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@47190 138bc75d-0d04-0410-961f-82ee72b054a4

libjava/ChangeLog
libjava/verify.cc

index 99a69b8..01b089a 100644 (file)
@@ -1,5 +1,11 @@
 2001-11-19  Tom Tromey  <tromey@redhat.com>
 
+       * verify.cc (_Jv_BytecodeVerifier::require_array_type): Special
+       case for boolean arrays.
+
+       * verify.cc (_Jv_BytecodeVerifier::compute_jump): Put PC into
+       error message.
+
        * verify.cc (_Jv_BytecodeVerifier::verify_instructions_0)
        [op_lshl, op_lshr, op_lushr]: Shift argument is an int, not a
        long.
index 2562d1a..b9571c4 100644 (file)
@@ -28,7 +28,6 @@ details.  */
 
 // TO DO
 // * read more about when classes must be loaded
-// * there are bugs with boolean arrays?
 // * class loader madness
 // * Lots and lots of debugging and testing
 // * type representation is still ugly.  look for the big switches
@@ -951,7 +950,18 @@ private:
 
     type t = array.element_type ();
     if (! element.compatible (t))
-      verify_fail ("incompatible array element type");
+      {
+       // Special case for byte arrays, which must also be boolean
+       // arrays.
+       bool ok = true;
+       if (element.key == byte_type)
+         {
+           type e2 (boolean_type);
+           ok = e2.compatible (t);
+         }
+       if (! ok)
+         verify_fail ("incompatible array element type");
+      }
 
     // Return T and not ELEMENT, because T might be specialized.
     return t;
@@ -992,7 +1002,7 @@ private:
   {
     int npc = start_PC + offset;
     if (npc < 0 || npc >= current_method->code_length)
-      verify_fail ("branch out of range");
+      verify_fail ("branch out of range", start_PC);
     return npc;
   }