[kaffe] CVS kaffe (dalibor): Resynced with GNU Classpath: gnu.* packages

Kaffe CVS Kaffe Mailing List <kaffe@kaffe.org>
Tue May 18 09:25:03 2004


PatchSet 4747 
Date: 2004/05/18 16:13:23
Author: dalibor
Branch: HEAD
Tag: (none) 
Log:
Resynced with GNU Classpath: gnu.* packages

2004-05-18  Dalibor Topic  <robilad@kaffe.org>

* libraries/javalib/java/awt/image/DataBufferDouble.java,
        libraries/javalib/java/awt/image/DataBufferFloat.java,
        libraries/javalib/java/awt/image/DataBufferShort.java:
New files, taken from GNU Classpath.

* libraries/javalib/Makefile.am,
        libraries/javalib/Makefile.in:
Regenerated.

        * libraries/javalib/profiles/default/coreawt.files,
        libraries/javalib/profiles/default/moreawt.files,
libraries/javalib/profiles/allatonce/all.files
Added the new files.

        * libraries/javalib/gnu/java/io/decode/KaffeDecoder.java,
        libraries/javalib/gnu/java/io/encode/KaffeEncoder.java:
(KaffeDecoder) Adapted to pass encoding name to superclass constructor.

        * libraries/javalib/gnu/java/awt/Buffers.java,
        libraries/javalib/gnu/java/io/decode/Decoder.java,
        libraries/javalib/gnu/java/io/encode/Encoder.java,
        libraries/javalib/gnu/java/nio/channels/FileChannelImpl.java,
        libraries/javalib/gnu/java/nio/charset/UTF_16Decoder.java,
        libraries/javalib/gnu/java/security/der/DERReader.java,
        libraries/javalib/gnu/java/text/AttributedFormatBuffer.java,
        libraries/javalib/gnu/java/text/CharacterBreakIterator.java,
        libraries/javalib/gnu/java/text/FormatBuffer.java,
        libraries/javalib/gnu/java/text/StringFormatBuffer.java:
Resynced with GNU Classpath.

2004-04-28  Guilhem Lavaux <guilhem@kaffe.org>

* gnu/java/text/FormatBuffer.java,
gnu/java/text/AttributedFormatBuffer.java,
gnu/java/text/StringFormatBuffer.java: New classes to implement
attributed iterators in java.text.

2004-04-23  Tom Tromey  <tromey@redhat.com>

* gnu/java/text/CharacterBreakIterator.java: Removed
unused import.

2004-04-23  Mark Wielaard  <mark@klomp.org>

* gnu/java/security/der/DERReader.java: Call static methods staticly.

2004-05-02  Mark Wielaard  <mark@klomp.org>

* gnu/java/nio/channels/FileChannelImpl.java (finalize): New method.

2004-04-30  Mark Wielaard  <mark@klomp.org>

* gnu/java/nio/channels/FileChannelImpl.java (truncate): Only truncate
when size is smaller.

2004-04-23  Michael Koch  <konqueror@gmx.de>

* gnu/java/nio/channels/FileChannelImpl.java
(SET, CUR): Unused, removed.

2004-04-13  Jeroen Frijters <jeroen@frijters.net>

* gnu/java/nio/channels/FileChannelImpl.java:
(FileChannelImpl(int,int)) Made package private instead of private.

2004-04-23  Tom Tromey  <tromey@redhat.com>

* gnu/java/nio/charset/UTF_16Decoder.java (put): Removed
unused method.

2004-05-07  Michael Koch  <konqueror@gmx.de>

* gnu/java/io/decode/Decoder.java,
gnu/java/io/encode/Encoder.java:
Fixed javadocs all over.

2004-04-23  Mark Wielaard  <mark@klomp.org>

* gnu/java/io/decode/Decoder.java (scheme_name): Make non-static
private final.
(scheme_description): Removed.
(in): Make final.
(getSchemeName): Make non-static.
(getSchemeDescription): Removed.
(Decoder): Make protected and add name parameter.
* gnu/java/io/encode/Encoder.java (scheme_description): Remove field.
(scheme_name): Make non-static private final.
(out): Make final.
(getSchemeName): Make non-static.
(getSchemeDescription): Removed.
(Encoder): Make protected and add parameter name to initialize
scheme_name.

2004-04-14  Sascha Brawer  <brawer@dandelis.ch>

* java/awt/image/DataBufferShort.java,
java/awt/image/DataBufferFloat.java,
java/awt/image/DataBufferDouble.java: New files.

* gnu/java/awt/Buffers.java (createBuffer, createBufferFromData,
getData): Added supportfor TYPE_SHORT, TYPE_FLOAT and TYPE_DOUBLE.

