-
Notifications
You must be signed in to change notification settings - Fork 85
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Problem with abstract aspects and cflow(within()) #238
Comments
Sorry for replying so late. Thanks for the problem report. I understand why you might want to use that pointcut. If your tracing aspect is the only one active and there is nothing like nested aspect execution, you could use The problem you are describing originates in the fact that the base aspect constructor wants to use a control flow counter from the sub aspect. That counter is static and should be initialised when the sub aspect is going through static initialisation, i.e. during class-loading. I would have expected that that would have happened already when the base aspect constructor is executing. Why this is not the case, is yet to be investigated. A workaround for now would be not to extend a base aspect but to put everything into a single aspect. |
A better solution would be, adapted from an example in the AspectJ Programming Guide: pointcut myAdvice(): adviceexecution() && within(AbstractAspect+);
pointcut self(): cflow(myAdvice());
pointcut myPointcut(): !self() && call(* *(..)); The addition of You can, of course, also merge the first two pointcuts into one: pointcut self(): cflow(adviceexecution() && within(AbstractAspect+));
pointcut myPointcut(): !self() && call(* *(..)); Unrelated to this issue, but an idea for you: If you also want to trace constructor calls, you could do this: pointcut myPointcut(): !self() && (call(* *(..)) || call(*.new(..))); The trace would still miss |
I think, I am not going to do anything to cover the corner case you just uncovered, because there is a good, canonical workaround. Generated aspect byte code would get more complex and potentially slower, too. The problem with @aclement, do you think this ought to be fixed or improved? |
@kriegaex, sorry for late feedback. With your explanations I was able to fix my problem, thank you very much. |
Given the following abstract and concrete aspect:
I get the following error when load-time weaving
Exception in thread "main" java.lang.ExceptionInInitializerError at de.tt.Main.main(Main.java:6) Caused by: java.lang.NullPointerException at de.tt.AbstractAspect.<clinit>(AbstractAspect.java:1) ... 1 more
Why is that? Interestingly, the error goes away when
cflow(within(de.tt.AbstractAspect))
withwithin(de.tt.AbstractAspect)
, orTested with a8a2f82.
Background: I am writing a very general aspect for access tracking and want to exclude any calls from my aspects. Is there a better way to achieve that?
The text was updated successfully, but these errors were encountered: