summaryrefslogtreecommitdiff
path: root/cppe/src/IceE/ObjectAdapterFactory.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'cppe/src/IceE/ObjectAdapterFactory.cpp')
-rw-r--r--cppe/src/IceE/ObjectAdapterFactory.cpp25
1 files changed, 23 insertions, 2 deletions
diff --git a/cppe/src/IceE/ObjectAdapterFactory.cpp b/cppe/src/IceE/ObjectAdapterFactory.cpp
index 2dfe68d3684..6cc8fe9209f 100644
--- a/cppe/src/IceE/ObjectAdapterFactory.cpp
+++ b/cppe/src/IceE/ObjectAdapterFactory.cpp
@@ -109,7 +109,11 @@ IceInternal::ObjectAdapterFactory::waitForShutdown()
}
ObjectAdapterPtr
-IceInternal::ObjectAdapterFactory::createObjectAdapter(const string& name, const string& endpoints)
+IceInternal::ObjectAdapterFactory::createObjectAdapter(const string& name, const string& endpoints
+#ifdef ICEE_HAS_ROUTER
+ , const RouterPrx& router
+#endif
+ )
{
IceUtil::Monitor<IceUtil::Mutex>::Lock sync(*this);
@@ -124,11 +128,28 @@ IceInternal::ObjectAdapterFactory::createObjectAdapter(const string& name, const
throw AlreadyRegisteredException(__FILE__, __LINE__, "object adapter", name);
}
- ObjectAdapterPtr adapter = new ObjectAdapter(_instance, _communicator, name, endpoints);
+ ObjectAdapterPtr adapter = new ObjectAdapter(_instance, _communicator, this, name, endpoints
+#ifdef ICEE_HAS_ROUTER
+ , router
+#endif
+ );
_adapters.insert(make_pair(name, adapter));
return adapter;
}
+void
+IceInternal::ObjectAdapterFactory::removeObjectAdapter(const string& name)
+{
+ IceUtil::Monitor<IceUtil::Mutex>::Lock sync(*this);
+
+ if(_waitForShutdown)
+ {
+ return;
+ }
+
+ _adapters.erase(name);
+}
+
namespace IceInternal {
struct FlushAdapter