[kaffe] CVS kaffe (dalibor): Resynced with GNU Classpath: java.lang

Kaffe CVS Kaffe Mailing List <kaffe@kaffe.org>
Mon May 17 18:16:02 2004


PatchSet 4742 
Date: 2004/05/18 01:10:25
Author: dalibor
Branch: HEAD
Tag: (none) 
Log:
Resynced with GNU Classpath: java.lang

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

        * libraries/javalib/java/lang/CharSequence.java,
        libraries/javalib/java/lang/Compiler.java,
        libraries/javalib/java/lang/Number.java,
        libraries/javalib/java/lang/RuntimePermission.java,
        libraries/javalib/java/lang/SecurityManager.java,
        libraries/javalib/java/lang/StringBuffer.java,
        libraries/javalib/java/lang/reflect/InvocationHandler.java,
        libraries/javalib/java/lang/reflect/Proxy.java:
Resynced with GNU Classpath.

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

* java/lang/Compiler.java,
java/lang/RuntimePermission.java,
java/lang/reflect/InvocationHandler.java,
java/lang/reflect/Proxy.java:
Fixed HTML in javadocs.

004-04-17  Michael Koch  <konqueror@gmx.de>

* java/lang/CharSequence.java
(subSequence): Likewise.
* java/lang/Number.java
(digits): Added comma to array definition.
* java/lang/SecurityManager.java:
Fixed javadocs all over.
* java/lang/String.java
(regionMatches): Fixed @param tag.
(startsWith): Likewise.
(substring): Likewise.
* java/lang/StringBuffer.java
(append): Likewise.

Members: 
	ChangeLog:1.2316->1.2317 
	libraries/javalib/java/lang/CharSequence.java:1.1->1.2 
	libraries/javalib/java/lang/Compiler.java:1.4->1.5 
	libraries/javalib/java/lang/Number.java:1.5->1.6 
	libraries/javalib/java/lang/RuntimePermission.java:1.2->1.3 
	libraries/javalib/java/lang/SecurityManager.java:1.18->1.19 
	libraries/javalib/java/lang/StringBuffer.java:1.25->1.26 
	libraries/javalib/java/lang/reflect/InvocationHandler.java:1.3->1.4 
	libraries/javalib/java/lang/reflect/Proxy.java:1.4->1.5 

Index: kaffe/ChangeLog
diff -u kaffe/ChangeLog:1.2316 kaffe/ChangeLog:1.2317
--- kaffe/ChangeLog:1.2316	Mon May 17 22:29:38 2004
+++ kaffe/ChangeLog	Tue May 18 01:10:25 2004
@@ -1,3 +1,38 @@
+2004-05-18  Dalibor Topic  <robilad@kaffe.org>
+
+        * libraries/javalib/java/lang/CharSequence.java,
+        libraries/javalib/java/lang/Compiler.java,
+        libraries/javalib/java/lang/Number.java,
+        libraries/javalib/java/lang/RuntimePermission.java,
+        libraries/javalib/java/lang/SecurityManager.java,
+        libraries/javalib/java/lang/StringBuffer.java,
+        libraries/javalib/java/lang/reflect/InvocationHandler.java,
+        libraries/javalib/java/lang/reflect/Proxy.java:
+	Resynced with GNU Classpath.
+
+	2004-04-12  Michael Koch  <konqueror@gmx.de>
+
+	* java/lang/Compiler.java,
+	java/lang/RuntimePermission.java,
+	java/lang/reflect/InvocationHandler.java,
+	java/lang/reflect/Proxy.java:
+	Fixed HTML in javadocs.
+
+	004-04-17  Michael Koch  <konqueror@gmx.de>
+
+	* java/lang/CharSequence.java
+	(subSequence): Likewise.
+	* java/lang/Number.java
+	(digits): Added comma to array definition.
+	* java/lang/SecurityManager.java:
+	Fixed javadocs all over.
+	* java/lang/String.java
+	(regionMatches): Fixed @param tag.
+	(startsWith): Likewise.
+	(substring): Likewise.
+	* java/lang/StringBuffer.java
+	(append): Likewise.
+	
 2004-05-17  Dalibor Topic  <robilad@kaffe.org>
 
 	* libraries/javalib/Klasses.jar.bootstrap:
