pointcut handleException(Message i):
execution (* myBean.onMessage(Message)) && args(i);
after(Message i) throwing(Throwable ex): handleException(i)
{
System.out.println("==============================================");
System.out.println("Exception after
\n"+"Exception:"+ex.getMessage());
System.out.println("==============================================");
}
However, while the advice seems to match, it never gets called, which kinda sucks.
Can anyone provide any insight into what might be wrong?
I no longer get a 'adviceDidNotMatch' error, (whenever i changed 'Exception' to 'Throwable'), but it still doesnt seem to link up.... (ie no wee arrow pointing at the side)
Sorry for the seemingly stupid request for help.... i just cant see where it isnt matching...
Many thanks.
Andy
----- Original Message ----
From: Dean Wampler <dean@xxxxxxxxxxxxxxxxxxxxx>
To: aspectj-users@xxxxxxxxxxx
Sent: Monday, 29 September, 2008 2:00:48 PM
Subject: Re: [aspectj-users] catching container managed transactions
Who calls the "onMessage" method? If you use the "call" pointcut designator, AspectJ has to be able to weave the handler "advice" into the code that does the calling. If that code is in a third-party jar that you don't want to modify, then use "execute" instead:
pointcut handleException(Message m):
execution(* myBean.onMessage(Message)) && args(m);
dean
Ok,
Ive changed this to match the following
pointcut handleException(Message m):
call (* myBean.onMessage(Message)) && args(m);
after(Message m) throwing (Exception ex): handleException(m)
{
//handle exception here
}
However, the pointcuts doesnt seem to get matched... have I got this all wrong?
I want to be able to access the message inside the handler, prefereably.
Andy
----- Original Message ----
From: Dean Wampler <
dean@xxxxxxxxxxxxxxxxxxxxx>
To:
aspectj-users@xxxxxxxxxxxSent: Monday, 29 September, 2008 1:21:14 PM
Subject: Re:
[aspectj-users] catching container managed transactions
Andy,
A little more information you might find useful. Since you print a message with the exception, you'll need to "bind" it with the "throwing":
after() throwing(Exception ex): mypointcut() {
System.out.println("Error here, guv" + e);
}
Also, just to be clear, if you actually wanted to recover from the exception, you can't do that with after throwing. The exception will still get thrown up the stack. To recover, you would have to use around advice.
dean
Hi
You are using an around advice:
void around(Message m) throws Exception: handleException(m)
{
try
{
proceed(m);
}
catch(Exception e)
{
System.out.println("Error here,guv "+e);
throw e;
}
}
the alternativ is using an after advice with a throwing clause. That means that the advice is only executed if your pointcut throws an exception.
after() throwing: mypointcut() {
//handle exception here
}
mvh
Hermod
Im not
sure i follow, can you give a quick 1-liner example, or point me to a relevant doco?
thanks.
Andrew
----- Original Message ----
From: "
hermod.opstvedt@xxxxxxxxx" <
hermod.opstvedt@xxxxxxxxx>
To:
aspectj-users@xxxxxxxxxxxSent: Monday, 29 September, 2008 9:55:30 AM
Subject: RE: [aspectj-users] catching container managed transactions
Hi
Why don't you use "after returning throwing" instead of around
advice.
Hermod
Hi
I have a message driven bean which, inherently, throws an exception back to the container to rollback jms messsages.
I want to be able to catch this exception, log something, and then let the exception carry on.
I have a pointcut defined as follows:
pointcut handleException(Message m):
call (* myBean.onMessage(Message)) && args(m);
With the advice being:
void around(Message m) throws Exception: handleException(m)
{
try
{
proceed(m);
}
catch(Exception e)
{
System.out.println("Error here,guv "+e);
throw e;
}
}
My question is two-fold:
1) Can we throw the exception like this and will the throw go back to the container managed transaction??
2) Is this the right way to do this kind of thing? (im assuming not, as the advice is marked as 'Not matched', but maybe this is one for the ajdt guys.)
Sorry - im completely new to this
stuff....
Regards,
Andy
* * * * * * * * * * * * * * * * * * * * * * *
* * * * * * * * * * * * * * *
This email with attachments is solely for the use of the individual or
entity to whom it is addressed. Please also be aware that the DnB NOR Group
cannot accept any payment orders or other legally binding correspondence with
customers as a part of an email.
This email message has been virus checked by the anti virus programs used
in the DnB NOR Group.
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
This email with attachments is solely for the use of the individual or
entity to whom it is addressed. Please also be aware that the DnB NOR Group
cannot accept any payment orders or other legally binding correspondence with
customers as a part of an email.
This email message has been virus checked by the anti virus programs used
in the DnB NOR Group.
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
_______________________________________________
aspectj-users mailing list
aspectj-users@xxxxxxxxxxxhttps://dev.eclipse.org/mailman/listinfo/aspectj-users
Dean Wampler, Ph.D.
dean at objectmentor.com
See also:
I want my tombstone to say:
Unknown Application Error in Dean Wampler.exe.
Application Terminated.
[Okay] [Cancel]
_______________________________________________
aspectj-users mailing list
aspectj-users@xxxxxxxxxxxhttps://dev.eclipse.org/mailman/listinfo/aspectj-users
Dean Wampler, Ph.D.
dean at objectmentor.com
See also:
I want my tombstone to say:
Unknown Application Error in Dean Wampler.exe.
Application Terminated.
[Okay] [Cancel]