Merge pull request #450 from bgould/io-enhancements

Closeable extends AutoCloseable; RandomAccessFile implements DataInput
This commit is contained in:
Joshua Warner 2015-07-29 08:24:32 -06:00
commit 7e4bd18742
2 changed files with 104 additions and 24 deletions

View File

@ -10,7 +10,7 @@
package java.io;
public interface Closeable {
public interface Closeable extends AutoCloseable {
void close()
throws IOException;
}

View File

@ -14,7 +14,8 @@ import java.lang.IllegalArgumentException;
import java.nio.ByteBuffer;
import java.nio.channels.FileChannel;
public class RandomAccessFile {
public class RandomAccessFile implements DataInput, Closeable {
private long peer;
private File file;
private long position = 0;
@ -77,44 +78,44 @@ public class RandomAccessFile {
public int read(byte b[], int off, int len) throws IOException {
if(b == null)
throw new IllegalArgumentException();
throw new IllegalArgumentException();
if (peer == 0)
throw new IOException();
if(len == 0)
return 0;
if (position + len > this.length)
throw new IOException();
if(len == 0)
return 0;
if (position + len > this.length)
throw new EOFException();
if (off < 0 || off + len > b.length)
if (off < 0 || off + len > b.length)
throw new ArrayIndexOutOfBoundsException();
int bytesRead = readBytes(peer, position, b, off, len);
position += bytesRead;
return bytesRead;
position += bytesRead;
return bytesRead;
}
public int read(byte b[]) throws IOException {
if(b == null)
throw new IllegalArgumentException();
throw new IllegalArgumentException();
if (peer == 0)
throw new IOException();
if(b.length == 0)
return 0;
if (position + b.length > this.length)
throw new IOException();
if(b.length == 0)
return 0;
if (position + b.length > this.length)
throw new EOFException();
int bytesRead = readBytes(peer, position, b, 0, b.length);
position += bytesRead;
return bytesRead;
position += bytesRead;
return bytesRead;
}
public void readFully(byte b[], int off, int len) throws IOException {
if(b == null)
throw new IllegalArgumentException();
if (b == null)
throw new IllegalArgumentException();
if (peer == 0)
throw new IOException();
if(len == 0)
return;
if (position + len > this.length)
throw new IOException();
if(len == 0)
return;
if (position + len > this.length)
throw new EOFException();
if (off < 0 || off + len > b.length)
if (off < 0 || off + len > b.length)
throw new ArrayIndexOutOfBoundsException();
int n = 0;
do {
@ -133,6 +134,85 @@ public class RandomAccessFile {
private static native int readBytes(long peer, long position, byte[] buffer,
int offset, int length);
public boolean readBoolean() throws IOException {
return readByte() != 0;
}
public int read() throws IOException {
try {
return readByte() & 0xff;
} catch (final EOFException e) {
return -1;
}
}
public byte readByte() throws IOException {
final byte[] buffer = new byte[1];
readFully(buffer);
return buffer[0];
}
public short readShort() throws IOException {
final byte[] buffer = new byte[2];
readFully(buffer);
return (short)((buffer[0] << 8) | buffer[1]);
}
public int readInt() throws IOException {
byte[] buf = new byte[4];
readFully(buf);
return ((buf[0] << 24) | (buf[1] << 16) | (buf[2] << 8) | buf[3]);
}
public float readFloat() throws IOException {
return Float.floatToIntBits(readInt());
}
public double readDouble() throws IOException {
return Double.doubleToLongBits(readLong());
}
public long readLong() throws IOException {
return ((readInt() & 0xffffffffl) << 32) | (readInt() & 0xffffffffl);
}
public char readChar() throws IOException {
return (char)readShort();
}
public int readUnsignedByte() throws IOException {
return readByte() & 0xff;
}
public int readUnsignedShort() throws IOException {
return readShort() & 0xffff;
}
public String readUTF() throws IOException {
int length = readUnsignedShort();
byte[] bytes = new byte[length];
readFully(bytes);
return new String(bytes, "UTF-8");
}
@Deprecated
public String readLine() throws IOException {
int c = read();
if (c < 0) {
return null;
} else if (c == '\n') {
return "";
}
StringBuilder builder = new StringBuilder();
for (;;) {
builder.append((char)c);
c = read();
if (c < 0 || c == '\n') {
return builder.toString();
}
}
}
public void write(int b) throws IOException {
int count = writeBytes(peer, position, new byte[] { (byte)b }, 0, 1);
if (count > 0) position += count;