|
|
402b94 |
--- src/corelib/kernel/qeventdispatcher_glib.cpp.sav 2014-03-28 15:26:37.000000000 +0100
|
|
|
402b94 |
+++ src/corelib/kernel/qeventdispatcher_glib.cpp 2014-04-24 09:44:09.358659204 +0200
|
|
|
402b94 |
@@ -255,22 +255,30 @@ struct GPostEventSource
|
|
|
402b94 |
GSource source;
|
|
|
402b94 |
QAtomicInt serialNumber;
|
|
|
402b94 |
int lastSerialNumber;
|
|
|
402b94 |
+ QEventLoop::ProcessEventsFlags processEventsFlags;
|
|
|
402b94 |
QEventDispatcherGlibPrivate *d;
|
|
|
402b94 |
};
|
|
|
402b94 |
|
|
|
402b94 |
static gboolean postEventSourcePrepare(GSource *s, gint *timeout)
|
|
|
402b94 |
{
|
|
|
402b94 |
+ GPostEventSource *source = reinterpret_cast<GPostEventSource *>(s);
|
|
|
402b94 |
QThreadData *data = QThreadData::current();
|
|
|
402b94 |
if (!data)
|
|
|
402b94 |
return false;
|
|
|
402b94 |
|
|
|
402b94 |
+ QEventLoop::ProcessEventsFlags excludeAllFlags
|
|
|
402b94 |
+ = QEventLoop::ExcludeUserInputEvents
|
|
|
402b94 |
+ | QEventLoop::ExcludeSocketNotifiers
|
|
|
402b94 |
+ | QEventLoop::X11ExcludeTimers;
|
|
|
402b94 |
+ if ((source->processEventsFlags & excludeAllFlags) == excludeAllFlags)
|
|
|
402b94 |
+ return false;
|
|
|
402b94 |
+
|
|
|
402b94 |
gint dummy;
|
|
|
402b94 |
if (!timeout)
|
|
|
402b94 |
timeout = &dummy;
|
|
|
402b94 |
const bool canWait = data->canWaitLocked();
|
|
|
402b94 |
*timeout = canWait ? -1 : 0;
|
|
|
402b94 |
|
|
|
402b94 |
- GPostEventSource *source = reinterpret_cast<GPostEventSource *>(s);
|
|
|
402b94 |
return (!canWait
|
|
|
402b94 |
|| (source->serialNumber != source->lastSerialNumber));
|
|
|
402b94 |
}
|
|
|
402b94 |
@@ -284,8 +292,14 @@ static gboolean postEventSourceDispatch(
|
|
|
402b94 |
{
|
|
|
402b94 |
GPostEventSource *source = reinterpret_cast<GPostEventSource *>(s);
|
|
|
402b94 |
source->lastSerialNumber = source->serialNumber;
|
|
|
402b94 |
- QCoreApplication::sendPostedEvents();
|
|
|
402b94 |
- source->d->runTimersOnceWithNormalPriority();
|
|
|
402b94 |
+ QEventLoop::ProcessEventsFlags excludeAllFlags
|
|
|
402b94 |
+ = QEventLoop::ExcludeUserInputEvents
|
|
|
402b94 |
+ | QEventLoop::ExcludeSocketNotifiers
|
|
|
402b94 |
+ | QEventLoop::X11ExcludeTimers;
|
|
|
402b94 |
+ if ((source->processEventsFlags & excludeAllFlags) != excludeAllFlags) {
|
|
|
402b94 |
+ QCoreApplication::sendPostedEvents();
|
|
|
402b94 |
+ source->d->runTimersOnceWithNormalPriority();
|
|
|
402b94 |
+ }
|
|
|
402b94 |
return true; // i dunno, george...
|
|
|
402b94 |
}
|
|
|
402b94 |
|
|
|
402b94 |
@@ -329,6 +343,7 @@ QEventDispatcherGlibPrivate::QEventDispa
|
|
|
402b94 |
postEventSource = reinterpret_cast<GPostEventSource *>(g_source_new(&postEventSourceFuncs,
|
|
|
402b94 |
sizeof(GPostEventSource)));
|
|
|
402b94 |
postEventSource->serialNumber = 1;
|
|
|
402b94 |
+ postEventSource->processEventsFlags = QEventLoop::AllEvents;
|
|
|
402b94 |
postEventSource->d = this;
|
|
|
402b94 |
g_source_set_can_recurse(&postEventSource->source, true);
|
|
|
402b94 |
g_source_attach(&postEventSource->source, mainContext);
|
|
|
402b94 |
@@ -423,6 +438,7 @@ bool QEventDispatcherGlib::processEvents
|
|
|
402b94 |
|
|
|
402b94 |
// tell postEventSourcePrepare() and timerSource about any new flags
|
|
|
402b94 |
QEventLoop::ProcessEventsFlags savedFlags = d->timerSource->processEventsFlags;
|
|
|
402b94 |
+ d->postEventSource->processEventsFlags = flags;
|
|
|
402b94 |
d->timerSource->processEventsFlags = flags;
|
|
|
402b94 |
d->socketNotifierSource->processEventsFlags = flags;
|
|
|
402b94 |
|
|
|
402b94 |
@@ -435,6 +451,7 @@ bool QEventDispatcherGlib::processEvents
|
|
|
402b94 |
while (!result && canWait)
|
|
|
402b94 |
result = g_main_context_iteration(d->mainContext, canWait);
|
|
|
402b94 |
|
|
|
402b94 |
+ d->postEventSource->processEventsFlags = savedFlags;
|
|
|
402b94 |
d->timerSource->processEventsFlags = savedFlags;
|
|
|
402b94 |
d->socketNotifierSource->processEventsFlags = savedFlags;
|
|
|
402b94 |
|
|
|
402b94 |
--- src/corelib/kernel/qeventdispatcher_unix.cpp.sav 2013-06-07 07:16:52.000000000 +0200
|
|
|
402b94 |
+++ src/corelib/kernel/qeventdispatcher_unix.cpp 2014-04-24 09:43:06.927589535 +0200
|
|
|
402b94 |
@@ -905,7 +905,15 @@ bool QEventDispatcherUNIX::processEvents
|
|
|
402b94 |
|
|
|
402b94 |
// we are awake, broadcast it
|
|
|
402b94 |
emit awake();
|
|
|
402b94 |
- QCoreApplicationPrivate::sendPostedEvents(0, 0, d->threadData);
|
|
|
402b94 |
+
|
|
|
402b94 |
+ QEventLoop::ProcessEventsFlags excludeAllFlags
|
|
|
402b94 |
+ = QEventLoop::ExcludeUserInputEvents
|
|
|
402b94 |
+ | QEventLoop::ExcludeSocketNotifiers
|
|
|
402b94 |
+ | QEventLoop::X11ExcludeTimers;
|
|
|
402b94 |
+ if ((flags & excludeAllFlags) == excludeAllFlags)
|
|
|
402b94 |
+ return false;
|
|
|
402b94 |
+ if(( flags & excludeAllFlags ) != excludeAllFlags )
|
|
|
402b94 |
+ QCoreApplicationPrivate::sendPostedEvents(0, 0, d->threadData);
|
|
|
402b94 |
|
|
|
402b94 |
int nevents = 0;
|
|
|
402b94 |
const bool canWait = (d->threadData->canWaitLocked()
|