[kaffe] CVS kaffe (guilhem): Partial synchronization with classpath/libgcj (nio). JVMPI/XPROF disable on Cygw

Kaffe CVS Kaffe Mailing List <kaffe@kaffe.org>
Sat Dec 27 13:19:02 2003


PatchSet 4239 
Date: 2003/12/27 21:15:47
Author: guilhem
Branch: HEAD
Tag: (none) 
Log:
Partial synchronization with classpath/libgcj (nio). JVMPI/XPROF disable on Cygwin

Members: 
	ChangeLog:1.1828->1.1829 
	configure:1.270->1.271 
	configure.in:1.235->1.236 
	config/i386/cygwin32/md.h:1.3->1.4 
	kaffe/kaffevm/systems/unix-jthreads/jthread.c:1.104->1.105 
	libraries/javalib/Makefile.am:1.150->1.151 
	libraries/javalib/Makefile.in:1.202->1.203 
	libraries/javalib/essential.files:1.33->1.34 
	libraries/javalib/gnu/java/lang/reflect/TypeSignature.java:1.3->1.4 
	libraries/javalib/gnu/java/net/DNSJavaInetAddressImpl.java:1.1->1.2 
	libraries/javalib/gnu/java/net/protocol/http/Connection.java:1.3->1.4 
	libraries/javalib/gnu/java/nio/ChannelInputStream.java:INITIAL->1.1 
	libraries/javalib/gnu/java/nio/ChannelOutputStream.java:INITIAL->1.1 
	libraries/javalib/gnu/java/nio/InputStreamChannel.java:INITIAL->1.1 
	libraries/javalib/gnu/java/nio/OutputStreamChannel.java:INITIAL->1.1 
	libraries/javalib/gnu/java/nio/SelectorImpl.java:1.6->1.7 
	libraries/javalib/gnu/java/rmi/server/RMIVoidValue.java:1.1->1.2 
	libraries/javalib/gnu/java/rmi/server/UnicastRemoteCall.java:1.2->1.3 
	libraries/javalib/gnu/java/rmi/server/UnicastServerRef.java:1.2->1.3 
	libraries/javalib/java/io/FilePermission.java:1.5->1.6 
	libraries/javalib/java/net/DatagramSocket.java:1.19->1.20 
	libraries/javalib/java/net/ServerSocket.java:1.20->1.21 
	libraries/javalib/java/net/URL.java:1.35->1.36 
	libraries/javalib/java/net/URLStreamHandler.java:1.13->1.14 
	libraries/javalib/java/nio/ByteOrder.java:1.4->1.5 
	libraries/javalib/java/nio/DirectByteBufferImpl.java:1.3->1.4 
	libraries/javalib/java/nio/channels/Channels.java:1.3->1.4 
	libraries/javalib/java/nio/channels/FileChannelImpl.java:1.3->1.4 
	libraries/javalib/java/nio/channels/spi/AbstractSelectableChannel.java:1.3->1.4 
	libraries/javalib/javax/naming/directory/Attribute.java:1.3->1.4 
	libraries/javalib/javax/naming/directory/Attributes.java:1.2->1.3 
	libraries/javalib/javax/naming/directory/DirContext.java:1.2->1.3 
	libraries/javalib/javax/naming/directory/InitialDirContext.java:1.1->1.2 
	libraries/javalib/javax/naming/directory/SearchResult.java:1.1->1.2 
	libraries/javalib/javax/naming/event/EventContext.java:1.2->1.3 
	libraries/javalib/javax/naming/event/EventDirContext.java:1.2->1.3 
	libraries/javalib/javax/naming/event/NamingEvent.java:1.1->1.2 
	libraries/javalib/javax/naming/event/NamingExceptionEvent.java:1.1->1.2 
	libraries/javalib/javax/naming/ldap/ControlFactory.java:1.1->1.2 
	libraries/javalib/javax/naming/ldap/ExtendedRequest.java:1.2->1.3 
	libraries/javalib/javax/naming/ldap/HasControls.java:1.2->1.3 
	libraries/javalib/javax/naming/ldap/InitialLdapContext.java:1.1->1.2 
	libraries/javalib/javax/naming/ldap/LdapContext.java:1.2->1.3 
	libraries/javalib/javax/naming/ldap/LdapReferralException.java:1.1->1.2 
	libraries/javalib/javax/naming/ldap/UnsolicitedNotification.java:1.2->1.3 
	libraries/javalib/javax/naming/ldap/UnsolicitedNotificationListener.java:1.2->1.3 
	libraries/javalib/javax/naming/spi/DirObjectFactory.java:1.2->1.3 
	libraries/javalib/javax/naming/spi/DirStateFactory.java:1.2->1.3 
	libraries/javalib/javax/naming/spi/DirectoryManager.java:1.1->1.2 
	libraries/javalib/javax/naming/spi/NamingManager.java:1.5->1.6 
	libraries/javalib/javax/naming/spi/ObjectFactoryBuilder.java:1.2->1.3 
	libraries/javalib/javax/naming/spi/ResolveResult.java:1.1->1.2 
	libraries/javalib/javax/naming/spi/Resolver.java:1.2->1.3 
	libraries/javalib/javax/naming/spi/StateFactory.java:1.2->1.3 
	libraries/javalib/pure-java/math/java/math/BigDecimal.java:1.3->1.4 
	libraries/javalib/pure-java/math/java/math/BigInteger.java:1.2->1.3 
	test/regression/URLTest.java:1.4->1.5 

