X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fupdate.h;h=461217a372ea61ae3802f0018a0026da76ff2339;hb=ef4b082c5d7452a34ce45f6d3bead46a7e846faf;hp=c86adb8736adad074625f8b7a73dd47ae1eb666e;hpb=5dc2dbdb6639f8d617a40209ad603d2a38f9df2a;p=dcpomatic.git diff --git a/src/lib/update.h b/src/lib/update.h index c86adb873..461217a37 100644 --- a/src/lib/update.h +++ b/src/lib/update.h @@ -21,14 +21,17 @@ * @brief UpdateChecker class. */ +#include "signaller.h" +#include #include #include #include #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 Signaller, public boost::noncopyable { public: UpdateChecker (); @@ -49,14 +52,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 +76,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 +93,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;