diff options
author | Marc Laukien <marc@zeroc.com> | 2001-09-17 03:53:34 +0000 |
---|---|---|
committer | Marc Laukien <marc@zeroc.com> | 2001-09-17 03:53:34 +0000 |
commit | 04cb7fa855e0d6acfa259857e70899fd521421b4 (patch) | |
tree | d0d3ff70a2f3762dd374d13cc44b2e5275cd87f3 /cpp/src/Ice/ServantFactoryManager.cpp | |
parent | lots of Freeze fixes (diff) | |
download | ice-04cb7fa855e0d6acfa259857e70899fd521421b4.tar.bz2 ice-04cb7fa855e0d6acfa259857e70899fd521421b4.tar.xz ice-04cb7fa855e0d6acfa259857e70899fd521421b4.zip |
fixes, fixes, fixes..
Diffstat (limited to 'cpp/src/Ice/ServantFactoryManager.cpp')
-rw-r--r-- | cpp/src/Ice/ServantFactoryManager.cpp | 53 |
1 files changed, 53 insertions, 0 deletions
diff --git a/cpp/src/Ice/ServantFactoryManager.cpp b/cpp/src/Ice/ServantFactoryManager.cpp new file mode 100644 index 00000000000..924f8729a3e --- /dev/null +++ b/cpp/src/Ice/ServantFactoryManager.cpp @@ -0,0 +1,53 @@ +// ********************************************************************** +// +// Copyright (c) 2001 +// MutableRealms, Inc. +// Huntsville, AL, USA +// +// All Rights Reserved +// +// ********************************************************************** + +#include <Ice/ServantFactoryManager.h> +#include <Ice/ServantFactory.h> + +using namespace std; +using namespace Ice; +using namespace IceInternal; + +void IceInternal::incRef(ServantFactoryManager* p) { p->__incRef(); } +void IceInternal::decRef(ServantFactoryManager* p) { p->__decRef(); } + +void +IceInternal::ServantFactoryManager::install(const ServantFactoryPtr& factory, const string& id) +{ + JTCSyncT<JTCMutex> sync(*this); + _factories.insert(make_pair(id, factory)); +} + +ServantFactoryPtr +IceInternal::ServantFactoryManager::lookup(const string& id) +{ + JTCSyncT<JTCMutex> sync(*this); + map<string, ::Ice::ServantFactoryPtr>::const_iterator p; + p = _factories.find(id); + if (p != _factories.end()) + { + return p->second; + } + else + { + return 0; + } +} + +IceInternal::ServantFactoryManager::ServantFactoryManager() +{ +} + +void +IceInternal::ServantFactoryManager::destroy() +{ + JTCSyncT<JTCMutex> sync(*this); + _factories.clear(); +} |