Index: kaffe/ChangeLog
diff -u kaffe/ChangeLog:1.1828 kaffe/ChangeLog:1.1829
--- kaffe/ChangeLog:1.1828	Fri Dec 26 18:51:20 2003
+++ kaffe/ChangeLog	Sat Dec 27 21:15:47 2003
@@ -1,3 +1,73 @@
+2003-12-27  Guilhem Lavaux <guilhem@kaffe.org>
+
+	* configure, libraries/javalib/Makefile.am,
+	libraries/javalib/Makefile.in: Regenerated.
+
+	* configure.in, config/i386/cygwin32/md.h,
+	kaffe/kaffevm/systems/unix-jthreads/jthread.c:
+	Disable JVMPI and XPROF when the system is a cygwin.
+
+	* libraries/javalib/essential.files: Added missing classes in NIO.
+
+	* test/regression/URLTest.java: Changed regression test. Checking here is
+	too strict and so the message could change.
+	
+	* libraries/javalib/gnu/java/lang/reflect/TypeSignature.java,
+	libraries/javalib/gnu/java/rmi/server/RMIVoidValue.java,
+	libraries/javalib/gnu/java/rmi/server/UnicastRemoteCall.java,
+	libraries/javalib/gnu/java/rmi/server/UnicastServerRef.java,
+	libraries/javalib/java/io/FilePermission.java,
+	libraries/javalib/java/net/DatagramSocket.java,
+	libraries/javalib/java/net/ServerSocket.java,
+	libraries/javalib/java/net/URL.java,
+	libraries/javalib/java/net/URLStreamHandler.java,
+	libraries/javalib/java/nio/ByteOrder.java,
+	libraries/javalib/java/nio/DirectByteBufferImpl.java,
+	libraries/javalib/java/nio/channels/Channels.java,
+	libraries/javalib/java/nio/channels/FileChannelImpl.java,
+	libraries/javalib/java/nio/channels/spi/AbstractSelectableChannel.java,
+	libraries/javalib/javax/naming/directory/Attribute.java,
+	libraries/javalib/javax/naming/directory/Attributes.java,
+	libraries/javalib/javax/naming/directory/DirContext.java,
+	libraries/javalib/javax/naming/directory/InitialDirContext.java,
+	libraries/javalib/javax/naming/directory/SearchResult.java,
+	libraries/javalib/javax/naming/event/EventContext.java,
+	libraries/javalib/javax/naming/event/EventDirContext.java,
+	libraries/javalib/javax/naming/event/NamingEvent.java,
+	libraries/javalib/javax/naming/event/NamingExceptionEvent.java,
+	libraries/javalib/javax/naming/ldap/ControlFactory.java,
+	libraries/javalib/javax/naming/ldap/ExtendedRequest.java,
+	libraries/javalib/javax/naming/ldap/HasControls.java,
+	libraries/javalib/javax/naming/ldap/InitialLdapContext.java,
+	libraries/javalib/javax/naming/ldap/LdapContext.java,
+	libraries/javalib/javax/naming/ldap/LdapReferralException.java,
+	libraries/javalib/javax/naming/ldap/UnsolicitedNotification.java,
+	libraries/javalib/javax/naming/ldap/UnsolicitedNotificationListener.java,
+	libraries/javalib/javax/naming/spi/DirObjectFactory.java,
+	libraries/javalib/javax/naming/spi/DirStateFactory.java,
+	libraries/javalib/javax/naming/spi/DirectoryManager.java,
+	libraries/javalib/javax/naming/spi/NamingManager.java,
+	libraries/javalib/javax/naming/spi/ObjectFactoryBuilder.java,
+	libraries/javalib/javax/naming/spi/ResolveResult.java,
+	libraries/javalib/javax/naming/spi/Resolver.java,
+	libraries/javalib/javax/naming/spi/StateFactory.java,
+	libraries/javalib/pure-java/math/java/math/BigDecimal.java,
+	libraries/javalib/pure-java/math/java/math/BigInteger.java:
+	Resynchronized with Classpath.
+
+	* libraries/javalib/java/nio/ByteOrder.java,
+	libraries/javalib/java/nio/DirectByteBufferImpl.java,
+	libraries/javalib/java/nio/channels/Channels.java,
+	libraries/javalib/java/nio/channels/FileChannelImpl.java,
+	libraries/javalib/java/nio/channels/spi/AbstractSelectableChannel.java,
+	libraries/javalib/gnu/java/net/protocol/http/Connection.java,
+	libraries/javalib/gnu/java/nio/ChannelInputStream.java,
+	libraries/javalib/gnu/java/nio/ChannelOutputStream.java,
+	libraries/javalib/gnu/java/nio/InputStreamChannel.java,
+	libraries/javalib/gnu/java/nio/OutputStreamChannel.java,
+	libraries/javalib/gnu/java/nio/SelectorImpl.java:
+	Merged from GCJ/libjava.
+	
 2003-12-26  Guilhem Lavaux <guilhem@kaffe.org>
 
 	* libraries/javalib/kjc.jar: Regenerated KJC to
