Author: markt
Date: Tue Nov 13 13:47:14 2012
New Revision: 1408721
URL: http://svn.apache.org/viewvc?rev=1408721&view=rev
Log:
Ensure onComplete() is called with the correct context.
Review from kkolinko
Modified:
tomcat/trunk/java/org/apache/catalina/core/AsyncContextImpl.java
Modified: tomcat/trunk/java/org/apache/catalina/core/AsyncContextImpl.java
URL:
http://svn.apache.org/viewvc/tomcat/trunk/java/org/apache/catalina/core/AsyncContextImpl.java?rev=1408721&r1=1408720&r2=1408721&view=diff
==============================================================================
--- tomcat/trunk/java/org/apache/catalina/core/AsyncContextImpl.java (original)
+++ tomcat/trunk/java/org/apache/catalina/core/AsyncContextImpl.java Tue Nov 13
13:47:14 2012
@@ -96,13 +96,22 @@ public class AsyncContextImpl implements
public void fireOnComplete() {
List<AsyncListenerWrapper> listenersCopy = new ArrayList<>();
listenersCopy.addAll(listeners);
- for (AsyncListenerWrapper listener : listenersCopy) {
- try {
- listener.fireOnComplete(event);
- } catch (IOException ioe) {
- log.warn("onComplete() failed for listener of type [" +
- listener.getClass().getName() + "]", ioe);
+
+ ClassLoader oldCL = Thread.currentThread().getContextClassLoader();
+ ClassLoader newCL = request.getContext().getLoader().getClassLoader();
+
+ try {
+ Thread.currentThread().setContextClassLoader(newCL);
+ for (AsyncListenerWrapper listener : listenersCopy) {
+ try {
+ listener.fireOnComplete(event);
+ } catch (IOException ioe) {
+ log.warn("onComplete() failed for listener of type [" +
+ listener.getClass().getName() + "]", ioe);
+ }
}
+ } finally {
+ Thread.currentThread().setContextClassLoader(oldCL);
}
}
---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]