diff options
| author | Carl Hetherington <cth@carlh.net> | 2013-12-30 23:10:49 +0000 |
|---|---|---|
| committer | Carl Hetherington <cth@carlh.net> | 2013-12-30 23:10:49 +0000 |
| commit | 6670f11c639e3515256f4f0eb3699e02155f67c9 (patch) | |
| tree | 1bdd2045e2cd2cb988a2bf209fecc0cb29e817b1 /src/lib | |
| parent | f87a0f16f8cee026ee33c3a46b93b43d4b3cf5ff (diff) | |
Handle exceptions thrown from ServerFinder.
Diffstat (limited to 'src/lib')
| -rw-r--r-- | src/lib/server_finder.cc | 10 | ||||
| -rw-r--r-- | src/lib/server_finder.h | 2 |
2 files changed, 11 insertions, 1 deletions
diff --git a/src/lib/server_finder.cc b/src/lib/server_finder.cc index de90e0d5c..5b67d8048 100644 --- a/src/lib/server_finder.cc +++ b/src/lib/server_finder.cc @@ -47,6 +47,7 @@ ServerFinder::ServerFinder () void ServerFinder::broadcast_thread () +try { boost::system::error_code error; boost::asio::io_service io_service; @@ -88,9 +89,14 @@ ServerFinder::broadcast_thread () dcpomatic_sleep (10); } } +catch (...) +{ + store_current (); +} void ServerFinder::listen_thread () +try { while (1) { shared_ptr<Socket> sock (new Socket (10)); @@ -117,6 +123,10 @@ ServerFinder::listen_thread () } } } +catch (...) +{ + store_current (); +} bool ServerFinder::server_found (string ip) const diff --git a/src/lib/server_finder.h b/src/lib/server_finder.h index 01e26f7df..202bee8f9 100644 --- a/src/lib/server_finder.h +++ b/src/lib/server_finder.h @@ -20,7 +20,7 @@ #include <boost/signals2.hpp> #include "server.h" -class ServerFinder +class ServerFinder : public ExceptionStore { public: void connect (boost::function<void (ServerDescription)>); |
