summaryrefslogtreecommitdiffstats
path: root/SQLiteStudio3/coreSQLiteStudio/common/signalwait.cpp
diff options
context:
space:
mode:
authorLibravatarUnit 193 <unit193@ubuntu.com>2015-04-19 22:30:21 -0400
committerLibravatarUnit 193 <unit193@ubuntu.com>2015-04-19 22:30:21 -0400
commita308f430f694423064ebc86fd0506c8c6fdb3d93 (patch)
treeceacd24fecf92f40980f8d8f3fd169e317c886af /SQLiteStudio3/coreSQLiteStudio/common/signalwait.cpp
parenta5b034d4a9c44f9bc1e83b01de82530f8fc63013 (diff)
Imported Upstream version 3.0.5upstream/3.0.5
Diffstat (limited to 'SQLiteStudio3/coreSQLiteStudio/common/signalwait.cpp')
-rw-r--r--SQLiteStudio3/coreSQLiteStudio/common/signalwait.cpp17
1 files changed, 15 insertions, 2 deletions
diff --git a/SQLiteStudio3/coreSQLiteStudio/common/signalwait.cpp b/SQLiteStudio3/coreSQLiteStudio/common/signalwait.cpp
index 90f9075..4a22e83 100644
--- a/SQLiteStudio3/coreSQLiteStudio/common/signalwait.cpp
+++ b/SQLiteStudio3/coreSQLiteStudio/common/signalwait.cpp
@@ -12,8 +12,11 @@ bool SignalWait::wait(int msTimeout)
{
QTime timer(0, 0, 0, msTimeout);
timer.start();
- while (!called && timer.elapsed() < msTimeout)
- qApp->processEvents(QEventLoop::ExcludeUserInputEvents);
+ while (!called && !failed && timer.elapsed() < msTimeout)
+ QCoreApplication::processEvents(QEventLoop::ExcludeUserInputEvents);
+
+ if (failed)
+ return false;
return called;
}
@@ -23,7 +26,17 @@ void SignalWait::reset()
called = false;
}
+void SignalWait::addFailSignal(QObject* object, const char* signal)
+{
+ connect(object, signal, this, SLOT(handleFailSignal()));
+}
+
void SignalWait::handleSignal()
{
called = true;
}
+
+void SignalWait::handleFailSignal()
+{
+ failed = true;
+}