org.aspectj.lang.reflect.Advice Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of aspectjweaver Show documentation
Show all versions of aspectjweaver Show documentation
The AspectJ weaver applies aspects to Java classes. It can be used as a Java agent in order to apply load-time
weaving (LTW) during class-loading and also contains the AspectJ runtime classes.
/* *******************************************************************
* Copyright (c) 2005 Contributors.
* All rights reserved.
* This program and the accompanying materials are made available
* under the terms of the Eclipse Public License v1.0
* which accompanies this distribution and is available at
* http://eclipse.org/legal/epl-v10.html
*
* Contributors:
* Adrian Colyer Initial implementation
* ******************************************************************/
package org.aspectj.lang.reflect;
import java.lang.reflect.Type;
/**
* Runtime representation of an advice declaration inside an aspect
*/
public interface Advice {
/**
* The declaring aspect
*/
AjType getDeclaringType();
/**
* The kind of advice (before, after-returning, after-throwing, etc.)
*/
AdviceKind getKind();
/**
* Returns the advice name, or the empty string if the advice is anonymous.
* If using the @AspectJ annotations, the advice name is the name of the
* annotated advice method. If using the code style, the advice is
* anonymous, unless the advice is annotated with the @AdviceName annotation,
* in which case the name given in the annotation is returned.
*/
String getName();
/**
* The advice parameters
*/
AjType>[] getParameterTypes();
/**
* The generic parameter types, @see java.lang.reflect.Method.getGenericParameterTypes
*/
Type[] getGenericParameterTypes();
/**
* The declared thrown exceptions by the advice
*/
AjType>[] getExceptionTypes();
/**
* The pointcut expression associated with the advice declaration.
*/
PointcutExpression getPointcutExpression();
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy