X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fupdate.h;h=5bb9e95016de1ed2bace2ec556fd54f9dccfef07;hb=b6235aa37eac2c91358ff058389b4391b52f4615;hp=f3a0ffc36f55498dc1046f0268164641af1e09df;hpb=e894cfe3d891135d1b92b62603a464e42bd6ed5c;p=dcpomatic.git diff --git a/src/lib/update.h b/src/lib/update.h index f3a0ffc36..5bb9e9501 100644 --- a/src/lib/update.h +++ b/src/lib/update.h @@ -27,8 +27,10 @@ #include #include +struct update_checker_test; + /** Class to check for the existance of an update for DCP-o-matic on a remote server */ -class UpdateChecker +class UpdateChecker : public boost::noncopyable { public: UpdateChecker (); @@ -49,14 +51,14 @@ public: return _state; } - /** @return the version string of the latest stable version (if _state == YES or NO) */ - std::string stable () { + /** @return new stable version, if there is one */ + boost::optional stable () { boost::mutex::scoped_lock lm (_data_mutex); return _stable; } - /** @return the version string of the latest test version (if _state == YES or NO) */ - std::string test () { + /** @return new test version, if there is one and Config is set to look for it */ + boost::optional test () { boost::mutex::scoped_lock lm (_data_mutex); return _test; } @@ -73,9 +75,13 @@ public: static UpdateChecker* instance (); -private: +private: + friend struct update_checker_test; + static UpdateChecker* _instance; + static bool version_less_than (std::string const & a, std::string const & b); + void set_state (State); void thread (); @@ -86,8 +92,8 @@ private: /** mutex to protect _state, _stable, _test and _emits */ mutable boost::mutex _data_mutex; State _state; - std::string _stable; - std::string _test; + boost::optional _stable; + boost::optional _test; int _emits; boost::thread* _thread;