From b3fdd29f6ca5d2f43eed835a1b02723fc8d0fd53 Mon Sep 17 00:00:00 2001 From: Dan Goodliffe Date: Sat, 29 Nov 2014 16:43:25 +0000 Subject: Remove the continue on error options for plugables and add proper handling into implementations where errors can be ignored --- project2/basics/caches/memoryCache.cpp | 2 +- project2/basics/options/showHelp.h | 2 +- project2/common/instanceStore.h | 4 ++-- project2/common/instanceStore.impl.h | 26 ++++---------------------- project2/common/library.cpp | 2 +- project2/common/logger.h | 2 +- project2/common/plugable.cpp | 4 ++-- project2/common/plugable.h | 2 +- project2/daemon/p2daemonAppEngine.cpp | 2 +- project2/files/presenterCache.cpp | 18 ++++++++++++------ project2/json/couchSession.cpp | 16 +++++++++++----- project2/sql/rdbmsDataSource.cpp | 6 +++--- project2/sql/sqlCache.cpp | 25 ++++++++++++++----------- project2/xml/sessionXml.cpp | 29 +++++++++++++++++------------ project2/xml/xmlCache.cpp | 9 +++++++-- project2/xml/xmlDocumentCache.cpp | 2 +- 16 files changed, 79 insertions(+), 72 deletions(-) diff --git a/project2/basics/caches/memoryCache.cpp b/project2/basics/caches/memoryCache.cpp index ee4f9b3..a69ca16 100644 --- a/project2/basics/caches/memoryCache.cpp +++ b/project2/basics/caches/memoryCache.cpp @@ -148,7 +148,7 @@ MemoryCache::CacheStore MemoryCache::Store; class CustomMemoryCacheLoader : public ElementLoader::For { public: - void onPeriodic() { + void onPeriodic() override { typedef MemoryCache::CacheStore::index::type::iterator iter; iter x = MemoryCache::Store.get().begin(); iter y = MemoryCache::Store.get().upper_bound(time(NULL) - MemoryCache::CacheLife); diff --git a/project2/basics/options/showHelp.h b/project2/basics/options/showHelp.h index 21eec95..75fb4cb 100644 --- a/project2/basics/options/showHelp.h +++ b/project2/basics/options/showHelp.h @@ -6,7 +6,7 @@ class ShowHelpComponent : public ComponentLoader { public: - void onConfigLoad(); + void onConfigLoad() override; static Options::TargetPtr Option(); private: diff --git a/project2/common/instanceStore.h b/project2/common/instanceStore.h index 5557b43..9a669ef 100644 --- a/project2/common/instanceStore.h +++ b/project2/common/instanceStore.h @@ -37,7 +37,7 @@ class InstanceMap : public InstanceStore(InstanceStore::GetAll(), n); } - static void OnEach(const boost::function & func, bool ContinueOnError = false); + static void OnEach(const boost::function & func); }; /// Anonymous collection of instances @@ -45,7 +45,7 @@ template class InstanceSet : public InstanceStore>> { public: typedef InstanceStore>> IStore; - static void OnAll(const boost::function & func, bool ContinueOnError = false); + static void OnAll(const boost::function & func); static void Remove(const boost::shared_ptr &); }; diff --git a/project2/common/instanceStore.impl.h b/project2/common/instanceStore.impl.h index 4152aba..dd64bd7 100644 --- a/project2/common/instanceStore.impl.h +++ b/project2/common/instanceStore.impl.h @@ -64,38 +64,20 @@ InstanceMap::Remove(const KeyType & k) template void -InstanceMap::OnEach(const boost::function & func, bool ContinueOnError) +InstanceMap::OnEach(const boost::function & func) { BOOST_FOREACH(const auto & l, IStore::GetAll()) { - if (ContinueOnError) { - try { - func(l); - } - catch (...) { - } - } - else { - func(l); - } + func(l); } IStore::prune(); } template void -InstanceSet::OnAll(const boost::function & func, bool ContinueOnError) +InstanceSet::OnAll(const boost::function & func) { BOOST_FOREACH(const auto & l, IStore::GetAll()) { - if (ContinueOnError) { - try { - func(l.get()); - } - catch (...) { - } - } - else { - func(l.get()); - } + func(l.get()); } IStore::prune(); } diff --git a/project2/common/library.cpp b/project2/common/library.cpp index 0c4a83b..11dadb3 100644 --- a/project2/common/library.cpp +++ b/project2/common/library.cpp @@ -25,7 +25,7 @@ Library::~Library() STORAGEOF(Library) libraries; class LibraryLoader : public ElementLoader::For { public: - void onIteration() + void onIteration() override { libraries.clear(); } diff --git a/project2/common/logger.h b/project2/common/logger.h index cac35ad..7f6e7a0 100644 --- a/project2/common/logger.h +++ b/project2/common/logger.h @@ -73,7 +73,7 @@ class LogDriverLoaderImpl : public LogDriverLoader::ForsetLoggerAt(this, level); if (level == -1) { instance.reset(); diff --git a/project2/common/plugable.cpp b/project2/common/plugable.cpp index 83d0cc5..969f530 100644 --- a/project2/common/plugable.cpp +++ b/project2/common/plugable.cpp @@ -1,8 +1,8 @@ #include "plugable.h" void -Plugable::onAllComponents(const boost::function & func, bool coe) +Plugable::onAllComponents(const boost::function & func) { - InstanceSet::OnAll(func, coe); + InstanceSet::OnAll(func); } diff --git a/project2/common/plugable.h b/project2/common/plugable.h index ce3439a..eaccd49 100644 --- a/project2/common/plugable.h +++ b/project2/common/plugable.h @@ -10,7 +10,7 @@ class ComponentLoader; class Plugable : public InstanceSet { public: - static void onAllComponents(const boost::function & func, bool coe = false); + static void onAllComponents(const boost::function & func); }; /// All loaders, keyed by string, enum, int, etc diff --git a/project2/daemon/p2daemonAppEngine.cpp b/project2/daemon/p2daemonAppEngine.cpp index 7a1c602..b48b75b 100644 --- a/project2/daemon/p2daemonAppEngine.cpp +++ b/project2/daemon/p2daemonAppEngine.cpp @@ -120,7 +120,7 @@ bool DaemonAppEngine::periodicCallback() { Logger()->messagebf(LOG_DEBUG, "%s: firing component periodics.", __PRETTY_FUNCTION__); - Plugable::onAllComponents(boost::bind(&ComponentLoader::onPeriodic, _1), true); + Plugable::onAllComponents(boost::bind(&ComponentLoader::onPeriodic, _1)); return true; } diff --git a/project2/files/presenterCache.cpp b/project2/files/presenterCache.cpp index 09ee9ee..da63bf3 100644 --- a/project2/files/presenterCache.cpp +++ b/project2/files/presenterCache.cpp @@ -1,6 +1,7 @@ -#include "../common/presenterCache.h" -#include "../common/exceptions.h" -#include "../common/options.h" +#include "presenterCache.h" +#include "exceptions.h" +#include "logger.h" +#include "options.h" #include #include #include @@ -248,12 +249,17 @@ END_OPTIONS(FilePresenterCache) class FilePresenterCacheLoader : public ElementLoader::For { public: - void onIdle() + void onIdle() override { - emptyDir(FilePresenterCache::Store); + try { + emptyDir(FilePresenterCache::Store); + } + catch (...) { + Logger()->messagebf(LOG_WARNING, "Failed to purge presenter caches from %s", FilePresenterCache::Store); + } FilePresenterCache::openCaches.clear(); } - void onConfigLoad() + void onConfigLoad() override { FilePresenterCache::openCaches.clear(); } diff --git a/project2/json/couchSession.cpp b/project2/json/couchSession.cpp index ee7bad2..60acefa 100644 --- a/project2/json/couchSession.cpp +++ b/project2/json/couchSession.cpp @@ -2,8 +2,9 @@ #include "curlHelper.h" #include "safeMapFind.h" #include "exceptions.h" -#include "../libmisc/buffer.h" -#include "../libmisc/curlsup.h" +#include "logger.h" +#include "buffer.h" +#include "curlsup.h" #include #include #include @@ -110,9 +111,14 @@ const Glib::ustring CouchSessionContainer::ExpiryKey("project2:expires"); class CustomCouchSessionLoader : public SessionContainerLoader::For { public: - void onPeriodic() { - deleteSessions(); - compactDB(); + void onPeriodic() override { + try { + deleteSessions(); + compactDB(); + } + catch (...) { + Logger()->messagebf(LOG_WARNING, "Failed to purge expired sessions and compact DB"); + } } INITOPTIONS; diff --git a/project2/sql/rdbmsDataSource.cpp b/project2/sql/rdbmsDataSource.cpp index 7965a29..86c6a6e 100644 --- a/project2/sql/rdbmsDataSource.cpp +++ b/project2/sql/rdbmsDataSource.cpp @@ -13,7 +13,7 @@ SimpleMessageException(UnknownConnectionProvider); /// Specialized ElementLoader for instances of RdbmsDataSource; handles persistent DB connections class RdbmsDataSourceLoader : public ElementLoader::For { public: - void onIdle() + void onIdle() override { // Disconnect all cached database connections RdbmsDataSource::dbhosts.clear(); @@ -22,7 +22,7 @@ class RdbmsDataSourceLoader : public ElementLoader::For { { return con.second->isExpired(); } - void onPeriodic() + void onPeriodic() override { // Disconnect expired database connections RdbmsDataSource::DBHosts::iterator i; @@ -30,7 +30,7 @@ class RdbmsDataSourceLoader : public ElementLoader::For { RdbmsDataSource::dbhosts.erase(i); } } - void onIteration() + void onIteration() override { RdbmsDataSource::changedDSNs.clear(); } diff --git a/project2/sql/sqlCache.cpp b/project2/sql/sqlCache.cpp index c495528..f20bfe4 100644 --- a/project2/sql/sqlCache.cpp +++ b/project2/sql/sqlCache.cpp @@ -267,18 +267,21 @@ time_t SqlCache::CacheLife; class CustomSqlCacheLoader : public ElementLoader::For { public: - void onIdle() + void onIdle() override { - if (!SqlCache::DataSource.empty()) { - boost::intrusive_ptr co = new CommonObjects(); - RdbmsDataSource * db = co->dataSource(SqlCache::DataSource); - Buffer del; - del.appendf("DELETE FROM %s WHERE p2_time < ?", SqlCache::HeaderTable.c_str()); - auto con = db->getWritable(); - ModifyPtr m(con->newModifyCommand(del)); - m->bindParamT(0, boost::posix_time::microsec_clock::universal_time() - boost::posix_time::seconds(SqlCache::CacheLife)); - m->execute(); - db->commit(); + try { + if (!SqlCache::DataSource.empty()) { + boost::intrusive_ptr co = new CommonObjects(); + RdbmsDataSource * db = co->dataSource(SqlCache::DataSource); + auto con = db->getWritable(); + ModifyPtr m(con->newModifyCommand(stringbf("DELETE FROM %s WHERE p2_time < ?", SqlCache::HeaderTable))); + m->bindParamT(0, boost::posix_time::microsec_clock::universal_time() - boost::posix_time::seconds(SqlCache::CacheLife)); + m->execute(); + db->commit(); + } + } + catch (...) { + Logger()->messagebf(LOG_WARNING, "Failed to purge expired caches from table %s", SqlCache::HeaderTable); } } }; diff --git a/project2/xml/sessionXml.cpp b/project2/xml/sessionXml.cpp index ff3beca..73bdccc 100644 --- a/project2/xml/sessionXml.cpp +++ b/project2/xml/sessionXml.cpp @@ -9,24 +9,28 @@ #include #include #include "options.h" +#include "logger.h" class CustomSessionContainerLoaderXml : public SessionContainerLoader::For { public: - void onBefore() + void onPeriodic() override { - boost::filesystem::create_directories(SessionContainerXml::xmlDir); - } - void onPeriodic() - { - boost::filesystem::directory_iterator end; - for (boost::filesystem::directory_iterator p(SessionContainerXml::xmlDir); p != end; ++p) { - xmlpp::DomParser session(p->path().string()); - xmlpp::Element * sess = session.get_document()->get_root_node(); - time_t expires = boost::lexical_cast(sess->get_attribute_value("expires")); - if (expires < time(NULL)) { - boost::filesystem::remove(*p); + try { + if (boost::filesystem::is_directory(SessionContainerXml::xmlDir)) { + boost::filesystem::directory_iterator end; + for (boost::filesystem::directory_iterator p(SessionContainerXml::xmlDir); p != end; ++p) { + xmlpp::DomParser session(p->path().string()); + xmlpp::Element * sess = session.get_document()->get_root_node(); + time_t expires = boost::lexical_cast(sess->get_attribute_value("expires")); + if (expires < time(NULL)) { + boost::filesystem::remove(*p); + } + } } } + catch (...) { + Logger()->messagebf(LOG_WARNING, "Failed to purge expired sessions in %s", SessionContainerXml::xmlDir); + } } }; DECLARE_OPTIONS(SessionContainerXml, "Session XML options") @@ -60,6 +64,7 @@ SessionContainerXml::SaveSession(SessionPtr currentSession) const xmlpp::Element * sess = d.create_root_node("session"); sess->set_attribute("expires", boost::lexical_cast(currentSession->ExpiryTime())); currentSession->ForeachValue(boost::bind(appendToXmlNode, sess, _1, _2)); + boost::filesystem::create_directories(SessionContainerXml::xmlDir); boost::filesystem::path p = xmlDir / boost::lexical_cast(currentSession->ID()); d.write_to_file(p.string()); } diff --git a/project2/xml/xmlCache.cpp b/project2/xml/xmlCache.cpp index bfa9c91..d6e2e04 100644 --- a/project2/xml/xmlCache.cpp +++ b/project2/xml/xmlCache.cpp @@ -87,9 +87,14 @@ time_t XmlCache::CacheLife; class CustomXmlCacheLoader : public ElementLoader::For { public: - void onIdle() + void onIdle() override { - emptyDir(XmlCache::Store); + try { + emptyDir(XmlCache::Store); + } + catch (...) { + Logger()->messagebf(LOG_WARNING, "Failed to purge caches from %s", XmlCache::Store); + } } bool emptyDir(const boost::filesystem::path & dir) diff --git a/project2/xml/xmlDocumentCache.cpp b/project2/xml/xmlDocumentCache.cpp index 52165fb..b0d850d 100644 --- a/project2/xml/xmlDocumentCache.cpp +++ b/project2/xml/xmlDocumentCache.cpp @@ -109,7 +109,7 @@ class XmlDocumentCacheClearer : public ComponentLoader { public: typedef bool KeyType; - void onIteration() + void onIteration() override { Logger()->messagef(LOG_DEBUG, "%s: Clearing XML document cache", __PRETTY_FUNCTION__); XmlDocumentCache::documents.clear(); -- cgit v1.2.3