summaryrefslogtreecommitdiff
path: root/java
diff options
context:
space:
mode:
authorMarc Laukien <marc@zeroc.com>2002-12-30 18:21:47 +0000
committerMarc Laukien <marc@zeroc.com>2002-12-30 18:21:47 +0000
commit608d89d46a87ad33a89a613effa50b7d469ca5a1 (patch)
tree159450e09853fd06775f1d0a6828b77e32574c4e /java
parentmore amd work (diff)
downloadice-608d89d46a87ad33a89a613effa50b7d469ca5a1.tar.bz2
ice-608d89d46a87ad33a89a613effa50b7d469ca5a1.tar.xz
ice-608d89d46a87ad33a89a613effa50b7d469ca5a1.zip
fixed shutdown problem with _dispatchCount
Diffstat (limited to 'java')
-rw-r--r--java/src/IceInternal/Connection.java16
1 files changed, 5 insertions, 11 deletions
diff --git a/java/src/IceInternal/Connection.java b/java/src/IceInternal/Connection.java
index c37d3616104..148845c70c3 100644
--- a/java/src/IceInternal/Connection.java
+++ b/java/src/IceInternal/Connection.java
@@ -444,6 +444,11 @@ public final class Connection extends EventHandler
{
try
{
+ if(--_dispatchCount == 0)
+ {
+ notifyAll();
+ }
+
if(_state == StateClosed)
{
return;
@@ -462,11 +467,6 @@ public final class Connection extends EventHandler
TraceUtil.traceReply("sending reply", os, _logger, _traceLevels);
_transceiver.write(os, _endpoint.timeout());
- if(--_dispatchCount == 0)
- {
- notifyAll();
- }
-
if(_state == StateClosing && _dispatchCount == 0)
{
initiateShutdown();
@@ -483,11 +483,6 @@ public final class Connection extends EventHandler
{
try
{
- if(_state == StateClosed)
- {
- return;
- }
-
if(--_dispatchCount == 0)
{
notifyAll();
@@ -977,7 +972,6 @@ public final class Connection extends EventHandler
}
unregisterWithPool();
destroyIncomingCache();
- _dispatchCount = 0;
break;
}
}