diff options
author | Alan Conway <aconway@apache.org> | 2008-07-17 00:03:50 +0000 |
---|---|---|
committer | Alan Conway <aconway@apache.org> | 2008-07-17 00:03:50 +0000 |
commit | e65b0086a2924ff04640b1350393a816249d01b3 (patch) | |
tree | b372c5386cc44e3ad16c4ae585088ed038a629e4 /cpp/src/qpid/Plugin.cpp | |
parent | e596837411d54a16dd3cb1e5de717664496c2bd0 (diff) | |
download | qpid-python-e65b0086a2924ff04640b1350393a816249d01b3.tar.gz |
Cluster: shadow connections, fix lifecycle & valgrind issues.
- tests/ForkedBroker: improved broker forking, exec full qpidd.
- Plugin::addFinalizer - more flexible way to shutdown plugins.
- Reworked cluster extension points using boost::function.
git-svn-id: https://svn.apache.org/repos/asf/incubator/qpid/trunk/qpid@677471 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'cpp/src/qpid/Plugin.cpp')
-rw-r--r-- | cpp/src/qpid/Plugin.cpp | 17 |
1 files changed, 11 insertions, 6 deletions
diff --git a/cpp/src/qpid/Plugin.cpp b/cpp/src/qpid/Plugin.cpp index b8206499ae..e4b76db28a 100644 --- a/cpp/src/qpid/Plugin.cpp +++ b/cpp/src/qpid/Plugin.cpp @@ -35,15 +35,20 @@ Plugin::Plugins& thePlugins() { return plugins; } -void call(boost::function<void()> f) { f(); } +void invoke(boost::function<void()> f) { f(); } } // namespace -Plugin::Target::~Target() { - std::for_each(cleanup.begin(), cleanup.end(), &call); +Plugin::Target::~Target() { finalize(); } + +void Plugin::Target::finalize() { + for_each(finalizers.begin(), finalizers.end(), invoke); + finalizers.clear(); } -void Plugin::Target::addCleanup(const boost::function<void()>& f) { cleanup.push_back(f); } +void Plugin::Target::addFinalizer(const boost::function<void()>& f) { + finalizers.push_back(f); +} Plugin::Plugin() { // Register myself. @@ -69,7 +74,7 @@ void Plugin::addOptions(Options& opts) { } } -void Plugin::earlyInitAll(Target& t) { each_plugin(boost::bind(&Plugin::earlyInitialize, _1, t)); } -void Plugin::initAll(Target& t) { each_plugin(boost::bind(&Plugin::initialize, _1, t)); } +void Plugin::earlyInitAll(Target& t) { each_plugin(boost::bind(&Plugin::earlyInitialize, _1, boost::ref(t))); } +void Plugin::initializeAll(Target& t) { each_plugin(boost::bind(&Plugin::initialize, _1, boost::ref(t))); } } // namespace qpid |