[kaffe] CVS kaffe (dalibor): Resynced with GNU Classpath: various small fixes
Kaffe CVS
Kaffe Mailing List <kaffe@kaffe.org>
Mon May 17 07:09:02 2004
PatchSet 4737
Date: 2004/05/17 13:54:58
Author: dalibor
Branch: HEAD
Tag: (none)
Log:
Resynced with GNU Classpath: various small fixes
2004-05-17 Dalibor Topic <robilad@kaffe.org>
* libraries/javalib/java/beans/Introspector.java,
libraries/javalib/java/beans/PropertyEditor.java,
libraries/javalib/java/beans/PropertyEditorManager.java,
libraries/javalib/java/beans/beancontext/BeanContextServiceProvider.java,
libraries/javalib/java/lang/Throwable.java,
libraries/javalib/java/security/SignedObject.java,
libraries/javalib/java/security/UnresolvedPermission.java,
libraries/javalib/java/text/AttributedString.java,
libraries/javalib/java/util/Calendar.java,
libraries/javalib/java/util/Date.java,
libraries/javalib/java/util/HashMap.java,
libraries/javalib/java/util/logging/Level.java,
libraries/javalib/java/util/zip/GZIPOutputStream.java:
Resynced with GNU Classpath.
2004-04-23 Tom Tromey <tromey@redhat.com>
* java/security/UnresolvedPermission.java: Cleaned up imports.
* java/util/Date.java (parse): Removed unused variable.
2004-04-17 Michael Koch <konqueror@gmx.de>
* java/security/SignedObject.java:
Fixed HTML tags in javadoc comments all over.
2004-04-17 Michael Koch <konqueror@gmx.de>
* java/beans/Introspector.java,
java/beans/PropertyEditor.java,
java/beans/PropertyEditorManager.java,
java/beans/beancontext/BeanContextServiceProvider.java:
Fixed HTML tags in javadocs.
2004-04-29 Mark Wielaard <mark@klomp.org>
Reported by f.haeglsperger@gmx.de [patch #2485]
* java/util/HashMap.java (rehash): Add entry at start of bucket.
2004-05-07 Jerry Quinn <jlquinn@optonline.net>
* java/util/Calendar.java (getActualMinimum,
getActualMaximum): Remove abstract. Implement.
2004-05-06 Michael Koch <konqueror@gmx.de>
* java/util/logging/Level.java:
Explicitly import java.io.Serializable.
2004-05-05 Michael Koch <konqueror@gmx.de>
* java/util/zip/GZIPOutputStream.java
(GZIPOutputStream): Initialize crc.
2004-04-29 Tom Tromey <tromey@redhat.com>
* java/text/AttributedString.java: Cleaned up imports.
2004-04-17 Michael Koch <konqueror@gmx.de>
* java/lang/CharSequence.java
(subSequence): Fixed <code> tag in javadoc.
2004-04-30 Grzegorz B. Prokopski <gadek@debian.org>
* java/lang/Throwable.java (nl): Remove static field.
(StaticData): New private static inner class.
(stackTraceStringBuffer): Use StaticData.nl.
Members:
ChangeLog:1.2311->1.2312
libraries/javalib/java/beans/Introspector.java:1.17->1.18
libraries/javalib/java/beans/PropertyEditor.java:1.4->1.5
libraries/javalib/java/beans/PropertyEditorManager.java:1.5->1.6
libraries/javalib/java/beans/beancontext/BeanContextServiceProvider.java:1.2->1.3
libraries/javalib/java/lang/Throwable.java:1.11->1.12
libraries/javalib/java/security/SignedObject.java:1.2->1.3
libraries/javalib/java/security/UnresolvedPermission.java:1.2->1.3
libraries/javalib/java/text/AttributedString.java:1.6->1.7
libraries/javalib/java/util/Calendar.java:1.19->1.20
libraries/javalib/java/util/Date.java:1.21->1.22
libraries/javalib/java/util/HashMap.java:1.22->1.23
libraries/javalib/java/util/logging/Level.java:1.2->1.3
libraries/javalib/java/util/zip/GZIPOutputStream.java:1.6->1.7
Index: kaffe/ChangeLog
diff -u kaffe/ChangeLog:1.2311 kaffe/ChangeLog:1.2312
--- kaffe/ChangeLog:1.2311 Sun May 16 16:45:14 2004
+++ kaffe/ChangeLog Mon May 17 13:54:58 2004
@@ -1,3 +1,73 @@
+2004-05-17 Dalibor Topic <robilad@kaffe.org>
+
+ * libraries/javalib/java/beans/Introspector.java,
+ libraries/javalib/java/beans/PropertyEditor.java,
+ libraries/javalib/java/beans/PropertyEditorManager.java,
+ libraries/javalib/java/beans/beancontext/BeanContextServiceProvider.java,
+ libraries/javalib/java/lang/Throwable.java,
+ libraries/javalib/java/security/SignedObject.java,
+ libraries/javalib/java/security/UnresolvedPermission.java,
+ libraries/javalib/java/text/AttributedString.java,
+ libraries/javalib/java/util/Calendar.java,
+ libraries/javalib/java/util/Date.java,
+ libraries/javalib/java/util/HashMap.java,
+ libraries/javalib/java/util/logging/Level.java,
+ libraries/javalib/java/util/zip/GZIPOutputStream.java:
+ Resynced with GNU Classpath.
+
+ 2004-04-23 Tom Tromey <tromey@redhat.com>
+
+ * java/security/UnresolvedPermission.java: Cleaned up imports.
+ * java/util/Date.java (parse): Removed unused variable.
+
+ 2004-04-17 Michael Koch <konqueror@gmx.de>
+
+ * java/security/SignedObject.java:
+ Fixed HTML tags in javadoc comments all over.
+
+ 2004-04-17 Michael Koch <konqueror@gmx.de>
+
+ * java/beans/Introspector.java,
+ java/beans/PropertyEditor.java,
+ java/beans/PropertyEditorManager.java,
+ java/beans/beancontext/BeanContextServiceProvider.java:
+ Fixed HTML tags in javadocs.
+
+ 2004-04-29 Mark Wielaard <mark@klomp.org>
+
+ Reported by f.haeglsperger@gmx.de [patch #2485]
+ * java/util/HashMap.java (rehash): Add entry at start of bucket.
+
+ 2004-05-07 Jerry Quinn <jlquinn@optonline.net>
+
+ * java/util/Calendar.java (getActualMinimum,
+ getActualMaximum): Remove abstract. Implement.
+
+ 2004-05-06 Michael Koch <konqueror@gmx.de>
+
+ * java/util/logging/Level.java:
+ Explicitly import java.io.Serializable.
+
+ 2004-05-05 Michael Koch <konqueror@gmx.de>
+
+ * java/util/zip/GZIPOutputStream.java
+ (GZIPOutputStream): Initialize crc.
+
+ 2004-04-29 Tom Tromey <tromey@redhat.com>
+
+ * java/text/AttributedString.java: Cleaned up imports.
+
+ 2004-04-17 Michael Koch <konqueror@gmx.de>
+
+ * java/lang/CharSequence.java
+ (subSequence): Fixed <code> tag in javadoc.
+
+ 2004-04-30 Grzegorz B. Prokopski <gadek@debian.org>
+
+ * java/lang/Throwable.java (nl): Remove static field.
+ (StaticData): New private static inner class.
+ (stackTraceStringBuffer): Use StaticData.nl.
+
2004-05-16 Guilhem Lavaux <guilhem@kaffe.org>
* libraries/javalib/java/text/CollationElementIterator.java
Index: kaffe/libraries/javalib/java/beans/Introspector.java
diff -u kaffe/libraries/javalib/java/beans/Introspector.java:1.17 kaffe/libraries/javalib/java/beans/Introspector.java:1.18
--- kaffe/libraries/javalib/java/beans/Introspector.java:1.17 Mon Mar 22 11:24:42 2004
+++ kaffe/libraries/javalib/java/beans/Introspector.java Mon May 17 13:55:02 2004
@@ -66,7 +66,7 @@
* When you call getBeanInfo(class c), the Introspector
* first searches for BeanInfo class to see if you
* provided any explicit information. It searches for a
- * class named <bean class name>BeanInfo in different
+ * class named <bean class name>BeanInfo in different
* packages, first searching the bean class's package
* and then moving on to search the beanInfoSearchPath.<P>
*
@@ -114,14 +114,14 @@
* type <type>. There may also be a
* <CODE>public <type>[] getXXX()</CODE> and a
* <CODE>public void setXXX(<type>)</CODE>
- * method as well.</CODE></LI>
+ * method as well.</LI>
* <LI>If there is a
* <CODE>public void setXXX(int,<type>)</CODE>
* method, then it is a write-only indexed property of
* type <type>. There may also be a
* <CODE>public <type>[] getXXX()</CODE> and a
* <CODE>public void setXXX(<type>)</CODE>
- * method as well.</CODE></LI>
+ * method as well.</LI>
* <LI>If there is a
* <CODE>public <type> getXXX()</CODE> method,
* then XXX is a read-only property of type
Index: kaffe/libraries/javalib/java/beans/PropertyEditor.java
diff -u kaffe/libraries/javalib/java/beans/PropertyEditor.java:1.4 kaffe/libraries/javalib/java/beans/PropertyEditor.java:1.5
--- kaffe/libraries/javalib/java/beans/PropertyEditor.java:1.4 Wed Oct 22 10:34:52 2003
+++ kaffe/libraries/javalib/java/beans/PropertyEditor.java Mon May 17 13:55:02 2004
@@ -77,7 +77,7 @@
** have isPaintable() return true and implement the paintValue() method.
** This method does not determine in any way how the value is edited;
** merely how it is displayed.</LI>
- ** <LU>Let the caller of the PropertyEditor give the user a text input. Do
+ ** <LI>Let the caller of the PropertyEditor give the user a text input. Do
** this by returning a non-null String from getAsText(). If you support
** text input, you *must* support setAsText().</LI>
** <LI>Give the caller a set of possible values, such as "true"/"false", that
Index: kaffe/libraries/javalib/java/beans/PropertyEditorManager.java
diff -u kaffe/libraries/javalib/java/beans/PropertyEditorManager.java:1.5 kaffe/libraries/javalib/java/beans/PropertyEditorManager.java:1.6
--- kaffe/libraries/javalib/java/beans/PropertyEditorManager.java:1.5 Mon Mar 22 11:24:42 2004
+++ kaffe/libraries/javalib/java/beans/PropertyEditorManager.java Mon May 17 13:55:02 2004
@@ -61,19 +61,20 @@
* already registered; if it is, that property editor is
* used. Next it takes the type's classname and appends
* "Editor" to it, and searches first in the class's
- * package and then in the property editor search path.<P>
+ * package and then in the property editor search path.
*
- * Default property editors are provided for:<P>
- * <OL>
- * <LI>boolean, byte, short, int, long, float, and double</LI>
- * <LI>java.lang.String</LI>
- * <LI>java.awt.Color</LI>
- * <LI>java.awt.Font</LI>
- * <OL>
+ * <p>Default property editors are provided for:</p>
+ *
+ * <ol>
+ * <li>boolean, byte, short, int, long, float, and double</li>
+ * <li>java.lang.String</li>
+ * <li>java.awt.Color</li>
+ * <li>java.awt.Font</li>
+ * </ol>
*
- * <STRONG>Spec Suggestion:</STRONG> Perhaps an editor for
+ * <p><strong>Spec Suggestion:</strong> Perhaps an editor for
* Filename or something like it should be provided. As well
- * as char.
+ * as char.</p>
*
* @author John Keiser
* @since 1.1
Index: kaffe/libraries/javalib/java/beans/beancontext/BeanContextServiceProvider.java
diff -u kaffe/libraries/javalib/java/beans/beancontext/BeanContextServiceProvider.java:1.2 kaffe/libraries/javalib/java/beans/beancontext/BeanContextServiceProvider.java:1.3
--- kaffe/libraries/javalib/java/beans/beancontext/BeanContextServiceProvider.java:1.2 Wed Oct 22 10:34:53 2003
+++ kaffe/libraries/javalib/java/beans/beancontext/BeanContextServiceProvider.java Mon May 17 13:55:03 2004
@@ -62,14 +62,12 @@
public interface BeanContextServiceProvider {
/**
* Get a service.
- * Called from <code>BeanContextServices.getService().
- * <P>
+ * Called from <code>BeanContextServices.getService()</code>.
*
- * If the requested service class is not available, or if this
+ * <p>If the requested service class is not available, or if this
* <code>BeanContextServiceProvider</code> chooses not honor the
* request for some reason, then this method will return
- * <code>null</code>.
- * <P>
+ * <code>null</code>.</p>
*
* This method may throw unchecked exceptions, so watch out.
*
Index: kaffe/libraries/javalib/java/lang/Throwable.java
diff -u kaffe/libraries/javalib/java/lang/Throwable.java:1.11 kaffe/libraries/javalib/java/lang/Throwable.java:1.12
--- kaffe/libraries/javalib/java/lang/Throwable.java:1.11 Mon Mar 22 11:24:47 2004
+++ kaffe/libraries/javalib/java/lang/Throwable.java Mon May 17 13:55:03 2004
@@ -1,5 +1,5 @@
/* java.lang.Throwable -- Root class for all Exceptions and Errors
- Copyright (C) 1998, 1999, 2002 Free Software Foundation, Inc.
+ Copyright (C) 1998, 1999, 2002, 2004 Free Software Foundation, Inc.
This file is part of GNU Classpath.
@@ -388,7 +388,7 @@
* then a line starting with three spaces and the string "... X more" is
* printed, where X is the number of remaining stackframes.
*
- * @param w the PrintWriter to write the trace to
+ * @param pw the PrintWriter to write the trace to
* @since 1.1
*/
public void printStackTrace (PrintWriter pw)
@@ -396,7 +396,20 @@
pw.print(stackTraceString());
}
- private static final String nl = System.getProperty("line.separator");
+ /*
+ * We use inner class to avoid a static initializer in this basic class.
+ */
+ private static class StaticData
+ {
+
+ private final static String nl;
+
+ static
+ {
+ nl = System.getProperty("line.separator");
+ }
+ }
+
// Create whole stack trace in a stringbuffer so we don't have to print
// it line by line. This prevents printing multiple stack traces from
// different threads to get mixed up when written to the same PrintWriter.
@@ -449,6 +462,7 @@
private static void stackTraceStringBuffer(StringBuffer sb, String name,
StackTraceElement[] stack, int equal)
{
+ String nl = StaticData.nl;
// (finish) first line
sb.append(name);
sb.append(nl);
Index: kaffe/libraries/javalib/java/security/SignedObject.java
diff -u kaffe/libraries/javalib/java/security/SignedObject.java:1.2 kaffe/libraries/javalib/java/security/SignedObject.java:1.3
--- kaffe/libraries/javalib/java/security/SignedObject.java:1.2 Wed May 14 23:20:09 2003
+++ kaffe/libraries/javalib/java/security/SignedObject.java Mon May 17 13:55:04 2004
@@ -98,7 +98,7 @@
* <p>The signature algorithm can be, among others, the NIST standard <i>DSS</i>,
* using <i>DSA</i> and <i>SHA-1</i>. The algorithm is specified using the same
* convention as that for signatures. The <i>DSA</i> algorithm using the
- * </i>SHA-1</i> message digest algorithm can be specified, for example, as
+ * <i>SHA-1</i> message digest algorithm can be specified, for example, as
* <code>"SHA/DSA"</code> or <code>"SHA-1/DSA"</code> (they are equivalent). In
* the case of <i>RSA</i>, there are multiple choices for the message digest
* algorithm, so the signing algorithm could be specified as, for example,
Index: kaffe/libraries/javalib/java/security/UnresolvedPermission.java
diff -u kaffe/libraries/javalib/java/security/UnresolvedPermission.java:1.2 kaffe/libraries/javalib/java/security/UnresolvedPermission.java:1.3
--- kaffe/libraries/javalib/java/security/UnresolvedPermission.java:1.2 Mon Mar 22 11:24:59 2004
+++ kaffe/libraries/javalib/java/security/UnresolvedPermission.java Mon May 17 13:55:05 2004
@@ -37,6 +37,8 @@
package java.security;
+// All uses of Certificate in this file refer to the one in the listed
+// package, not this one.
import java.security.cert.Certificate;
import java.util.Arrays;
import java.util.Enumeration;
Index: kaffe/libraries/javalib/java/text/AttributedString.java
diff -u kaffe/libraries/javalib/java/text/AttributedString.java:1.6 kaffe/libraries/javalib/java/text/AttributedString.java:1.7
--- kaffe/libraries/javalib/java/text/AttributedString.java:1.6 Fri Apr 23 17:35:12 2004
+++ kaffe/libraries/javalib/java/text/AttributedString.java Mon May 17 13:55:05 2004
@@ -40,7 +40,6 @@
import java.util.Arrays;
import java.util.HashMap;
-import java.util.HashSet;
import java.util.Hashtable;
import java.util.Iterator;
import java.util.Map;
Index: kaffe/libraries/javalib/java/util/Calendar.java
diff -u kaffe/libraries/javalib/java/util/Calendar.java:1.19 kaffe/libraries/javalib/java/util/Calendar.java:1.20
--- kaffe/libraries/javalib/java/util/Calendar.java:1.19 Thu Apr 22 11:40:44 2004
+++ kaffe/libraries/javalib/java/util/Calendar.java Mon May 17 13:55:06 2004
@@ -926,8 +926,21 @@
* @return the actual minimum value.
* @since jdk1.2
*/
- // FIXME: XXX: Not abstract in JDK 1.2.
- public abstract int getActualMinimum(int field);
+ public int getActualMinimum(int field)
+ {
+ Calendar tmp = (Calendar)clone(); // To avoid restoring state
+ int min = tmp.getGreatestMinimum(field);
+ int end = tmp.getMinimum(field);
+ tmp.set(field, min);
+ for (; min > end; min--)
+ {
+ tmp.add(field, -1); // Try to get smaller
+ if (tmp.get(field) != min - 1)
+ break; // Done if not successful
+
+ }
+ return min;
+ }
/**
* Gets the actual maximum value that is allowed for the specified field.
@@ -936,8 +949,20 @@
* @return the actual maximum value.
* @since jdk1.2
*/
- // FIXME: XXX: Not abstract in JDK 1.2.
- public abstract int getActualMaximum(int field);
+ public int getActualMaximum(int field)
+ {
+ Calendar tmp = (Calendar)clone(); // To avoid restoring state
+ int max = tmp.getLeastMaximum(field);
+ int end = tmp.getMaximum(field);
+ tmp.set(field, max);
+ for (; max < end; max++)
+ {
+ tmp.add(field, 1);
+ if (tmp.get(field) != max + 1)
+ break;
+ }
+ return max;
+ }
/**
* Return a clone of this object.
Index: kaffe/libraries/javalib/java/util/Date.java
diff -u kaffe/libraries/javalib/java/util/Date.java:1.21 kaffe/libraries/javalib/java/util/Date.java:1.22
--- kaffe/libraries/javalib/java/util/Date.java:1.21 Fri Jan 9 18:14:08 2004
+++ kaffe/libraries/javalib/java/util/Date.java Mon May 17 13:55:06 2004
@@ -460,7 +460,6 @@
int curYear = 1900 + new Date().getYear();
int firstYear = curYear - 80;
year = firstYear / 100 * 100 + num;
- int yx = year;
if (year < firstYear)
year += 100;
}
Index: kaffe/libraries/javalib/java/util/HashMap.java
diff -u kaffe/libraries/javalib/java/util/HashMap.java:1.22 kaffe/libraries/javalib/java/util/HashMap.java:1.23
--- kaffe/libraries/javalib/java/util/HashMap.java:1.22 Thu Apr 22 11:40:44 2004
+++ kaffe/libraries/javalib/java/util/HashMap.java Mon May 17 13:55:06 2004
@@ -743,18 +743,9 @@
{
int idx = hash(e.key);
HashEntry dest = buckets[idx];
-
- if (dest != null)
- {
- while (dest.next != null)
- dest = dest.next;
- dest.next = e;
- }
- else
- buckets[idx] = e;
-
HashEntry next = e.next;
- e.next = null;
+ e.next = buckets[idx];
+ buckets[idx] = e;
e = next;
}
}
Index: kaffe/libraries/javalib/java/util/logging/Level.java
diff -u kaffe/libraries/javalib/java/util/logging/Level.java:1.2 kaffe/libraries/javalib/java/util/logging/Level.java:1.3
--- kaffe/libraries/javalib/java/util/logging/Level.java:1.2 Wed May 14 23:20:10 2003
+++ kaffe/libraries/javalib/java/util/logging/Level.java Mon May 17 13:55:07 2004
@@ -40,9 +40,9 @@
package java.util.logging;
+import java.io.Serializable;
import java.util.ResourceBundle;
-
/**
* A class for indicating logging levels. A number of commonly used
* levels is pre-defined (such as <code>java.util.logging.Level.INFO</code>),
@@ -52,8 +52,7 @@
*
* @author Sascha Brawer <brawer@acm.org>
*/
-public class Level
- implements java.io.Serializable
+public class Level implements Serializable
{
/* The integer values are the same as in the Sun J2SE 1.4.
* They have been obtained with a test program. In J2SE 1.4.1,
Index: kaffe/libraries/javalib/java/util/zip/GZIPOutputStream.java
diff -u kaffe/libraries/javalib/java/util/zip/GZIPOutputStream.java:1.6 kaffe/libraries/javalib/java/util/zip/GZIPOutputStream.java:1.7
--- kaffe/libraries/javalib/java/util/zip/GZIPOutputStream.java:1.6 Wed Apr 21 14:59:06 2004
+++ kaffe/libraries/javalib/java/util/zip/GZIPOutputStream.java Mon May 17 13:55:08 2004
@@ -82,6 +82,7 @@
{
super(out, new Deflater(Deflater.DEFAULT_COMPRESSION, true), size);
+ crc = new CRC32();
int mod_time = (int) (System.currentTimeMillis() / 1000L);
byte[] gzipHeader =
{