summaryrefslogtreecommitdiffstats
path: root/sca-java-2.x/trunk/modules/implementation-java
diff options
context:
space:
mode:
authorrfeng <rfeng@13f79535-47bb-0310-9956-ffa450edef68>2010-06-23 21:07:57 +0000
committerrfeng <rfeng@13f79535-47bb-0310-9956-ffa450edef68>2010-06-23 21:07:57 +0000
commit6c11af12d8a323fff0f42523c5630ad032cf8b0c (patch)
treeb902660dcf8a68cbde252196a9c8184f62442ba9 /sca-java-2.x/trunk/modules/implementation-java
parentc878a832cc25d9a5ee6b5223b4b981f1c9d9b651 (diff)
Allow package fields to be used for SCA reference/property
git-svn-id: http://svn.us.apache.org/repos/asf/tuscany@957343 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'sca-java-2.x/trunk/modules/implementation-java')
-rw-r--r--sca-java-2.x/trunk/modules/implementation-java/src/main/java/org/apache/tuscany/sca/implementation/java/impl/JavaClassIntrospectorImpl.java8
-rw-r--r--sca-java-2.x/trunk/modules/implementation-java/src/main/java/org/apache/tuscany/sca/implementation/java/introspect/JavaIntrospectionHelper.java53
2 files changed, 48 insertions, 13 deletions
diff --git a/sca-java-2.x/trunk/modules/implementation-java/src/main/java/org/apache/tuscany/sca/implementation/java/impl/JavaClassIntrospectorImpl.java b/sca-java-2.x/trunk/modules/implementation-java/src/main/java/org/apache/tuscany/sca/implementation/java/impl/JavaClassIntrospectorImpl.java
index ff41517862..491408098e 100644
--- a/sca-java-2.x/trunk/modules/implementation-java/src/main/java/org/apache/tuscany/sca/implementation/java/impl/JavaClassIntrospectorImpl.java
+++ b/sca-java-2.x/trunk/modules/implementation-java/src/main/java/org/apache/tuscany/sca/implementation/java/impl/JavaClassIntrospectorImpl.java
@@ -84,17 +84,11 @@ public class JavaClassIntrospectorImpl {
}
}
- Set<Field> fields = JavaIntrospectionHelper.getAllPublicAndProtectedFields(clazz, true);
+ Set<Field> fields = JavaIntrospectionHelper.getInjectableFields(clazz, true);
for (Field field : fields) {
visitor.visitField(field, type);
}
- // Check if any private fields have illegal annotations that should be raised as errors
- Set<Field> privateFields = JavaIntrospectionHelper.getPrivateFields(clazz);
- for (Field field : privateFields) {
- visitor.visitField(field, type);
- }
-
Set<Method> methods = JavaIntrospectionHelper.getAllUniquePublicProtectedMethods(clazz, true);
for (Method method : methods) {
visitor.visitMethod(method, type);
diff --git a/sca-java-2.x/trunk/modules/implementation-java/src/main/java/org/apache/tuscany/sca/implementation/java/introspect/JavaIntrospectionHelper.java b/sca-java-2.x/trunk/modules/implementation-java/src/main/java/org/apache/tuscany/sca/implementation/java/introspect/JavaIntrospectionHelper.java
index 186e46c486..c6f45b93f3 100644
--- a/sca-java-2.x/trunk/modules/implementation-java/src/main/java/org/apache/tuscany/sca/implementation/java/introspect/JavaIntrospectionHelper.java
+++ b/sca-java-2.x/trunk/modules/implementation-java/src/main/java/org/apache/tuscany/sca/implementation/java/introspect/JavaIntrospectionHelper.java
@@ -50,7 +50,7 @@ import org.oasisopen.sca.ServiceReference;
*/
public final class JavaIntrospectionHelper {
private static final Logger logger = Logger.getLogger(JavaIntrospectionHelper.class.getName());
- private static final Class[] EMPTY_CLASS_ARRY = new Class[0];
+ private static final Class<?>[] EMPTY_CLASS_ARRY = new Class[0];
/**
* Hide the constructor
@@ -62,7 +62,7 @@ public final class JavaIntrospectionHelper {
* Returns a collection of public, and protected fields declared by a class
* or one of its supertypes
*/
- public static Set<Field> getAllPublicAndProtectedFields(Class clazz, boolean validating) {
+ public static Set<Field> getAllPublicAndProtectedFields(Class<?> clazz, boolean validating) {
return getAllPublicAndProtectedFields(clazz, new HashSet<Field>(), validating);
}
@@ -78,7 +78,7 @@ public final class JavaIntrospectionHelper {
* Recursively evaluates the type hierarchy to return all fields that are
* public or protected
*/
- private static Set<Field> getAllPublicAndProtectedFields(Class clazz, Set<Field> fields, boolean validating) {
+ private static Set<Field> getAllPublicAndProtectedFields(Class<?> clazz, Set<Field> fields, boolean validating) {
if (clazz == null || clazz.isArray() || Object.class.equals(clazz)) {
return fields;
}
@@ -86,7 +86,8 @@ public final class JavaIntrospectionHelper {
Field[] declaredFields = clazz.getDeclaredFields();
for (final Field field : declaredFields) {
int modifiers = field.getModifiers();
- if ((Modifier.isPublic(modifiers) || Modifier.isProtected(modifiers)) && !Modifier.isStatic(modifiers)) {
+ // The field should be non-final and non-static
+ if ((Modifier.isPublic(modifiers) || Modifier.isProtected(modifiers)) && !Modifier.isStatic(modifiers) && !Modifier.isFinal(modifiers)) {
// Allow privileged access to set accessibility. Requires ReflectPermission
// in security policy.
AccessController.doPrivileged(new PrivilegedAction<Object>() {
@@ -104,6 +105,46 @@ public final class JavaIntrospectionHelper {
}
return fields;
}
+
+ /**
+ * Returns a collection of injectable fields (neither final or static) declared by a class
+ * or one of its supertypes
+ */
+ public static Set<Field> getInjectableFields(Class<?> clazz, boolean validating) {
+ return getInjectableFields(clazz, new HashSet<Field>(), validating);
+ }
+
+ /**
+ * Recursively evaluates the type hierarchy to return all fields that are
+ * not static or final
+ */
+ private static Set<Field> getInjectableFields(Class<?> clazz, Set<Field> fields, boolean validating) {
+ if (clazz == null || clazz.isArray() || Object.class.equals(clazz)) {
+ return fields;
+ }
+ fields = getInjectableFields(clazz.getSuperclass(), fields, validating);
+ Field[] declaredFields = clazz.getDeclaredFields();
+ for (final Field field : declaredFields) {
+ int modifiers = field.getModifiers();
+ // The field should be non-final and non-static
+ if (!Modifier.isStatic(modifiers) && !Modifier.isFinal(modifiers)) {
+ // Allow privileged access to set accessibility. Requires ReflectPermission
+ // in security policy.
+ AccessController.doPrivileged(new PrivilegedAction<Object>() {
+ public Object run() {
+ field.setAccessible(true); // ignore Java accessibility
+ return null;
+ }
+ });
+ fields.add(field);
+ } else {
+ if (validating) {
+ checkInvalidAnnotations(field);
+ }
+ }
+ }
+ return fields;
+ }
/**
* Returns a collection of public and protected methods declared by a class
@@ -113,14 +154,14 @@ public final class JavaIntrospectionHelper {
* cached. It is assumed that this method will be used during a
* configuration phase.
*/
- public static Set<Method> getAllUniquePublicProtectedMethods(Class clazz, boolean validating) {
+ public static Set<Method> getAllUniquePublicProtectedMethods(Class<?> clazz, boolean validating) {
return getAllUniqueMethods(clazz, new HashSet<Method>(), validating);
}
/**
* Recursively evaluates the type hierarchy to return all unique methods
*/
- private static Set<Method> getAllUniqueMethods(Class pClass, Set<Method> methods, boolean validating) {
+ private static Set<Method> getAllUniqueMethods(Class<?> pClass, Set<Method> methods, boolean validating) {
if (pClass == null || pClass.isArray() || Object.class.equals(pClass)) {
return methods;
}