Replacing executor with schedule in fs-watcher: tags are used to limit number of notification per event
diff --git a/gui/fs-watcher.cc b/gui/fs-watcher.cc
index a97f8b4..94c6b3f 100644
--- a/gui/fs-watcher.cc
+++ b/gui/fs-watcher.cc
@@ -38,7 +38,7 @@
QObject* parent)
: QObject(parent)
, m_watcher (new QFileSystemWatcher())
- , m_executor (1)
+ , m_scheduler (new Scheduler ())
, m_dirPath (dirPath)
, m_onChange (onChange)
, m_onDelete (onDelete)
@@ -52,22 +52,27 @@
connect (m_watcher, SIGNAL (directoryChanged (QString)), this, SLOT (DidDirectoryChanged (QString)));
connect (m_watcher, SIGNAL (fileChanged (QString)), this, SLOT (DidFileChanged (QString)));
- m_executor.execute (bind (&FsWatcher::ScanDirectory_Notify_Execute, this, m_dirPath));
- m_executor.start ();
+ m_scheduler->start ();
+
+ Scheduler::scheduleOneTimeTask (m_scheduler, 0.1,
+ bind (&FsWatcher::ScanDirectory_Notify_Execute, this, m_dirPath),
+ m_dirPath.toStdString ()); // only one task will be scheduled per directory
}
FsWatcher::~FsWatcher()
{
- m_executor.shutdown ();
- delete m_watcher;
+ m_scheduler->shutdown ();
}
void
FsWatcher::DidDirectoryChanged (QString dirPath)
{
- // _LOG_DEBUG ("Triggered DirPath: " << dirPath.toStdString ());
+ _LOG_DEBUG ("Triggered DirPath: " << dirPath.toStdString ());
- m_executor.execute (bind (&FsWatcher::ScanDirectory_Notify_Execute, this, dirPath));
+ // m_executor.execute (bind (&FsWatcher::ScanDirectory_Notify_Execute, this, dirPath));
+ Scheduler::scheduleOneTimeTask (m_scheduler, 0.5,
+ bind (&FsWatcher::ScanDirectory_Notify_Execute, this, dirPath),
+ dirPath.toStdString ()); // only one task will be scheduled per directory
}
void
@@ -85,32 +90,23 @@
if (filesystem::exists (filesystem::path (absPathTriggeredFile)))
{
_LOG_DEBUG ("Triggered UPDATE of file: " << triggeredFile.relative_path ().generic_string ());
- m_onChange (triggeredFile.relative_path ());
+ // m_onChange (triggeredFile.relative_path ());
+
+ Scheduler::scheduleOneTimeTask (m_scheduler, 0.5,
+ bind (m_onChange, triggeredFile.relative_path ()),
+ triggeredFile.relative_path ().string());
}
else
{
_LOG_DEBUG ("Triggered DELETE of file: " << triggeredFile.relative_path ().generic_string ());
- m_onDelete (triggeredFile.relative_path ());
+ // m_onDelete (triggeredFile.relative_path ());
+
+ Scheduler::scheduleOneTimeTask (m_scheduler, 0.5,
+ bind (m_onDelete, triggeredFile.relative_path ()),
+ triggeredFile.relative_path ().string());
}
}
-
-void FsWatcher::DidDirectoryChanged_Execute (QString dirPath)
-{
-// // scan directory and populate file list
-// QHash<QString, qint64> currentState = scanDirectory(dirPath);
-
-// // reconcile directory and report changes
-// std::vector<sEventInfo> dirChanges = reconcileDirectory(currentState, dirPath);
-// #ifdef _DEBUG
-// // DEBUG: Print Changes
-// printChanges(dirChanges);
-// #endif
-// // emit the signal if not empty
-// if(!dirChanges.empty())
-// emit dirEventSignal(dirChanges);
-}
-
void
FsWatcher::ScanDirectory_Notify_Execute (QString dirPath)
{
diff --git a/gui/fs-watcher.h b/gui/fs-watcher.h
index 6ba6671..109e8da 100644
--- a/gui/fs-watcher.h
+++ b/gui/fs-watcher.h
@@ -26,7 +26,7 @@
#include <QFileSystemWatcher>
#include <boost/filesystem.hpp>
-#include "executor.h"
+#include "scheduler.h"
class FsWatcher : public QObject
{
@@ -57,9 +57,6 @@
private:
// handle callback from the watcher
- void
- DidDirectoryChanged_Execute (QString dirPath);
-
// scan directory and notify callback about any file changes
void
ScanDirectory_Notify_Execute (QString dirPath);
@@ -76,7 +73,7 @@
private:
QFileSystemWatcher* m_watcher; // filesystem watcher
- Executor m_executor;
+ SchedulerPtr m_scheduler;
QString m_dirPath; // monitored path