diff options
author | Bernard Normier <bernard@zeroc.com> | 2016-07-26 18:07:13 -0400 |
---|---|---|
committer | Bernard Normier <bernard@zeroc.com> | 2016-07-26 18:07:13 -0400 |
commit | 6b130bc0088cdb0d55efc1e4f0fe36033bad770a (patch) | |
tree | ac9c5ed4272e9b2fbde2f8e9adf72caea1cd1595 /cpp/src/Ice/PropertiesAdminI.cpp | |
parent | ICE-7252 - Disable optimizer for non-VC140 builds (diff) | |
download | ice-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.cpp | 48 |
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 + } |