Members: 
	ChangeLog:1.2320->1.2321 
	libraries/javalib/Makefile.am:1.186->1.187 
	libraries/javalib/Makefile.in:1.249->1.250 
	libraries/javalib/gnu/java/awt/Buffers.java:1.2->1.3 
	libraries/javalib/gnu/java/io/decode/Decoder.java:1.2->1.3 
	libraries/javalib/gnu/java/io/decode/KaffeDecoder.java:1.3->1.4 
	libraries/javalib/gnu/java/io/encode/Encoder.java:1.2->1.3 
	libraries/javalib/gnu/java/io/encode/KaffeEncoder.java:1.2->1.3 
	libraries/javalib/gnu/java/nio/channels/FileChannelImpl.java:1.1->1.2 
	libraries/javalib/gnu/java/nio/charset/UTF_16Decoder.java:1.1->1.2 
	libraries/javalib/gnu/java/security/der/DERReader.java:1.2->1.3 
	libraries/javalib/gnu/java/text/AttributedFormatBuffer.java:1.3->1.4 
	libraries/javalib/gnu/java/text/CharacterBreakIterator.java:1.2->1.3 
	libraries/javalib/gnu/java/text/FormatBuffer.java:1.3->1.4 
	libraries/javalib/gnu/java/text/StringFormatBuffer.java:1.3->1.4 
	libraries/javalib/java/awt/image/DataBufferDouble.java:INITIAL->1.1 
	libraries/javalib/java/awt/image/DataBufferFloat.java:INITIAL->1.1 
	libraries/javalib/java/awt/image/DataBufferShort.java:INITIAL->1.1 
	libraries/javalib/profiles/allatonce/all.files:1.44->1.45 
	libraries/javalib/profiles/default/coreawt.files:1.6->1.7 
	libraries/javalib/profiles/default/moreawt.files:1.4->1.5 

Index: kaffe/ChangeLog
diff -u kaffe/ChangeLog:1.2320 kaffe/ChangeLog:1.2321
--- kaffe/ChangeLog:1.2320	Tue May 18 13:38:55 2004
+++ kaffe/ChangeLog	Tue May 18 16:13:23 2004
@@ -1,5 +1,109 @@
 2004-05-18  Dalibor Topic  <robilad@kaffe.org>
 
+	* libraries/javalib/java/awt/image/DataBufferDouble.java,
+        libraries/javalib/java/awt/image/DataBufferFloat.java,
+        libraries/javalib/java/awt/image/DataBufferShort.java:
+	New files, taken from GNU Classpath.
+	
+	* libraries/javalib/Makefile.am,
+        libraries/javalib/Makefile.in:
+	Regenerated.
+
+        * libraries/javalib/profiles/default/coreawt.files,
+        libraries/javalib/profiles/default/moreawt.files,
+	libraries/javalib/profiles/allatonce/all.files
+	Added the new files.
+
+        * libraries/javalib/gnu/java/io/decode/KaffeDecoder.java,
+        libraries/javalib/gnu/java/io/encode/KaffeEncoder.java:
+	(KaffeDecoder) Adapted to pass encoding name to superclass constructor.
+	
+        * libraries/javalib/gnu/java/awt/Buffers.java,
+        libraries/javalib/gnu/java/io/decode/Decoder.java,
+        libraries/javalib/gnu/java/io/encode/Encoder.java,
+        libraries/javalib/gnu/java/nio/channels/FileChannelImpl.java,
+        libraries/javalib/gnu/java/nio/charset/UTF_16Decoder.java,
+        libraries/javalib/gnu/java/security/der/DERReader.java,
+        libraries/javalib/gnu/java/text/AttributedFormatBuffer.java,
+        libraries/javalib/gnu/java/text/CharacterBreakIterator.java,
+        libraries/javalib/gnu/java/text/FormatBuffer.java,
+        libraries/javalib/gnu/java/text/StringFormatBuffer.java:
+	Resynced with GNU Classpath.
+	
+	2004-04-28  Guilhem Lavaux <guilhem@kaffe.org>
+
+	* gnu/java/text/FormatBuffer.java,
+	gnu/java/text/AttributedFormatBuffer.java,
+	gnu/java/text/StringFormatBuffer.java: New classes to implement
+	attributed iterators in java.text.
+
+	2004-04-23  Tom Tromey  <tromey@redhat.com>
+
+	* gnu/java/text/CharacterBreakIterator.java: Removed
+	unused import.
+
+	2004-04-23  Mark Wielaard  <mark@klomp.org>
+
+	* gnu/java/security/der/DERReader.java: Call static methods staticly.
+
+	2004-05-02  Mark Wielaard  <mark@klomp.org>
+
+	* gnu/java/nio/channels/FileChannelImpl.java (finalize): New method.
+
+	2004-04-30  Mark Wielaard  <mark@klomp.org>
+
+	* gnu/java/nio/channels/FileChannelImpl.java (truncate): Only truncate
+	when size is smaller.
+
+	2004-04-23  Michael Koch  <konqueror@gmx.de>
+
+	* gnu/java/nio/channels/FileChannelImpl.java
+	(SET, CUR): Unused, removed.
+
+	2004-04-13  Jeroen Frijters <jeroen@frijters.net>
+
+	* gnu/java/nio/channels/FileChannelImpl.java:
+	(FileChannelImpl(int,int)) Made package private instead of private.
+
+	2004-04-23  Tom Tromey  <tromey@redhat.com>
+
+	* gnu/java/nio/charset/UTF_16Decoder.java (put): Removed
+	unused method.
+
+	2004-05-07  Michael Koch  <konqueror@gmx.de>
+
+	* gnu/java/io/decode/Decoder.java,
+	gnu/java/io/encode/Encoder.java:
+	Fixed javadocs all over.
+
+	2004-04-23  Mark Wielaard  <mark@klomp.org>
+
+	* gnu/java/io/decode/Decoder.java (scheme_name): Make non-static
+	private final.
+	(scheme_description): Removed.
+	(in): Make final.
+	(getSchemeName): Make non-static.
+	(getSchemeDescription): Removed.
+	(Decoder): Make protected and add name parameter.
+	* gnu/java/io/encode/Encoder.java (scheme_description): Remove field.
+	(scheme_name): Make non-static private final.
+	(out): Make final.
+	(getSchemeName): Make non-static.
+	(getSchemeDescription): Removed.
+	(Encoder): Make protected and add parameter name to initialize
+	scheme_name.
+
+	2004-04-14  Sascha Brawer  <brawer@dandelis.ch>
+
+	* java/awt/image/DataBufferShort.java,
+	java/awt/image/DataBufferFloat.java,
+	java/awt/image/DataBufferDouble.java: New files.
+	
+	* gnu/java/awt/Buffers.java (createBuffer, createBufferFromData,
+	getData): Added support	for TYPE_SHORT, TYPE_FLOAT and TYPE_DOUBLE.
+
+2004-05-18  Dalibor Topic  <robilad@kaffe.org>
+
 	* libraries/javalib/Makefile.am,
         libraries/javalib/Makefile.in:
 	Regenerated.
