diff options
author | Jarek Kobus <jaroslaw.kobus@qt.io> | 2022-10-28 15:09:46 +0200 |
---|---|---|
committer | Jarek Kobus <jaroslaw.kobus@qt.io> | 2022-11-09 17:47:02 +0000 |
commit | d81abf1fb46c8f30bfd52f9ca95c2da941266b25 (patch) | |
tree | 967e485ea94a6b69a4cd7a8102c6dcc5e7a5519d /src/plugins | |
parent | c49de14c9dd4c92b25642d379d525a057fa0d409 (diff) | |
download | qt-creator-d81abf1fb46c8f30bfd52f9ca95c2da941266b25.tar.gz |
DiffEditorPlugin: Expose plugin's future synchronizer
Change-Id: I208a0e6b9c9776486972177f845e76d33121a2a3
Reviewed-by: hjk <hjk@qt.io>
Reviewed-by: Qt CI Bot <qt_ci_bot@qt-project.org>
Reviewed-by: <github-actions-qt-creator@cristianadam.eu>
Diffstat (limited to 'src/plugins')
-rw-r--r-- | src/plugins/diffeditor/diffeditorplugin.cpp | 7 | ||||
-rw-r--r-- | src/plugins/diffeditor/diffeditorplugin.h | 6 | ||||
-rw-r--r-- | src/plugins/diffeditor/sidebysidediffeditorwidget.cpp | 5 | ||||
-rw-r--r-- | src/plugins/diffeditor/unifieddiffeditorwidget.cpp | 5 |
4 files changed, 12 insertions, 11 deletions
diff --git a/src/plugins/diffeditor/diffeditorplugin.cpp b/src/plugins/diffeditor/diffeditorplugin.cpp index a8b2b1331b..617c19f7b7 100644 --- a/src/plugins/diffeditor/diffeditorplugin.cpp +++ b/src/plugins/diffeditor/diffeditorplugin.cpp @@ -580,13 +580,12 @@ bool DiffEditorPlugin::initialize(const QStringList &arguments, QString *errorMe return true; } -void DiffEditorPlugin::addFuture(const QFuture<void> &future) +FutureSynchronizer *DiffEditorPlugin::futureSynchronizer() { - QTC_ASSERT(s_instance, return); - s_instance->d->m_futureSynchronizer.addFuture(future); + QTC_ASSERT(s_instance, return nullptr); + return &s_instance->d->m_futureSynchronizer; } - } // namespace Internal } // namespace DiffEditor diff --git a/src/plugins/diffeditor/diffeditorplugin.h b/src/plugins/diffeditor/diffeditorplugin.h index 0cf10548ba..e3ec8924f4 100644 --- a/src/plugins/diffeditor/diffeditorplugin.h +++ b/src/plugins/diffeditor/diffeditorplugin.h @@ -8,6 +8,8 @@ #include <coreplugin/diffservice.h> #include <extensionsystem/iplugin.h> +namespace Utils { class FutureSynchronizer; } + QT_BEGIN_NAMESPACE template <typename T> class QFuture; @@ -39,9 +41,7 @@ public: bool initialize(const QStringList &arguments, QString *errorMessage) final; - template <typename T> - static void addFuture(const QFuture<T> &future) { addFuture(QFuture<void>(future)); } - static void addFuture(const QFuture<void> &future); + static Utils::FutureSynchronizer *futureSynchronizer(); private: class DiffEditorPluginPrivate *d = nullptr; diff --git a/src/plugins/diffeditor/sidebysidediffeditorwidget.cpp b/src/plugins/diffeditor/sidebysidediffeditorwidget.cpp index 4fba7076c4..9870baccfd 100644 --- a/src/plugins/diffeditor/sidebysidediffeditorwidget.cpp +++ b/src/plugins/diffeditor/sidebysidediffeditorwidget.cpp @@ -25,6 +25,7 @@ #include <texteditor/textdocumentlayout.h> #include <texteditor/texteditorsettings.h> +#include <utils/futuresynchronizer.h> #include <utils/runextensions.h> #include <utils/tooltip/tooltip.h> @@ -784,7 +785,7 @@ SideBySideDiffEditorWidget::~SideBySideDiffEditorWidget() { if (m_watcher) { m_watcher->cancel(); - DiffEditorPlugin::addFuture(m_watcher->future()); + DiffEditorPlugin::futureSynchronizer()->addFuture(m_watcher->future()); } } @@ -816,7 +817,7 @@ void SideBySideDiffEditorWidget::clear(const QString &message) editor->clearAll(message); if (m_watcher) { m_watcher->cancel(); - DiffEditorPlugin::addFuture(m_watcher->future()); + DiffEditorPlugin::futureSynchronizer()->addFuture(m_watcher->future()); m_watcher.reset(); m_controller.setBusyShowing(false); } diff --git a/src/plugins/diffeditor/unifieddiffeditorwidget.cpp b/src/plugins/diffeditor/unifieddiffeditorwidget.cpp index 400e987755..663e53166f 100644 --- a/src/plugins/diffeditor/unifieddiffeditorwidget.cpp +++ b/src/plugins/diffeditor/unifieddiffeditorwidget.cpp @@ -21,6 +21,7 @@ #include <texteditor/textdocumentlayout.h> #include <texteditor/texteditorsettings.h> +#include <utils/futuresynchronizer.h> #include <utils/qtcassert.h> #include <utils/runextensions.h> #include <utils/tooltip/tooltip.h> @@ -57,7 +58,7 @@ UnifiedDiffEditorWidget::~UnifiedDiffEditorWidget() { if (m_watcher) { m_watcher->cancel(); - DiffEditorPlugin::addFuture(m_watcher->future()); + DiffEditorPlugin::futureSynchronizer()->addFuture(m_watcher->future()); } } @@ -204,7 +205,7 @@ void UnifiedDiffEditorWidget::clear(const QString &message) setSelections({}); if (m_watcher) { m_watcher->cancel(); - DiffEditorPlugin::addFuture(m_watcher->future()); + DiffEditorPlugin::futureSynchronizer()->addFuture(m_watcher->future()); m_watcher.reset(); m_controller.setBusyShowing(false); } |