diff options
author | wisberg <wisberg> | 2002-12-16 17:09:36 +0000 |
---|---|---|
committer | wisberg <wisberg> | 2002-12-16 17:09:36 +0000 |
commit | c3300283ecc397d26ad9dfe31d1710ec45db2af0 (patch) | |
tree | e9acb7f3d33c1499975cec9ef3cc7ea151078344 /runtime | |
parent | 3cde920c3f7eb8241bf569007e25225d80b43c0f (diff) | |
download | aspectj-c3300283ecc397d26ad9dfe31d1710ec45db2af0.tar.gz aspectj-c3300283ecc397d26ad9dfe31d1710ec45db2af0.zip |
initial version
Diffstat (limited to 'runtime')
36 files changed, 1886 insertions, 0 deletions
diff --git a/runtime/src/.cvsignore b/runtime/src/.cvsignore new file mode 100644 index 000000000..a3f0b1b77 --- /dev/null +++ b/runtime/src/.cvsignore @@ -0,0 +1 @@ +*.lst diff --git a/runtime/src/org/aspectj/lang/JoinPoint.java b/runtime/src/org/aspectj/lang/JoinPoint.java new file mode 100644 index 000000000..4fae1571a --- /dev/null +++ b/runtime/src/org/aspectj/lang/JoinPoint.java @@ -0,0 +1,179 @@ +/* ******************************************************************* + * Copyright (c) 1999-2001 Xerox Corporation, + * 2002 Palo Alto Research Center, Incorporated (PARC). + * All rights reserved. + * This program and the accompanying materials are made available + * under the terms of the Common Public License v1.0 + * which accompanies this distribution and is available at + * http://www.eclipse.org/legal/cpl-v10.html + * + * Contributors: + * Xerox/PARC initial implementation + * ******************************************************************/ + + +package org.aspectj.lang; + +import org.aspectj.lang.reflect.SourceLocation; + +/** + * <p>Provides reflective access to both the state available at a join point and + * static information about it. This information is available from the body + * of advice using the special form <code>thisJoinPoint</code>. The primary + * use of this reflective information is for tracing and logging applications. + * </p> + * + * <pre> + * aspect Logging { + * before(): within(com.bigboxco..*) && execution(public * *(..)) { + * System.err.println("entering: " + thisJoinPoint); + * System.err.println(" w/args: " + thisJoinPoint.getArgs()); + * System.err.println(" at: " + thisJoinPoint.getSourceLocation()); + * } + * } + * </pre> + */ +public interface JoinPoint { + + String toString(); + + /** + * Returns an abbreviated string representation of the join point. + */ + String toShortString(); + + /** + * Returns an extended string representation of the join point. + */ + String toLongString(); + + /** + * <p> Returns the currently executing object. This will always be + * the same object as that matched by the <code>this</code> pointcut + * designator. Unless you specifically need this reflective access, + * you should use the <code>this</code> pointcut designator to + * get at this object for better static typing and performance.</p> + * + * <p> Returns null when there is no currently executing object available. + * This includes all join points that occur in a static context.</p> + */ + Object getThis(); + + /** + * <p> Returns the target object. This will always be + * the same object as that matched by the <code>target</code> pointcut + * designator. Unless you specifically need this reflective access, + * you should use the <code>target</code> pointcut designator to + * get at this object for better static typing and performance.</p> + * + * <p> Returns null when there is no target object.</p> + + */ + Object getTarget(); + + /** + * <p>Returns the arguments at this join point.</p> + */ + Object[] getArgs(); + + /** Returns the signature at the join point. + * + * <code>getStaticPart().getSignature()</code> returns the same object + */ + Signature getSignature(); + + /** <p>Returns the source location corresponding to the join point.</p> + * + * <p>If there is no source location available, returns null.</p> + * + * <p>Returns the SourceLocation of the defining class for default constructors.</p> + * + * <p> <code>getStaticPart().getSourceLocation()</code> returns the same object. </p> + */ + SourceLocation getSourceLocation(); + + /** Returns a String representing the kind of join point. This + * String is guaranteed to be + * interned. <code>getStaticPart().getKind()</code> returns + * the same object. + */ + String getKind(); + + + /** + * <p>This helper object contains only the static information about a join point. + * It is available from the <code>JoinPoint.getStaticPart()</code> method, and + * can be accessed separately within advice using the special form + * <code>thisJoinPointStaticPart</code>.</p> + * + * <p>If you are only interested in the static information about a join point, + * you should access it through this type for the best performance. This + * is particularly useful for library methods that want to do serious + * manipulations of this information, i.e.</p> + * + * <pre> + * public class LoggingUtils { + * public static void prettyPrint(JoinPoint.StaticPart jp) { + * ... + * } + * } + * + * aspect Logging { + * before(): ... { LoggingUtils.prettyPrint(thisJoinPointStaticPart); } + * } + * </pre> + * + * @see JoinPoint#getStaticPart() + */ + public interface StaticPart { + /** Returns the signature at the join point. */ + Signature getSignature(); + + /** <p>Returns the source location corresponding to the join point.</p> + * + * <p>If there is no source location available, returns null.</p> + * + * <p>Returns the SourceLocation of the defining class for default constructors.</p> + */ + SourceLocation getSourceLocation(); + + /** <p> Returns a String representing the kind of join point. This String + * is guaranteed to be interned</p> + */ + String getKind(); + + String toString(); + + /** + * Returns an abbreviated string representation of the join point + */ + String toShortString(); + + /** + * Returns an extended string representation of the join point + */ + String toLongString(); + } + + + /** <p> Returns an object that encapsulates the static parts of this join point </p> + */ + StaticPart getStaticPart(); + + + /** + * The legal return values from getKind() + */ + static String METHOD_EXECUTION = "method-execution"; + static String METHOD_CALL = "method-call"; + static String CONSTRUCTOR_EXECUTION = "constructor-execution"; + static String CONSTRUCTOR_CALL = "constructor-call"; + static String FIELD_GET = "field-get"; + static String FIELD_SET = "field-set"; + static String STATICINITIALIZATION = "staticinitialization"; + static String PREINTIALIZATION = "preinitialization"; + static String INITIALIZATION = "initialization"; + static String EXCEPTION_HANDLER = "exception-handler"; + + static String ADVICE_EXECUTION = "advice-execution"; //??? consider this vs. pcd +} diff --git a/runtime/src/org/aspectj/lang/NoAspectBoundException.java b/runtime/src/org/aspectj/lang/NoAspectBoundException.java new file mode 100644 index 000000000..4bebcfb47 --- /dev/null +++ b/runtime/src/org/aspectj/lang/NoAspectBoundException.java @@ -0,0 +1,21 @@ +/* ******************************************************************* + * Copyright (c) 1999-2001 Xerox Corporation, + * 2002 Palo Alto Research Center, Incorporated (PARC). + * All rights reserved. + * This program and the accompanying materials are made available + * under the terms of the Common Public License v1.0 + * which accompanies this distribution and is available at + * http://www.eclipse.org/legal/cpl-v10.html + * + * Contributors: + * Xerox/PARC initial implementation + * ******************************************************************/ + + +package org.aspectj.lang; + +/** Thrown by the <code>aspectOf(..)</code> special method on aspect types + * when there is no aspect of that type currently bound. + */ +public class NoAspectBoundException extends RuntimeException { +} diff --git a/runtime/src/org/aspectj/lang/Signature.java b/runtime/src/org/aspectj/lang/Signature.java new file mode 100644 index 000000000..91e2f00a2 --- /dev/null +++ b/runtime/src/org/aspectj/lang/Signature.java @@ -0,0 +1,95 @@ +/* ******************************************************************* + * Copyright (c) 1999-2001 Xerox Corporation, + * 2002 Palo Alto Research Center, Incorporated (PARC). + * All rights reserved. + * This program and the accompanying materials are made available + * under the terms of the Common Public License v1.0 + * which accompanies this distribution and is available at + * http://www.eclipse.org/legal/cpl-v10.html + * + * Contributors: + * Xerox/PARC initial implementation + * ******************************************************************/ + + +package org.aspectj.lang; + +/** <p>Represents the signature at a join point. This interface parallels + * <code>java.lang.reflect.Member</code>. </p> + * + * <p>This interface is typically used for tracing or logging applications + * to obtain reflective information about the join point, i.e. using + * the j2se 1.4 <code>java.util.logging</code> API</p> + * <pre> + * aspect Logging { + * Logger logger = Logger.getLogger("MethodEntries"); + * + * before(): within(com.bigboxco..*) && execution(public * *(..)) { + * Signature sig = thisJoinPoint.getSignature(); + * logger.entering(sig.getDeclaringType().getName(), + * sig.getName()); + * } + * } + * </pre> + * + * + * <p>More detailed information about a specific kind of signature can + * be obtained by casting this <code>Signature</code> object into one + * of its more specific sub-types available in + * <code>org.aspectj.lang.reflect</code>. + * + * @see java.lang.reflect.Member + * @see java.util.logging.Logger + */ +public interface Signature { + String toString(); + /** + * Returns an abbreviated string representation of this signature. + */ + String toShortString(); + + /** + * Returns an extended string representation of this signature. + */ + String toLongString(); + + + /** + * Returns the identifier part of this signature; i.e. for methods this + * will return the method name. + * + * @see java.lang.reflect.Member#getName + */ + String getName(); + + /** + * Returns the modifiers on this signature represented as an int. Use + * the constants and helper methods defined on + * <code>java.lang.reflect.Modifier</code> to manipulate this, i.e. + * <pre> + * // check if this signature is public + * java.lang.reflect.Modifier.isPublic(sig.getModifiers()); + * + * // print out the modifiers + * java.lang.reflect.Modifier.toString(sig.getModifiers()); + * </pre> + * + * @see java.lang.reflect.Member#getModifiers + * @see java.lang.reflect.Modifier + */ + int getModifiers(); + + /** + * <p>Returns a <code>java.lang.Class</code> object representing the class, + * interface, or aspect that declared this member. For intra-member + * declarations, this will be the type on which the member is declared, + * not the type where the declaration is lexically written. Use + * <code>SourceLocation.getWithinType()</code> to get the type in + * which the declaration occurs lexically.</p> + * <p>For consistency with <code>java.lang.reflect.Member</code>, this + * method should have been named <code>getDeclaringClass()</code>.</p> + * + * @see java.lang.reflect.Member#getDeclaringClass + */ + Class getDeclaringType(); +} diff --git a/runtime/src/org/aspectj/lang/SoftException.java b/runtime/src/org/aspectj/lang/SoftException.java new file mode 100644 index 000000000..e3c19ed80 --- /dev/null +++ b/runtime/src/org/aspectj/lang/SoftException.java @@ -0,0 +1,37 @@ +/* ******************************************************************* + * Copyright (c) 1999-2001 Xerox Corporation, + * 2002 Palo Alto Research Center, Incorporated (PARC). + * All rights reserved. + * This program and the accompanying materials are made available + * under the terms of the Common Public License v1.0 + * which accompanies this distribution and is available at + * http://www.eclipse.org/legal/cpl-v10.html + * + * Contributors: + * Xerox/PARC initial implementation + * ******************************************************************/ + + +package org.aspectj.lang; + +/** + * Wrapper for checked exceptions matched by a 'declare soft'. + * You can soften checked exceptions at join points by using + * the form <code>declare soft: TypePattern: Pointcut</code>. + * At the join points, any exceptions thrown which match + * TypePattern will be wrapped in <code>SoftException</code> + * and rethrown. You can get the original exception using + * <code>getWrappedThrowable()</code>. + */ +public class SoftException extends RuntimeException { + Throwable inner; + public SoftException(Throwable inner) { + super(); + this.inner = inner; + } + + public Throwable getWrappedThrowable() { return inner; } + + //XXX should add a getCause() method to parallel j2se 1.4's new + //XXX chained exception mechanism +} diff --git a/runtime/src/org/aspectj/lang/package.html b/runtime/src/org/aspectj/lang/package.html new file mode 100644 index 000000000..a5fe7ae5d --- /dev/null +++ b/runtime/src/org/aspectj/lang/package.html @@ -0,0 +1,14 @@ +<html> +<body> +Provides several interfaces for obtaining reflective information about a +join point, as well as several exceptions that can be thrown by AspectJ +code. +<p> +<code>JoinPoint</code> and <code>Signature</code> provide reflective +information about a join point. Instances of these interfaces are +available inside of <code>advice</code> with the special variables +<code>thisJoinPoint</code>, <code>thisJoinPointStaticPart</code>, and +<code>thisEnclosingJoinPointStaticPart</code>.</p> + +</body> +</html> diff --git a/runtime/src/org/aspectj/lang/reflect/AdviceSignature.java b/runtime/src/org/aspectj/lang/reflect/AdviceSignature.java new file mode 100644 index 000000000..8afc4e1ac --- /dev/null +++ b/runtime/src/org/aspectj/lang/reflect/AdviceSignature.java @@ -0,0 +1,21 @@ +/* ******************************************************************* + * Copyright (c) 1999-2001 Xerox Corporation, + * 2002 Palo Alto Research Center, Incorporated (PARC). + * All rights reserved. + * This program and the accompanying materials are made available + * under the terms of the Common Public License v1.0 + * which accompanies this distribution and is available at + * http://www.eclipse.org/legal/cpl-v10.html + * + * Contributors: + * Xerox/PARC initial implementation + * ******************************************************************/ + + +package org.aspectj.lang.reflect; + +public interface AdviceSignature extends CodeSignature { + Class getReturnType(); /* name is consistent with reflection API */ + /* before and after always return Void.TYPE */ + /* (some around also return Void.Type) */ +} diff --git a/runtime/src/org/aspectj/lang/reflect/CatchClauseSignature.java b/runtime/src/org/aspectj/lang/reflect/CatchClauseSignature.java new file mode 100644 index 000000000..8932395aa --- /dev/null +++ b/runtime/src/org/aspectj/lang/reflect/CatchClauseSignature.java @@ -0,0 +1,22 @@ +/* ******************************************************************* + * Copyright (c) 1999-2001 Xerox Corporation, + * 2002 Palo Alto Research Center, Incorporated (PARC). + * All rights reserved. + * This program and the accompanying materials are made available + * under the terms of the Common Public License v1.0 + * which accompanies this distribution and is available at + * http://www.eclipse.org/legal/cpl-v10.html + * + * Contributors: + * Xerox/PARC initial implementation + * ******************************************************************/ + + +package org.aspectj.lang.reflect; + +import org.aspectj.lang.Signature; + +public interface CatchClauseSignature extends Signature { + Class getParameterType(); + String getParameterName(); +} diff --git a/runtime/src/org/aspectj/lang/reflect/CodeSignature.java b/runtime/src/org/aspectj/lang/reflect/CodeSignature.java new file mode 100644 index 000000000..795cb6dc9 --- /dev/null +++ b/runtime/src/org/aspectj/lang/reflect/CodeSignature.java @@ -0,0 +1,21 @@ +/* ******************************************************************* + * Copyright (c) 1999-2001 Xerox Corporation, + * 2002 Palo Alto Research Center, Incorporated (PARC). + * All rights reserved. + * This program and the accompanying materials are made available + * under the terms of the Common Public License v1.0 + * which accompanies this distribution and is available at + * http://www.eclipse.org/legal/cpl-v10.html + * + * Contributors: + * Xerox/PARC initial implementation + * ******************************************************************/ + + +package org.aspectj.lang.reflect; + +public interface CodeSignature extends MemberSignature { + Class[] getParameterTypes(); + String[] getParameterNames(); + Class[] getExceptionTypes(); +} diff --git a/runtime/src/org/aspectj/lang/reflect/ConstructorSignature.java b/runtime/src/org/aspectj/lang/reflect/ConstructorSignature.java new file mode 100644 index 000000000..66ab51397 --- /dev/null +++ b/runtime/src/org/aspectj/lang/reflect/ConstructorSignature.java @@ -0,0 +1,18 @@ +/* ******************************************************************* + * Copyright (c) 1999-2001 Xerox Corporation, + * 2002 Palo Alto Research Center, Incorporated (PARC). + * All rights reserved. + * This program and the accompanying materials are made available + * under the terms of the Common Public License v1.0 + * which accompanies this distribution and is available at + * http://www.eclipse.org/legal/cpl-v10.html + * + * Contributors: + * Xerox/PARC initial implementation + * ******************************************************************/ + + +package org.aspectj.lang.reflect; + +public interface ConstructorSignature extends CodeSignature { +} diff --git a/runtime/src/org/aspectj/lang/reflect/FieldSignature.java b/runtime/src/org/aspectj/lang/reflect/FieldSignature.java new file mode 100644 index 000000000..0983509c5 --- /dev/null +++ b/runtime/src/org/aspectj/lang/reflect/FieldSignature.java @@ -0,0 +1,21 @@ +/* ******************************************************************* + * Copyright (c) 1999-2001 Xerox Corporation, + * 2002 Palo Alto Research Center, Incorporated (PARC). + * All rights reserved. + * This program and the accompanying materials are made available + * under the terms of the Common Public License v1.0 + * which accompanies this distribution and is available at + * http://www.eclipse.org/legal/cpl-v10.html + * + * Contributors: + * Xerox/PARC initial implementation + * ******************************************************************/ + + +package org.aspectj.lang.reflect; + +import org.aspectj.lang.Signature; + +public interface FieldSignature extends MemberSignature { + public Class getFieldType(); +} diff --git a/runtime/src/org/aspectj/lang/reflect/InitializerSignature.java b/runtime/src/org/aspectj/lang/reflect/InitializerSignature.java new file mode 100644 index 000000000..2b75f92a6 --- /dev/null +++ b/runtime/src/org/aspectj/lang/reflect/InitializerSignature.java @@ -0,0 +1,17 @@ +/* ******************************************************************* + * Copyright (c) 1999-2001 Xerox Corporation, + * 2002 Palo Alto Research Center, Incorporated (PARC). + * All rights reserved. + * This program and the accompanying materials are made available + * under the terms of the Common Public License v1.0 + * which accompanies this distribution and is available at + * http://www.eclipse.org/legal/cpl-v10.html + * + * Contributors: + * Xerox/PARC initial implementation + * ******************************************************************/ + + +package org.aspectj.lang.reflect; + +public interface InitializerSignature extends CodeSignature { } diff --git a/runtime/src/org/aspectj/lang/reflect/MemberSignature.java b/runtime/src/org/aspectj/lang/reflect/MemberSignature.java new file mode 100644 index 000000000..31f21df7d --- /dev/null +++ b/runtime/src/org/aspectj/lang/reflect/MemberSignature.java @@ -0,0 +1,20 @@ +/* ******************************************************************* + * Copyright (c) 1999-2001 Xerox Corporation, + * 2002 Palo Alto Research Center, Incorporated (PARC). + * All rights reserved. + * This program and the accompanying materials are made available + * under the terms of the Common Public License v1.0 + * which accompanies this distribution and is available at + * http://www.eclipse.org/legal/cpl-v10.html + * + * Contributors: + * Xerox/PARC initial implementation + * ******************************************************************/ + + +package org.aspectj.lang.reflect; + +import org.aspectj.lang.Signature; + +public interface MemberSignature extends Signature { +} diff --git a/runtime/src/org/aspectj/lang/reflect/MethodSignature.java b/runtime/src/org/aspectj/lang/reflect/MethodSignature.java new file mode 100644 index 000000000..f26d6c504 --- /dev/null +++ b/runtime/src/org/aspectj/lang/reflect/MethodSignature.java @@ -0,0 +1,19 @@ +/* ******************************************************************* + * Copyright (c) 1999-2001 Xerox Corporation, + * 2002 Palo Alto Research Center, Incorporated (PARC). + * All rights reserved. + * This program and the accompanying materials are made available + * under the terms of the Common Public License v1.0 + * which accompanies this distribution and is available at + * http://www.eclipse.org/legal/cpl-v10.html + * + * Contributors: + * Xerox/PARC initial implementation + * ******************************************************************/ + + +package org.aspectj.lang.reflect; + +public interface MethodSignature extends CodeSignature { + Class getReturnType(); /* name is consistent with reflection API */ +} diff --git a/runtime/src/org/aspectj/lang/reflect/SourceLocation.java b/runtime/src/org/aspectj/lang/reflect/SourceLocation.java new file mode 100644 index 000000000..cb6bfcf95 --- /dev/null +++ b/runtime/src/org/aspectj/lang/reflect/SourceLocation.java @@ -0,0 +1,30 @@ +/* ******************************************************************* + * Copyright (c) 1999-2001 Xerox Corporation, + * 2002 Palo Alto Research Center, Incorporated (PARC). + * All rights reserved. + * This program and the accompanying materials are made available + * under the terms of the Common Public License v1.0 + * which accompanies this distribution and is available at + * http://www.eclipse.org/legal/cpl-v10.html + * + * Contributors: + * Xerox/PARC initial implementation + * ******************************************************************/ + + +package org.aspectj.lang.reflect; + +/** For defining code, the class defined and location in a source file. */ +public interface SourceLocation { + Class getWithinType(); + + String getFileName(); + int getLine(); + + /** + * @deprecated can not be implemented for bytecode weaving, may + * be removed in 1.1gold. + */ + int getColumn(); +} + diff --git a/runtime/src/org/aspectj/lang/reflect/package.html b/runtime/src/org/aspectj/lang/reflect/package.html new file mode 100644 index 000000000..fc51a5b60 --- /dev/null +++ b/runtime/src/org/aspectj/lang/reflect/package.html @@ -0,0 +1,18 @@ +<html> +<body> +<p>Contains interfaces that extend <code>Signature</code> to provide +additional information about each possible join point signature. This +additional information can be accessed by casting a Signature object +to the appropriate type, i.e.</p> +<pre> + before(): call(* *(..)) { + MethodSignature sig = (MethodSignature)thisJoinPoint.getSignature(); + ... + } +</pre> + +<p>This package also contains <code>SourceLocation</code> that provides +information about the location in source code that corresponds to a +particular join point.</p> +</body> +</html> diff --git a/runtime/src/org/aspectj/runtime/CFlow.java b/runtime/src/org/aspectj/runtime/CFlow.java new file mode 100644 index 000000000..59165f8a7 --- /dev/null +++ b/runtime/src/org/aspectj/runtime/CFlow.java @@ -0,0 +1,39 @@ +/* ******************************************************************* + * Copyright (c) 1999-2001 Xerox Corporation, + * 2002 Palo Alto Research Center, Incorporated (PARC). + * All rights reserved. + * This program and the accompanying materials are made available + * under the terms of the Common Public License v1.0 + * which accompanies this distribution and is available at + * http://www.eclipse.org/legal/cpl-v10.html + * + * Contributors: + * Xerox/PARC initial implementation + * ******************************************************************/ + + +package org.aspectj.runtime; + +public class CFlow { + private Object _aspect; + + public CFlow() { + this(null); + } + + public CFlow(Object _aspect) { + this._aspect = _aspect; + } + + public Object getAspect() { + return this._aspect; + } + + public void setAspect(Object _aspect) { + this._aspect = _aspect; + } + + public Object get(int index) { + return null; + } +} diff --git a/runtime/src/org/aspectj/runtime/internal/AroundClosure.java b/runtime/src/org/aspectj/runtime/internal/AroundClosure.java new file mode 100644 index 000000000..1d5ad810a --- /dev/null +++ b/runtime/src/org/aspectj/runtime/internal/AroundClosure.java @@ -0,0 +1,39 @@ +/* ******************************************************************* + * Copyright (c) 1999-2001 Xerox Corporation, + * 2002 Palo Alto Research Center, Incorporated (PARC). + * All rights reserved. + * This program and the accompanying materials are made available + * under the terms of the Common Public License v1.0 + * which accompanies this distribution and is available at + * http://www.eclipse.org/legal/cpl-v10.html + * + * Contributors: + * Xerox/PARC initial implementation + * ******************************************************************/ + + +package org.aspectj.runtime.internal; + +public abstract class AroundClosure { + //private Object[] state; + + public AroundClosure(/* Object[] state */) { + // this.state = state; + } + + protected Object[] state; + protected Object[] preInitializationState; + public AroundClosure(Object[] state) { + this.state = state; + } + + public Object[] getPreInitializationState() { + return preInitializationState; + } + + /** + * This takes in the same arguments as are passed to the proceed + * call in the around advice (with primitives coerced to Object types) + */ + public abstract Object run(Object[] args) throws Throwable; +} diff --git a/runtime/src/org/aspectj/runtime/internal/CFlowPlusState.java b/runtime/src/org/aspectj/runtime/internal/CFlowPlusState.java new file mode 100644 index 000000000..b47addde3 --- /dev/null +++ b/runtime/src/org/aspectj/runtime/internal/CFlowPlusState.java @@ -0,0 +1,32 @@ +/* ******************************************************************* + * Copyright (c) 1999-2001 Xerox Corporation, + * 2002 Palo Alto Research Center, Incorporated (PARC). + * All rights reserved. + * This program and the accompanying materials are made available + * under the terms of the Common Public License v1.0 + * which accompanies this distribution and is available at + * http://www.eclipse.org/legal/cpl-v10.html + * + * Contributors: + * Xerox/PARC initial implementation + * ******************************************************************/ + + +package org.aspectj.runtime.internal; + +public class CFlowPlusState extends org.aspectj.runtime.CFlow { + private Object[] state; + + public CFlowPlusState(Object[] state) { + this.state = state; + } + + public CFlowPlusState(Object[] state, Object _aspect) { + super(_aspect); + this.state = state; + } + + public Object get(int index) { + return state[index]; + } +} diff --git a/runtime/src/org/aspectj/runtime/internal/CFlowStack.java b/runtime/src/org/aspectj/runtime/internal/CFlowStack.java new file mode 100644 index 000000000..d3b18c710 --- /dev/null +++ b/runtime/src/org/aspectj/runtime/internal/CFlowStack.java @@ -0,0 +1,107 @@ +/* ******************************************************************* + * Copyright (c) 1999-2001 Xerox Corporation, + * 2002 Palo Alto Research Center, Incorporated (PARC). + * All rights reserved. + * This program and the accompanying materials are made available + * under the terms of the Common Public License v1.0 + * which accompanies this distribution and is available at + * http://www.eclipse.org/legal/cpl-v10.html + * + * Contributors: + * Xerox/PARC initial implementation + * ******************************************************************/ + + +package org.aspectj.runtime.internal; + +import org.aspectj.lang.NoAspectBoundException; +import org.aspectj.runtime.CFlow; + +import java.util.Stack; +import java.util.Hashtable; +import java.util.Vector; +import java.util.Enumeration; + +public class CFlowStack { + private Hashtable stacks = new Hashtable(); + private Thread cached_thread; + private Stack cached_stack; + private int change_count = 0; + private static final int COLLECT_AT = 20000; + private static final int MIN_COLLECT_AT = 100; + + private synchronized Stack getThreadStack() { + if (Thread.currentThread() != cached_thread) { + cached_thread = Thread.currentThread(); + cached_stack = (Stack)stacks.get(cached_thread); + if (cached_stack == null) { + cached_stack = new Stack(); + stacks.put(cached_thread, cached_stack); + } + change_count++; + // Collect more often if there are many threads, but not *too* often + if (change_count > Math.max(MIN_COLLECT_AT, COLLECT_AT/stacks.size())) { + Stack dead_stacks = new Stack(); + for (Enumeration e = stacks.keys(); e.hasMoreElements(); ) { + Thread t = (Thread)e.nextElement(); + if (!t.isAlive()) dead_stacks.push(t); + } + for (Enumeration e = dead_stacks.elements(); e.hasMoreElements(); ) { + Thread t = (Thread)e.nextElement(); + stacks.remove(t); + } + change_count = 0; + } + } + return cached_stack; + } + + //XXX dangerous, try to remove + public void push(Object obj) { + getThreadStack().push(obj); + } + + public void pushInstance(Object obj) { + getThreadStack().push(new CFlow(obj)); + } + + public void push(Object[] obj) { + getThreadStack().push(new CFlowPlusState(obj)); + } + + public void pop() { + getThreadStack().pop(); + } + + public Object peek() { + Stack stack = getThreadStack(); + if (stack.isEmpty()) throw new org.aspectj.lang.NoAspectBoundException(); + return (Object)stack.peek(); + } + + public Object get(int index) { + return peekCFlow().get(index); + } + + public Object peekInstance() { + CFlow cf = peekCFlow(); + if (cf != null ) return cf.getAspect(); + else throw new NoAspectBoundException(); + } + + public CFlow peekCFlow() { + Stack stack = getThreadStack(); + if (stack.isEmpty()) return null; + return (CFlow)stack.peek(); + } + + public CFlow peekTopCFlow() { + Stack stack = getThreadStack(); + if (stack.isEmpty()) return null; + return (CFlow)stack.get(0); + } + + public boolean isValid() { + return !getThreadStack().isEmpty(); + } +} diff --git a/runtime/src/org/aspectj/runtime/internal/Conversions.java b/runtime/src/org/aspectj/runtime/internal/Conversions.java new file mode 100644 index 000000000..24be02d0d --- /dev/null +++ b/runtime/src/org/aspectj/runtime/internal/Conversions.java @@ -0,0 +1,145 @@ +/* ******************************************************************* + * Copyright (c) 1999-2001 Xerox Corporation, + * 2002 Palo Alto Research Center, Incorporated (PARC). + * All rights reserved. + * This program and the accompanying materials are made available + * under the terms of the Common Public License v1.0 + * which accompanies this distribution and is available at + * http://www.eclipse.org/legal/cpl-v10.html + * + * Contributors: + * Xerox/PARC initial implementation + * ******************************************************************/ + + +package org.aspectj.runtime.internal; + +public final class Conversions { + // Can't make instances of me + private Conversions() {} + + // we might want to keep a cache of small integers around + public static Object intObject(int i) { + return new Integer(i); + } + public static Object shortObject(short i) { + return new Short(i); + } + public static Object byteObject(byte i) { + return new Byte(i); + } + public static Object charObject(char i) { + return new Character(i); + } + public static Object longObject(long i) { + return new Long(i); + } + public static Object floatObject(float i) { + return new Float(i); + } + public static Object doubleObject(double i) { + return new Double(i); + } + public static Object booleanObject(boolean i) { + return new Boolean(i); + } + public static Object voidObject() { + return null; + } + + + public static int intValue(Object o) { + if (o == null) { + return 0; + } else if (o instanceof Number) { + return ((Number)o).intValue(); + } else { + throw new ClassCastException(o.getClass().getName() + + " can not be converted to int"); + } + } + public static long longValue(Object o) { + if (o == null) { + return 0; + } else if (o instanceof Number) { + return ((Number)o).longValue(); + } else { + throw new ClassCastException(o.getClass().getName() + + " can not be converted to long"); + } + } + public static float floatValue(Object o) { + if (o == null) { + return 0; + } else if (o instanceof Number) { + return ((Number)o).floatValue(); + } else { + throw new ClassCastException(o.getClass().getName() + + " can not be converted to float"); + } + } + public static double doubleValue(Object o) { + if (o == null) { + return 0; + } else if (o instanceof Number) { + return ((Number)o).doubleValue(); + } else { + throw new ClassCastException(o.getClass().getName() + + " can not be converted to double"); + } + } + public static byte byteValue(Object o) { + if (o == null) { + return 0; + } else if (o instanceof Number) { + return ((Number)o).byteValue(); + } else { + throw new ClassCastException(o.getClass().getName() + + " can not be converted to byte"); + } + } + public static short shortValue(Object o) { + if (o == null) { + return 0; + } else if (o instanceof Number) { + return ((Number)o).shortValue(); + } else { + throw new ClassCastException(o.getClass().getName() + + " can not be converted to short"); + } + } + public static char charValue(Object o) { + if (o == null) { + return 0; + } else if (o instanceof Character) { + return ((Character)o).charValue(); + } else { + throw new ClassCastException(o.getClass().getName() + + " can not be converted to char"); + } + } + public static boolean booleanValue(Object o) { + if (o == null) { + return false; + } else if (o instanceof Boolean) { + return ((Boolean)o).booleanValue(); + } else { + throw new ClassCastException(o.getClass().getName() + + " can not be converted to boolean"); + } + } + + /** + * identity function for now. This is not typed to "void" because we happen + * to know that in Java, any void context (i.e., {@link ExprStmt}) + * can also handle a return value. + */ + public static Object voidValue(Object o) { + if (o == null) { + return o; + } else { + // !!! this may be an error in the future + return o; + } + } +} diff --git a/runtime/src/org/aspectj/runtime/internal/PerObjectMap.java b/runtime/src/org/aspectj/runtime/internal/PerObjectMap.java new file mode 100644 index 000000000..5a4b5b765 --- /dev/null +++ b/runtime/src/org/aspectj/runtime/internal/PerObjectMap.java @@ -0,0 +1,35 @@ +/* ******************************************************************* + * Copyright (c) 1999-2001 Xerox Corporation, + * 2002 Palo Alto Research Center, Incorporated (PARC). + * All rights reserved. + * This program and the accompanying materials are made available + * under the terms of the Common Public License v1.0 + * which accompanies this distribution and is available at + * http://www.eclipse.org/legal/cpl-v10.html + * + * Contributors: + * Xerox/PARC initial implementation + * ******************************************************************/ + + +package org.aspectj.runtime.internal; + +import org.aspectj.runtime.CFlow; + + +// REQUIRES JAVA 2!!!!!!!!!!!!!!!! +import java.util.WeakHashMap; + +public class PerObjectMap { + private WeakHashMap map = new WeakHashMap(); + + public boolean hasAspect(Object o) { return map.containsKey(o); } + + public Object aspectOf(Object o) { + return map.get(o); + } + + public void bind(Object object, Object _aspect) { + map.put(object, _aspect); + } +} diff --git a/runtime/src/org/aspectj/runtime/reflect/AdviceSignatureImpl.java b/runtime/src/org/aspectj/runtime/reflect/AdviceSignatureImpl.java new file mode 100644 index 000000000..7ea1ceff1 --- /dev/null +++ b/runtime/src/org/aspectj/runtime/reflect/AdviceSignatureImpl.java @@ -0,0 +1,58 @@ +/* ******************************************************************* + * Copyright (c) 1999-2001 Xerox Corporation, + * 2002 Palo Alto Research Center, Incorporated (PARC). + * All rights reserved. + * This program and the accompanying materials are made available + * under the terms of the Common Public License v1.0 + * which accompanies this distribution and is available at + * http://www.eclipse.org/legal/cpl-v10.html + * + * Contributors: + * Xerox/PARC initial implementation + * ******************************************************************/ + + +package org.aspectj.runtime.reflect; + +import org.aspectj.lang.*; +import org.aspectj.lang.reflect.*; + +import java.lang.reflect.Modifier; + +class AdviceSignatureImpl extends CodeSignatureImpl implements AdviceSignature { + Class returnType; + + AdviceSignatureImpl(int modifiers, String name, Class declaringType, + Class[] parameterTypes, String[] parameterNames, Class[] exceptionTypes, + Class returnType) + { + super(modifiers, name, declaringType, parameterTypes, parameterNames, + exceptionTypes); + this.returnType = returnType; + } + + AdviceSignatureImpl(String stringRep) { + super(stringRep); + } + /* name is consistent with reflection API + before and after always return Void.TYPE + (some around also return Void.Type) */ + public Class getReturnType() { + if (returnType == null) returnType = extractType(6); + return returnType; + } + + String toString(StringMaker sm) { + //XXX this signature needs a lot of work + StringBuffer buf = new StringBuffer("ADVICE: "); + buf.append(sm.makeModifiersString(getModifiers())); + if (sm.includeArgs) buf.append(sm.makeTypeName(getReturnType())); + if (sm.includeArgs) buf.append(" "); + buf.append(sm.makePrimaryTypeName(getDeclaringType())); + buf.append("."); + buf.append(getName()); + sm.addSignature(buf, getParameterTypes()); + sm.addThrows(buf, getExceptionTypes()); + return buf.toString(); + } +} diff --git a/runtime/src/org/aspectj/runtime/reflect/CatchClauseSignatureImpl.java b/runtime/src/org/aspectj/runtime/reflect/CatchClauseSignatureImpl.java new file mode 100644 index 000000000..638b7fea9 --- /dev/null +++ b/runtime/src/org/aspectj/runtime/reflect/CatchClauseSignatureImpl.java @@ -0,0 +1,48 @@ +/* ******************************************************************* + * Copyright (c) 1999-2001 Xerox Corporation, + * 2002 Palo Alto Research Center, Incorporated (PARC). + * All rights reserved. + * This program and the accompanying materials are made available + * under the terms of the Common Public License v1.0 + * which accompanies this distribution and is available at + * http://www.eclipse.org/legal/cpl-v10.html + * + * Contributors: + * Xerox/PARC initial implementation + * ******************************************************************/ + + +package org.aspectj.runtime.reflect; + +import org.aspectj.lang.*; +import org.aspectj.lang.reflect.*; + +class CatchClauseSignatureImpl extends SignatureImpl implements CatchClauseSignature { + Class parameterType; + String parameterName; + + CatchClauseSignatureImpl(Class declaringType, + Class parameterType, String parameterName) + { + super(0, "catch", declaringType); + this.parameterType = parameterType; + this.parameterName = parameterName; + } + + CatchClauseSignatureImpl(String stringRep) { + super(stringRep); + } + + public Class getParameterType() { + if (parameterType == null) parameterType = extractType(3); + return parameterType; + } + public String getParameterName() { + if (parameterName == null) parameterName = extractString(4); + return parameterName; + } + + String toString(StringMaker sm) { + return "catch(" + sm.makeTypeName(getParameterType()) + ")"; + } +} diff --git a/runtime/src/org/aspectj/runtime/reflect/CodeSignatureImpl.java b/runtime/src/org/aspectj/runtime/reflect/CodeSignatureImpl.java new file mode 100644 index 000000000..1045152d4 --- /dev/null +++ b/runtime/src/org/aspectj/runtime/reflect/CodeSignatureImpl.java @@ -0,0 +1,49 @@ +/* ******************************************************************* + * Copyright (c) 1999-2001 Xerox Corporation, + * 2002 Palo Alto Research Center, Incorporated (PARC). + * All rights reserved. + * This program and the accompanying materials are made available + * under the terms of the Common Public License v1.0 + * which accompanies this distribution and is available at + * http://www.eclipse.org/legal/cpl-v10.html + * + * Contributors: + * Xerox/PARC initial implementation + * ******************************************************************/ + + +package org.aspectj.runtime.reflect; + +import org.aspectj.lang.*; +import org.aspectj.lang.reflect.*; + +abstract class CodeSignatureImpl extends MemberSignatureImpl implements CodeSignature { + Class[] parameterTypes; + String[] parameterNames; + Class[] exceptionTypes; + + CodeSignatureImpl(int modifiers, String name, Class declaringType, + Class[] parameterTypes, String[] parameterNames, Class[] exceptionTypes) + { + super(modifiers, name, declaringType); + this.parameterTypes = parameterTypes; + this.parameterNames = parameterNames; + this.exceptionTypes = exceptionTypes; + } + CodeSignatureImpl(String stringRep) { + super(stringRep); + } + + public Class[] getParameterTypes() { + if (parameterTypes == null) parameterTypes = extractTypes(3); + return parameterTypes; + } + public String[] getParameterNames() { + if (parameterNames == null) parameterNames = extractStrings(4); + return parameterNames; + } + public Class[] getExceptionTypes() { + if (exceptionTypes == null) exceptionTypes = extractTypes(5); + return exceptionTypes; + } +} diff --git a/runtime/src/org/aspectj/runtime/reflect/ConstructorSignatureImpl.java b/runtime/src/org/aspectj/runtime/reflect/ConstructorSignatureImpl.java new file mode 100644 index 000000000..49b0827f9 --- /dev/null +++ b/runtime/src/org/aspectj/runtime/reflect/ConstructorSignatureImpl.java @@ -0,0 +1,41 @@ +/* ******************************************************************* + * Copyright (c) 1999-2001 Xerox Corporation, + * 2002 Palo Alto Research Center, Incorporated (PARC). + * All rights reserved. + * This program and the accompanying materials are made available + * under the terms of the Common Public License v1.0 + * which accompanies this distribution and is available at + * http://www.eclipse.org/legal/cpl-v10.html + * + * Contributors: + * Xerox/PARC initial implementation + * ******************************************************************/ + + +package org.aspectj.runtime.reflect; + +import org.aspectj.lang.reflect.*; +import org.aspectj.lang.*; + +class ConstructorSignatureImpl extends CodeSignatureImpl implements ConstructorSignature { + ConstructorSignatureImpl(int modifiers, Class declaringType, + Class[] parameterTypes, String[] parameterNames, Class[] exceptionTypes) + { + super(modifiers, "<init>", declaringType, parameterTypes, parameterNames, exceptionTypes); + } + + ConstructorSignatureImpl(String stringRep) { + super(stringRep); + } + + public String getName() { return "<init>"; } + + String toString(StringMaker sm) { + StringBuffer buf = new StringBuffer(); + buf.append(sm.makeModifiersString(getModifiers())); + buf.append(sm.makePrimaryTypeName(getDeclaringType())); + sm.addSignature(buf, getParameterTypes()); + sm.addThrows(buf, getExceptionTypes()); + return buf.toString(); + } +} diff --git a/runtime/src/org/aspectj/runtime/reflect/Factory.java b/runtime/src/org/aspectj/runtime/reflect/Factory.java new file mode 100644 index 000000000..781286389 --- /dev/null +++ b/runtime/src/org/aspectj/runtime/reflect/Factory.java @@ -0,0 +1,90 @@ +/* ******************************************************************* + * Copyright (c) 1999-2001 Xerox Corporation, + * 2002 Palo Alto Research Center, Incorporated (PARC). + * All rights reserved. + * This program and the accompanying materials are made available + * under the terms of the Common Public License v1.0 + * which accompanies this distribution and is available at + * http://www.eclipse.org/legal/cpl-v10.html + * + * Contributors: + * Xerox/PARC initial implementation + * ******************************************************************/ + + +package org.aspectj.runtime.reflect; + +import org.aspectj.lang.*; +import org.aspectj.lang.reflect.*; + +public final class Factory { + Class lexicalClass; + ClassLoader lookupClassLoader; + String filename; + public Factory(String filename, Class lexicalClass) { + //System.out.println("making + this.filename = filename; + this.lexicalClass = lexicalClass; + lookupClassLoader = lexicalClass.getClassLoader(); + } + + public JoinPoint.StaticPart makeSJP(String kind, Signature sig, SourceLocation loc) { + return new JoinPointImpl.StaticPartImpl(kind, sig, loc); + } + + public JoinPoint.StaticPart makeSJP(String kind, Signature sig, int l, int c) { + return new JoinPointImpl.StaticPartImpl(kind, sig, makeSourceLoc(l, c)); + } + + public JoinPoint.StaticPart makeSJP(String kind, Signature sig, int l) { + return new JoinPointImpl.StaticPartImpl(kind, sig, makeSourceLoc(l, -1)); + } + + public static JoinPoint makeJP(JoinPoint.StaticPart staticPart, + Object _this, Object target, Object[] args) + { + return new JoinPointImpl(staticPart, _this, target, args); + } + + public MethodSignature makeMethodSig(String stringRep) { + MethodSignatureImpl ret = new MethodSignatureImpl(stringRep); + ret.setLookupClassLoader(lookupClassLoader); + return ret; + } + + public ConstructorSignature makeConstructorSig(String stringRep) { + ConstructorSignatureImpl ret = new ConstructorSignatureImpl(stringRep); + ret.setLookupClassLoader(lookupClassLoader); + return ret; + } + + public FieldSignature makeFieldSig(String stringRep) { + FieldSignatureImpl ret = new FieldSignatureImpl(stringRep); + ret.setLookupClassLoader(lookupClassLoader); + return ret; + } + + public AdviceSignature makeAdviceSig(String stringRep) { + AdviceSignatureImpl ret = new AdviceSignatureImpl(stringRep); + ret.setLookupClassLoader(lookupClassLoader); + return ret; + } + + public InitializerSignature makeInitializerSig(String stringRep) { + InitializerSignatureImpl ret = new InitializerSignatureImpl(stringRep); + ret.setLookupClassLoader(lookupClassLoader); + return ret; + } + + public CatchClauseSignature makeCatchClauseSig(String stringRep) { + CatchClauseSignatureImpl ret = new CatchClauseSignatureImpl(stringRep); + ret.setLookupClassLoader(lookupClassLoader); + return ret; + } + + + public SourceLocation makeSourceLoc(int line, int col) + { + return new SourceLocationImpl(lexicalClass, this.filename, line, col); + } +} diff --git a/runtime/src/org/aspectj/runtime/reflect/FieldSignatureImpl.java b/runtime/src/org/aspectj/runtime/reflect/FieldSignatureImpl.java new file mode 100644 index 000000000..5ab058edd --- /dev/null +++ b/runtime/src/org/aspectj/runtime/reflect/FieldSignatureImpl.java @@ -0,0 +1,51 @@ +/* ******************************************************************* + * Copyright (c) 1999-2001 Xerox Corporation, + * 2002 Palo Alto Research Center, Incorporated (PARC). + * All rights reserved. + * This program and the accompanying materials are made available + * under the terms of the Common Public License v1.0 + * which accompanies this distribution and is available at + * http://www.eclipse.org/legal/cpl-v10.html + * + * Contributors: + * Xerox/PARC initial implementation + * ******************************************************************/ + + +package org.aspectj.runtime.reflect; + +import org.aspectj.lang.reflect.*; +import org.aspectj.lang.*; + +import java.lang.reflect.Modifier; + +public class FieldSignatureImpl extends MemberSignatureImpl implements FieldSignature { + Class fieldType; + + FieldSignatureImpl(int modifiers, String name, Class declaringType, + Class fieldType) + { + super(modifiers, name, declaringType); + this.fieldType = fieldType; + } + + FieldSignatureImpl(String stringRep) { + super(stringRep); + } + + public Class getFieldType() { + if (fieldType == null) fieldType = extractType(3); + return fieldType; + } + + String toString(StringMaker sm) { + StringBuffer buf = new StringBuffer(); + buf.append(sm.makeModifiersString(getModifiers())); + if (sm.includeArgs) buf.append(sm.makeTypeName(getFieldType())); + if (sm.includeArgs) buf.append(" "); + buf.append(sm.makePrimaryTypeName(getDeclaringType())); + buf.append("."); + buf.append(getName()); + return buf.toString(); + } +} diff --git a/runtime/src/org/aspectj/runtime/reflect/InitializerSignatureImpl.java b/runtime/src/org/aspectj/runtime/reflect/InitializerSignatureImpl.java new file mode 100644 index 000000000..f7065d673 --- /dev/null +++ b/runtime/src/org/aspectj/runtime/reflect/InitializerSignatureImpl.java @@ -0,0 +1,44 @@ +/* ******************************************************************* + * Copyright (c) 1999-2001 Xerox Corporation, + * 2002 Palo Alto Research Center, Incorporated (PARC). + * All rights reserved. + * This program and the accompanying materials are made available + * under the terms of the Common Public License v1.0 + * which accompanies this distribution and is available at + * http://www.eclipse.org/legal/cpl-v10.html + * + * Contributors: + * Xerox/PARC initial implementation + * ******************************************************************/ + + +package org.aspectj.runtime.reflect; + +import org.aspectj.lang.reflect.*; +import org.aspectj.lang.*; + +import java.lang.reflect.Modifier; + +class InitializerSignatureImpl extends CodeSignatureImpl implements InitializerSignature { + InitializerSignatureImpl(int modifiers, Class declaringType) { + super(modifiers, Modifier.isStatic(modifiers) ? "<clinit>" : "<init>", declaringType, EMPTY_CLASS_ARRAY, + EMPTY_STRING_ARRAY, EMPTY_CLASS_ARRAY); + } + + InitializerSignatureImpl(String stringRep) { + super(stringRep); + } + + public String getName() { + return Modifier.isStatic(getModifiers()) ? "<clinit>": "<init>"; + } + + String toString(StringMaker sm) { + StringBuffer buf = new StringBuffer(); + buf.append(sm.makeModifiersString(getModifiers())); + buf.append(sm.makePrimaryTypeName(getDeclaringType())); + buf.append("."); + buf.append(getName()); + return buf.toString(); + } +} diff --git a/runtime/src/org/aspectj/runtime/reflect/JoinPointImpl.java b/runtime/src/org/aspectj/runtime/reflect/JoinPointImpl.java new file mode 100644 index 000000000..573d8b338 --- /dev/null +++ b/runtime/src/org/aspectj/runtime/reflect/JoinPointImpl.java @@ -0,0 +1,76 @@ +/* ******************************************************************* + * Copyright (c) 1999-2001 Xerox Corporation, + * 2002 Palo Alto Research Center, Incorporated (PARC). + * All rights reserved. + * This program and the accompanying materials are made available + * under the terms of the Common Public License v1.0 + * which accompanies this distribution and is available at + * http://www.eclipse.org/legal/cpl-v10.html + * + * Contributors: + * Xerox/PARC initial implementation + * ******************************************************************/ + + +package org.aspectj.runtime.reflect; + +import org.aspectj.lang.*; + +import org.aspectj.lang.reflect.SourceLocation; + +class JoinPointImpl implements JoinPoint { + static class StaticPartImpl implements JoinPoint.StaticPart { + String kind; + Signature signature; + SourceLocation sourceLocation; + + public StaticPartImpl(String kind, Signature signature, SourceLocation sourceLocation) { + this.kind = kind; + this.signature = signature; + this.sourceLocation = sourceLocation; + } + + public String getKind() { return kind; } + public Signature getSignature() { return signature; } + public SourceLocation getSourceLocation() { return sourceLocation; } + + String toString(StringMaker sm) { + StringBuffer buf = new StringBuffer(); + buf.append(sm.makeKindName(getKind())); + buf.append("("); + buf.append(((SignatureImpl)getSignature()).toString(sm)); + buf.append(")"); + return buf.toString(); + } + + public final String toString() { return toString(StringMaker.middleStringMaker); } + public final String toShortString() { return toString(StringMaker.shortStringMaker); } + public final String toLongString() { return toString(StringMaker.longStringMaker); } + } + + Object _this; + Object target; + Object[] args; + org.aspectj.lang.JoinPoint.StaticPart staticPart; + + public JoinPointImpl(org.aspectj.lang.JoinPoint.StaticPart staticPart, Object _this, Object target, Object[] args) { + this.staticPart = staticPart; + this._this = _this; + this.target = target; + this.args = args; + } + + public Object getThis() { return _this; } + public Object getTarget() { return target; } + public Object[] getArgs() { return args; } + + public org.aspectj.lang.JoinPoint.StaticPart getStaticPart() { return staticPart; } + + public String getKind() { return staticPart.getKind(); } + public Signature getSignature() { return staticPart.getSignature(); } + public SourceLocation getSourceLocation() { return staticPart.getSourceLocation(); } + + public final String toString() { return staticPart.toString(); } + public final String toShortString() { return staticPart.toShortString(); } + public final String toLongString() { return staticPart.toLongString(); } +} diff --git a/runtime/src/org/aspectj/runtime/reflect/MemberSignatureImpl.java b/runtime/src/org/aspectj/runtime/reflect/MemberSignatureImpl.java new file mode 100644 index 000000000..3097a1abf --- /dev/null +++ b/runtime/src/org/aspectj/runtime/reflect/MemberSignatureImpl.java @@ -0,0 +1,28 @@ +/* ******************************************************************* + * Copyright (c) 1999-2001 Xerox Corporation, + * 2002 Palo Alto Research Center, Incorporated (PARC). + * All rights reserved. + * This program and the accompanying materials are made available + * under the terms of the Common Public License v1.0 + * which accompanies this distribution and is available at + * http://www.eclipse.org/legal/cpl-v10.html + * + * Contributors: + * Xerox/PARC initial implementation + * ******************************************************************/ + + +package org.aspectj.runtime.reflect; + +import org.aspectj.lang.*; +import org.aspectj.lang.reflect.*; + +abstract class MemberSignatureImpl extends SignatureImpl implements MemberSignature { + MemberSignatureImpl(int modifiers, String name, Class declaringType) { + super(modifiers, name, declaringType); + } + + public MemberSignatureImpl(String stringRep) { + super(stringRep); + } +} diff --git a/runtime/src/org/aspectj/runtime/reflect/MethodSignatureImpl.java b/runtime/src/org/aspectj/runtime/reflect/MethodSignatureImpl.java new file mode 100644 index 000000000..4318dc9ca --- /dev/null +++ b/runtime/src/org/aspectj/runtime/reflect/MethodSignatureImpl.java @@ -0,0 +1,55 @@ +/* ******************************************************************* + * Copyright (c) 1999-2001 Xerox Corporation, + * 2002 Palo Alto Research Center, Incorporated (PARC). + * All rights reserved. + * This program and the accompanying materials are made available + * under the terms of the Common Public License v1.0 + * which accompanies this distribution and is available at + * http://www.eclipse.org/legal/cpl-v10.html + * + * Contributors: + * Xerox/PARC initial implementation + * ******************************************************************/ + + +package org.aspectj.runtime.reflect; + +import org.aspectj.lang.*; +import org.aspectj.lang.reflect.*; +import java.lang.reflect.Modifier; + +class MethodSignatureImpl extends CodeSignatureImpl implements MethodSignature { + Class returnType; + + MethodSignatureImpl(int modifiers, String name, Class declaringType, + Class[] parameterTypes, String[] parameterNames, Class[] exceptionTypes, + Class returnType) + { + super(modifiers, name, declaringType, parameterTypes, parameterNames, + exceptionTypes); + this.returnType = returnType; + } + + MethodSignatureImpl(String stringRep) { + super(stringRep); + } + + /* name is consistent with reflection API */ + public Class getReturnType() { + if (returnType == null) returnType = extractType(6); + return returnType; + } + + String toString(StringMaker sm) { + StringBuffer buf = new StringBuffer(); + buf.append(sm.makeModifiersString(getModifiers())); + if (sm.includeArgs) buf.append(sm.makeTypeName(getReturnType())); + if (sm.includeArgs) buf.append(" "); + buf.append(sm.makePrimaryTypeName(getDeclaringType())); + buf.append("."); + buf.append(getName()); + sm.addSignature(buf, getParameterTypes()); + sm.addThrows(buf, getExceptionTypes()); + return buf.toString(); + } +} diff --git a/runtime/src/org/aspectj/runtime/reflect/SignatureImpl.java b/runtime/src/org/aspectj/runtime/reflect/SignatureImpl.java new file mode 100644 index 000000000..ec46bbbab --- /dev/null +++ b/runtime/src/org/aspectj/runtime/reflect/SignatureImpl.java @@ -0,0 +1,188 @@ +/* ******************************************************************* + * Copyright (c) 1999-2001 Xerox Corporation, + * 2002 Palo Alto Research Center, Incorporated (PARC). + * All rights reserved. + * This program and the accompanying materials are made available + * under the terms of the Common Public License v1.0 + * which accompanies this distribution and is available at + * http://www.eclipse.org/legal/cpl-v10.html + * + * Contributors: + * Xerox/PARC initial implementation + * ******************************************************************/ + + +package org.aspectj.runtime.reflect; + +import org.aspectj.lang.*; +import org.aspectj.lang.reflect.*; + +import java.util.*; + +abstract class SignatureImpl implements Signature { + int modifiers = -1; + String name; + Class declaringType; + + SignatureImpl(int modifiers, String name, Class declaringType) { + this.modifiers = modifiers; + this.name = name; + this.declaringType = declaringType; + } + + abstract String toString(StringMaker sm); + + public final String toString() { return toString(StringMaker.middleStringMaker); } + public final String toShortString() { return toString(StringMaker.shortStringMaker); } + public final String toLongString() { return toString(StringMaker.longStringMaker); } + + public int getModifiers() { + if (modifiers == -1) modifiers = extractInt(0); + return modifiers; + } + public String getName() { + if (name == null) name = extractString(1); + return name; + } + public Class getDeclaringType() { + if (declaringType == null) declaringType = extractType(2); + return declaringType; + } + + + String fullTypeName(Class type) { + if (type == null) return "ANONYMOUS"; + if (type.isArray()) return fullTypeName(type.getComponentType()) + "[]"; + return type.getName().replace('$', '.'); + } + + String stripPackageName(String name) { + int dot = name.lastIndexOf('.'); + if (dot == -1) return name; + return name.substring(dot+1); + } + + String shortTypeName(Class type) { + if (type == null) return "ANONYMOUS"; + if (type.isArray()) return shortTypeName(type.getComponentType()) + "[]"; + return stripPackageName(type.getName()).replace('$', '.'); + } + + void addFullTypeNames(StringBuffer buf, Class[] types) { + for (int i = 0; i < types.length; i++) { + if (i > 0) buf.append(", "); + buf.append(fullTypeName(types[i])); + } + } + void addShortTypeNames(StringBuffer buf, Class[] types) { + for (int i = 0; i < types.length; i++) { + if (i > 0) buf.append(", "); + buf.append(shortTypeName(types[i])); + } + } + + void addTypeArray(StringBuffer buf, Class[] types) { + addFullTypeNames(buf, types); + } + + // lazy version + String stringRep; + ClassLoader lookupClassLoader = null; + + public void setLookupClassLoader(ClassLoader loader) { + this.lookupClassLoader = loader; + } + + private ClassLoader getLookupClassLoader() { + if (lookupClassLoader == null) lookupClassLoader = this.getClass().getClassLoader(); + return lookupClassLoader; + } + + public SignatureImpl(String stringRep) { + this.stringRep = stringRep; + } + + static final char SEP = '-'; + + String extractString(int n) { + //System.out.println(n + ": from " + stringRep); + + int startIndex = 0; + int endIndex = stringRep.indexOf(SEP); + while (n-- > 0) { + startIndex = endIndex+1; + endIndex = stringRep.indexOf(SEP, startIndex); + } + if (endIndex == -1) endIndex = stringRep.length(); + + //System.out.println(" " + stringRep.substring(startIndex, endIndex)); + + return stringRep.substring(startIndex, endIndex); + } + + int extractInt(int n) { + String s = extractString(n); + return Integer.parseInt(s, 16); + } + + Class extractType(int n) { + String s = extractString(n); + return makeClass(s); + } + + static Hashtable prims = new Hashtable(); + static { + prims.put("void", Void.TYPE); + prims.put("boolean", Boolean.TYPE); + prims.put("byte", Byte.TYPE); + prims.put("char", Character.TYPE); + prims.put("short", Short.TYPE); + prims.put("int", Integer.TYPE); + prims.put("long", Long.TYPE); + prims.put("float", Float.TYPE); + prims.put("double", Double.TYPE); + } + + Class makeClass(String s) { + if (s.equals("*")) return null; + Class ret = (Class)prims.get(s); + if (ret != null) return ret; + try { + /* The documentation of Class.forName explains why this is the right thing + * better than I could here. + */ + ClassLoader loader = getLookupClassLoader(); + if (loader == null) { + return Class.forName(s); + } else { + return loader.loadClass(s); + } + } catch (ClassNotFoundException e) { + //System.out.println("null for: " + s); + //XXX there should be a better return value for this + return ClassNotFoundException.class; + } + } + + static String[] EMPTY_STRING_ARRAY = new String[0]; + static Class[] EMPTY_CLASS_ARRAY = new Class[0]; + + static final String INNER_SEP = ":"; + + String[] extractStrings(int n) { + String s = extractString(n); + StringTokenizer st = new StringTokenizer(s, INNER_SEP); + final int N = st.countTokens(); + String[] ret = new String[N]; + for (int i = 0; i < N; i++) ret[i]= st.nextToken(); + return ret; + } + Class[] extractTypes(int n) { + String s = extractString(n); + StringTokenizer st = new StringTokenizer(s, INNER_SEP); + final int N = st.countTokens(); + Class[] ret = new Class[N]; + for (int i = 0; i < N; i++) ret[i]= makeClass(st.nextToken()); + return ret; + } +} diff --git a/runtime/src/org/aspectj/runtime/reflect/SourceLocationImpl.java b/runtime/src/org/aspectj/runtime/reflect/SourceLocationImpl.java new file mode 100644 index 000000000..6a04283b3 --- /dev/null +++ b/runtime/src/org/aspectj/runtime/reflect/SourceLocationImpl.java @@ -0,0 +1,43 @@ +/* ******************************************************************* + * Copyright (c) 1999-2001 Xerox Corporation, + * 2002 Palo Alto Research Center, Incorporated (PARC). + * All rights reserved. + * This program and the accompanying materials are made available + * under the terms of the Common Public License v1.0 + * which accompanies this distribution and is available at + * http://www.eclipse.org/legal/cpl-v10.html + * + * Contributors: + * Xerox/PARC initial implementation + * ******************************************************************/ + + +package org.aspectj.runtime.reflect; + +import org.aspectj.lang.*; +import org.aspectj.lang.reflect.*; + +class SourceLocationImpl implements SourceLocation { + Class withinType; + String fileName; + int line; + int column; + + SourceLocationImpl(Class withinType, String fileName, int line, int column) { + this.withinType = withinType; + this.fileName = fileName; + this.line = line; + this.column = column; + } + + public Class getWithinType() { return withinType; } + public String getFileName() { return fileName; } + public int getLine() { return line; } + public int getColumn() { return column; } + + public String toString() { + return getFileName() + ":" + getLine() + + ((getColumn() == -1) ? "" : ":" + getColumn()); + } +} + diff --git a/runtime/src/org/aspectj/runtime/reflect/StringMaker.java b/runtime/src/org/aspectj/runtime/reflect/StringMaker.java new file mode 100644 index 000000000..bc46f992c --- /dev/null +++ b/runtime/src/org/aspectj/runtime/reflect/StringMaker.java @@ -0,0 +1,134 @@ +/* ******************************************************************* + * Copyright (c) 1999-2001 Xerox Corporation, + * 2002 Palo Alto Research Center, Incorporated (PARC). + * All rights reserved. + * This program and the accompanying materials are made available + * under the terms of the Common Public License v1.0 + * which accompanies this distribution and is available at + * http://www.eclipse.org/legal/cpl-v10.html + * + * Contributors: + * Xerox/PARC initial implementation + * ******************************************************************/ + + +package org.aspectj.runtime.reflect; + +import org.aspectj.lang.*; +import org.aspectj.lang.reflect.*; + +import java.lang.reflect.Modifier; + +class StringMaker { + boolean shortTypeNames = true; + boolean includeArgs = true; + boolean includeThrows = false; + boolean includeModifiers = false; + boolean shortPrimaryTypeNames = false; + + boolean includeJoinPointTypeName = true; + boolean includeEnclosingPoint = true; + boolean shortKindName = true; + + static StringMaker shortStringMaker; + static { + shortStringMaker = new StringMaker(); + shortStringMaker.shortTypeNames = true; + shortStringMaker.includeArgs = false; + shortStringMaker.includeThrows = false; + shortStringMaker.includeModifiers = false; + shortStringMaker.shortPrimaryTypeNames = true; + + shortStringMaker.includeJoinPointTypeName = false; + shortStringMaker.includeEnclosingPoint = false; + + } + + static StringMaker middleStringMaker; + static { + middleStringMaker = new StringMaker(); + middleStringMaker.shortTypeNames = true; + middleStringMaker.includeArgs = true; + middleStringMaker.includeThrows = false; + middleStringMaker.includeModifiers = false; + middleStringMaker.shortPrimaryTypeNames = false; + } + + static StringMaker longStringMaker; + static { + longStringMaker = new StringMaker(); + longStringMaker.shortTypeNames = false; + longStringMaker.includeArgs = true; + longStringMaker.includeThrows = false; + longStringMaker.includeModifiers = true; + longStringMaker.shortPrimaryTypeNames = false; + longStringMaker.shortKindName = false; + } + + String makeKindName(String name) { + int dash = name.lastIndexOf('-'); + if (dash == -1) return name; + return name.substring(dash+1); + } + + String makeModifiersString(int modifiers) { + if (!includeModifiers) return ""; + String str = Modifier.toString(modifiers); + if (str.length() == 0) return ""; + return str + " "; + } + + String stripPackageName(String name) { + int dot = name.lastIndexOf('.'); + if (dot == -1) return name; + return name.substring(dot+1); + } + + String makeTypeName(Class type, boolean shortName) { + if (type == null) return "ANONYMOUS"; + if (type.isArray()) return makeTypeName(type.getComponentType(), shortName) + "[]"; + if (shortName) { + return stripPackageName(type.getName()).replace('$', '.'); + } else { + return type.getName().replace('$', '.'); + } + } + + public String makeTypeName(Class type) { + return makeTypeName(type, shortTypeNames); + } + + public String makePrimaryTypeName(Class type) { + return makeTypeName(type, shortPrimaryTypeNames); + } + + public void addTypeNames(StringBuffer buf, Class[] types) { + for (int i = 0; i < types.length; i++) { + if (i > 0) buf.append(", "); + buf.append(makeTypeName(types[i])); + } + } + + public void addSignature(StringBuffer buf, Class[] types) { + if (types == null) return; + if (!includeArgs) { + if (types.length == 0) { + buf.append("()"); + return; + } else { + buf.append("(..)"); + return; + } + } + buf.append("("); + addTypeNames(buf, types); + buf.append(")"); + } + + public void addThrows(StringBuffer buf, Class[] types) { + if (!includeThrows || types == null || types.length == 0) return; + + buf.append(" throws "); + addTypeNames(buf, types); + } +} diff --git a/runtime/testsrc/RuntimeModuleTests.java b/runtime/testsrc/RuntimeModuleTests.java new file mode 100644 index 000000000..ced7ba2ca --- /dev/null +++ b/runtime/testsrc/RuntimeModuleTests.java @@ -0,0 +1,30 @@ +/* ******************************************************************* + * Copyright (c) 1999-2001 Xerox Corporation, + * 2002 Palo Alto Research Center, Incorporated (PARC). + * All rights reserved. + * This program and the accompanying materials are made available + * under the terms of the Common Public License v1.0 + * which accompanies this distribution and is available at + * http://www.eclipse.org/legal/cpl-v10.html + * + * Contributors: + * Xerox/PARC initial implementation + * ******************************************************************/ + + +// default package + +import junit.framework.*; + +public class RuntimeModuleTests extends TestCase { + + public static Test suite() { + TestSuite suite = new TestSuite(RuntimeModuleTests.class.getName()); + suite.addTestSuite(RuntimeModuleTests.class); // minimum 1 test (testNothing) + return suite; + } + + public RuntimeModuleTests(String name) { super(name); } + + public void testNothing() {} +} |