aboutsummaryrefslogtreecommitdiffstats
path: root/SQLiteStudio3/coreSQLiteStudio/common/lazytrigger.cpp
diff options
context:
space:
mode:
authorLibravatarUnit 193 <unit193@ubuntu.com>2018-07-27 23:51:12 -0400
committerLibravatarUnit 193 <unit193@ubuntu.com>2018-07-27 23:51:12 -0400
commitfeda8a7db8d1d7c5439aa8f8feef7cc0dd2b59a0 (patch)
tree1e50f5f666f419143f510d5ded00fe2006b7bd85 /SQLiteStudio3/coreSQLiteStudio/common/lazytrigger.cpp
parentd9aa870e5d509cc7309ab82dd102a937ab58613a (diff)
New upstream version 3.2.1+dfsg1upstream/3.2.1+dfsg1
Diffstat (limited to 'SQLiteStudio3/coreSQLiteStudio/common/lazytrigger.cpp')
-rw-r--r--SQLiteStudio3/coreSQLiteStudio/common/lazytrigger.cpp37
1 files changed, 37 insertions, 0 deletions
diff --git a/SQLiteStudio3/coreSQLiteStudio/common/lazytrigger.cpp b/SQLiteStudio3/coreSQLiteStudio/common/lazytrigger.cpp
new file mode 100644
index 0000000..2c39f34
--- /dev/null
+++ b/SQLiteStudio3/coreSQLiteStudio/common/lazytrigger.cpp
@@ -0,0 +1,37 @@
+#include "lazytrigger.h"
+#include <QTimer>
+
+LazyTrigger::LazyTrigger(int delay, QObject* parent, const char* slot) :
+ QObject(parent)
+{
+ timer = new QTimer(this);
+ timer->setSingleShot(true);
+ timer->setInterval(delay);
+ connect(timer, &QTimer::timeout, this, &LazyTrigger::triggered);
+ if (slot)
+ connect(timer, SIGNAL(timeout()), parent, slot);
+}
+
+LazyTrigger::LazyTrigger(int delay, LazyTrigger::Condition condition, QObject* parent, const char* slot) :
+ LazyTrigger(delay, parent, slot)
+{
+ this->condition = condition;
+}
+
+void LazyTrigger::setDelay(int delay)
+{
+ timer->setInterval(delay);
+}
+
+void LazyTrigger::schedule()
+{
+ timer->stop();
+
+ if (!condition || condition())
+ timer->start();
+}
+
+void LazyTrigger::cancel()
+{
+ timer->stop();
+}