Index: kaffe/libraries/javalib/Makefile.am
diff -u kaffe/libraries/javalib/Makefile.am:1.186 kaffe/libraries/javalib/Makefile.am:1.187
--- kaffe/libraries/javalib/Makefile.am:1.186	Tue May 18 13:39:00 2004
+++ kaffe/libraries/javalib/Makefile.am	Tue May 18 16:13:25 2004
@@ -902,8 +902,11 @@
 	java/awt/image/ComponentSampleModel.java \
 	java/awt/image/CropImageFilter.java \
 	java/awt/image/DataBufferByte.java \
+	java/awt/image/DataBufferDouble.java \
+	java/awt/image/DataBufferFloat.java \
 	java/awt/image/DataBufferInt.java \
 	java/awt/image/DataBuffer.java \
+	java/awt/image/DataBufferShort.java \
 	java/awt/image/DataBufferUShort.java \
 	java/awt/image/DirectColorModel.java \
 	java/awt/image/FilteredImageSource.java \
Index: kaffe/libraries/javalib/Makefile.in
diff -u kaffe/libraries/javalib/Makefile.in:1.249 kaffe/libraries/javalib/Makefile.in:1.250
--- kaffe/libraries/javalib/Makefile.in:1.249	Tue May 18 13:39:00 2004
+++ kaffe/libraries/javalib/Makefile.in	Tue May 18 16:13:26 2004
@@ -1246,8 +1246,11 @@
 	java/awt/image/ComponentSampleModel.java \
 	java/awt/image/CropImageFilter.java \
 	java/awt/image/DataBufferByte.java \
+	java/awt/image/DataBufferDouble.java \
+	java/awt/image/DataBufferFloat.java \
 	java/awt/image/DataBufferInt.java \
 	java/awt/image/DataBuffer.java \
+	java/awt/image/DataBufferShort.java \
 	java/awt/image/DataBufferUShort.java \
 	java/awt/image/DirectColorModel.java \
 	java/awt/image/FilteredImageSource.java \
