X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Fsupport%2FFileMonitor.h;h=07a8dc532c93335007ab4f9b79e5b24afa445dd6;hb=759769131a4e5bd021ddb5e8fc5995a2af537e05;hp=e2bbb1b1feba5310a321a9c5cbeeb7097c677376;hpb=9926927fb1a38f15ec4fa1334075720925a3295e;p=lyx.git diff --git a/src/support/FileMonitor.h b/src/support/FileMonitor.h index e2bbb1b1fe..07a8dc532c 100644 --- a/src/support/FileMonitor.h +++ b/src/support/FileMonitor.h @@ -17,6 +17,7 @@ #define FILEMONITOR_H #include "support/FileName.h" +#include "support/signals.h" #include @@ -24,8 +25,6 @@ #include #include -#include - namespace lyx { namespace support { @@ -61,26 +60,16 @@ typedef std::unique_ptr ActiveFileMonitorPtr; /// monitor.connect(...); /// (stops watching the first) /// -/// Block notifications for the duration of a scope: -/// { -/// FileMonitorBlocker block = monitor.block(); -/// ... -/// } -/// -/// Reset connections: -/// monitor.disconnect(); -/// or the disconnect method of the connection object for the boost signal. -/// class FileSystemWatcher { public: - // as described above + /// as described above static FileMonitorPtr monitor(FileName const & filename); /// same but with an ActiveFileMonitor static ActiveFileMonitorPtr activeMonitor(FileName const & filename, int interval = 10000); - // Output whether the paths tracked by qwatcher_ and the active - // FileMonitorGuards are in correspondence. + /// Output whether the paths tracked by qwatcher_ and the active + /// FileMonitorGuards are in correspondence. static void debug(); private: FileSystemWatcher(); @@ -88,9 +77,9 @@ private: static FileSystemWatcher & instance(); /// std::shared_ptr getGuard(FileName const & filename); - // Caches the monitor guards but allow them to be destroyed + /// Caches the monitor guards but allow them to be destroyed std::map> store_; - // This class is a wrapper for QFileSystemWatcher + /// This class is a wrapper for QFileSystemWatcher std::unique_ptr const qwatcher_; }; @@ -109,18 +98,16 @@ public: ~FileMonitorGuard(); /// absolute path being tracked std::string const & filename() { return filename_; } - /// if false, emit fileChanged() when we notice the existence of the file - void setExists(bool exists) { exists_ = exists; } public Q_SLOTS: /// Make sure it is being monitored, after e.g. a deletion. See /// . This is called /// automatically. - void refresh(); + void refresh(bool emit = true); Q_SIGNALS: /// Connect to this to be notified when the file changes - void fileChanged() const; + void fileChanged(bool exists) const; private Q_SLOTS: /// Receive notifications from the QFileSystemWatcher @@ -129,72 +116,45 @@ private Q_SLOTS: private: std::string const filename_; QFileSystemWatcher * qwatcher_; + /// for emitting fileChanged() when the file is created or deleted bool exists_; }; -class FileMonitorBlockerGuard : public QObject -{ - Q_OBJECT - QPointer monitor_; - int delay_; - -public: - FileMonitorBlockerGuard(FileMonitor * monitor); - ~FileMonitorBlockerGuard(); - void setDelay(int delay); -}; - - -typedef std::shared_ptr FileMonitorBlocker; - - /// Main class class FileMonitor : public QObject { Q_OBJECT - friend class FileMonitorBlockerGuard; public: FileMonitor(std::shared_ptr monitor); - typedef boost::signals2::signal sig; + typedef signals2::signal sig; + typedef sig::slot_type slot; /// Connect and you'll be informed when the file has changed. - boost::signals2::connection connect(sig::slot_type const &); - /// disconnect all slots connected to the boost signal fileChanged_ or to - /// the qt signal fileChanged() - void disconnect(); + signals2::connection connect(slot const &); /// absolute path being tracked std::string const & filename() { return monitor_->filename(); } - /// Creates a guard that blocks notifications. Copyable. Notifications from - /// this monitor are blocked as long as there are copies around. - /// \param delay is the amount waited in ms after expiration of the guard - /// before reconnecting. This delay thing is to deal with asynchronous - /// notifications in a not so elegant fashion. But it can also be used to - /// slow down incoming events. - FileMonitorBlocker block(int delay = 0); /// Make sure the good file is being monitored, after e.g. a move or a /// deletion. See . This is /// called automatically. - void refresh() { return monitor_->refresh(); } + void refresh() { monitor_->refresh(); } Q_SIGNALS: /// Connect to this to be notified when the file changes - void fileChanged() const; + void fileChanged(bool exists) const; protected Q_SLOTS: /// Receive notifications from the FileMonitorGuard - void changed(); + void changed(bool exists); /// - void reconnectToFileMonitorGuard(); + void connectToFileMonitorGuard(); private: - // boost signal + /// boost signal sig fileChanged_; - // the unique watch for our file + /// the unique watch for our file std::shared_ptr const monitor_; - // - std::weak_ptr blocker_; };