From 2b2a2e94466da48f216216b9783d25eb907ed756 Mon Sep 17 00:00:00 2001 From: JET Date: Thu, 3 Nov 2011 19:30:44 -0600 Subject: [PATCH] Completion of previous fix. --- classpath/java/io/RandomAccessFile.java | 21 ++++++++++++++++++--- 1 file changed, 18 insertions(+), 3 deletions(-) diff --git a/classpath/java/io/RandomAccessFile.java b/classpath/java/io/RandomAccessFile.java index 2a1080bb4f..cc3c41e757 100644 --- a/classpath/java/io/RandomAccessFile.java +++ b/classpath/java/io/RandomAccessFile.java @@ -14,23 +14,36 @@ public class RandomAccessFile { private long peer; private File file; private long position = 0; + private long length; public RandomAccessFile(String name, String mode) throws FileNotFoundException { if (! mode.equals("r")) throw new IllegalArgumentException(); file = new File(name); + open(); + } + private void open() throws FileNotFoundException { long[] result = new long[2]; - open(name, result); + open(file.getPath(), result); peer = result[0]; + length = result[1]; } private static native void open(String name, long[] result) throws FileNotFoundException; + private void refresh() throws IOException { + if (file.length() != length) { + close(); + open(); + } + } + public long length() throws IOException { - return file.length(); + refresh(); + return length; } public long getFilePointer() throws IOException { @@ -50,7 +63,9 @@ public class RandomAccessFile { if (length == 0) return; - if (position + length > this.length()) throw new EOFException(); + if (position + length > this.length) { + if (position + length > length()) throw new EOFException(); + } if (offset < 0 || offset + length > buffer.length) throw new ArrayIndexOutOfBoundsException();