Index: kaffe/libraries/javalib/java/lang/CharSequence.java
diff -u kaffe/libraries/javalib/java/lang/CharSequence.java:1.1 kaffe/libraries/javalib/java/lang/CharSequence.java:1.2
--- kaffe/libraries/javalib/java/lang/CharSequence.java:1.1	Wed Nov  6 11:52:25 2002
+++ kaffe/libraries/javalib/java/lang/CharSequence.java	Tue May 18 01:10:27 2004
@@ -78,7 +78,7 @@
   int length();
 
   /**
-   * Returns a new <code>CharSequence</char> of the indicated range.
+   * Returns a new <code>CharSequence</code> of the indicated range.
    *
    * @param begin the start index (inclusive)
    * @param end the end index (exclusive)
Index: kaffe/libraries/javalib/java/lang/Compiler.java
diff -u kaffe/libraries/javalib/java/lang/Compiler.java:1.4 kaffe/libraries/javalib/java/lang/Compiler.java:1.5
--- kaffe/libraries/javalib/java/lang/Compiler.java:1.4	Sat Mar 13 16:27:22 2004
+++ kaffe/libraries/javalib/java/lang/Compiler.java	Tue May 18 01:10:27 2004
@@ -81,7 +81,7 @@
   }
 
   /**
-   * Compile the classes whose name matches <code>classNames/code>.
+   * Compile the classes whose name matches <code>classNames</code>.
    *
    * @param classNames the name of classes to compile
    * @return <code>false</code> if no compiler is available or
Index: kaffe/libraries/javalib/java/lang/Number.java
diff -u kaffe/libraries/javalib/java/lang/Number.java:1.5 kaffe/libraries/javalib/java/lang/Number.java:1.6
--- kaffe/libraries/javalib/java/lang/Number.java:1.5	Thu Feb 20 13:52:09 2003
+++ kaffe/libraries/javalib/java/lang/Number.java	Tue May 18 01:10:27 2004
@@ -69,7 +69,7 @@
     '0', '1', '2', '3', '4', '5', '6', '7', '8', '9',
     'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j',
     'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't',
-    'u', 'v', 'w', 'x', 'y', 'z'
+    'u', 'v', 'w', 'x', 'y', 'z',
   };
 
   /**
Index: kaffe/libraries/javalib/java/lang/RuntimePermission.java
diff -u kaffe/libraries/javalib/java/lang/RuntimePermission.java:1.2 kaffe/libraries/javalib/java/lang/RuntimePermission.java:1.3
--- kaffe/libraries/javalib/java/lang/RuntimePermission.java:1.2	Sat Mar 13 16:27:22 2004
+++ kaffe/libraries/javalib/java/lang/RuntimePermission.java	Tue May 18 01:10:27 2004
@@ -118,7 +118,7 @@
  *       access to in the system</td>
  *   <td>rogue code can stop arbitrary threads</td></tr>
  * <tr>
- *   <td><code>modifyThreadGroup</td>
+ *   <td><code>modifyThreadGroup</code></td>
  *   <td>allows the application to modify thread groups using any of the
  *       methods <code>destroy</code>, <code>resume</code>,
  *       <code>setDaemon</code>, <code>setMaxPriority</code>,
@@ -141,7 +141,7 @@
  *   <td>rogue code can write files, including viruses, and can modify the
  *       virtual machine binary; if not just fill up the disk</td></tr>
  * <tr>
- *   <td><code>loadLibrary.<code><em>library name</em></td>
+ *   <td><code>loadLibrary.</code><em>library name</em></td>
  *   <td>dynamic linking of the named library</td>
  *   <td>native code can bypass many security checks of pure Java</td></tr>
  * <tr>
Index: kaffe/libraries/javalib/java/lang/SecurityManager.java
diff -u kaffe/libraries/javalib/java/lang/SecurityManager.java:1.18 kaffe/libraries/javalib/java/lang/SecurityManager.java:1.19
--- kaffe/libraries/javalib/java/lang/SecurityManager.java:1.18	Wed Apr  7 20:02:38 2004
+++ kaffe/libraries/javalib/java/lang/SecurityManager.java	Tue May 18 01:10:27 2004
@@ -86,7 +86,7 @@
  * // now, in worker thread
  * if (sm != null)
  *   sm.checkPermission(permission, context);
- * <pre>
+ * </pre>
  *
  * <p>Permissions fall into these categories: File, Socket, Net, Security,
  * Runtime, Property, AWT, Reflect, and Serializable. Each of these
@@ -174,13 +174,15 @@
    * Find the ClassLoader of the first non-system class on the execution
    * stack. A non-system class is one whose ClassLoader is not equal to
    * {@link ClassLoader#getSystemClassLoader()} or its ancestors. This
-   * will return null in three cases:<br><nl>
+   * will return null in three cases:
+   *
+   * <ul>
    * <li>All methods on the stack are from system classes</li>
    * <li>All methods on the stack up to the first "privileged" caller, as
    *  created by {@link AccessController.doPrivileged(PrivilegedAction)},
    *  are from system classes</li>
    * <li>A check of <code>java.security.AllPermission</code> succeeds.</li>
-   * </nl>
+   * </ul>
    * 
    * @return the most recent non-system ClassLoader on the execution stack
    * @deprecated use {@link #checkPermission(Permission)} instead
@@ -194,13 +196,15 @@
    * Find the first non-system class on the execution stack. A non-system
    * class is one whose ClassLoader is not equal to
    * {@link ClassLoader#getSystemClassLoader()} or its ancestors. This
-   * will return null in three cases:<br><nl>
+   * will return null in three cases:
+   *
+   * <ul>
    * <li>All methods on the stack are from system classes</li>
    * <li>All methods on the stack up to the first "privileged" caller, as
    *  created by {@link AccessController.doPrivileged(PrivilegedAction)},
    *  are from system classes</li>
    * <li>A check of <code>java.security.AllPermission</code> succeeds.</li>
-   * </nl>
+   * </ul>
    * 
    * @return the most recent non-system Class on the execution stack
    * @deprecated use {@link #checkPermission(Permission)} instead
@@ -231,13 +235,15 @@
    * Get the depth on the execution stack of the most recent non-system class.
    * A non-system class is one whose ClassLoader is not equal to
    * {@link ClassLoader#getSystemClassLoader()} or its ancestors. This
-   * will return -1 in three cases:<br><nl>
+   * will return -1 in three cases:
+   *
+   * <ul>
    * <li>All methods on the stack are from system classes</li>
    * <li>All methods on the stack up to the first "privileged" caller, as
    *  created by {@link AccessController.doPrivileged(PrivilegedAction)},
    *  are from system classes</li>
    * <li>A check of <code>java.security.AllPermission</code> succeeds.</li>
-   * </nl>
+   * </ul>
    * 
    * @return the index of the most recent non-system Class on the stack
    * @deprecated use {@link #checkPermission(Permission)} instead
@@ -365,8 +371,8 @@
    * Check if the current thread is allowed to modify another Thread. This is
    * called by Thread.stop(), suspend(), resume(), interrupt(), destroy(),
    * setPriority(), setName(), and setDaemon(). The default implementation
-   * checks <code>RuntimePermission("modifyThread") on system threads (ie.
-   * threads in ThreadGroup with a null parent), and returns silently on
+   * checks <code>RuntimePermission("modifyThread")</code> on system threads
+   * (ie. threads in ThreadGroup with a null parent), and returns silently on
    * other threads.
    *
    * <p>If you override this, you must do two things. First, call
@@ -398,8 +404,8 @@
    * ThreadGroup.ThreadGroup() (to add this ThreadGroup to a parent),
    * ThreadGroup.stop(), suspend(), resume(), interrupt(), destroy(),
    * setDaemon(), and setMaxPriority(). The default implementation
-   * checks <code>RuntimePermission("modifyThread") on the system group (ie.
-   * the one with a null parent), and returns silently on other groups.
+   * checks <code>RuntimePermission("modifyThread")</code> on the system group
+   * (ie. the one with a null parent), and returns silently on other groups.
    *
    * <p>If you override this, you must do two things. First, call
    * <code>super.checkAccess(t)</code>, to make sure you are not relaxing
@@ -651,13 +657,15 @@
    * @param host the host to connect to
    * @param port the port to connect on
    * @param context the context to determine access for
+   *
    * @throws SecurityException if permission is denied, or if context is
    *         not an AccessControlContext
    * @throws NullPointerException if host is null
+   *
    * @see #getSecurityContext()
    * @see AccessControlContext#checkPermission(Permission)
    */