Index: kaffe/libraries/javalib/gnu/java/awt/Buffers.java
diff -u kaffe/libraries/javalib/gnu/java/awt/Buffers.java:1.2 kaffe/libraries/javalib/gnu/java/awt/Buffers.java:1.3
--- kaffe/libraries/javalib/gnu/java/awt/Buffers.java:1.2	Mon Mar 22 11:24:09 2004
+++ kaffe/libraries/javalib/gnu/java/awt/Buffers.java	Tue May 18 16:13:27 2004
@@ -1,4 +1,4 @@
-/* Copyright (C) 2000, 2002  Free Software Foundation
+/* Copyright (C) 2000, 2002, 2004  Free Software Foundation
 
 This file is part of GNU Classpath.
 
@@ -36,10 +36,7 @@
 
 package gnu.java.awt;
 
-import java.awt.image.DataBuffer;
-import java.awt.image.DataBufferByte;
-import java.awt.image.DataBufferInt;
-import java.awt.image.DataBufferUShort;
+import java.awt.image.*;
 
 /** 
  * Utility class for creating and accessing data buffers of arbitrary
@@ -86,10 +83,16 @@
       {
       case DataBuffer.TYPE_BYTE:
 	return new DataBufferByte(size, numBanks);
+      case DataBuffer.TYPE_SHORT:
+	return new DataBufferShort(size, numBanks);
       case DataBuffer.TYPE_USHORT:
 	return new DataBufferUShort(size, numBanks);
       case DataBuffer.TYPE_INT:
 	return new DataBufferInt(size, numBanks);
+      case DataBuffer.TYPE_FLOAT:
+	return new DataBufferFloat(size, numBanks);
+      case DataBuffer.TYPE_DOUBLE:
+	return new DataBufferDouble(size, numBanks);
       default:
 	throw new UnsupportedOperationException();
       }
@@ -109,10 +112,16 @@
       {
       case DataBuffer.TYPE_BYTE:
 	return new DataBufferByte((byte[]) data, size);
+      case DataBuffer.TYPE_SHORT:
+	return new DataBufferShort((short[]) data, size);
       case DataBuffer.TYPE_USHORT:
 	return new DataBufferUShort((short[]) data, size);
       case DataBuffer.TYPE_INT:
 	return new DataBufferInt((int[]) data, size);
+      case DataBuffer.TYPE_FLOAT:
+	return new DataBufferFloat((float[]) data, size);
+      case DataBuffer.TYPE_DOUBLE:
+	return new DataBufferDouble((double[]) data, size);
       default:
 	throw new UnsupportedOperationException();
       }
@@ -129,10 +138,22 @@
   {
     if (buffer instanceof DataBufferByte)
       return ((DataBufferByte) buffer).getData();
+
+    if (buffer instanceof DataBufferShort)
+      return ((DataBufferShort) buffer).getData();
+
     if (buffer instanceof DataBufferUShort)
       return ((DataBufferUShort) buffer).getData();
+
     if (buffer instanceof DataBufferInt)
       return ((DataBufferInt) buffer).getData();
+
+    if (buffer instanceof DataBufferFloat)
+      return ((DataBufferFloat) buffer).getData();
+
+    if (buffer instanceof DataBufferDouble)
+      return ((DataBufferDouble) buffer).getData();
+
     throw new ClassCastException("Unknown data buffer type");
   }
 
@@ -152,6 +173,11 @@
 	from = ((DataBufferByte) src).getData();
 	if (dest == null) dest = new byte[length+destOffset];
       }
+    else if (src instanceof DataBufferShort)
+      {
+	from = ((DataBufferShort) src).getData();
+	if (dest == null) dest = new short[length+destOffset];
+      }
     else if (src instanceof DataBufferUShort)
       {
 	from = ((DataBufferUShort) src).getData();
@@ -161,6 +187,16 @@
       {
 	from = ((DataBufferInt) src).getData();
 	if (dest == null) dest = new int[length+destOffset];
+      }
+    else if (src instanceof DataBufferFloat)
+      {
+	from = ((DataBufferFloat) src).getData();
+	if (dest == null) dest = new float[length+destOffset];
+      }
+    else if (src instanceof DataBufferDouble)
+      {
+	from = ((DataBufferDouble) src).getData();
+	if (dest == null) dest = new double[length+destOffset];
       }
     else
       {
Index: kaffe/libraries/javalib/gnu/java/io/decode/Decoder.java
diff -u kaffe/libraries/javalib/gnu/java/io/decode/Decoder.java:1.2 kaffe/libraries/javalib/gnu/java/io/decode/Decoder.java:1.3
--- kaffe/libraries/javalib/gnu/java/io/decode/Decoder.java:1.2	Mon Mar 22 11:24:14 2004
+++ kaffe/libraries/javalib/gnu/java/io/decode/Decoder.java	Tue May 18 16:13:28 2004
@@ -1,5 +1,5 @@
 /* Decoder.java -- Base class for byte->char decoders
-   Copyright (C) 1998 Free Software Foundation, Inc.
+   Copyright (C) 1998, 2004 Free Software Foundation, Inc.
 
 This file is part of GNU Classpath.
 
@@ -60,16 +60,9 @@
  */
 
 /**
-  * This is the name of the current encoding. MUST be overriden by
-  * subclasses.
+  * This is the name of the current encoding. Set in the constructor.
   */
-protected static String scheme_name = "undefined";
-
-/**
-  * This is a description of the current encoding.  MUST be overridden
-  * by subclasses.
-  */
-protected static String scheme_description = "undefined";
+private final String scheme_name;
 
 /*************************************************************************/
 
@@ -80,62 +73,46 @@
 /**
   * This is the <code>InputStream</code> bytes are read from
   */