Index: kaffe/configure
diff -u kaffe/configure:1.270 kaffe/configure:1.271
--- kaffe/configure:1.270	Wed Dec 24 19:06:50 2003
+++ kaffe/configure	Sat Dec 27 21:15:48 2003
@@ -19288,9 +19288,14 @@
 fi
 
 
+NOSIGCONTEXT=false
+
 case $Khost_os in
 win32*)
 	SYSTEM=win32 ;;
+cygwin*)
+	SYSTEM=unix;
+	NOSIGCONTEXT=true;;
 *)
 	SYSTEM=unix ;;
 esac
@@ -19468,11 +19473,15 @@
 case "$enable_jvmpi" in
 "") ;;
 no) ;;
-*)
+*) if test "x$NOSIGCONTEXT" = "xtrue"; then
+	echo "JVMPI does not support Cygwin"
+   else
+
 cat >>confdefs.h <<\_ACEOF
 #define ENABLE_JVMPI 1
 _ACEOF
-;;
+
+   fi;;
 esac
 
 
@@ -19516,6 +19525,11 @@
   enableval="$enable_xprofiling"
 
 fi;
+if test "x$NOSIGCONTEXT" = "xtrue"; then
+  echo "XProfiling does not support Cygwin"
+  enable_xprofiling=no
+fi
+
 case "$enable_xprofiling" in
 "") xprofiling=no ;;
 no) xprofiling=no ;;
Index: kaffe/configure.in
diff -u kaffe/configure.in:1.235 kaffe/configure.in:1.236
--- kaffe/configure.in:1.235	Wed Dec 24 19:06:54 2003
+++ kaffe/configure.in	Sat Dec 27 21:15:52 2003
@@ -159,9 +159,14 @@
 dnl -------------------------------------------------------------------------
 
 dnl What kind of system are we using?
+NOSIGCONTEXT=false
+
 case $Khost_os in
 win32*)
 	SYSTEM=win32 ;;
+cygwin*)
+	SYSTEM=unix;
+	NOSIGCONTEXT=true;;
 *)
 	SYSTEM=unix ;;
 esac
@@ -330,7 +335,11 @@
 case "$enable_jvmpi" in
 "") ;;
 no) ;;
-*) AC_DEFINE(ENABLE_JVMPI, 1, [JVM Profiling Interface]);;
+*) if test "x$NOSIGCONTEXT" = "xtrue"; then
+	echo "JVMPI does not support Cygwin"
+   else
+	AC_DEFINE(ENABLE_JVMPI, 1, [JVM Profiling Interface])
+   fi;;
 esac
 
 AM_CONDITIONAL(ENABLE_JVMPI, test x"$enable_jvmpi" = x"yes")
@@ -354,6 +363,11 @@
 need_libxprof=no
 
 AC_ARG_ENABLE(xprofiling,[  --enable-xprofiling     Enable profiling for C and jitted code])
+if test "x$NOSIGCONTEXT" = "xtrue"; then
+  echo "XProfiling does not support Cygwin"
+  enable_xprofiling=no
+fi
+
 case "$enable_xprofiling" in
 "") xprofiling=no ;;
 no) xprofiling=no ;;
Index: kaffe/config/i386/cygwin32/md.h
diff -u kaffe/config/i386/cygwin32/md.h:1.3 kaffe/config/i386/cygwin32/md.h:1.4
--- kaffe/config/i386/cygwin32/md.h:1.3	Thu Dec 11 17:56:21 2003
+++ kaffe/config/i386/cygwin32/md.h	Sat Dec 27 21:15:54 2003
@@ -26,7 +26,10 @@
 #undef SP_OFFSET
 #define	SP_OFFSET	7
 
-#error Signal handlers are not supported on CygWin32.
+#define SIGNAL_ARGS(sig, sc) int sig
+#define SIGNAL_CONTEXT_POINTER(scp) int scp
+#define GET_SIGNAL_CONTEXT_POINTER(sc) (NULL)
+#define SIGNAL_PC(scp) (0)
 
 #if defined(TRANSLATOR)
 #include "jit-md.h"
