summaryrefslogtreecommitdiff
path: root/java/src/IceInternal/RetryTask.java
diff options
context:
space:
mode:
Diffstat (limited to 'java/src/IceInternal/RetryTask.java')
-rw-r--r--java/src/IceInternal/RetryTask.java23
1 files changed, 16 insertions, 7 deletions
diff --git a/java/src/IceInternal/RetryTask.java b/java/src/IceInternal/RetryTask.java
index 2c991f65819..713c8bc856a 100644
--- a/java/src/IceInternal/RetryTask.java
+++ b/java/src/IceInternal/RetryTask.java
@@ -21,17 +21,26 @@ class RetryTask implements Runnable
public void
run()
{
- if(_queue.remove(this))
- {
- _outAsync.processRetry(false);
- }
+ _outAsync.processRetry(false);
+
+ //
+ // NOTE: this must be called last, destroy() blocks until all task
+ // are removed to prevent the client thread pool to be destroyed
+ // (we still need the client thread pool at this point to call
+ // exception callbacks with CommunicatorDestroyedException).
+ //
+ _queue.remove(this);
}
- public void
+ public boolean
destroy()
{
- _future.cancel(false);
- _outAsync.processRetry(true);
+ if(_future.cancel(false))
+ {
+ _outAsync.processRetry(true);
+ return true;
+ }
+ return false;
}
public void setFuture(java.util.concurrent.Future<?> future)