ArrayHelper.java, [...]: Reformatted to match classpath's versions.
authorMichael Koch <konqueror@gmx.de>
Tue, 17 Jun 2003 12:01:37 +0000 (12:01 +0000)
committerMichael Koch <mkoch@gcc.gnu.org>
Tue, 17 Jun 2003 12:01:37 +0000 (12:01 +0000)
2003-06-17  Michael Koch  <konqueror@gmx.de>

* gnu/java/lang/ArrayHelper.java,
gnu/java/lang/ClassHelper.java:
Reformatted to match classpath's versions.

From-SVN: r68078

libjava/ChangeLog
libjava/gnu/java/lang/ArrayHelper.java
libjava/gnu/java/lang/ClassHelper.java

index f2d62925748f17b2dd28bfd6dc4aa9d28bc74ae3..d43c1db5b66a2aba48703ac493e1c195c069ba40 100644 (file)
@@ -1,3 +1,9 @@
+2003-06-17  Michael Koch  <konqueror@gmx.de>
+
+       * gnu/java/lang/ArrayHelper.java,
+       gnu/java/lang/ClassHelper.java:
+       Reformatted to match classpath's versions.
+
 2003-06-14  Michael Koch  <konqueror@gmx.de>
 
        * gnu/java/nio/FileChannelImpl.java
