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

15 years ago
15 years ago
15 years ago
15 years ago
15 years ago
15 years ago
15 years ago
15 years ago
15 years ago
15 years ago
15 years ago
15 years ago
15 years ago
15 years ago
15 years ago
15 years ago
15 years ago
15 years ago
15 years ago
15 years ago
15 years ago
15 years ago
15 years ago
15 years ago
15 years ago
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. }