public class KindedPointcut extends Pointcut
Pointcut.StateAND, ANNOTATION, ARGS, ATARGS, ATTHIS_OR_TARGET, ATWITHIN, ATWITHINCODE, CFLOW, CONCRETE, EMPTY_STRING_ARRAY, HANDLER, hasBeenParameterized, IF, IF_FALSE, IF_TRUE, KINDED, lastMatchedShadowId, m_ignoreUnboundBindingForNames, NONE, NOT, OR, pointcutKind, REFERENCE, RESOLVED, state, SYMBOLIC, THIS_OR_TARGET, USER_EXTENSION, WITHIN, WITHINCODEend, sourceContext, start| Constructor and Description |
|---|
KindedPointcut(Shadow.Kind kind,
SignaturePattern signature) |
KindedPointcut(Shadow.Kind kind,
SignaturePattern signature,
ShadowMunger munger) |
| Modifier and Type | Method and Description |
|---|---|
java.lang.Object |
accept(PatternNodeVisitor visitor,
java.lang.Object data) |
Pointcut |
concretize1(ResolvedType inAspect,
ResolvedType declaringType,
IntMap bindings)
Resolves and removes ReferencePointcuts, replacing with basic ones
|
boolean |
couldEverMatchSameJoinPointsAs(KindedPointcut other) |
int |
couldMatchKinds()
The set of ShadowKinds that this Pointcut could possibly match - an int whose bits are set according to the Kinds specified
in Shadow.java
|
boolean |
equals(java.lang.Object other) |
FuzzyBoolean |
fastMatch(FastMatchInfo info)
Could I match any shadows in the code defined within this type?
|
protected Test |
findResidueInternal(Shadow shadow,
ExposedState state) |
Shadow.Kind |
getKind() |
SignaturePattern |
getSignature() |
int |
hashCode() |
protected FuzzyBoolean |
matchInternal(Shadow shadow) |
Pointcut |
parameterizeWith(java.util.Map typeVariableMap,
World w) |
void |
postRead(ResolvedType enclosingType) |
static Pointcut |
read(VersionedDataInputStream s,
ISourceContext context) |
void |
resolveBindings(IScope scope,
Bindings bindings) |
java.lang.String |
toString() |
void |
write(CompressingDataOutputStream s) |
assertState, check, concretize, concretize, concretize, findResidue, fromString, getPointcutKind, getTypeVariablesInScope, isDeclare, makeMatchesNothing, match, resolve, setTypeVariablesInScope, shouldCopyLocationForConcretizecopyLocationFrom, getEnd, getFileName, getSourceContext, getSourceLocation, getStart, readLocation, setLocation, traverse, writeLocationpublic KindedPointcut(Shadow.Kind kind, SignaturePattern signature)
public KindedPointcut(Shadow.Kind kind, SignaturePattern signature, ShadowMunger munger)
public SignaturePattern getSignature()
public int couldMatchKinds()
PointcutcouldMatchKinds in class Pointcutpublic boolean couldEverMatchSameJoinPointsAs(KindedPointcut other)
public FuzzyBoolean fastMatch(FastMatchInfo info)
Pointcutprotected FuzzyBoolean matchInternal(Shadow shadow)
matchInternal in class Pointcutpublic boolean equals(java.lang.Object other)
equals in class java.lang.Objectpublic int hashCode()
hashCode in class java.lang.Objectpublic java.lang.String toString()
toString in class java.lang.Objectpublic void postRead(ResolvedType enclosingType)
public void write(CompressingDataOutputStream s) throws java.io.IOException
write in class PatternNodejava.io.IOExceptionpublic static Pointcut read(VersionedDataInputStream s, ISourceContext context) throws java.io.IOException
java.io.IOExceptionpublic void resolveBindings(IScope scope, Bindings bindings)
resolveBindings in class Pointcutprotected Test findResidueInternal(Shadow shadow, ExposedState state)
findResidueInternal in class Pointcutpublic Pointcut concretize1(ResolvedType inAspect, ResolvedType declaringType, IntMap bindings)
Pointcutconcretize1 in class PointcutinAspect - the aspect to resolve relative tobindings - a Map from formal index in the current lexical context -> formal index in the concrete advice that will run
This must always return a new Pointcut object (even if the concretized Pointcut is identical to the resolved one).
That behavior is assumed in many places. XXX fix implementors to handle statepublic Pointcut parameterizeWith(java.util.Map typeVariableMap, World w)
parameterizeWith in class Pointcutpublic Shadow.Kind getKind()
public java.lang.Object accept(PatternNodeVisitor visitor, java.lang.Object data)
accept in class PatternNode