ObjectInputStream.java (read): AND byte with 0xff to make result unsigned.
authorBryce McKinlay <bryce@albatross.co.nz>
Sat, 27 Jan 2001 06:04:29 +0000 (06:04 +0000)
committerBryce McKinlay <bryce@gcc.gnu.org>
Sat, 27 Jan 2001 06:04:29 +0000 (06:04 +0000)
* java/io/ObjectInputStream.java (read): AND byte with 0xff to make
result unsigned.
(read (byte[], int, int)): Only call readNextBlock() if the block
buffer would actually be overrun. Increment blockDataPosition.
(callReadMethod): Propagate exceptions from invocation target.
* java/io/ObjectOutputStream.java (callWriteMethod): Propagate
exceptions from invocation target.

From-SVN: r39293

libjava/ChangeLog
libjava/java/io/ObjectInputStream.java
libjava/java/io/ObjectOutputStream.java

index 55fb358c47301144c1f333fbc3a7d98a454b4333..b4916054ca8ad118ee64e33dc544440bffcdd7a9 100644 (file)
@@ -1,3 +1,13 @@
+2001-01-27  Bryce McKinlay  <bryce@albatross.co.nz>
+
+       * java/io/ObjectInputStream.java (read): AND byte with 0xff to make
+       result unsigned.
+       (read (byte[], int, int)): Only call readNextBlock() if the block 
+       buffer would actually be overrun. Increment blockDataPosition.
+       (callReadMethod): Propagate exceptions from invocation target.
+       * java/io/ObjectOutputStream.java (callWriteMethod): Propagate 
+       exceptions from invocation target.
+
 2001-01-26  Tom Tromey  <tromey@redhat.com>
 
        * jni.cc (_Jv_JNI_GetAnyMethodID): Rewrite signature from external
index 595e9de6854ef1ff9baeb5cc0c65fe6514d1790f..9c10d58388d7044ca62178d5b48e8a68a338a6d6 100644 (file)
@@ -577,21 +577,23 @@ public class ObjectInputStream extends InputStream
     {
       if (this.blockDataPosition >= this.blockDataBytes)
        readNextBlock ();
-      return this.blockData[this.blockDataPosition++];
+      return (this.blockData[this.blockDataPosition++] & 0xff);
     }
     else
       return this.realInputStream.read ();
   }
 
-  public int read (byte data[], int offset, int length) throws IOException
+  public int read (byte[] data, int offset, int length) throws IOException
   {
     if (this.readDataFromBlock)
     {
-      if (this.blockDataPosition + length >= this.blockDataBytes)
+      if (this.blockDataPosition + length > this.blockDataBytes)
        readNextBlock ();
 
       System.arraycopy (this.blockData, this.blockDataPosition,
                        data, offset, length);
+      blockDataPosition += length;     
+
       return length;
     }
     else
@@ -1359,16 +1361,29 @@ public class ObjectInputStream extends InputStream
   {
     try
       {
-       Class classArgs[] = {Class.forName ("java.io.ObjectInputStream")};
+       Class classArgs[] = {ObjectInputStream.class};
        Method m = getMethod (klass, "readObject", classArgs);
        if (m == null)
          return;
        Object args[] = {this};
-       m.invoke (obj, args);   
+       m.invoke (obj, args);
       }
-    catch (Exception _)
+    catch (InvocationTargetException x)
+      {
+        /* Rethrow if possible. */
+       Throwable exception = x.getTargetException();
+       if (exception instanceof RuntimeException)
+         throw (RuntimeException) exception;
+       if (exception instanceof IOException)
+         throw (IOException) exception;
+
+       throw new IOException ("Exception thrown from readObject() on " +
+                              klass + ": " + exception.getClass().getName());
+      }
+    catch (Exception x)
       {
-       throw new IOException ();
+       throw new IOException ("Failure invoking readObject() on " +
+                              klass + ": " + x.getClass().getName());
       }
   }
     
index cd6202ef87745e8c676df020442570c074c7022c..faf7ea1a21b37c96ed3afc6289206496f6445baa 100644 (file)
@@ -633,7 +633,7 @@ public class ObjectOutputStream extends OutputStream
   /**
      @see java.io.DataOutputStream#write (byte[])
   */
-  public void write (byte b[]) throws IOException
+  public void write (byte[] b) throws IOException
   {
     write (b, 0, b.length);
   }
@@ -642,7 +642,7 @@ public class ObjectOutputStream extends OutputStream
   /**
      @see java.io.DataOutputStream#write (byte[],int,int)
   */
-  public void write (byte b[], int off, int len) throws IOException
+  public void write (byte[] b, int off, int len) throws IOException
   {
     if (writeDataAsBlocks)
     {
@@ -1175,22 +1175,35 @@ public class ObjectOutputStream extends OutputStream
 
   private void callWriteMethod (Object obj) throws IOException
   {
+    Class klass = obj.getClass ();
     try
       {
-       Class classArgs[] = {Class.forName ("java.io.ObjectOutputStream")};
-       Class klass = obj.getClass ();
+       Class classArgs[] = {ObjectOutputStream.class};
        Method m = getMethod (klass, "writeObject", classArgs);
        if (m == null)
          return;
        Object args[] = {this};
        m.invoke (obj, args);   
       }
-    catch (Exception _)
+    catch (InvocationTargetException x)
       {
-       throw new IOException ();
+        /* Rethrow if possible. */
+       Throwable exception = x.getTargetException();
+       if (exception instanceof RuntimeException)
+         throw (RuntimeException) exception;
+       if (exception instanceof IOException)
+         throw (IOException) exception;
+
+       throw new IOException ("Exception thrown from writeObject() on " +
+                              klass + ": " + exception.getClass().getName());
+      }
+    catch (Exception x)
+      {
+       throw new IOException ("Failure invoking writeObject() on " +
+                              klass + ": " + x.getClass().getName());
       }
   }
-    
+
   private boolean getBooleanField (Object obj, String field_name) throws IOException
   {
     try
@@ -1331,7 +1344,7 @@ public class ObjectOutputStream extends OutputStream
   private static native Field getField (Class klass, String name)
     throws java.lang.NoSuchFieldException;
 
-  private static native Method getMethod (Class klass, String name, Class args[])
+  private static native Method getMethod (Class klass, String name, Class[] args)
     throws java.lang.NoSuchMethodException;
 
   // this value comes from 1.2 spec, but is used in 1.1 as well