summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--runtime/src/org/aspectj/runtime/reflect/Factory.java29
1 files changed, 28 insertions, 1 deletions
diff --git a/runtime/src/org/aspectj/runtime/reflect/Factory.java b/runtime/src/org/aspectj/runtime/reflect/Factory.java
index 01bc8eff3..3ee924f99 100644
--- a/runtime/src/org/aspectj/runtime/reflect/Factory.java
+++ b/runtime/src/org/aspectj/runtime/reflect/Factory.java
@@ -14,6 +14,10 @@
package org.aspectj.runtime.reflect;
+import java.lang.reflect.Constructor;
+import java.lang.reflect.Member;
+import java.lang.reflect.Method;
+
import org.aspectj.lang.*;
import org.aspectj.lang.reflect.*;
@@ -23,7 +27,7 @@ public final class Factory {
String filename;
public Factory(String filename, Class lexicalClass) {
//System.out.println("making
- this.filename = filename;
+ this.filename = filename;
this.lexicalClass = lexicalClass;
lookupClassLoader = lexicalClass.getClassLoader();
}
@@ -40,6 +44,29 @@ public final class Factory {
return new JoinPointImpl.StaticPartImpl(kind, sig, makeSourceLoc(l, -1));
}
+ public static JoinPoint.StaticPart makeEncSJP(Member member) {
+ Signature sig = null;
+ String kind = null;
+ if (member instanceof Method) {
+ Method method = (Method) member;
+ sig = new MethodSignatureImpl(method.getModifiers(),method.getName(),
+ method.getDeclaringClass(),method.getParameterTypes(),
+ new String[method.getParameterTypes().length],
+ method.getExceptionTypes(),method.getReturnType());
+ kind = JoinPoint.METHOD_EXECUTION;
+ } else if (member instanceof Constructor) {
+ Constructor cons = (Constructor) member;
+ sig = new ConstructorSignatureImpl(cons.getModifiers(),cons.getDeclaringClass(),
+ cons.getParameterTypes(),
+ new String[cons.getParameterTypes().length],
+ cons.getExceptionTypes());
+ kind = JoinPoint.CONSTRUCTOR_EXECUTION;
+ } else {
+ throw new IllegalArgumentException("member must be either a method or constructor");
+ }
+ return new JoinPointImpl.StaticPartImpl(kind,sig,null);
+ }
+
private static Object[] NO_ARGS = new Object[0];
public static JoinPoint makeJP(JoinPoint.StaticPart staticPart,
Object _this, Object target)