diff options
author | randomdan <randomdan@localhost> | 2013-12-30 18:09:46 +0000 |
---|---|---|
committer | randomdan <randomdan@localhost> | 2013-12-30 18:09:46 +0000 |
commit | 5bc4aed347b174b61ba37a5d05b7665ac0f4b11c (patch) | |
tree | 897e9f059c5246b2eb27dabdb9695dd53b44fcec /project2/common/instanceStore.h | |
parent | Manage database connections on a per thread basis (diff) | |
download | project2-5bc4aed347b174b61ba37a5d05b7665ac0f4b11c.tar.bz2 project2-5bc4aed347b174b61ba37a5d05b7665ac0f4b11c.tar.xz project2-5bc4aed347b174b61ba37a5d05b7665ac0f4b11c.zip |
Allow instanceSet to catch or propergate exceptions with onAll*, exceptions in options setting functions propergate
Diffstat (limited to 'project2/common/instanceStore.h')
-rw-r--r-- | project2/common/instanceStore.h | 26 |
1 files changed, 18 insertions, 8 deletions
diff --git a/project2/common/instanceStore.h b/project2/common/instanceStore.h index c61ccfe..36f4e73 100644 --- a/project2/common/instanceStore.h +++ b/project2/common/instanceStore.h @@ -29,25 +29,35 @@ class InstanceStore { prune(); } - static void OnEach(const boost::function<void(typename StoreType::value_type &)> & func) + static void OnEach(const boost::function<void(typename StoreType::value_type &)> & func, bool ContinueOnError = false) { BOOST_FOREACH(const auto & l, GetAll()) { - try { - func(l.get()); + if (ContinueOnError) { + try { + func(l.get()); + } + catch (...) { + } } - catch (...) { + else { + func(l.get()); } } prune(); } - static void OnAll(const boost::function<void(Type *)> & func) + static void OnAll(const boost::function<void(Type *)> & func, bool ContinueOnError = false) { BOOST_FOREACH(const auto & l, GetAll()) { - try { - func(l.get()); + if (ContinueOnError) { + try { + func(l.get()); + } + catch (...) { + } } - catch (...) { + else { + func(l.get()); } } prune(); |