-protected InputStream in;
+protected final InputStream in;
 
 /*************************************************************************/
 
 /*
- * Class Methods
+ * Constructors
  */
 
 /**
-  * This method returns the name of the encoding scheme in use
-  *
-  * @return The name of the encoding scheme
-  */
-public static String
-getSchemeName()
-{
-  return(scheme_name);
-}
-
-/*************************************************************************/
-
-/**
-  * This method returns a description of the encoding scheme in use
+  * This method initializes a new <code>Decoder</code> to read from the
+  * specified <code>InputStream</code>.
   *
-  * @param A description of the decoding scheme.
+  * @param in The <code>InputStream</code> to read from
+  * @param name The character scheme name
   */
-public static String
-getSchemeDescription()
+protected
+Decoder(InputStream in, String name)
 {
-  return(scheme_description);
+  this.in = in;
+  this.scheme_name = name;
 }
 
 /*************************************************************************/
 
 /*
- * Constructors
+ * Instance Methods
  */
 
 /**
-  * This method initializes a new <code>Decoder</code> to read from the
-  * specified <code>InputStream</code>.
+  * This method returns the name of the encoding scheme in use
   *
-  * @param in The <code>InputStream</code> to read from
+  * @return The name of the encoding scheme
   */
-public
-Decoder(InputStream in)
+public String
+getSchemeName()
 {
-  this.in = in;
+  return(scheme_name);
 }
 
 /*************************************************************************/
-
-/*
- * Instance Methods
- */
-
 /**
   * For a given set of bytes, this method returns the number of characters
   * that byte array will translate into.  If the bytes do not all translate 
@@ -197,7 +174,7 @@
 /*************************************************************************/
 
 /**
-  * This method converts <code>len<code> bytes from a specified array to
+  * This method converts <code>len</code> bytes from a specified array to
   * characters starting at index <code>offset</code> into the array.  The
   * results are returned in a newly allocated char array.
   *
Index: kaffe/libraries/javalib/gnu/java/io/decode/KaffeDecoder.java
diff -u kaffe/libraries/javalib/gnu/java/io/decode/KaffeDecoder.java:1.3 kaffe/libraries/javalib/gnu/java/io/decode/KaffeDecoder.java:1.4
--- kaffe/libraries/javalib/gnu/java/io/decode/KaffeDecoder.java:1.3	Mon Mar 22 11:24:14 2004
+++ kaffe/libraries/javalib/gnu/java/io/decode/KaffeDecoder.java	Tue May 18 16:13:28 2004
@@ -41,7 +41,7 @@
 KaffeDecoder(InputStream in, String enc)
    throws java.io.UnsupportedEncodingException
 {
-  super(in);
+  super(in, enc);
   // try {
       converter = ByteToCharConverter.getConverter(enc);
   // }
Index: kaffe/libraries/javalib/gnu/java/io/encode/Encoder.java
diff -u kaffe/libraries/javalib/gnu/java/io/encode/Encoder.java:1.2 kaffe/libraries/javalib/gnu/java/io/encode/Encoder.java:1.3
--- kaffe/libraries/javalib/gnu/java/io/encode/Encoder.java:1.2	Mon Mar 22 11:24:14 2004
+++ kaffe/libraries/javalib/gnu/java/io/encode/Encoder.java	Tue May 18 16:13:28 2004
@@ -1,5 +1,5 @@
 /* Encoder.java -- Base class for char->byte encoders
-   Copyright (C) 1998 Free Software Foundation, Inc.
+   Copyright (C) 1998, 2004 Free Software Foundation, Inc.
 
 This file is part of GNU Classpath.
 
@@ -63,13 +63,7 @@
   * This is the name of the current encoding. MUST be overriden by
   * subclasses.
   */
-protected static String scheme_name = "undefined";
-
-/**
-  * This is a description of the current encoding.  MUST be overridden
-  * by subclasses.
-  */
-protected static String scheme_description = "undefined";
+private final String scheme_name;
 
 /*************************************************************************/
 
@@ -80,7 +74,7 @@
 /**
   * This is the <code>OutputStream</code> bytes are written to
   */
-protected OutputStream out;
+protected final OutputStream out;
 
 /**
   * This is the value that is substituted for bad characters that can't
@@ -104,7 +98,7 @@
   *
   * @return The name of the encoding scheme
   */
