summaryrefslogtreecommitdiff
path: root/cpp/src/Ice/PropertiesAdminI.cpp
diff options
context:
space:
mode:
authorBernard Normier <bernard@zeroc.com>2016-07-26 18:07:13 -0400
committerBernard Normier <bernard@zeroc.com>2016-07-26 18:07:13 -0400
commit6b130bc0088cdb0d55efc1e4f0fe36033bad770a (patch)
treeac9c5ed4272e9b2fbde2f8e9adf72caea1cd1595 /cpp/src/Ice/PropertiesAdminI.cpp
parentICE-7252 - Disable optimizer for non-VC140 builds (diff)
downloadice-6b130bc0088cdb0d55efc1e4f0fe36033bad770a.tar.bz2
ice-6b130bc0088cdb0d55efc1e4f0fe36033bad770a.tar.xz
ice-6b130bc0088cdb0d55efc1e4f0fe36033bad770a.zip
C++11 mapping for PropertiesAdminUpdateCallback
Diffstat (limited to 'cpp/src/Ice/PropertiesAdminI.cpp')
-rw-r--r--cpp/src/Ice/PropertiesAdminI.cpp48
1 files changed, 48 insertions, 0 deletions
diff --git a/cpp/src/Ice/PropertiesAdminI.cpp b/cpp/src/Ice/PropertiesAdminI.cpp
index a7e6174c79c..3b5198531dd 100644
--- a/cpp/src/Ice/PropertiesAdminI.cpp
+++ b/cpp/src/Ice/PropertiesAdminI.cpp
@@ -21,10 +21,12 @@ const char* traceCategory = "Admin.Properties";
}
+#ifndef ICE_CPP11_MAPPING
PropertiesAdminUpdateCallback::~PropertiesAdminUpdateCallback()
{
// Out of line to avoid weak vtable
}
+#endif
NativePropertiesAdmin::~NativePropertiesAdmin()
{
@@ -198,12 +200,32 @@ PropertiesAdminI::setProperties_async(const AMD_PropertiesAdmin_setPropertiesPtr
//
// Copy the callbacks to allow callbacks to update the callbacks.
//
+
+#ifdef ICE_CPP11_MAPPING
+ auto callbacks = _updateCallbacks;
+#else
vector<PropertiesAdminUpdateCallbackPtr> callbacks = _updateCallbacks;
+#endif
+
if(!callbacks.empty())
{
PropertyDict changes = added;
changes.insert(changed.begin(), changed.end());
changes.insert(removed.begin(), removed.end());
+
+#ifdef ICE_CPP11_MAPPING
+ for(const auto& cb: callbacks)
+ {
+ try
+ {
+ cb(changes);
+ }
+ catch(...)
+ {
+ // Ignore.
+ }
+ }
+#else
for(vector<PropertiesAdminUpdateCallbackPtr>::const_iterator p = callbacks.begin(); p != callbacks.end(); ++p)
{
try
@@ -215,9 +237,33 @@ PropertiesAdminI::setProperties_async(const AMD_PropertiesAdmin_setPropertiesPtr
// Ignore.
}
}
+#endif
}
}
+
+#ifdef ICE_CPP11_MAPPING
+
+std::function<void()>
+PropertiesAdminI::addUpdateCallback(std::function<void(const Ice::PropertyDict&)> cb)
+{
+ Lock sync(*this);
+
+ auto p = _updateCallbacks.insert(_updateCallbacks.end(), std::move(cb));
+ auto propertiesAdmin = shared_from_this();
+
+ return [p, propertiesAdmin] { propertiesAdmin->removeUpdateCallback(p); };
+}
+
+void
+PropertiesAdminI::removeUpdateCallback(std::list<std::function<void(const Ice::PropertyDict&)>>::iterator p)
+{
+ Lock sync(*this);
+ _updateCallbacks.erase(p);
+}
+
+#else
+
void
PropertiesAdminI::addUpdateCallback(const PropertiesAdminUpdateCallbackPtr& cb)
{
@@ -232,4 +278,6 @@ PropertiesAdminI::removeUpdateCallback(const PropertiesAdminUpdateCallbackPtr& c
_updateCallbacks.erase(remove(_updateCallbacks.begin(), _updateCallbacks.end(), cb), _updateCallbacks.end());
}
+#endif
+
}