-  public void checkConnect(String host, int port, Object securityContext)
+  public void checkConnect(String host, int port, Object context)
   {
     // XXX Should be:
     // if (! (context instanceof AccessControlContext))
@@ -776,9 +784,12 @@
    * you override this, call <code>super.checkPropertyAccess</code> rather
    * than throwing an exception.
    *
+   * @param key the key of the property to check
+   *
    * @throws SecurityException if permission is denied
    * @throws NullPointerException if key is null
    * @throws IllegalArgumentException if key is ""
+   *
    * @see System#getProperty(String)
    */
   public void checkPropertyAccess(String key)
@@ -862,8 +873,7 @@
    */
   public void checkAwtEventQueueAccess()
   {
-    // Should be: checkPermission(new AWTPermission("accessEventQueue"));
-    throw new SecurityException("Cannot access the AWT event queue.");
+    checkPermission(new AWTPermission("accessEventQueue"));
   }
 
   /**
Index: kaffe/libraries/javalib/java/lang/StringBuffer.java
diff -u kaffe/libraries/javalib/java/lang/StringBuffer.java:1.25 kaffe/libraries/javalib/java/lang/StringBuffer.java:1.26
--- kaffe/libraries/javalib/java/lang/StringBuffer.java:1.25	Sun Mar  7 17:10:53 2004
+++ kaffe/libraries/javalib/java/lang/StringBuffer.java	Tue May 18 01:10:27 2004
@@ -396,7 +396,7 @@
   /**
    * Append the <code>char</code> to this <code>StringBuffer</code>.
    *
-   * @param c the <code>char</code> to append
+   * @param ch the <code>char</code> to append
    * @return this <code>StringBuffer</code>
    */
   public synchronized StringBuffer append(char ch)
Index: kaffe/libraries/javalib/java/lang/reflect/InvocationHandler.java
diff -u kaffe/libraries/javalib/java/lang/reflect/InvocationHandler.java:1.3 kaffe/libraries/javalib/java/lang/reflect/InvocationHandler.java:1.4
--- kaffe/libraries/javalib/java/lang/reflect/InvocationHandler.java:1.3	Sat Mar 13 16:27:22 2004
+++ kaffe/libraries/javalib/java/lang/reflect/InvocationHandler.java	Tue May 18 01:10:28 2004
@@ -49,37 +49,38 @@
  * interface.  But in order for the proxy instance to do any good, it
  * needs to know what to do when interface methods are invoked!  So,
  * this interface is basically a cool wrapper that provides runtime
- * code generation needed by proxy instances.<p>
+ * code generation needed by proxy instances.
  *
- * While this interface was designed for use by Proxy, it will also
- * work on any object in general.<p>
+ * <p>While this interface was designed for use by Proxy, it will also
+ * work on any object in general.</p>
  *
- * Hints for implementing this class:<br>
+ * <p>Hints for implementing this class:</p>
+ * 
  * <ul>
- *  <li>Don't forget that Object.equals, Object.hashCode, and
- *      Object.toString will call this handler.  In particular,
- *      a naive call to proxy.equals, proxy.hashCode, or proxy.toString
- *      will put you in an infinite loop.  And remember that string
- *      concatenation also invokes toString.</li>
- *  <li>Obey the contract of the Method object you are handling, or
- *      the proxy instance will be forced to throw a
- *      {@link NullPointerException}, {@link ClassCastException},
- *      or {@link UndeclaredThrowableException}.</li>
- *  <li>Be prepared to wrap/unwrap primitives as necessary.</li>
- *  <li>The Method object may be owned by a different interface than
- *      what was actually used as the qualifying type of the method
- *      invocation in the Java source code. This means that it might
- *      not always be safe to throw an exception listed as belonging
- *      to the method's throws clause.</li>
+ * <li>Don't forget that Object.equals, Object.hashCode, and
+ *     Object.toString will call this handler.  In particular,
+ *     a naive call to proxy.equals, proxy.hashCode, or proxy.toString
+ *     will put you in an infinite loop.  And remember that string
+ *     concatenation also invokes toString.</li>
+ * <li>Obey the contract of the Method object you are handling, or
+ *     the proxy instance will be forced to throw a
+ *     {@link NullPointerException}, {@link ClassCastException},
+ *     or {@link UndeclaredThrowableException}.</li>
+ * <li>Be prepared to wrap/unwrap primitives as necessary.</li>
+ * <li>The Method object may be owned by a different interface than
+ *     what was actually used as the qualifying type of the method
+ *     invocation in the Java source code. This means that it might
+ *     not always be safe to throw an exception listed as belonging
+ *     to the method's throws clause.</li>
  * </ul>
  *
  * <p><small>For a fun time, create an InvocationHandler that handles the
- * methods of a proxy instance of the InvocationHandler interface!</small>
+ * methods of a proxy instance of the InvocationHandler interface!</small></p>
  *
  * @see Proxy
  * @see UndeclaredThrowableException
  *
- * @author Eric Blake <ebb9@email.byu.edu>
+ * @author Eric Blake (ebb9@email.byu.edu)
  * @since 1.3
  * @status updated to 1.4
  */
Index: kaffe/libraries/javalib/java/lang/reflect/Proxy.java
diff -u kaffe/libraries/javalib/java/lang/reflect/Proxy.java:1.4 kaffe/libraries/javalib/java/lang/reflect/Proxy.java:1.5
--- kaffe/libraries/javalib/java/lang/reflect/Proxy.java:1.4	Wed Apr 28 16:22:43 2004
+++ kaffe/libraries/javalib/java/lang/reflect/Proxy.java	Tue May 18 01:10:28 2004
@@ -211,35 +211,36 @@
    * Returns the proxy {@link Class} for the given ClassLoader and array
    * of interfaces, dynamically generating it if necessary.
    *
-   * There are several restrictions on this method, the violation of
+   * <p>There are several restrictions on this method, the violation of
    * which will result in an IllegalArgumentException or
-   * NullPointerException:
+   * NullPointerException:</p>
+   * 
    * <ul>
-   *  <li>All objects in `interfaces' must represent distinct interfaces.
-   *      Classes, primitive types, null, and duplicates are forbidden.</li>
-   *  <li>The interfaces must be visible in the specified ClassLoader.
-   *      In other words, for each interface i:
-   *      <code>Class.forName(i.getName(), false, loader) == i</code>
-   *      must be true.</li>
-   *  <li>All non-public interfaces (if any) must reside in the same
-   *      package, or the proxy class would be non-instantiable.  If
-   *      there are no non-public interfaces, the package of the proxy
-   *      class is unspecified.</li>
-   *  <li>All interfaces must be compatible - if two declare a method
-   *      with the same name and parameters, the return type must be
-   *      the same and the throws clause of the proxy class will be
-   *      the maximal subset of subclasses of the throws clauses for
-   *      each method that is overridden.</li>
-   *  <li>VM constraints limit the number of interfaces a proxy class
-   *      may directly implement (however, the indirect inheritance
-   *      of {@link Serializable} does not count against this limit).
-   *      Even though most VMs can theoretically have 65535
-   *      superinterfaces for a class, the actual limit is smaller
-   *      because a class's constant pool is limited to 65535 entries,
-   *      and not all entries can be interfaces.</li>
-   * </ul><p>
+   * <li>All objects in `interfaces' must represent distinct interfaces.
+   *     Classes, primitive types, null, and duplicates are forbidden.</li>
+   * <li>The interfaces must be visible in the specified ClassLoader.
+   *     In other words, for each interface i:
+   *     <code>Class.forName(i.getName(), false, loader) == i</code>
+   *     must be true.</li>
+   * <li>All non-public interfaces (if any) must reside in the same
+   *     package, or the proxy class would be non-instantiable.  If
+   *     there are no non-public interfaces, the package of the proxy
+   *     class is unspecified.</li>
+   * <li>All interfaces must be compatible - if two declare a method
+   *     with the same name and parameters, the return type must be
+   *     the same and the throws clause of the proxy class will be
+   *     the maximal subset of subclasses of the throws clauses for
+   *     each method that is overridden.</li>
+   * <li>VM constraints limit the number of interfaces a proxy class
+   *     may directly implement (however, the indirect inheritance
+   *     of {@link Serializable} does not count against this limit).
+   *     Even though most VMs can theoretically have 65535
+   *     superinterfaces for a class, the actual limit is smaller
+   *     because a class's constant pool is limited to 65535 entries,
+   *     and not all entries can be interfaces.</li>
+   * </ul>
    *
-   * Note that different orders of interfaces produce distinct classes.
+   * <p>Note that different orders of interfaces produce distinct classes.</p>
    *
    * @param loader the class loader to define the proxy class in; null
    *        implies the bootstrap class loader