-public static String
+public String
 getSchemeName()
 {
   return(scheme_name);
@@ -112,19 +106,6 @@
 
 /*************************************************************************/
 
-/**
-  * This method returns a description of the encoding scheme in use
-  *
-  * @param A description of the decoding scheme.
-  */
-public static String
-getSchemeDescription()
-{
-  return(scheme_description);
-}
-
-/*************************************************************************/
-
 /*
  * Constructors
  */
@@ -133,12 +114,14 @@
   * This method initializes a new <code>Encoder</code> to write to the
   * specified <code>OutputStream</code>.
   *
+  * @param name The character scheme name
   * @param out The <code>OutputStream</code> to read from
   */
-public
-Encoder(OutputStream out)
+protected
+Encoder(OutputStream out, String name)
 {
   this.out = out;
+  this.scheme_name = name;
 }
 
 /*************************************************************************/
@@ -212,7 +195,7 @@
 /*************************************************************************/
 
 /**
-  * This method converts <code>len<code> chars from a specified array to
+  * This method converts <code>len</code> chars from a specified array to
   * bytes starting at index <code>offset</code> into the array.  The
   * results are returned in a newly allocated byte array.
   *
Index: kaffe/libraries/javalib/gnu/java/io/encode/KaffeEncoder.java
diff -u kaffe/libraries/javalib/gnu/java/io/encode/KaffeEncoder.java:1.2 kaffe/libraries/javalib/gnu/java/io/encode/KaffeEncoder.java:1.3
--- kaffe/libraries/javalib/gnu/java/io/encode/KaffeEncoder.java:1.2	Mon Mar 22 11:24:14 2004
+++ kaffe/libraries/javalib/gnu/java/io/encode/KaffeEncoder.java	Tue May 18 16:13:28 2004
@@ -48,7 +48,7 @@
 public
 KaffeEncoder(OutputStream out, String enc)
 {
-  super(out);
+  super(out, enc);
   try {
       converter = CharToByteConverter.getConverter(enc);
   }
Index: kaffe/libraries/javalib/gnu/java/nio/channels/FileChannelImpl.java
diff -u kaffe/libraries/javalib/gnu/java/nio/channels/FileChannelImpl.java:1.1 kaffe/libraries/javalib/gnu/java/nio/channels/FileChannelImpl.java:1.2
--- kaffe/libraries/javalib/gnu/java/nio/channels/FileChannelImpl.java:1.1	Mon Apr 12 11:40:24 2004
+++ kaffe/libraries/javalib/gnu/java/nio/channels/FileChannelImpl.java	Tue May 18 16:13:29 2004
@@ -60,13 +60,8 @@
  * Instances of this class are created by invoking getChannel
  * Upon a Input/Output/RandomAccessFile object.
  */
-
 public final class FileChannelImpl extends FileChannel
 {
-  // These are WHENCE values for seek.
-//   public static final int SET = 0;
-//   public static final int CUR = 1;
-
   // These are mode values for open().
   public static final int READ   = 1;
   public static final int WRITE  = 2;
@@ -97,11 +92,9 @@
   // However, this is necessary because if open() throws an exception
   // we want to make sure this has the value -1.  This is the most
   // efficient way to accomplish that.
-  int fd = -1;
+  private int fd = -1;
 
-  int mode;
-  int length;
-  long pos;
+  private int mode;
 
   public FileChannelImpl ()
   {
@@ -114,30 +107,38 @@
     this.mode = mode;
   }
 
+  /* Used by init() (native code) */
+  FileChannelImpl (int fd, int mode)
+  {
+    this.fd = fd;
+    this.mode = mode;
+  }
+
   public static FileChannelImpl in;
   public static FileChannelImpl out;
   public static FileChannelImpl err;
 
   private native int open (String path, int mode) throws FileNotFoundException;
 
-  /** Attach to an already-opened file.  */
-  public FileChannelImpl (int desc, int mode)
-  {
-    fd = desc;
-    this.mode = mode;
-  }
-
   public native int available () throws IOException;
-  private native long implPosition ();
-  private native void seek (long newPosition);
-  private native void implTruncate (long size);
+  private native long implPosition () throws IOException;
+  private native void seek (long newPosition) throws IOException;
+  private native void implTruncate (long size) throws IOException;
   
-  public native void unlock (long pos, long len);
+  public native void unlock (long pos, long len) throws IOException;
 
   public native long size () throws IOException;
     
   protected native void implCloseChannel() throws IOException;
 
+  /**
+   * Makes sure the Channel is properly closed.
+   */
+  protected void finalize() throws IOException
+  {
+    this.close();
+  }
+
   public int read (ByteBuffer dst) throws IOException
   {
     int result;
@@ -356,7 +357,7 @@
    * Otherwise return false.
    */
   private native boolean lock(long position, long size,
-			      boolean shared, boolean wait);
+			      boolean shared, boolean wait) throws IOException;
   
   public FileLock lock (long position, long size, boolean shared)
     throws IOException
@@ -420,7 +421,9 @@
     if ((mode & WRITE) == 0)
        throw new NonWritableChannelException ();
 
-    implTruncate (size);
+    if (size < size ())
+      implTruncate (size);
+
     return this;
   }
 }
Index: kaffe/libraries/javalib/gnu/java/nio/charset/UTF_16Decoder.java
diff -u kaffe/libraries/javalib/gnu/java/nio/charset/UTF_16Decoder.java:1.1 kaffe/libraries/javalib/gnu/java/nio/charset/UTF_16Decoder.java:1.2
--- kaffe/libraries/javalib/gnu/java/nio/charset/UTF_16Decoder.java:1.1	Thu Nov 28 13:39:26 2002
+++ kaffe/libraries/javalib/gnu/java/nio/charset/UTF_16Decoder.java	Tue May 18 16:13:30 2004
@@ -144,24 +144,6 @@
       }
   }
 
