You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

PointcutDesignatorHandlerBasedPointcut.java 6.0KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187
  1. /* *******************************************************************
  2. * Copyright (c) 2005 Contributors.
  3. * All rights reserved.
  4. * This program and the accompanying materials are made available
  5. * under the terms of the Eclipse Public License v1.0
  6. * which accompanies this distribution and is available at
  7. * http://eclipse.org/legal/epl-v10.html
  8. *
  9. * Contributors:
  10. * Adrian Colyer Initial implementation
  11. * ******************************************************************/
  12. package org.aspectj.weaver.internal.tools;
  13. import java.io.IOException;
  14. import java.util.Map;
  15. import org.aspectj.util.FuzzyBoolean;
  16. import org.aspectj.weaver.CompressingDataOutputStream;
  17. import org.aspectj.weaver.IntMap;
  18. import org.aspectj.weaver.ReferenceType;
  19. import org.aspectj.weaver.ReferenceTypeDelegate;
  20. import org.aspectj.weaver.ResolvedType;
  21. import org.aspectj.weaver.Shadow;
  22. import org.aspectj.weaver.World;
  23. import org.aspectj.weaver.ast.Literal;
  24. import org.aspectj.weaver.ast.Test;
  25. import org.aspectj.weaver.patterns.Bindings;
  26. import org.aspectj.weaver.patterns.ExposedState;
  27. import org.aspectj.weaver.patterns.FastMatchInfo;
  28. import org.aspectj.weaver.patterns.IScope;
  29. import org.aspectj.weaver.patterns.PatternNodeVisitor;
  30. import org.aspectj.weaver.patterns.Pointcut;
  31. import org.aspectj.weaver.reflect.ReflectionBasedReferenceTypeDelegate;
  32. import org.aspectj.weaver.reflect.ReflectionFastMatchInfo;
  33. import org.aspectj.weaver.reflect.ReflectionShadow;
  34. import org.aspectj.weaver.reflect.ReflectionWorld;
  35. import org.aspectj.weaver.tools.ContextBasedMatcher;
  36. import org.aspectj.weaver.tools.MatchingContext;
  37. /**
  38. * Implementation of Pointcut that is backed by a user-extension pointcut designator handler.
  39. *
  40. */
  41. public class PointcutDesignatorHandlerBasedPointcut extends Pointcut {
  42. private final ContextBasedMatcher matcher;
  43. private final World world;
  44. public PointcutDesignatorHandlerBasedPointcut(ContextBasedMatcher expr, World world) {
  45. this.matcher = expr;
  46. this.world = world;
  47. }
  48. /*
  49. * (non-Javadoc)
  50. *
  51. * @see org.aspectj.weaver.patterns.Pointcut#getPointcutKind()
  52. */
  53. public byte getPointcutKind() {
  54. return Pointcut.USER_EXTENSION;
  55. }
  56. /*
  57. * (non-Javadoc)
  58. *
  59. * @see org.aspectj.weaver.patterns.Pointcut#fastMatch(org.aspectj.weaver.patterns.FastMatchInfo)
  60. */
  61. public FuzzyBoolean fastMatch(FastMatchInfo info) {
  62. if (info instanceof ReflectionFastMatchInfo) {
  63. // Really need a reflectionworld here...
  64. if (!(world instanceof ReflectionWorld)) {
  65. throw new IllegalStateException("Can only match user-extension pcds with a ReflectionWorld");
  66. }
  67. Class<?> clazz = null;
  68. try {
  69. clazz = Class.forName(info.getType().getName(), false, ((ReflectionWorld) world).getClassLoader());
  70. } catch (ClassNotFoundException cnfe) {
  71. if (info.getType() instanceof ReferenceType) {
  72. ReferenceTypeDelegate rtd = ((ReferenceType)info.getType()).getDelegate();
  73. if (rtd instanceof ReflectionBasedReferenceTypeDelegate) {
  74. clazz = ((ReflectionBasedReferenceTypeDelegate)rtd).getClazz();
  75. }
  76. }
  77. }
  78. if (clazz == null) {
  79. return FuzzyBoolean.MAYBE;
  80. }
  81. return FuzzyBoolean.fromBoolean(this.matcher.couldMatchJoinPointsInType(clazz, ((ReflectionFastMatchInfo) info).getMatchingContext()));
  82. }
  83. throw new IllegalStateException("Can only match user-extension pcds against Reflection FastMatchInfo objects");
  84. }
  85. /*
  86. * (non-Javadoc)
  87. *
  88. * @see org.aspectj.weaver.patterns.Pointcut#couldMatchKinds()
  89. */
  90. public int couldMatchKinds() {
  91. return Shadow.ALL_SHADOW_KINDS_BITS;
  92. }
  93. /*
  94. * (non-Javadoc)
  95. *
  96. * @see org.aspectj.weaver.patterns.Pointcut#matchInternal(org.aspectj.weaver.Shadow)
  97. */
  98. protected FuzzyBoolean matchInternal(Shadow shadow) {
  99. if (shadow instanceof ReflectionShadow) {
  100. MatchingContext context = ((ReflectionShadow) shadow).getMatchingContext();
  101. org.aspectj.weaver.tools.FuzzyBoolean match = this.matcher.matchesStatically(context);
  102. if (match == org.aspectj.weaver.tools.FuzzyBoolean.MAYBE) {
  103. return FuzzyBoolean.MAYBE;
  104. } else if (match == org.aspectj.weaver.tools.FuzzyBoolean.YES) {
  105. return FuzzyBoolean.YES;
  106. } else if (match == org.aspectj.weaver.tools.FuzzyBoolean.NO) {
  107. return FuzzyBoolean.NO;
  108. }
  109. }
  110. throw new IllegalStateException("Can only match user-extension pcds against Reflection shadows (not BCEL)");
  111. }
  112. /*
  113. * (non-Javadoc)
  114. *
  115. * @see org.aspectj.weaver.patterns.Pointcut#resolveBindings(org.aspectj.weaver.patterns.IScope,
  116. * org.aspectj.weaver.patterns.Bindings)
  117. */
  118. protected void resolveBindings(IScope scope, Bindings bindings) {
  119. // no-op
  120. }
  121. /*
  122. * (non-Javadoc)
  123. *
  124. * @see org.aspectj.weaver.patterns.Pointcut#concretize1(org.aspectj.weaver.ResolvedType, org.aspectj.weaver.ResolvedType,
  125. * org.aspectj.weaver.IntMap)
  126. */
  127. protected Pointcut concretize1(ResolvedType inAspect, ResolvedType declaringType, IntMap bindings) {
  128. return this;
  129. }
  130. /*
  131. * (non-Javadoc)
  132. *
  133. * @see org.aspectj.weaver.patterns.Pointcut#findResidueInternal(org.aspectj.weaver.Shadow,
  134. * org.aspectj.weaver.patterns.ExposedState)
  135. */
  136. protected Test findResidueInternal(Shadow shadow, ExposedState state) {
  137. if (!this.matcher.mayNeedDynamicTest()) {
  138. return Literal.TRUE;
  139. } else {
  140. // could be more efficient here!
  141. matchInternal(shadow);
  142. return new MatchingContextBasedTest(this.matcher);
  143. }
  144. }
  145. /*
  146. * (non-Javadoc)
  147. *
  148. * @see org.aspectj.weaver.patterns.Pointcut#parameterizeWith(java.util.Map)
  149. */
  150. public Pointcut parameterizeWith(Map typeVariableMap, World w) {
  151. return this;
  152. }
  153. /*
  154. * (non-Javadoc)
  155. *
  156. * @see org.aspectj.weaver.patterns.PatternNode#write(java.io.DataOutputStream)
  157. */
  158. public void write(CompressingDataOutputStream s) throws IOException {
  159. throw new UnsupportedOperationException("can't write custom pointcut designator expressions to stream");
  160. }
  161. /*
  162. * (non-Javadoc)
  163. *
  164. * @see org.aspectj.weaver.patterns.PatternNode#accept(org.aspectj.weaver.patterns.PatternNodeVisitor, java.lang.Object)
  165. */
  166. public Object accept(PatternNodeVisitor visitor, Object data) {
  167. // visitor.visit(this);
  168. // no-op?
  169. return data;
  170. }
  171. }