summaryrefslogtreecommitdiff
path: root/cpp/src/IceGrid/NodeSessionManager.cpp
diff options
context:
space:
mode:
authorBenoit Foucher <benoit@zeroc.com>2009-02-11 15:37:23 +0100
committerBenoit Foucher <benoit@zeroc.com>2009-02-12 09:45:06 +0100
commitf7b2cf35dad61149a95874a50d25cbb6580b75dc (patch)
tree860a2537b0a872ca66f0bde601390d03aa286d84 /cpp/src/IceGrid/NodeSessionManager.cpp
parentFixed bug 3712 - bogus del tmp.buf in Make.rules.cs.mak (diff)
downloadice-f7b2cf35dad61149a95874a50d25cbb6580b75dc.tar.bz2
ice-f7b2cf35dad61149a95874a50d25cbb6580b75dc.tar.xz
ice-f7b2cf35dad61149a95874a50d25cbb6580b75dc.zip
Fixed bug 3722 & 3723 - IceGrid leaks upon start failure
Diffstat (limited to 'cpp/src/IceGrid/NodeSessionManager.cpp')
-rw-r--r--cpp/src/IceGrid/NodeSessionManager.cpp14
1 files changed, 12 insertions, 2 deletions
diff --git a/cpp/src/IceGrid/NodeSessionManager.cpp b/cpp/src/IceGrid/NodeSessionManager.cpp
index 718a559f92f..878c0bb03d7 100644
--- a/cpp/src/IceGrid/NodeSessionManager.cpp
+++ b/cpp/src/IceGrid/NodeSessionManager.cpp
@@ -322,19 +322,29 @@ NodeSessionManager::destroy()
NodeSessionMap sessions;
{
Lock sync(*this);
+ if(_destroyed)
+ {
+ return;
+ }
_destroyed = true;
_sessions.swap(sessions);
notifyAll();
}
- _thread->terminate();
+ if(_thread)
+ {
+ _thread->terminate();
+ }
NodeSessionMap::const_iterator p;
for(p = sessions.begin(); p != sessions.end(); ++p)
{
p->second->terminate();
}
- _thread->getThreadControl().join();
+ if(_thread)
+ {
+ _thread->getThreadControl().join();
+ }
for(p = sessions.begin(); p != sessions.end(); ++p)
{
p->second->getThreadControl().join();