summaryrefslogtreecommitdiff
path: root/cpp/src/Ice/LocatorInfo.cpp
diff options
context:
space:
mode:
authorDwayne Boone <dwayne@zeroc.com>2009-05-08 13:48:51 -0230
committerDwayne Boone <dwayne@zeroc.com>2009-05-08 13:48:51 -0230
commitcdc0f62f4fe737454bbb96031695415c4f9be406 (patch)
treeec007ba67d4f0e579becf7c7709137a619b5de8d /cpp/src/Ice/LocatorInfo.cpp
parentBug 3966 - deadlock in LocatorInfo (diff)
downloadice-cdc0f62f4fe737454bbb96031695415c4f9be406.tar.bz2
ice-cdc0f62f4fe737454bbb96031695415c4f9be406.tar.xz
ice-cdc0f62f4fe737454bbb96031695415c4f9be406.zip
Bug 3409 - add sequence checking to ruby/python
Diffstat (limited to 'cpp/src/Ice/LocatorInfo.cpp')
-rw-r--r--cpp/src/Ice/LocatorInfo.cpp13
1 files changed, 12 insertions, 1 deletions
diff --git a/cpp/src/Ice/LocatorInfo.cpp b/cpp/src/Ice/LocatorInfo.cpp
index 4cd06442f3b..7d866d3da2e 100644
--- a/cpp/src/Ice/LocatorInfo.cpp
+++ b/cpp/src/Ice/LocatorInfo.cpp
@@ -581,7 +581,18 @@ IceInternal::LocatorInfo::getLocatorRegistry()
//
// Do not make locator calls from within sync.
//
- LocatorRegistryPrx locatorRegistry = locator->getRegistry();
+ LocatorRegistryPrx locatorRegistry;
+ try
+ {
+ locatorRegistry = locator->getRegistry();
+ }
+ catch(const Ice::Exception&)
+ {
+ IceUtil::Monitor<IceUtil::Mutex>::Lock sync(*this);
+ notifyAll();
+
+ throw;
+ }
{
IceUtil::Monitor<IceUtil::Mutex>::Lock sync(*this);