summaryrefslogtreecommitdiff
path: root/cpp/src/Ice/Instance.cpp
diff options
context:
space:
mode:
authorBenoit Foucher <benoit@zeroc.com>2012-09-06 14:32:45 +0200
committerBenoit Foucher <benoit@zeroc.com>2012-09-06 14:32:45 +0200
commit55653e8e80f1a4ed1c54742de9fdb81cc1ca0bd9 (patch)
tree859ce7d45c580afb8abf6c9c86296e795d8e4a19 /cpp/src/Ice/Instance.cpp
parentAdded Python properties demo, fixed bugs (diff)
downloadice-55653e8e80f1a4ed1c54742de9fdb81cc1ca0bd9.tar.bz2
ice-55653e8e80f1a4ed1c54742de9fdb81cc1ca0bd9.tar.xz
ice-55653e8e80f1a4ed1c54742de9fdb81cc1ca0bd9.zip
Performance improvments
Diffstat (limited to 'cpp/src/Ice/Instance.cpp')
-rw-r--r--cpp/src/Ice/Instance.cpp12
1 files changed, 7 insertions, 5 deletions
diff --git a/cpp/src/Ice/Instance.cpp b/cpp/src/Ice/Instance.cpp
index 5edfcd294d4..71dde521406 100644
--- a/cpp/src/Ice/Instance.cpp
+++ b/cpp/src/Ice/Instance.cpp
@@ -1103,17 +1103,19 @@ IceInternal::Instance::Instance(const CommunicatorPtr& communicator, const Initi
PropertiesAdminIPtr props = new PropertiesAdminI("Properties", _initData.properties, _initData.logger);
_adminFacets.insert(FacetMap::value_type("Properties",props));
- // Make sure the MetricsAdmin plugin received property update notifications.
- props->addUpdateCallback(admin);
-
//
// Setup the communicator observer only the metrics admin plugin only if the user didn't already set an
// Ice observer resovler.
//
if(!_initData.observer &&
- (_adminFacetFilter.empty() || _adminFacetFilter.find("MetricsAdmin") != _adminFacetFilter.end()))
+ (_adminFacetFilter.empty() || _adminFacetFilter.find("MetricsAdmin") != _adminFacetFilter.end()) &&
+ _initData.properties->getProperty("Ice.Admin.Endpoints") != "")
{
- _initData.observer = new IceMX::CommunicatorObserverI(admin);
+ IceMX::CommunicatorObserverIPtr observer = new IceMX::CommunicatorObserverI(admin);
+ _initData.observer = observer;
+
+ // Make sure the MetricsAdmin plugin received property update notifications.
+ props->addUpdateCallback(observer);
}
__setNoDelete(false);