diff options
author | Michael Koch <konqueror@gmx.de> | 2004-04-08 20:04:11 +0000 |
---|---|---|
committer | Michael Koch <konqueror@gmx.de> | 2004-04-08 20:04:11 +0000 |
commit | 40de253a8b42b244b873a4ab776b29e74790286f (patch) | |
tree | 102a991cd52694a81f4f1e7adbb7a544ed84c5a7 /java/nio/channels/Channels.java | |
parent | c989d198d05e0949cc190568b042683b31b2cce5 (diff) | |
download | classpath-40de253a8b42b244b873a4ab776b29e74790286f.tar.gz |
2004-04-08 Michael Koch <konqueror@gmx.de>
* configure.ac: Added gnu/java/nio/channels/Makefile to output files.
* gnu/java/nio/Makefile.am: Added subdir channels.
* include/gnu_java_nio_channels_FileChannelImpl.h: New file.
* include/java_io_FileDescriptor.h,
include/java_nio_DirectByteBufferImpl.h: Updates.
* include/java_nio_channels_FileChannelImpl.h: Removed.
* include/Makefile.am: Handle generation of
gnu_java_nio_channels_FileChannelImpl.h.
* java/nio/channels/Makefile.am (EXTRA_DIST): Removed FileChannelImpl.java.
* native/jni/java-nio/Makefile.am
(libjavanio_la_SOURCES): Removed java_nio_FileChannelImpl.c and
added gnu_java_nio_channels_FileChannelImpl.c.
* native/jni/java-io/FileDescriptor.c: Commented out all code.
* native/jni/java-nio/gnu_java_nio_channels_FileChannelImpl.c: New file.
* native/jni/java-nio/java_nio_DirectByteBufferImpl.c: Fixed method names.
* native/jni/java-nio/java_nio_FileChannelImpl.c: Removed.
2004-04-08 Per Bothner <per@bothner.com>
* java/nio/channels/Channels.java (newInputStream, newOutputStream):
Optimize when argument is a FileChannelImpl.
(newInputStream(FileChannelImpl), newOutputStream(FileChannelImpl)):
New native methods.
2004-04-08 Per Bothner <per@bothner.com>
* java/nio/channels/FileChannelImpl.java: Moved to package
gnu/java/nio/channels, since we need to refer to it from java.io.
* java/nio/channels/natFileChannelImpl.cc: Removed file.
* gnu/java/nio/channels/FileChannelImpl.java: New class, renamed
from java/nio/channels. Don't depend on FileDescriptor.
(in, out, err): New static fields.
(mode): New field.
(SET, CUR, READ, WRITE, APPEND, EXCL, SYNC, DSYNC): Moved constants
from FileDescriptor.
(by): Removed MappedByteBuffer field.
(map): New working implementation.
* java/io/FileDescriptor.java: Implement on top of FileChannel.
Remove native methods.
* gnu/java/nio/FileLockImpl.java (fd): Remove field, replacing it by:
(ch): New FileChannelImpl field. Update constructor to match.
(releaseImpl): Remove native method. Instead ...
(release): Call unlock on channel.
* java/io/FileInputStream.java (ch): Change type to FileChannelImpl.
(<init>(File)): Allocate a FileChannelImpl, not a FileDescriptor.
(<init>(FileChannelImpl)): New package-private constructor.
(<init>(FileDescriptor)): Extract FileChannelImpl from arg.
(available, close, read, skip): Implement using FileChannelImpl.
(getFD): Allocate FileDescriptor if needed.
(getChannel): Is now trivial.
* java/io/FileOutputStream.java: Corresponding changes.
* java/io/RandomAccessFile.java: Corresponding changes.
* java/nio/MappedByteBuffer.java: (forceImpl, isLoadedImpl, loadImpl,
unmapImpl): New dummy methods, to be overridden by subclass.
(finalize, isLoaded, load, force): New methods.
* java/nio/MappedByteBufferImpl.java: More-or-less rewrite.
Now works, at least for read mapping.
2004-04-08 Per Bothner <per@bothner.com>
* java/nio/CharBufferImpl.java: Inline super constructor.
* java/nio/DoubleBufferImpl.java: Likewise.
* java/nio/FloatBufferImpl.java: Likewise.
* java/nio/IntBufferImpl.java: Likewise.
* java/nio/LongBufferImpl.java: Likewise.
* java/nio/ShortBufferImpl.java: Likewise.
* java/nio/CharBuffer.java: Remove unused constructor.
* java/nio/DoubleBuffer.java: Likewise.
* java/nio/FloatBuffer.java: Likewise.
* java/nio/IntBuffer.java: Likewise.
* java/nio/LongBuffer.java: Likewise.
* java/nio/ShortBuffer.java: Likewise.
* java/nio/CharViewBufferImpl.java: New convenience constructor.
Fix buggy call to super constructor.
* java/nio/DoubleViewBufferImpl.java: Likewise.
* java/nio/FloatViewBufferImpl.java: Likewise.
* java/nio/IntViewBufferImpl.java: Likewise.
* java/nio/LongViewBufferImpl.java: Likewise.
* java/nio/ShortViewBufferImpl.java: Likewise.
* java/nio/ByteBuffer.java (endian): Make non-private so other
java.nio classes can inherit it.
(<init>): Don't bother clearing array_offset.
* java/nio/ByteBuffer.java (allocate): Re-implement using wrap.
* java/nio/ByteBuffer.java (get(byte[],int,int)): Check underflow.
Remove redundant test.
* java/nio/ByteBufferImpl.java (asCharBuffer, asShortBuffer,
asIntBuffer, asLongBuffer, asFloatBuffer, asDoubleBuffer):
Use new XxxViewBufferImpl constructors.
* java/nio/MappedByteBufferImpl.java: Likewise.
* java/nio/DirectByteBufferImpl.java: Likewise.
* java/nio/ByteBufferImpl.java: Remove one constructor.
Inline super in remaining constructor.
* java/nio/ByteBuffer.java: Remove unused constructor.
* java/nio/ByteBufferImpl.java (shiftDown): New optimized method.
* java/nio/ByteBufferImpl.java (get, put): Add array_offset.
* java/nio/DirectByteBufferImpl.java (owner): New field.
(offset): Remove unused field.
(<init>): Modify one and add another constructor. Change callers.
(allocateDirect): Removed - not used.
(getImpl, putImpl): Make static and pass address explicitly,
to make them useful for MappedByteBufferImpl.
(get, put): Check for underflow. Modify for new getImpl.
(getImpl): New native method where target is array.
(get(byte[],int,int)): Use the above.
(adjustAddress): New static native method.
(slice, duplicate, asReadOnly): New implementations.
2004-04-08 Per Bothner <per@bothner.com>
* java/nio/ByteBuffer.java (shiftDown): New helper method.
* java/nio/ByteBufferImpl.java (compact): Use new shiftDown method.
* sava/nio/ByteBufferHelper.java: Remove redundant 'final' specifiers.
Pass ByteOrder parameter to most methods, since the underlying
ByteBuffer's order isn't always what we should use.
* java/nio/ByteBufferImpl.java: Pass byte-order various places.
* java/nio/DirectByteBufferImpl.java: Likewise.
Use ByteBufferHelper methods.
* java/nio/MappedByteBufferImpl.java: Likewise.
(compact): Use shiftDown.
* java/nio/CharViewBufferImpl.java (<init>): Pass byte-order.
(get, put): Use ByteBufferHelper.
(compact): Use new shiftDown method.
(duplicate(boolean)): New helper method.
(duplicate, asReadOnlyBuffer): Use it.
(order): Return endian field.
* java/nio/DoubleViewBufferImpl.java: Likewise.
* java/nio/FloatViewBufferImpl.java: Likewise.
* java/nio/IntViewBufferImpl.java: Likewise.
* java/nio/LongViewBufferImpl.java: Likewise.
* java/nio/ShortViewBufferImpl.java: Likewise.
* java/nio/CharViewBufferImpl.java (subsequence): Redundant test.
* java/nio/DirectByteBufferImpl.java (shiftDown): New native method.
(compact): Re-implement using shiftDown.
Diffstat (limited to 'java/nio/channels/Channels.java')
-rw-r--r-- | java/nio/channels/Channels.java | 47 |
1 files changed, 29 insertions, 18 deletions
diff --git a/java/nio/channels/Channels.java b/java/nio/channels/Channels.java index cb6154e96..9eb2ec7bf 100644 --- a/java/nio/channels/Channels.java +++ b/java/nio/channels/Channels.java @@ -1,4 +1,4 @@ -/* Channels.java -- +/* Channels.java -- Copyright (C) 2002, 2003 Free Software Foundation, Inc. This file is part of GNU Classpath. @@ -41,6 +41,9 @@ import gnu.java.nio.ChannelInputStream; import gnu.java.nio.ChannelOutputStream; import gnu.java.nio.InputStreamChannel; import gnu.java.nio.OutputStreamChannel; +import gnu.java.nio.channels.FileChannelImpl; +import java.io.FileInputStream; +import java.io.FileOutputStream; import java.io.InputStream; import java.io.OutputStream; import java.io.Reader; @@ -49,27 +52,36 @@ import java.nio.charset.Charset; import java.nio.charset.CharsetDecoder; import java.nio.charset.CharsetEncoder; + /** * @since 1.4 */ -public final class Channels +public final class Channels { /** * Constructs a stream that reads bytes from the given channel. */ public static InputStream newInputStream(ReadableByteChannel ch) { + if (ch instanceof FileChannelImpl) + return newInputStream((FileChannelImpl) ch); return new ChannelInputStream(ch); } - + /** * Constructs a stream that writes bytes to the given channel. */ - public static OutputStream newOutputStream(WritableByteChannel ch) + public static OutputStream newOutputStream(WritableByteChannel ch) { + if (ch instanceof FileChannelImpl) + return newOutputStream((FileChannelImpl) ch); return new ChannelOutputStream(ch); } - + + static native FileInputStream newInputStream(FileChannelImpl ch); + + static native FileOutputStream newOutputStream(FileChannelImpl ch); + /** * Constructs a channel that reads bytes from the given stream. */ @@ -77,23 +89,23 @@ public final class Channels { return new InputStreamChannel(in); } - + /** * Constructs a channel that writes bytes to the given stream. */ public static WritableByteChannel newChannel(OutputStream out) { - return new OutputStreamChannel (out); + return new OutputStreamChannel(out); } /** * Constructs a reader that decodes bytes from the given channel using the * given decoder. */ - public static Reader newReader (ReadableByteChannel ch, CharsetDecoder dec, - int minBufferCap) + public static Reader newReader(ReadableByteChannel ch, CharsetDecoder dec, + int minBufferCap) { - throw new Error ("not implemented"); + throw new Error("not implemented"); } /** @@ -103,19 +115,19 @@ public final class Channels * @exception UnsupportedCharsetException If no support for the named charset * is available in this instance of the Java virtual machine. */ - public static Reader newReader (ReadableByteChannel ch, String csName) + public static Reader newReader(ReadableByteChannel ch, String csName) { - return newReader (ch, Charset.forName (csName).newDecoder (), -1); + return newReader(ch, Charset.forName(csName).newDecoder(), -1); } /** * Constructs a writer that encodes characters using the given encoder and * writes the resulting bytes to the given channel. */ - public static Writer newWriter (WritableByteChannel ch, CharsetEncoder enc, - int minBufferCap) + public static Writer newWriter(WritableByteChannel ch, CharsetEncoder enc, + int minBufferCap) { - throw new Error ("not implemented"); + throw new Error("not implemented"); } /** @@ -125,9 +137,8 @@ public final class Channels * @exception UnsupportedCharsetException If no support for the named charset * is available in this instance of the Java virtual machine. */ - public static Writer newWriter (WritableByteChannel ch, - String csName) + public static Writer newWriter(WritableByteChannel ch, String csName) { - return newWriter (ch, Charset.forName (csName).newEncoder (), -1); + return newWriter(ch, Charset.forName(csName).newEncoder(), -1); } } |