-  /**
-   * Writes <code>c</code> to <code>out</code> in the byte order
-   * specified by <code>byteOrder</code>.
-   **/
-  private void put (ByteBuffer out, char c)
-  {
-    if (byteOrder == BIG_ENDIAN)
-      {
-        out.put ((byte) (c >> 8));
-        out.put ((byte) (c & 0xFF));
-      }
-    else
-      {
-        out.put ((byte) (c & 0xFF));
-        out.put ((byte) (c >> 8));
-      }
-  }
-
   protected void implReset ()
   {
     byteOrder = originalByteOrder;
Index: kaffe/libraries/javalib/gnu/java/security/der/DERReader.java
diff -u kaffe/libraries/javalib/gnu/java/security/der/DERReader.java:1.2 kaffe/libraries/javalib/gnu/java/security/der/DERReader.java:1.3
--- kaffe/libraries/javalib/gnu/java/security/der/DERReader.java:1.2	Mon Mar 22 11:24:24 2004
+++ kaffe/libraries/javalib/gnu/java/security/der/DERReader.java	Tue May 18 16:13:31 2004
@@ -38,23 +38,26 @@
 
 package gnu.java.security.der;
 
-import gnu.java.security.OID;
-
 import java.io.BufferedInputStream;
 import java.io.ByteArrayInputStream;
 import java.io.ByteArrayOutputStream;
 import java.io.EOFException;
-import java.io.IOException;
 import java.io.InputStream;
+import java.io.IOException;
+
 import java.math.BigInteger;
+
 import java.nio.ByteBuffer;
 import java.nio.CharBuffer;
 import java.nio.charset.Charset;
 import java.nio.charset.CharsetDecoder;
+
 import java.util.Calendar;
 import java.util.Date;
 import java.util.TimeZone;
 
+import gnu.java.security.OID;
+
 /**
  * This class decodes DER sequences into Java objects. The methods of
  * this class do not have knowledge of higher-levels of structure in the
@@ -332,7 +335,7 @@
               Integer.parseInt(str.substring( 6,  8)),    // hour
               Integer.parseInt(str.substring( 8, 10)));   // minute
             if (date.length() == 12);
-              calendar.set(calendar.SECOND,
+              calendar.set(Calendar.SECOND,
                 Integer.parseInt(str.substring(10, 12)));
           }
         catch (NumberFormatException nfe)
@@ -359,13 +362,13 @@
                 case 18:
                 case 17:
                 case 16:
-                  calendar.set(calendar.MILLISECOND,
+                  calendar.set(Calendar.MILLISECOND,
                     Integer.parseInt(date.substring(15)));
                 case 14:
-                  calendar.set(calendar.SECOND,
+                  calendar.set(Calendar.SECOND,
                     Integer.parseInt(date.substring(12, 14)));
                 case 12:
-                  calendar.set(calendar.MINUTE,
+                  calendar.set(Calendar.MINUTE,
                     Integer.parseInt(date.substring(10, 12)));
               }
           }
Index: kaffe/libraries/javalib/gnu/java/text/AttributedFormatBuffer.java
diff -u kaffe/libraries/javalib/gnu/java/text/AttributedFormatBuffer.java:1.3 kaffe/libraries/javalib/gnu/java/text/AttributedFormatBuffer.java:1.4
--- kaffe/libraries/javalib/gnu/java/text/AttributedFormatBuffer.java:1.3	Wed Mar 24 20:23:58 2004
+++ kaffe/libraries/javalib/gnu/java/text/AttributedFormatBuffer.java	Tue May 18 16:13:31 2004
@@ -40,6 +40,12 @@
 import java.util.ArrayList;
 import java.util.HashMap;
 
+/**
+ * This class is an implementation of a FormatBuffer with attributes.
+ * 
+ * @author Guilhem Lavaux <guilhem@kaffe.org>
+ * @date April 10, 2004
+ */
 public class AttributedFormatBuffer implements FormatBuffer
 {
   private StringBuffer buffer;
@@ -50,13 +56,23 @@
   private int startingRange;
   AttributedCharacterIterator.Attribute defaultAttr;
 
+  /**
+   * This constructor accepts a StringBuffer. If the buffer contains
+   * already some characters they will not be attributed. 
+   */
   public AttributedFormatBuffer(StringBuffer buffer)
   {
     this.buffer = buffer;
     this.ranges = new ArrayList();
     this.attributes = new ArrayList();
     this.defaultAttr = null;
-    this.startingRange = -1;
+    if (buffer.length() != 0)
+      {
+	this.startingRange = buffer.length();
+	addAttribute(buffer.length(), null);
+      }
+    else
+      this.startingRange = -1;
   }
 
   public AttributedFormatBuffer(int prebuffer)
@@ -178,6 +194,10 @@
     startingRange = -1;
   }
 
+  /**
+   * This method synchronizes the state of the attribute array.
+   * After calling it you may call {@link #getDefaultAttribute()}.
+   */
   public void sync()
   {
     if (startingRange < 0 || startingRange == buffer.length())
@@ -193,16 +213,33 @@
     System.arraycopy(attributes.toArray(), 0, a_attributes, 0, a_attributes.length);
   }
 
+  /**
+   * This method returns the internal StringBuffer describing
+   * the attributed string.
+   *
+   * @return An instance of StringBuffer which contains the string.
+   */
   public StringBuffer getBuffer()
   {
     return buffer;
   }
-  
+
+  /**
+   * This method returns the ranges for the attributes.
+   *
+   * @return An array of int describing the ranges.
+   */
   public int[] getRanges()
   {
     return a_ranges;
   }
 
+  /**
+   * This method returns the array containing the map on the 
+   * attributes.
+   *
+   * @return An array of {@link java.util.Map} containing the attributes.
+   */
   public HashMap[] getAttributes()
   {
     return a_attributes;
Index: kaffe/libraries/javalib/gnu/java/text/CharacterBreakIterator.java
diff -u kaffe/libraries/javalib/gnu/java/text/CharacterBreakIterator.java:1.2 kaffe/libraries/javalib/gnu/java/text/CharacterBreakIterator.java:1.3
--- kaffe/libraries/javalib/gnu/java/text/CharacterBreakIterator.java:1.2	Mon Mar 22 11:24:26 2004
+++ kaffe/libraries/javalib/gnu/java/text/CharacterBreakIterator.java	Tue May 18 16:13:31 2004
@@ -160,7 +160,6 @@
     if (iter.getIndex() == iter.getBeginIndex())
       return DONE;
 
-    int start = iter.getBeginIndex();
     while (iter.getIndex() >= iter.getBeginIndex())
       {
 	char c = iter.previous();
Index: kaffe/libraries/javalib/gnu/java/text/FormatBuffer.java
diff -u kaffe/libraries/javalib/gnu/java/text/FormatBuffer.java:1.3 kaffe/libraries/javalib/gnu/java/text/FormatBuffer.java:1.4
--- kaffe/libraries/javalib/gnu/java/text/FormatBuffer.java:1.3	Wed Mar 24 20:23:58 2004
+++ kaffe/libraries/javalib/gnu/java/text/FormatBuffer.java	Tue May 18 16:13:31 2004
@@ -39,17 +39,98 @@
 import java.text.AttributedCharacterIterator;
 import java.util.HashMap;
 
+/**
+ * This interface describes a modifiable buffer which contains attributed
+ * characters. The implementation may or may not implements attributes. It
+ * aims to greatly simplify and clarify the implementation of java.text 
+ * formatters. The buffer may be appended or have its tail cut. It may also
+ * be completely cleant up.
+ *
+ * @author Guilhem Lavaux <guilhem@kaffe.org>
+ * @date April 10, 2004
+ */
 public interface FormatBuffer 
 {
+  /**
+   * This method appends a simple string to the buffer. This part of
+   * the buffer will be attributed using the default attribute.
+   *
+   * @param s The string to append to the buffer.
+   */
   public void append(String s);
+
+  /**
+   * This method appends a simple string to the buffer. This part of
+   * the buffer will have the specified attribute (and only this one).
+   * The default attribute may be changed after calling this method.
+   *
+   * @param s The string to append to the buffer.
+   * @param attr Attribute to use for the string in the buffer.
+   */
   public void append(String s, AttributedCharacterIterator.Attribute attr);
+
+  /**
+   * This method appends a simple string to the buffer. This part of
+   * the buffer will be attributed using the specified ranges and attributes.
+   * To have an example on how to specify ranges see {@link gnu.java.text.FormatCharacterIterator}. 
+   * 
+   * @param s The string to append to the buffer.
+   * @param ranges The ranges describing how the attributes should be applied
+   * to the string.
+   * @param attrs The attributes of the string in the buffer.
+   */
   public void append(String s, int[] ranges, HashMap[] attrs);
+
+  /**
+   * This method appends a simple char to the buffer. This part of
+   * the buffer will be attributed using the default attribute.
+   *
+   * @param c The character to append to the buffer.
+   */
   public void append(char c);
+
+  /**
+   * This method appends a simple character to the buffer. This part of
+   * the buffer will have the specified attribute (and only this one).
+   * The default attribute may be changed after calling this method.
+   *
+   * @param c The character to append to the buffer.
+   * @param attr Attribute to use for the character in the buffer.
+   */
   public void append(char c, AttributedCharacterIterator.Attribute attr);
+
+  /**
+   * This method changes the current default attribute for the next string
+   * or character which will be appended to the buffer.
+   *
+   * @param attr The attribute which will be used by default.
+   */
   public void setDefaultAttribute(AttributedCharacterIterator.Attribute attr);
+
+  /**
+   * This method returns the current default attribute for the buffer.
+   *
+   * @return The default attribute for the buffer.
+   */
   public AttributedCharacterIterator.Attribute getDefaultAttribute();
+
+  /**
+   * This method cuts the last characters of the buffer. The number of
+   * characters to cut is given by "length".

*** Patch too long, truncated ***