From c9b2423aaed459c68dd8f43b1de0edee4eb287c8 Mon Sep 17 00:00:00 2001 From: Neil Date: Fri, 28 May 2021 14:46:21 +1000 Subject: Better exception handling for noexcept methods. More accurate noexcept marking. --- src/Document.cxx | 18 ++++++++++++------ 1 file changed, 12 insertions(+), 6 deletions(-) (limited to 'src/Document.cxx') diff --git a/src/Document.cxx b/src/Document.cxx index 70a711028..c20f7beea 100644 --- a/src/Document.cxx +++ b/src/Document.cxx @@ -2477,12 +2477,18 @@ bool Document::AddWatcher(DocWatcher *watcher, void *userData) { return true; } -bool Document::RemoveWatcher(DocWatcher *watcher, void *userData) { - std::vector::iterator it = - std::find(watchers.begin(), watchers.end(), WatcherWithUserData(watcher, userData)); - if (it != watchers.end()) { - watchers.erase(it); - return true; +bool Document::RemoveWatcher(DocWatcher *watcher, void *userData) noexcept { + try { + // This can never fail as WatcherWithUserData constructor and == are noexcept + // but std::find is not noexcept. + std::vector::iterator it = + std::find(watchers.begin(), watchers.end(), WatcherWithUserData(watcher, userData)); + if (it != watchers.end()) { + watchers.erase(it); + return true; + } + } catch (...) { + // Ignore any exception } return false; } -- cgit v1.2.3