index 271e248f52313811b8bc6ef50e21947b6dffef33..0216caba167c75566370cb676012480b0cbfd299 100644 (file)
@@ -1,5 +1,5 @@
-/* gnu.java.lang.ArrayHelper
-   Copyright (C) 1998 Free Software Foundation, Inc.
+/* ArrayHelper.java -- Helper methods for handling array operations
+   Copyright (C) 1998, 2002 Free Software Foundation, Inc.
 
 This file is part of GNU Classpath.
 
@@ -7,7 +7,7 @@ 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
@@ -39,25 +39,42 @@ exception statement from your version. */
 package gnu.java.lang;
 
 /**
- ** ArrayHelper helps you do things with arrays.
- **
- ** @author John Keiser
- ** @version 1.1.0, 29 Jul 1998
- **/
-
-public class ArrayHelper {
-       public static boolean contains(Object[] array, Object searchFor) {
-               return indexOf(array,searchFor) != -1;
-       }
+ * ArrayHelper helps you do things with arrays.
+ *
+ * @author John Keiser
+ */
+public class ArrayHelper
+{
+  /**
+   * Counterpart to java.util.Collection.contains.
+   *
+   * @param array the array to search
+   * @param searchFor the object to locate
+   * @return true if some array element <code>equals(searchFor)</code>
+   */
+  public static boolean contains(Object[] array, Object searchFor)
+  {
+    return indexOf(array, searchFor) != -1;
+  }
 
-       public static int indexOf(Object[] array, Object searchFor) {
-               for(int i=0;i<array.length;i++) {
-                       if(array[i].equals(searchFor)) {
-                               return i;
-                       }
-               }
-               return -1;
-       }
+  /**
+   * Counterpart to java.util.Collection.indexOf.
+   *
+   * @param array the array to search
+   * @param searchFor the object to locate
+   * @return the index of the first equal object, or -1
+   */
+  public static int indexOf(Object[] array, Object searchFor)
+  {
+    for (int i = 0; i < array.length; i++)
+      {
+        if(array[i].equals(searchFor))
+          {
+            return i;
+          }
+      }
+    return -1;
+  }
 
        public static boolean equalsArray(Object[] a, Object[] b) {
                if(a.length == b.length) {
index 0d2ce5d4a7762c692921b8ecfeec624ea2b19c0e..16d699e3453e18311d2d8d76ce12aec1d9c6774f 100644 (file)
@@ -1,5 +1,5 @@
-/* gnu.java.lang.ClassHelper
-   Copyright (C) 1998 Free Software Foundation, Inc.
+/* ClassHelper.java -- Utility methods to augment java.lang.Class
+   Copyright (C) 1998, 2002 Free Software Foundation, Inc.
 
 This file is part of GNU Classpath.
 
@@ -7,7 +7,7 @@ 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
@@ -42,202 +42,144 @@ import java.util.*;
 import java.lang.reflect.*;
 
 /**
- ** ClassHelper has various methods that ought to have been
- ** in class.
- **
- ** @author John Keiser
- ** @version 1.1.0, 29 Jul 1998
- **/
-
-public class ClassHelper {
-       /** Strip the package part from the class name.
-        ** @param clazz the class to get the truncated name from
-        ** @return the truncated class name.
-        **/
-       public static String getTruncatedClassName(Class clazz) {
-               return getTruncatedName(clazz.getName());
-       }
-       /** Strip the package part from the class name, or the
-        ** class part from the method or field name.
-        ** @param name the name to truncate.
-        ** @return the truncated name.
-        **/
-       public static String getTruncatedName(String name) {
-               int lastInd = name.lastIndexOf('.');
-               if(lastInd == -1) {
-                       return name;
-               } else {
-                       return name.substring(lastInd+1);
-               }
-       }
-
-       /** Strip the last portion of the name (after the last
-        ** dot).
-        ** @param name the name to get package of.
-        ** @return the package name.  "" if no package.
-        **/
-       public static String getPackagePortion(String name) {
-               int lastInd = name.lastIndexOf('.');
-               if(lastInd == -1) {
-                       return "";
-               } else {
-                       return name.substring(0,lastInd);
-               }
-       }
-
-       static Hashtable allMethods = new Hashtable();
-       static Hashtable allMethodsAtDeclaration = new Hashtable();
-
-       /** Get all the methods, public, private and
-        ** otherwise, from the class, getting them
-        ** from the most recent class to find them.
-        **/
-       public static Method[] getAllMethods(Class clazz) {
-               Method[] retval = (Method[])allMethods.get(clazz);
-               if(retval == null) {
-                       Method[] superMethods;
-                       if(clazz.getSuperclass() != null) {
-                               superMethods = getAllMethods(clazz.getSuperclass());
-                       } else {
-                               superMethods = new Method[0];
-                       }
-                       Vector v = new Vector();
-                       Method[] currentMethods = clazz.getDeclaredMethods();
-                       for(int i=0;i<currentMethods.length;i++) {
-                               v.addElement(currentMethods[i]);
-                       }
-                       for(int i=0;i<superMethods.length;i++) {
-                               boolean addOK = true;
-                               for(int j=0;j<currentMethods.length;j++) {
-                                       if(getTruncatedName(superMethods[i].getName()).equals(getTruncatedName(currentMethods[j].getName()))
-                                          && ArrayHelper.equalsArray(superMethods[i].getParameterTypes(),currentMethods[j].getParameterTypes())) {
-                                               addOK = false;
-                                       }
-                               }
-                               if(addOK) {
-                                       v.addElement(superMethods[i]);
-                               }
-                       }
-
-                       retval = new Method[v.size()];
-                       v.copyInto(retval);
-                       allMethods.put(clazz,retval);
-               }
-               return retval;
-       }
-
-       /** Get all the methods, public, private and
-        ** otherwise, from the class, and get them from
-        ** their point of declaration.
-        **/
-       public static Method[] getAllMethodsAtDeclaration(Class clazz) {
-               Method[] retval = (Method[])allMethodsAtDeclaration.get(clazz);
-               if(retval == null) {
-                       Method[] superMethods;
-                       if(clazz.getSuperclass() != null) {
-                               superMethods = getAllMethodsAtDeclaration(clazz.getSuperclass());
-                       } else {
-                               superMethods = new Method[0];
-                       }
-                       Vector v = new Vector();
-                       Method[] currentMethods = clazz.getDeclaredMethods();
-                       for(int i=0;i<superMethods.length;i++) {
-                               v.addElement(superMethods[i]);
-                       }
-                       for(int i=0;i<superMethods.length;i++) {
-                               boolean addOK = true;
-                               for(int j=0;j<currentMethods.length;j++) {
-                                       if(getTruncatedName(superMethods[i].getName()).equals(getTruncatedName(currentMethods[j].getName()))
-                                          && ArrayHelper.equalsArray(superMethods[i].getParameterTypes(),currentMethods[j].getParameterTypes())) {
-                                               addOK = false;
-                                       }
-                               }
-                               if(addOK) {
-                                       v.addElement(superMethods[i]);
-                               }
-                       }
-
-                       retval = new Method[v.size()];
-                       v.copyInto(retval);
-                       allMethodsAtDeclaration.put(clazz,retval);
-               }
-               return retval;
-       }
-
-       static Hashtable allFields = new Hashtable();
-       static Hashtable allFieldsAtDeclaration = new Hashtable();
-
-       /** Get all the fields, public, private and
-        ** otherwise, from the class, getting them
-        ** from the most recent class to find them.
-        **/
-       public static Field[] getAllFields(Class clazz) {
-               Field[] retval = (Field[])allFields.get(clazz);
-               if(retval == null) {
-                       Field[] superFields;
-                       if(clazz.getSuperclass() != null) {
-                               superFields = getAllFields(clazz.getSuperclass());
-                       } else {
-                               superFields = new Field[0];
-                       }
-                       Vector v = new Vector();
-                       Field[] currentFields = clazz.getDeclaredFields();
-                       for(int i=0;i<currentFields.length;i++) {
-                               v.addElement(currentFields[i]);
-                       }
-                       for(int i=0;i<superFields.length;i++) {
-                               boolean addOK = true;
-                               for(int j=0;j<currentFields.length;j++) {
-                                       if(getTruncatedName(superFields[i].getName()).equals(getTruncatedName(currentFields[j].getName()))) {
-                                               addOK = false;
-                                       }
-                               }
-                               if(addOK) {
-                                       v.addElement(superFields[i]);
-                               }
-                       }
-
-                       retval = new Field[v.size()];
-                       v.copyInto(retval);
-                       allFields.put(clazz,retval);
-               }
-               return retval;
-       }
-
-       /** Get all the fields, public, private and
-        ** otherwise, from the class, and get them from
-        ** their point of declaration.
-        **/
-       public static Field[] getAllFieldsAtDeclaration(Class clazz) {
-               Field[] retval = (Field[])allFieldsAtDeclaration.get(clazz);
-               if(retval == null) {
-                       Field[] superFields;
-                       if(clazz.getSuperclass() != null) {
-                               superFields = getAllFieldsAtDeclaration(clazz.getSuperclass());
-                       } else {
-                               superFields = new Field[0];
-                       }
-                       Vector v = new Vector();
-                       Field[] currentFields = clazz.getDeclaredFields();
-                       for(int i=0;i<superFields.length;i++) {
-                               v.addElement(superFields[i]);
-                       }
-                       for(int i=0;i<superFields.length;i++) {
-                               boolean addOK = true;
-                               for(int j=0;j<currentFields.length;j++) {
-                                       if(getTruncatedName(superFields[i].getName()).equals(getTruncatedName(currentFields[j].getName()))) {
-                                               addOK = false;
-                                       }
-                               }
-                               if(addOK) {
-                                       v.addElement(superFields[i]);
-                               }
-                       }
-
-                       retval = new Field[v.size()];
-                       v.copyInto(retval);
-                       allFieldsAtDeclaration.put(clazz,retval);
-               }
-               return retval;
-       }
+ * ClassHelper has various methods that ought to have been in Class.
+ *
+ * @author John Keiser
+ * @author Eric Blake <ebb9@email.byu.edu>
+ */
+public class ClassHelper
+{
+  /**
+   * Strip the package part from the class name.
+   *
+   * @param clazz the class to get the truncated name from
+   * @return the truncated class name
+   */
+  public static String getTruncatedClassName(Class clazz)
+  {
+    return getTruncatedName(clazz.getName());
+  }
+
+  /**
+   * Strip the package part from the class name, or the class part from
+   * the method or field name.
+   *
+   * @param name the name to truncate
+   * @return the truncated name
+   */
+  public static String getTruncatedName(String name)
+  {
+    int lastInd = name.lastIndexOf('.');
+    if (lastInd == -1)
+      return name;
+    return name.substring(lastInd + 1);
+  }
+
+  /**
+   * Strip the last portion of the name (after the last dot).
+   *
+   * @param name the name to get package of
+   * @return the package name, or "" if no package
+   */
+  public static String getPackagePortion(String name)
+  {
+    int lastInd = name.lastIndexOf('.');
+    if (lastInd == -1)
+      return "";
+    return name.substring(0, lastInd);
+  }
+
+  /** Cache of methods found in getAllMethods(). */
+  private static Map allMethods = new HashMap();
+
+  /**
+   * Get all the methods, public, private and otherwise, from the class,
+   * getting them from the most recent class to find them. This may not
+   * be quite the correct approach, as this includes methods that are not
+   * inherited or accessible from clazz, so beware.
+   *
+   * @param clazz the class to start at
+   * @return all methods declared or inherited in clazz
+   */
+  public static Method[] getAllMethods(Class clazz)
+  {
+    Method[] retval = (Method[]) allMethods.get(clazz);
+    if (retval == null)
+      {
+        Set methods = new HashSet();
+        Class c = clazz;
+        while (c != null)
+          {
+            Method[] currentMethods = c.getDeclaredMethods();
+          loop:
+            for (int i = 0; i < currentMethods.length; i++)
+              {
+                Method current = currentMethods[i];
+                int size = methods.size();
+                Iterator iter = methods.iterator();
+                while (--size >= 0)
+                  {
+                    Method override = (Method) iter.next();
+                    if (current.getName().equals(override.getName())
+                        && Arrays.equals(current.getParameterTypes(),
+                                         override.getParameterTypes())
+                        && current.getReturnType() == override.getReturnType())
+                      continue loop;
+                  }
+                methods.add(current);
+              }
+            c = c.getSuperclass();
+          }
+        retval = new Method[methods.size()];
+        methods.toArray(retval);
+        allMethods.put(clazz, retval);
+      }
+    return retval;
+  }
+
+  /** Cache of fields found in getAllFields(). */
+  private static Map allFields = new HashMap();
+
+  /**
+   * Get all the fields, public, private and otherwise, from the class,
+   * getting them from the most recent class to find them. This may not
+   * be quite the correct approach, as this includes fields that are not
+   * inherited or accessible from clazz, so beware.
+   *
+   * @param clazz the class to start at
+   * @return all fields declared or inherited in clazz
+   */
+  public static Field[] getAllFields(Class clazz)
+  {
+    Field[] retval = (Field[]) allFields.get(clazz);
+    if (retval == null)
+      {
+        Set fields = new HashSet();
+        Class c = clazz;
+        while (c != null)
+          {
+            Field[] currentFields = c.getDeclaredFields();
+          loop:
+            for (int i = 0; i < currentFields.length; i++)
+              {
+                Field current = currentFields[i];
+                int size = fields.size();
+                Iterator iter = fields.iterator();
+                while (--size >= 0)
+                  {
+                    Field override = (Field) iter.next();
+                    if (current.getName().equals(override.getName())
+                        && current.getType() == override.getType())
+                      continue loop;
+                  }
+                fields.add(current);
+              }
+            c = c.getSuperclass();
+          }
+        retval = new Field[fields.size()];
+        fields.toArray(retval);
+        allFields.put(clazz, retval);
+      }
+    return retval;
+  }
 }