2014-07-01 00:24:06 +00:00
|
|
|
package org.capnproto;
|
|
|
|
|
|
|
|
import java.io.IOException;
|
|
|
|
import java.nio.ByteBuffer;
|
|
|
|
import java.nio.channels.WritableByteChannel;
|
|
|
|
|
2014-09-03 21:50:23 +00:00
|
|
|
public final class BufferedOutputStreamWrapper implements BufferedOutputStream {
|
2014-07-01 00:24:06 +00:00
|
|
|
|
2014-09-05 19:52:05 +00:00
|
|
|
private final WritableByteChannel inner;
|
|
|
|
private final ByteBuffer buf;
|
2014-07-01 00:24:06 +00:00
|
|
|
|
2014-09-03 21:50:23 +00:00
|
|
|
public BufferedOutputStreamWrapper(WritableByteChannel w) {
|
2014-07-01 00:24:06 +00:00
|
|
|
this.inner = w;
|
|
|
|
this.buf = ByteBuffer.allocate(8192);
|
|
|
|
}
|
|
|
|
|
2014-09-03 18:12:46 +00:00
|
|
|
public final int write(ByteBuffer src) throws IOException {
|
2014-07-01 00:24:06 +00:00
|
|
|
int available = this.buf.remaining();
|
2014-09-03 18:12:46 +00:00
|
|
|
int size = src.remaining();
|
2014-07-01 00:24:06 +00:00
|
|
|
if (size <= available) {
|
2014-09-03 18:12:46 +00:00
|
|
|
this.buf.put(src);
|
2014-07-01 00:24:06 +00:00
|
|
|
} else if (size <= this.buf.capacity()) {
|
|
|
|
//# Too much for this buffer, but not a full buffer's worth,
|
|
|
|
//# so we'll go ahead and copy.
|
2014-09-03 18:12:46 +00:00
|
|
|
ByteBuffer slice = src.slice();
|
|
|
|
slice.limit(available);
|
|
|
|
this.buf.put(slice);
|
|
|
|
|
|
|
|
this.buf.rewind();
|
2014-09-25 18:40:44 +00:00
|
|
|
while(this.buf.hasRemaining()) {
|
|
|
|
this.inner.write(this.buf);
|
2014-09-03 18:12:46 +00:00
|
|
|
}
|
2014-09-25 18:40:44 +00:00
|
|
|
this.buf.rewind();
|
2014-09-03 18:12:46 +00:00
|
|
|
|
2014-09-03 21:50:23 +00:00
|
|
|
src.position(src.position() + available);
|
2014-09-03 18:12:46 +00:00
|
|
|
this.buf.put(src);
|
2014-07-01 00:24:06 +00:00
|
|
|
} else {
|
|
|
|
//# Writing so much data that we might as well write
|
|
|
|
//# directly to avoid a copy.
|
2014-09-03 18:12:46 +00:00
|
|
|
|
|
|
|
int pos = this.buf.position();
|
|
|
|
this.buf.rewind();
|
2014-09-25 18:40:44 +00:00
|
|
|
ByteBuffer slice = this.buf.slice();
|
2014-09-03 18:12:46 +00:00
|
|
|
slice.limit(pos);
|
2014-09-25 18:40:44 +00:00
|
|
|
while (slice.hasRemaining()) {
|
|
|
|
this.inner.write(slice);
|
|
|
|
}
|
|
|
|
while (src.hasRemaining()) {
|
|
|
|
this.inner.write(src);
|
2014-09-03 18:12:46 +00:00
|
|
|
}
|
2014-07-01 00:24:06 +00:00
|
|
|
}
|
2014-09-03 18:12:46 +00:00
|
|
|
return size;
|
2014-07-01 00:24:06 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public final ByteBuffer getWriteBuffer() {
|
|
|
|
return this.buf;
|
|
|
|
}
|
|
|
|
|
|
|
|
public final void close() throws IOException {
|
|
|
|
this.inner.close();
|
|
|
|
}
|
|
|
|
|
|
|
|
public final boolean isOpen() {
|
|
|
|
return this.inner.isOpen();
|
|
|
|
}
|
|
|
|
}
|