KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > org > exolab > jms > net > util > MethodHelper


1 /**
2  * Redistribution and use of this software and associated documentation
3  * ("Software"), with or without modification, are permitted provided
4  * that the following conditions are met:
5  *
6  * 1. Redistributions of source code must retain copyright
7  * statements and notices. Redistributions must also contain a
8  * copy of this document.
9  *
10  * 2. Redistributions in binary form must reproduce the
11  * above copyright notice, this list of conditions and the
12  * following disclaimer in the documentation and/or other
13  * materials provided with the distribution.
14  *
15  * 3. The name "Exolab" must not be used to endorse or promote
16  * products derived from this Software without prior written
17  * permission of Exoffice Technologies. For written permission,
18  * please contact info@exolab.org.
19  *
20  * 4. Products derived from this Software may not be called "Exolab"
21  * nor may "Exolab" appear in their names without prior written
22  * permission of Exoffice Technologies. Exolab is a registered
23  * trademark of Exoffice Technologies.
24  *
25  * 5. Due credit should be given to the Exolab Project
26  * (http://www.exolab.org/).
27  *
28  * THIS SOFTWARE IS PROVIDED BY EXOFFICE TECHNOLOGIES AND CONTRIBUTORS
29  * ``AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT
30  * NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
31  * FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
32  * EXOFFICE TECHNOLOGIES OR ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
33  * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
34  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
35  * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
36  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
37  * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
38  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
39  * OF THE POSSIBILITY OF SUCH DAMAGE.
40  *
41  * Copyright 2003-2005 (C) Exoffice Technologies Inc. All Rights Reserved.
42  *
43  * $Id: MethodHelper.java,v 1.2 2005/04/02 13:47:16 tanderson Exp $
44  */

45 package org.exolab.jms.net.util;
46
47 import java.lang.reflect.Method JavaDoc;
48 import java.util.ArrayList JavaDoc;
49
50
51 /**
52  * Helper class for performing reflection.
53  *
54  * @author <a HREF="mailto:tma@netspace.net.au">Tim Anderson</a>
55  * @version $Revision: 1.2 $ $Date: 2005/04/02 13:47:16 $
56  */

57 public final class MethodHelper {
58
59     /**
60      * Prevent construction of helper class.
61      */

62     private MethodHelper() {
63     }
64
65     /**
66      * Returns all the interface-declared methods of a class.
67      * This includes those implemented by superclasses.
68      *
69      * @param clazz the class
70      * @return a list of the interface-declared methods for <code>clazz</code>
71      */

72     public static Method JavaDoc[] getAllInterfaceMethods(Class JavaDoc clazz) {
73         final int size = 10;
74         ArrayList JavaDoc result = new ArrayList JavaDoc(size);
75         getInterfaceMethods(getAllInterfaces(clazz), result);
76         return (Method JavaDoc[]) result.toArray(new Method JavaDoc[0]);
77     }
78
79     /**
80      * Returns the interface-declared methods of a class.
81      *
82      * @param clazz the class
83      * @return a list of the interface-declared methods for <code>clazz</code>
84      */

85     public static Method JavaDoc[] getInterfaceMethods(Class JavaDoc clazz) {
86         final int size = 10;
87         ArrayList JavaDoc result = new ArrayList JavaDoc(size);
88         getInterfaceMethods(clazz.getInterfaces(), result);
89         return (Method JavaDoc[]) result.toArray(new Method JavaDoc[0]);
90     }
91
92     /**
93      * Calculates a unique identifier for a method. The identifier is unique
94      * within the declaring class.
95      *
96      * @param method the method
97      * @return a unique identifier for <code>method</code>
98      */

99     public static long getMethodID(Method JavaDoc method) {
100         final int shift = 32;
101         long hash = method.getDeclaringClass().getName().hashCode();
102         hash ^= method.getName().hashCode();
103         hash ^= method.getReturnType().getName().hashCode();
104         Class JavaDoc[] args = method.getParameterTypes();
105         for (int i = 0; i < args.length; ++i) {
106             hash ^= ((long) args[i].getName().hashCode()) << shift;
107         }
108         return hash;
109     }
110
111     /**
112      * Determines all of the interface-declared methods from a set of interfaces
113      * and their super-interfaces.
114      *
115      * @param interfaces the interfaces
116      * @param result the array to contain the result
117      */

118     private static void getInterfaceMethods(Class JavaDoc[] interfaces,
119                                             ArrayList JavaDoc result) {
120         for (int i = 0; i < interfaces.length; ++i) {
121             Class JavaDoc iface = interfaces[i];
122             getInterfaceMethods(iface.getInterfaces(), result);
123             Method JavaDoc[] methods = iface.getMethods();
124             for (int j = 0; j < methods.length; ++j) {
125                 if (methods[j].getDeclaringClass() == interfaces[i]) {
126                     result.add(methods[j]);
127                 }
128             }
129         }
130     }
131
132     /**
133      * Returns all of the interfaces implemented by a class.
134      *
135      * @param clazz the class
136      * @return a list of the interfaces implemented by the class.
137      */

138     public static Class JavaDoc[] getAllInterfaces(Class JavaDoc clazz) {
139         ArrayList JavaDoc result = new ArrayList JavaDoc();
140         getAllInterfaces(clazz, result);
141         return (Class JavaDoc[]) result.toArray(new Class JavaDoc[0]);
142     }
143
144     /**
145      * Returns all of the interfaces inplemented by a class.
146
147      * @param clazz the class
148      * @param result the array to contain the result
149      */

150     private static void getAllInterfaces(Class JavaDoc clazz, ArrayList JavaDoc result) {
151         Class JavaDoc[] interfaces = clazz.getInterfaces();
152         for (int i = 0; i < interfaces.length; ++i) {
153             if (!result.contains(interfaces[i])) {
154                 result.add(interfaces[i]);
155             }
156         }
157         Class JavaDoc superClass = clazz.getSuperclass();
158         if (superClass != null) {
159             getAllInterfaces(superClass, result);
160         }
161     }
162 }
163
Popular Tags