summaryrefslogtreecommitdiff
path: root/src/plugins
diff options
context:
space:
mode:
authorJarek Kobus <jaroslaw.kobus@qt.io>2022-10-28 15:09:46 +0200
committerJarek Kobus <jaroslaw.kobus@qt.io>2022-11-09 17:47:02 +0000
commitd81abf1fb46c8f30bfd52f9ca95c2da941266b25 (patch)
tree967e485ea94a6b69a4cd7a8102c6dcc5e7a5519d /src/plugins
parentc49de14c9dd4c92b25642d379d525a057fa0d409 (diff)
downloadqt-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.cpp7
-rw-r--r--src/plugins/diffeditor/diffeditorplugin.h6
-rw-r--r--src/plugins/diffeditor/sidebysidediffeditorwidget.cpp5
-rw-r--r--src/plugins/diffeditor/unifieddiffeditorwidget.cpp5
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);
}