diff options
author | Qt Forward Merge Bot <qt_forward_merge_bot@qt-project.org> | 2019-09-09 09:21:48 +0200 |
---|---|---|
committer | Qt Forward Merge Bot <qt_forward_merge_bot@qt-project.org> | 2019-09-09 09:21:48 +0200 |
commit | 2eead078c86a4d24403d3d1ba737dbc3096a8b42 (patch) | |
tree | 58b8da96c63fe4c1e59d3707f0b633592210a82d /src/corelib/kernel | |
parent | 94902905ec203626abc050744d14898674dc2bbd (diff) | |
parent | 89d0a03c067b42155b1a2d310f8514f595abfd61 (diff) |
Merge remote-tracking branch 'origin/5.14' into 5.15
Change-Id: If8e9d88771243fd9e221b49f53d7d8b111a8ce2a
Diffstat (limited to 'src/corelib/kernel')
-rw-r--r-- | src/corelib/kernel/qeventdispatcher_winrt.cpp | 23 |
1 files changed, 12 insertions, 11 deletions
diff --git a/src/corelib/kernel/qeventdispatcher_winrt.cpp b/src/corelib/kernel/qeventdispatcher_winrt.cpp index 600c6c38fd..f7a1f969a8 100644 --- a/src/corelib/kernel/qeventdispatcher_winrt.cpp +++ b/src/corelib/kernel/qeventdispatcher_winrt.cpp @@ -44,12 +44,13 @@ #include <QtCore/QHash> #include <QtCore/QMutex> #include <QtCore/QSemaphore> -#include <QtCore/QSharedPointer> #include <QtCore/qfunctions_winrt.h> #include <private/qabstracteventdispatcher_p.h> #include <private/qcoreapplication_p.h> #include <functional> +#include <memory> + #include <wrl.h> #include <windows.foundation.h> #include <windows.system.threading.h> @@ -300,19 +301,19 @@ HRESULT QEventDispatcherWinRT::runOnMainThread(const std::function<HRESULT()> &d if (QThread::currentThread() == QCoreApplication::instance()->thread()) return delegate(); - auto semaphore = QSharedPointer<QSemaphore>(new QSemaphore); - auto ptrSemaphore = new QSharedPointer<QSemaphore>(semaphore); - auto result = QSharedPointer<HRESULT>(new HRESULT); - auto ptrResult = new QSharedPointer<HRESULT>(result); + struct State { + QSemaphore semaphore; + HRESULT result; + }; + + const auto state = std::make_shared<State>(); - QMetaObject::invokeMethod(QCoreApplication::instance(), [delegate, ptrSemaphore, ptrResult]() { - **ptrResult = delegate(); - delete ptrResult; - (*ptrSemaphore)->release(); - delete ptrSemaphore; + QMetaObject::invokeMethod(QCoreApplication::instance(), [delegate, state]() { + const QSemaphoreReleaser releaser{state->semaphore}; + state->result = delegate(); }, nullptr); - return semaphore->tryAcquire(1, timeout) ? *result : E_FAIL; + return state->semaphore.tryAcquire(1, timeout) ? state->result : E_FAIL; } bool QEventDispatcherWinRT::processEvents(QEventLoop::ProcessEventsFlags flags) |