Index: kaffe/kaffe/kaffevm/systems/unix-jthreads/jthread.c
diff -u kaffe/kaffe/kaffevm/systems/unix-jthreads/jthread.c:1.104 kaffe/kaffe/kaffevm/systems/unix-jthreads/jthread.c:1.105
--- kaffe/kaffe/kaffevm/systems/unix-jthreads/jthread.c:1.104	Fri Dec 19 18:36:00 2003
+++ kaffe/kaffe/kaffevm/systems/unix-jthreads/jthread.c	Sat Dec 27 21:15:54 2003
@@ -417,7 +417,9 @@
 {
 	if( currentJThread->status != THREAD_SUSPENDED )
 	{
+#ifdef ENABLE_JVMPI
 		EXCEPTIONFRAME(jthread_current()->localData.topFrame, sc);
+#endif
 	}
 	
 	/*
Index: kaffe/libraries/javalib/Makefile.am
diff -u kaffe/libraries/javalib/Makefile.am:1.150 kaffe/libraries/javalib/Makefile.am:1.151
--- kaffe/libraries/javalib/Makefile.am:1.150	Tue Dec 23 20:18:42 2003
+++ kaffe/libraries/javalib/Makefile.am	Sat Dec 27 21:15:55 2003
@@ -389,13 +389,17 @@
 	gnu/java/net/protocol/jar/Connection.java \
 	gnu/java/net/protocol/jar/Handler.java
 gnu_java_nio_SRCS = \
+	gnu/java/nio/ChannelInputStream.java \
+	gnu/java/nio/ChannelOutputStream.java \
 	gnu/java/nio/DatagramChannelImpl.java \
 	gnu/java/nio/DatagramChannelSelectionKey.java \
 	gnu/java/nio/FileLockImpl.java \
+	gnu/java/nio/InputStreamChannel.java \
 	gnu/java/nio/NIOConstants.java \
 	gnu/java/nio/NIODatagramSocket.java \
 	gnu/java/nio/NIOServerSocket.java \
 	gnu/java/nio/NIOSocket.java \
+	gnu/java/nio/OutputStreamChannel.java \
 	gnu/java/nio/PipeImpl.java \
 	gnu/java/nio/SelectionKeyImpl.java \
 	gnu/java/nio/SelectorImpl.java \
Index: kaffe/libraries/javalib/Makefile.in
diff -u kaffe/libraries/javalib/Makefile.in:1.202 kaffe/libraries/javalib/Makefile.in:1.203
--- kaffe/libraries/javalib/Makefile.in:1.202	Wed Dec 24 19:07:23 2003
+++ kaffe/libraries/javalib/Makefile.in	Sat Dec 27 21:15:55 2003
@@ -662,13 +662,17 @@
 	gnu/java/net/protocol/jar/Handler.java
 
 gnu_java_nio_SRCS = \
+	gnu/java/nio/ChannelInputStream.java \
+	gnu/java/nio/ChannelOutputStream.java \
 	gnu/java/nio/DatagramChannelImpl.java \
 	gnu/java/nio/DatagramChannelSelectionKey.java \
 	gnu/java/nio/FileLockImpl.java \
+	gnu/java/nio/InputStreamChannel.java \
 	gnu/java/nio/NIOConstants.java \
 	gnu/java/nio/NIODatagramSocket.java \
 	gnu/java/nio/NIOServerSocket.java \
 	gnu/java/nio/NIOSocket.java \
+	gnu/java/nio/OutputStreamChannel.java \
 	gnu/java/nio/PipeImpl.java \
 	gnu/java/nio/SelectionKeyImpl.java \
 	gnu/java/nio/SelectorImpl.java \
Index: kaffe/libraries/javalib/essential.files
diff -u kaffe/libraries/javalib/essential.files:1.33 kaffe/libraries/javalib/essential.files:1.34
--- kaffe/libraries/javalib/essential.files:1.33	Mon Nov  3 04:25:49 2003
+++ kaffe/libraries/javalib/essential.files	Sat Dec 27 21:15:55 2003
@@ -20,13 +20,17 @@
 gnu/java/nio/charset/UTF_16.java
 gnu/java/nio/charset/UTF_16LE.java
 gnu/java/nio/charset/UTF_8.java
+gnu/java/nio/ChannelInputStream.java
+gnu/java/nio/ChannelOutputStream.java
 gnu/java/nio/DatagramChannelImpl.java
 gnu/java/nio/DatagramChannelSelectionKey.java
 gnu/java/nio/FileLockImpl.java
+gnu/java/nio/InputStreamChannel.java
 gnu/java/nio/NIOConstants.java
 gnu/java/nio/NIODatagramSocket.java
 gnu/java/nio/NIOServerSocket.java
 gnu/java/nio/NIOSocket.java
+gnu/java/nio/OutputStreamChannel.java
 gnu/java/nio/PipeImpl.java
 gnu/java/nio/SelectionKeyImpl.java
 gnu/java/nio/SelectorImpl.java
Index: kaffe/libraries/javalib/gnu/java/lang/reflect/TypeSignature.java
diff -u kaffe/libraries/javalib/gnu/java/lang/reflect/TypeSignature.java:1.3 kaffe/libraries/javalib/gnu/java/lang/reflect/TypeSignature.java:1.4
--- kaffe/libraries/javalib/gnu/java/lang/reflect/TypeSignature.java:1.3	Wed Dec  3 19:57:15 2003
+++ kaffe/libraries/javalib/gnu/java/lang/reflect/TypeSignature.java	Sat Dec 27 21:15:56 2003
@@ -173,7 +173,8 @@
    * @see #getEncodingOfClass(Class, boolean)
    * @see #getClassForEncoding(String, boolean)
    */
-   public static Class getClassForEncoding(String type_code, boolean descriptor, ClassLoader loader)
+  public static Class getClassForEncoding(String type_code, boolean descriptor,
+		 			  ClassLoader loader)
     throws ClassNotFoundException
   {
     if (descriptor)
Index: kaffe/libraries/javalib/gnu/java/net/DNSJavaInetAddressImpl.java
diff -u kaffe/libraries/javalib/gnu/java/net/DNSJavaInetAddressImpl.java:1.1 kaffe/libraries/javalib/gnu/java/net/DNSJavaInetAddressImpl.java:1.2
--- kaffe/libraries/javalib/gnu/java/net/DNSJavaInetAddressImpl.java:1.1	Tue Dec 23 20:18:54 2003
+++ kaffe/libraries/javalib/gnu/java/net/DNSJavaInetAddressImpl.java	Sat Dec 27 21:15:56 2003
@@ -52,7 +52,6 @@
 import org.xbill.DNS.DClass;
 import org.xbill.DNS.ReverseMap;
 
-/* This class is just a forward to native implementation. */
 public class DNSJavaInetAddressImpl implements InetAddressImpl
 {
   static private Resolver resolver = null;
@@ -60,7 +59,6 @@
   public String getHostByAddr(byte[] ip)
     throws UnknownHostException
   {
-    
     if (resolver == null)
       resolver = new ExtendedResolver();
 
Index: kaffe/libraries/javalib/gnu/java/net/protocol/http/Connection.java
diff -u kaffe/libraries/javalib/gnu/java/net/protocol/http/Connection.java:1.3 kaffe/libraries/javalib/gnu/java/net/protocol/http/Connection.java:1.4
--- kaffe/libraries/javalib/gnu/java/net/protocol/http/Connection.java:1.3	Tue Dec 23 20:18:54 2003
+++ kaffe/libraries/javalib/gnu/java/net/protocol/http/Connection.java	Sat Dec 27 21:15:57 2003
@@ -119,11 +119,6 @@
   private ByteArrayOutputStream bufferedOutputStream;
 
   /**
-   * The PrintWriter for this connection (used internally)
-   */
-  private PrintWriter outputWriter;
-
-  /**
    * This is the object that holds the header field information
    */
   private HeaderFieldHelper headers = new HeaderFieldHelper();
@@ -164,13 +159,11 @@
 	socket = new Socket(url.getHost(), port);
       }
 
-    if (doInput)
-      inputStream = new DataInputStream
-	(new BufferedInputStream (socket.getInputStream()));
+    inputStream =
+      new DataInputStream(new BufferedInputStream(socket.getInputStream()));
 
     outputStream = new BufferedOutputStream (socket.getOutputStream());
     bufferedOutputStream = new ByteArrayOutputStream (256); //default is too small
-    outputWriter = new PrintWriter (new OutputStreamWriter (outputStream, "8859_1")); 
 
     sendRequest();
     receiveReply();
@@ -202,36 +195,30 @@
    */
   void sendRequest() throws IOException
   {
+    // Create PrintWriter for easier sending of headers.
+    PrintWriter outputWriter =
+      new PrintWriter(new OutputStreamWriter(outputStream, "8859_1")); 
+    
     // Send request including any request properties that were set.
     outputWriter.print (getRequestMethod() + " " + url.getFile()
                         + " HTTP/1.1\r\n");
 
     // Set additional HTTP headers.
     if (getRequestProperty ("Host") == null)
-      {
-        setRequestProperty ("Host", url.getHost());
-      }
+      setRequestProperty ("Host", url.getHost());
     
     if (getRequestProperty ("Connection") == null)
-      {
-        setRequestProperty ("Connection", "Close");
-      }
+      setRequestProperty ("Connection", "Close");
     
     if (getRequestProperty ("user-agent") == null)
-      {
-        setRequestProperty ("user-agent", "gnu-classpath/"
-                            + System.getProperty ("classpath.version"));
-      }
+      setRequestProperty ("user-agent", "gnu-classpath/"
+                          + System.getProperty ("classpath.version"));
     
     if (getRequestProperty ("accept") == null)
-      {
-        setRequestProperty ("accept", "*/*");
-      }
+      setRequestProperty ("accept", "*/*");
     
     if (getRequestProperty ("Content-type") == null)
-      {
-        setRequestProperty ("Content-type", "application/x-www-form-urlencoded");
-      }
+      setRequestProperty ("Content-type", "application/x-www-form-urlencoded");
 
     // Set correct content length.
     setRequestProperty ("Content-length", String.valueOf (bufferedOutputStream.size()));
@@ -257,7 +244,7 @@
   /**
    * Read HTTP reply from inputStream.
    */
-  void receiveReply() throws IOException
+  private void receiveReply() throws IOException
   {
     // Parse the reply
     String line = inputStream.readLine();
@@ -268,6 +255,8 @@
         || (line.length() < (idx + 6)))
       throw new IOException ("Server reply was unparseable: " + saveline);
 
+    headers.addHeaderField (null, line);
+
     line = line.substring (idx + 1);
     String code = line.substring (0, 3);
     
@@ -349,6 +338,59 @@
   }
 
   /**
+   * Return a boolean indicating whether or not this connection is
+   * going through a proxy
+   *
+   * @return true if using a proxy, false otherwise
+   */
+  public boolean usingProxy()
+  {
+    return proxyInUse;
+  }
+
+  /**
+   * Returns an InputStream for reading from this connection.  This stream
+   * will be "queued up" for reading just the contents of the requested file.
+   * Overrides URLConnection.getInputStream()
+   *
+   * @return An InputStream for this connection.
+   *
+   * @exception IOException If an error occurs
+   */
+  public InputStream getInputStream() throws IOException
+  {
+    if (!connected)
+      connect();
+
+    if (!doInput)
+      throw new ProtocolException("Can't open InputStream if doInput is false");
+    
+    return inputStream;
+  }
+
+  /**
+   * Returns on OutputStream for writing to this connection.
+   *
+   * @return An OutputStream for this connection.
+   *
+   * @exception IOException If an error occurs
+   */
+  public OutputStream getOutputStream() throws IOException
+  {
+    if (!doOutput)
+      throw new ProtocolException
+        ("Want output stream while haven't setDoOutput(true)");
+    
+    if (!method.equals ("POST")) //But we might support "PUT" in future
+      setRequestMethod ("POST");
+  
+    if (!connected)
+      connect();
+    
+    return bufferedOutputStream;
+  }
+
+  /**
    * Overrides java.net.HttpURLConnection.setRequestMethod() in order to
    * restrict the available methods to only those we support.
    *
@@ -368,34 +410,18 @@
       throw new ProtocolException ("Unsupported or unknown request method " +
                                    method);
   }
-  
-  /**
-   * Return a boolean indicating whether or not this connection is
-   * going through a proxy
-   *
-   * @return true if using a proxy, false otherwise
-   */
-  public boolean usingProxy()
-  {
-    return proxyInUse;
-  }
 
   /**
-   * This method returns the header field key at the specified numeric
+   * This method returns the header field value at the specified numeric
    * index.
    *
    * @param n The index into the header field array
    *
-   * @return The name of the header field key, or <code>null</code> if the
-   * specified index is not valid.
+   * @return The value of the specified header field, or <code>null</code>
+   * if the specified index is not valid.
    */
-  public String getHeaderFieldKey (int n)
+  public String getHeaderField(int n)
   {
-    if (n < 1)
-      return null;
-
-    n--;
-
     if (!connected)
       try
 	{
@@ -406,24 +432,20 @@
 	  return null;
 	}
 
-    return headers.getHeaderFieldKeyByIndex (n);
+    return headers.getHeaderFieldValueByIndex (n);
   }
 
   /**
-   * This method returns the header field value at the specified numeric
+   * This method returns the header field key at the specified numeric
    * index.
    *
    * @param n The index into the header field array
    *
-   * @return The value of the specified header field, or <code>null</code>
-   * if the specified index is not valid.
+   * @return The name of the header field key, or <code>null</code> if the
+   * specified index is not valid.
    */
-  public String getHeaderField (int n)
+  public String getHeaderFieldKey(int n)
   {
-    if (n < 1)
-      return null;
-
-    n--;
     if (!connected)
       try
 	{
@@ -434,43 +456,6 @@
 	  return null;
 	}
 
-    return headers.getHeaderFieldValueByIndex (n);
-  }
-
-  /**
-   * Returns an InputStream for reading from this connection.  This stream
-   * will be "queued up" for reading just the contents of the requested file.
-   * Overrides URLConnection.getInputStream()
-   *
-   * @return An InputStream for this connection.
-   *
-   * @exception IOException If an error occurs
-   */
-  public InputStream getInputStream() throws IOException
-  {
-    if(inputStream != null)
-      return inputStream;
-
-    if (!connected)
-      connect();
-
-    return inputStream;
-  }
-
-  public OutputStream getOutputStream() throws IOException
-  {
-    if (!doOutput)
-      throw new ProtocolException
-        ("Want output stream while haven't setDoOutput(true)");
-    
-    if (!method.equals ("POST")) //But we might support "PUT" in future
-      setRequestMethod ("POST");
-  
-    if (!connected)
-      connect();
-  
-    return bufferedOutputStream;
+    return headers.getHeaderFieldKeyByIndex (n);
   }
-
-
 }
===================================================================
Checking out kaffe/libraries/javalib/gnu/java/nio/ChannelInputStream.java
RCS:  /home/cvs/kaffe/kaffe/libraries/javalib/gnu/java/nio/ChannelInputStream.java,v
VERS: 1.1
***************
--- /dev/null	Sun Aug  4 19:57:58 2002
+++ kaffe/libraries/javalib/gnu/java/nio/ChannelInputStream.java	Sat Dec 27 21:18:06 2003
@@ -0,0 +1,79 @@
+/* ChannelInputStream.java -- 
+   Copyright (C) 2003 Free Software Foundation, Inc.
+
+This file is part of GNU Classpath.
+
+GNU Classpath is free software; you can redistribute it and/or modify
+it under the terms of the GNU General Public License as published by
+the Free Software Foundation; either version 2, or (at your option)
+any later version.
+
+GNU Classpath is distributed in the hope that it will be useful, but
+WITHOUT ANY WARRANTY; without even the implied warranty of
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+General Public License for more details.
+
+You should have received a copy of the GNU General Public License
+along with GNU Classpath; see the file COPYING.  If not, write to the
+Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
+02111-1307 USA.
+
+Linking this library statically or dynamically with other modules is
+making a combined work based on this library.  Thus, the terms and
+conditions of the GNU General Public License cover the whole
+combination.
+
+As a special exception, the copyright holders of this library give you
+permission to link this library with independent modules to produce an
+executable, regardless of the license terms of these independent
+modules, and to copy and distribute the resulting executable under
+terms of your choice, provided that you also meet, for each linked
+independent module, the terms and conditions of the license of that
+module.  An independent module is a module which is not derived from
+or based on this library.  If you modify this library, you may extend
+this exception to your version of the library, but you are not
+obligated to do so.  If you do not wish to do so, delete this
+exception statement from your version. */
+
+
+package gnu.java.nio;
+
+import java.io.InputStream;
+import java.io.IOException;
+import java.nio.ByteBuffer;
+import java.nio.channels.IllegalBlockingModeException;
+import java.nio.channels.ReadableByteChannel;
+import java.nio.channels.SelectableChannel;
+
+/**
+ * @author Michael Koch
+ */
+public final class ChannelInputStream extends InputStream
+{
+  private ReadableByteChannel ch;
+  
+  public ChannelInputStream (ReadableByteChannel ch)
+  {
+    super();
+    
+    this.ch = ch;
+  }
+
+  public int read() throws IOException
+  {
+    if (ch instanceof SelectableChannel
+	&& (! ((SelectableChannel) ch).isBlocking()))
+      throw new IllegalBlockingModeException();
+      
+    ByteBuffer buffer = ByteBuffer.allocate(1);
+    int result = ch.read(buffer);
+
+    if (result == -1)
+      return -1;
+
+    if (result == 0)
+      throw new IOException("Could not read from channel");
+
+     return buffer.get(0);
+  }
+}
===================================================================
Checking out kaffe/libraries/javalib/gnu/java/nio/ChannelOutputStream.java
RCS:  /home/cvs/kaffe/kaffe/libraries/javalib/gnu/java/nio/ChannelOutputStream.java,v
VERS: 1.1
***************
--- /dev/null	Sun Aug  4 19:57:58 2002
+++ kaffe/libraries/javalib/gnu/java/nio/ChannelOutputStream.java	Sat Dec 27 21:18:06 2003
@@ -0,0 +1,67 @@
+/* ChannelOutputStream.java -- 
+   Copyright (C) 2003 Free Software Foundation, Inc.
+
+This file is part of GNU Classpath.
+
+GNU Classpath is free software; you can redistribute it and/or modify
+it under the terms of the GNU General Public License as published by
+the Free Software Foundation; either version 2, or (at your option)
+any later version.
+
+GNU Classpath is distributed in the hope that it will be useful, but
+WITHOUT ANY WARRANTY; without even the implied warranty of
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+General Public License for more details.
+
+You should have received a copy of the GNU General Public License
+along with GNU Classpath; see the file COPYING.  If not, write to the
+Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
+02111-1307 USA.
+
+Linking this library statically or dynamically with other modules is
+making a combined work based on this library.  Thus, the terms and
+conditions of the GNU General Public License cover the whole
+combination.
+
+As a special exception, the copyright holders of this library give you
+permission to link this library with independent modules to produce an
+executable, regardless of the license terms of these independent
+modules, and to copy and distribute the resulting executable under
+terms of your choice, provided that you also meet, for each linked
+independent module, the terms and conditions of the license of that
+module.  An independent module is a module which is not derived from
+or based on this library.  If you modify this library, you may extend
+this exception to your version of the library, but you are not
+obligated to do so.  If you do not wish to do so, delete this
+exception statement from your version. */
+
+
+package gnu.java.nio;
+
+import java.io.OutputStream;
+import java.io.IOException;
+import java.nio.ByteBuffer;
+import java.nio.channels.WritableByteChannel;
+
+/**
+ * @author Michael Koch
+ */
+public final class ChannelOutputStream extends OutputStream
+{
+  private WritableByteChannel ch;
+  
+  public ChannelOutputStream (WritableByteChannel ch)
+  {
+    super();
+    
+    this.ch = ch;
+  }
+
+  public void write (int value) throws IOException
+  {
+    ByteBuffer buffer = ByteBuffer.allocate (1);
+    buffer.put ((byte) (value & 0xff));
+    buffer.flip();
+    ch.write (buffer);
+  }
+}
===================================================================
Checking out kaffe/libraries/javalib/gnu/java/nio/InputStreamChannel.java
RCS:  /home/cvs/kaffe/kaffe/libraries/javalib/gnu/java/nio/InputStreamChannel.java,v
VERS: 1.1
***************
--- /dev/null	Sun Aug  4 19:57:58 2002
+++ kaffe/libraries/javalib/gnu/java/nio/InputStreamChannel.java	Sat Dec 27 21:18:06 2003
@@ -0,0 +1,88 @@
+/* InputStreamChannel.java -- 
+   Copyright (C) 2003 Free Software Foundation, Inc.
+
+This file is part of GNU Classpath.
+
+GNU Classpath is free software; you can redistribute it and/or modify
+it under the terms of the GNU General Public License as published by
+the Free Software Foundation; either version 2, or (at your option)
+any later version.
+
+GNU Classpath is distributed in the hope that it will be useful, but
+WITHOUT ANY WARRANTY; without even the implied warranty of
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+General Public License for more details.
+
+You should have received a copy of the GNU General Public License
+along with GNU Classpath; see the file COPYING.  If not, write to the
+Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
+02111-1307 USA.
+
+Linking this library statically or dynamically with other modules is
+making a combined work based on this library.  Thus, the terms and
+conditions of the GNU General Public License cover the whole
+combination.
+
+As a special exception, the copyright holders of this library give you
+permission to link this library with independent modules to produce an
+executable, regardless of the license terms of these independent
+modules, and to copy and distribute the resulting executable under
+terms of your choice, provided that you also meet, for each linked
+independent module, the terms and conditions of the license of that
+module.  An independent module is a module which is not derived from
+or based on this library.  If you modify this library, you may extend
+this exception to your version of the library, but you are not
+obligated to do so.  If you do not wish to do so, delete this
+exception statement from your version. */
+
+
+package gnu.java.nio;
+
+import java.io.InputStream;
+import java.io.IOException;
+import java.nio.ByteBuffer;
+import java.nio.channels.ClosedChannelException;
+import java.nio.channels.ReadableByteChannel;
+
+/**
+ * @author Michael Koch
+ */
+public final class InputStreamChannel implements ReadableByteChannel
+{
+  private boolean closed = false;
+  private InputStream in;
+  
+  public InputStreamChannel (InputStream in)
+  {
+    super();
+    this.in = in;
+  }
+
+  public void close() throws IOException
+  {
+    if (!closed)
+      {
+        in.close();
+        closed = true;
+      }
+  }
+
+  public boolean isOpen()
+  {
+    return !closed;
+  }
+
+  public int read (ByteBuffer dst) throws IOException
+  {
+    if (!isOpen())
+      throw new ClosedChannelException();
+    
+    byte[] buffer = new byte [dst.remaining()];
+    int readBytes = in.read (buffer);
+
+    if (readBytes > 0)
+      dst.put (buffer, 0, readBytes);
+
+    return readBytes;
+  }
+}
===================================================================
Checking out kaffe/libraries/javalib/gnu/java/nio/OutputStreamChannel.java
RCS:  /home/cvs/kaffe/kaffe/libraries/javalib/gnu/java/nio/OutputStreamChannel.java,v
VERS: 1.1
***************
--- /dev/null	Sun Aug  4 19:57:58 2002
+++ kaffe/libraries/javalib/gnu/java/nio/OutputStreamChannel.java	Sat Dec 27 21:18:06 2003
@@ -0,0 +1,87 @@
+/* OutputStreamChannel.java -- 
+   Copyright (C) 2003 Free Software Foundation, Inc.
+
+This file is part of GNU Classpath.
+
+GNU Classpath is free software; you can redistribute it and/or modify
+it under the terms of the GNU General Public License as published by
+the Free Software Foundation; either version 2, or (at your option)
+any later version.
+
+GNU Classpath is distributed in the hope that it will be useful, but
+WITHOUT ANY WARRANTY; without even the implied warranty of
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+General Public License for more details.
+
+You should have received a copy of the GNU General Public License
+along with GNU Classpath; see the file COPYING.  If not, write to the
+Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
+02111-1307 USA.
+
+Linking this library statically or dynamically with other modules is
+making a combined work based on this library.  Thus, the terms and
+conditions of the GNU General Public License cover the whole
+combination.
+
+As a special exception, the copyright holders of this library give you
+permission to link this library with independent modules to produce an
+executable, regardless of the license terms of these independent
+modules, and to copy and distribute the resulting executable under
+terms of your choice, provided that you also meet, for each linked
+independent module, the terms and conditions of the license of that
+module.  An independent module is a module which is not derived from
+or based on this library.  If you modify this library, you may extend
+this exception to your version of the library, but you are not
+obligated to do so.  If you do not wish to do so, delete this
+exception statement from your version. */
+
+
+package gnu.java.nio;
+
+import java.io.OutputStream;
+import java.io.IOException;
+import java.nio.ByteBuffer;
+import java.nio.channels.ClosedChannelException;
+import java.nio.channels.WritableByteChannel;
+
+/**
+ * @author Michael Koch
+ */
+public final class OutputStreamChannel implements WritableByteChannel
+{
+  private boolean closed = false;
+  private OutputStream out;
+  
+  public OutputStreamChannel (OutputStream out)
+  {
+    super();
+    
+    this.out = out;
+  }
+
+  public void close() throws IOException
+  {
+    if (!closed)
+      {
+        out.close();
+        closed = true;
+      }
+  }
+
+  public boolean isOpen()
+  {
+    return !closed;
+  }
+  
+  public int write (ByteBuffer src) throws IOException
+  {
+    if (!isOpen())
+      throw new ClosedChannelException();
+    
+    int len = src.remaining();
+    byte[] buffer = new byte [len];
+    src.get (buffer);
+    out.write (buffer);
+    return len;
+  }
+}
Index: kaffe/libraries/javalib/gnu/java/nio/SelectorImpl.java
diff -u kaffe/libraries/javalib/gnu/java/nio/SelectorImpl.java:1.6 kaffe/libraries/javalib/gnu/java/nio/SelectorImpl.java:1.7
--- kaffe/libraries/javalib/gnu/java/nio/SelectorImpl.java:1.6	Tue Oct 28 12:29:38 2003
+++ kaffe/libraries/javalib/gnu/java/nio/SelectorImpl.java	Sat Dec 27 21:15:57 2003
@@ -65,12 +65,34 @@
   private Set keys;
   private Set selected;
 

*** Patch too long, truncated ***