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.

MissingResolvedTypeWithKnownSignature.java 6.6KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251
  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 v 2.0
  6. * which accompanies this distribution and is available at
  7. * https://www.eclipse.org/org/documents/epl-2.0/EPL-2.0.txt
  8. *
  9. * Contributors:
  10. * Adrian Colyer Initial implementation
  11. * ******************************************************************/
  12. package org.aspectj.weaver;
  13. import java.util.Collections;
  14. import java.util.List;
  15. import org.aspectj.bridge.ISourceLocation;
  16. import org.aspectj.bridge.context.CompilationAndWeavingContext;
  17. /**
  18. * When we try to resolve a type in the world that we require to be present, and then fail to find it, we return an instance of this
  19. * class. This class defers the production of the "can't find type error" until the first time that someone asks a question that
  20. * can't be answered solely from the signature. This enables the weaver to be more tolerant of missing types.
  21. *
  22. */
  23. public class MissingResolvedTypeWithKnownSignature extends ResolvedType {
  24. private boolean issuedCantFindTypeError = false;
  25. private boolean issuedJoinPointWarning = false;
  26. private boolean issuedMissingInterfaceWarning = false;
  27. /**
  28. * @param signature
  29. * @param world
  30. */
  31. public MissingResolvedTypeWithKnownSignature(String signature, World world) {
  32. super(signature, world);
  33. }
  34. @Override
  35. public boolean isMissing() {
  36. return true;
  37. }
  38. /**
  39. * @param signature
  40. * @param signatureErasure
  41. * @param world
  42. */
  43. public MissingResolvedTypeWithKnownSignature(String signature, String signatureErasure, World world) {
  44. super(signature, signatureErasure, world);
  45. }
  46. /*
  47. * (non-Javadoc)
  48. *
  49. * @see org.aspectj.weaver.ResolvedType#getDeclaredFields()
  50. */
  51. @Override
  52. public ResolvedMember[] getDeclaredFields() {
  53. raiseCantFindType(WeaverMessages.CANT_FIND_TYPE_FIELDS);
  54. return ResolvedMember.NONE;
  55. }
  56. /*
  57. * (non-Javadoc)
  58. *
  59. * @see org.aspectj.weaver.ResolvedType#getDeclaredMethods()
  60. */
  61. @Override
  62. public ResolvedMember[] getDeclaredMethods() {
  63. raiseCantFindType(WeaverMessages.CANT_FIND_TYPE_METHODS);
  64. return ResolvedMember.NONE;
  65. }
  66. @Override
  67. public AnnotationAJ[] getAnnotations() {
  68. raiseCantFindType(WeaverMessages.CANT_FIND_TYPE_ANNOTATION);
  69. return AnnotationAJ.EMPTY_ARRAY;
  70. }
  71. @Override
  72. public ResolvedType[] getDeclaredInterfaces() {
  73. raiseCantFindType(WeaverMessages.CANT_FIND_TYPE_INTERFACES);
  74. return ResolvedType.EMPTY_RESOLVED_TYPE_ARRAY;
  75. }
  76. @Override
  77. public ResolvedMember[] getDeclaredPointcuts() {
  78. raiseCantFindType(WeaverMessages.CANT_FIND_TYPE_POINTCUTS);
  79. return ResolvedMember.NONE;
  80. }
  81. @Override
  82. public ResolvedType getSuperclass() {
  83. raiseCantFindType(WeaverMessages.CANT_FIND_TYPE_SUPERCLASS);
  84. return ResolvedType.MISSING;
  85. }
  86. @Override
  87. public int getModifiers() {
  88. raiseCantFindType(WeaverMessages.CANT_FIND_TYPE_MODIFIERS);
  89. return 0;
  90. }
  91. /*
  92. * (non-Javadoc)
  93. *
  94. * @see org.aspectj.weaver.ResolvedType#getSourceContext()
  95. */
  96. @Override
  97. public ISourceContext getSourceContext() {
  98. return new ISourceContext() {
  99. @Override
  100. public ISourceLocation makeSourceLocation(IHasPosition position) {
  101. return null;
  102. }
  103. @Override
  104. public ISourceLocation makeSourceLocation(int line, int offset) {
  105. return null;
  106. }
  107. @Override
  108. public int getOffset() {
  109. return 0;
  110. }
  111. @Override
  112. public void tidy() {
  113. }
  114. };
  115. }
  116. /*
  117. * (non-Javadoc)
  118. *
  119. * @see org.aspectj.weaver.ResolvedType#isAssignableFrom(org.aspectj.weaver.ResolvedType)
  120. */
  121. @Override
  122. public boolean isAssignableFrom(ResolvedType other) {
  123. raiseCantFindType(WeaverMessages.CANT_FIND_TYPE_ASSIGNABLE, other.getName());
  124. return false;
  125. }
  126. @Override
  127. public boolean isAssignableFrom(ResolvedType other, boolean allowMissing) {
  128. if (allowMissing) {
  129. return false;
  130. } else {
  131. return isAssignableFrom(other);
  132. }
  133. }
  134. /*
  135. * (non-Javadoc)
  136. *
  137. * @see org.aspectj.weaver.ResolvedType#isCoerceableFrom(org.aspectj.weaver.ResolvedType)
  138. */
  139. @Override
  140. public boolean isCoerceableFrom(ResolvedType other) {
  141. raiseCantFindType(WeaverMessages.CANT_FIND_TYPE_COERCEABLE, other.getName());
  142. return false;
  143. }
  144. /*
  145. * (non-Javadoc)
  146. *
  147. * @see org.aspectj.weaver.AnnotatedElement#hasAnnotation(org.aspectj.weaver.UnresolvedType)
  148. */
  149. @Override
  150. public boolean hasAnnotation(UnresolvedType ofType) {
  151. raiseCantFindType(WeaverMessages.CANT_FIND_TYPE_ANNOTATION);
  152. return false;
  153. }
  154. @Override
  155. public List getInterTypeMungers() {
  156. return Collections.EMPTY_LIST;
  157. }
  158. @Override
  159. public List getInterTypeMungersIncludingSupers() {
  160. return Collections.EMPTY_LIST;
  161. }
  162. @Override
  163. public List getInterTypeParentMungers() {
  164. return Collections.EMPTY_LIST;
  165. }
  166. @Override
  167. public List getInterTypeParentMungersIncludingSupers() {
  168. return Collections.EMPTY_LIST;
  169. }
  170. @Override
  171. protected void collectInterTypeMungers(List collector) {
  172. return;
  173. }
  174. public void raiseWarningOnJoinPointSignature(String signature) {
  175. if (issuedJoinPointWarning) {
  176. return;
  177. }
  178. String message = WeaverMessages.format(WeaverMessages.CANT_FIND_TYPE_JOINPOINT, getName(), signature);
  179. message += "\n" + CompilationAndWeavingContext.getCurrentContext();
  180. world.getLint().cantFindTypeAffectingJoinPointMatch.signal(message, null);
  181. // MessageUtil.warn(world.getMessageHandler(),message);
  182. issuedJoinPointWarning = true;
  183. }
  184. public void raiseWarningOnMissingInterfaceWhilstFindingMethods() {
  185. if (issuedMissingInterfaceWarning) {
  186. return;
  187. }
  188. String message = WeaverMessages.format(WeaverMessages.CANT_FIND_TYPE_INTERFACE_METHODS, getName(), signature);
  189. message += "\n" + CompilationAndWeavingContext.getCurrentContext();
  190. world.getLint().cantFindTypeAffectingJoinPointMatch.signal(message, null);
  191. // MessageUtil.warn(world.getMessageHandler(),message);
  192. issuedMissingInterfaceWarning = true;
  193. }
  194. private void raiseCantFindType(String key) {
  195. if (!world.getLint().cantFindType.isEnabled()) {
  196. return;
  197. }
  198. if (issuedCantFindTypeError) {
  199. return;
  200. }
  201. String message = WeaverMessages.format(key, getName());
  202. message += "\n" + CompilationAndWeavingContext.getCurrentContext();
  203. world.getLint().cantFindType.signal(message, null);
  204. // MessageUtil.error(world.getMessageHandler(),message);
  205. issuedCantFindTypeError = true;
  206. }
  207. private void raiseCantFindType(String key, String insert) {
  208. if (issuedCantFindTypeError) {
  209. return;
  210. }
  211. String message = WeaverMessages.format(key, getName(), insert);
  212. message += "\n" + CompilationAndWeavingContext.getCurrentContext();
  213. world.getLint().cantFindType.signal(message, null);
  214. // MessageUtil.error(world.getMessageHandler(),message);
  215. issuedCantFindTypeError = true;
  216. }
  217. }