summaryrefslogtreecommitdiff
path: root/src/plugins/cpptools/cppprojectupdater.cpp
diff options
context:
space:
mode:
authorChristian Kandeler <christian.kandeler@qt.io>2021-08-30 10:58:08 +0200
committerChristian Kandeler <christian.kandeler@qt.io>2021-09-01 14:53:58 +0000
commit284817fae6514701902ccdb834c2faa46462f2e8 (patch)
tree44a8c7d9813dc110b61c4639036366c7696bd7e9 /src/plugins/cpptools/cppprojectupdater.cpp
parent3e1fa0f170d523971d2c3c12da15a6e291f56511 (diff)
downloadqt-creator-284817fae6514701902ccdb834c2faa46462f2e8.tar.gz
Merge CppTools into CppEditor
There was no proper separation of responsibilities between these plugins. In particular, CppTools had lots of editor-related functionality, so it's not clear why it was separated out in the first place. In fact, for a lot of code, it seemed quite arbitrary where it was put (just one example: switchHeaderSource() was in CppTools, wheras switchDeclarationDefinition() was in CppEditor). Merging the plugins will enable us to get rid of various convoluted pseudo-abstractions that were only introduced to keep up the artificial separation. Change-Id: Iafc3bce625b4794f6d4aa03df6cddc7f2d26716a Reviewed-by: Christian Stenger <christian.stenger@qt.io>
Diffstat (limited to 'src/plugins/cpptools/cppprojectupdater.cpp')
-rw-r--r--src/plugins/cpptools/cppprojectupdater.cpp179
1 files changed, 0 insertions, 179 deletions
diff --git a/src/plugins/cpptools/cppprojectupdater.cpp b/src/plugins/cpptools/cppprojectupdater.cpp
deleted file mode 100644
index 957f24b98e..0000000000
--- a/src/plugins/cpptools/cppprojectupdater.cpp
+++ /dev/null
@@ -1,179 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2017 The Qt Company Ltd.
-** Contact: https://www.qt.io/licensing/
-**
-** This file is part of Qt Creator.
-**
-** Commercial License Usage
-** Licensees holding valid commercial Qt licenses may use this file in
-** accordance with the commercial license agreement provided with the
-** Software or, alternatively, in accordance with the terms contained in
-** a written agreement between you and The Qt Company. For licensing terms
-** and conditions see https://www.qt.io/terms-conditions. For further
-** information use the contact form at https://www.qt.io/contact-us.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3 as published by the Free Software
-** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
-** included in the packaging of this file. Please review the following
-** information to ensure the GNU General Public License requirements will
-** be met: https://www.gnu.org/licenses/gpl-3.0.html.
-**
-****************************************************************************/
-
-#include "cppprojectupdater.h"
-
-#include "cppmodelmanager.h"
-#include "cppprojectinfogenerator.h"
-#include "generatedcodemodelsupport.h"
-
-#include <coreplugin/progressmanager/progressmanager.h>
-
-#include <projectexplorer/toolchainmanager.h>
-
-#include <utils/algorithm.h>
-#include <utils/fileutils.h>
-#include <utils/qtcassert.h>
-#include <utils/runextensions.h>
-
-#include <QFutureInterface>
-
-using namespace ProjectExplorer;
-
-namespace CppTools {
-
-CppProjectUpdater::CppProjectUpdater()
-{
- connect(&m_generateFutureWatcher,
- &QFutureWatcher<ProjectInfo>::finished,
- this,
- &CppProjectUpdater::onProjectInfoGenerated);
- m_futureSynchronizer.setCancelOnWait(true);
-}
-
-CppProjectUpdater::~CppProjectUpdater()
-{
- cancel();
-}
-
-void CppProjectUpdater::update(const ProjectUpdateInfo &projectUpdateInfo)
-{
- update(projectUpdateInfo, {});
-}
-
-void CppProjectUpdater::update(const ProjectUpdateInfo &projectUpdateInfo,
- const QList<ProjectExplorer::ExtraCompiler *> &extraCompilers)
-{
- // Stop previous update.
- cancel();
-
- m_extraCompilers = Utils::transform(extraCompilers, [](ExtraCompiler *compiler) {
- return QPointer<ExtraCompiler>(compiler);
- });
- m_projectUpdateInfo = projectUpdateInfo;
-
- using namespace ProjectExplorer;
-
- // Run the project info generator in a worker thread and continue if that one is finished.
- auto generateFuture = Utils::runAsync([=](QFutureInterface<ProjectInfo::ConstPtr> &futureInterface) {
- ProjectUpdateInfo fullProjectUpdateInfo = projectUpdateInfo;
- if (fullProjectUpdateInfo.rppGenerator)
- fullProjectUpdateInfo.rawProjectParts = fullProjectUpdateInfo.rppGenerator();
- Internal::ProjectInfoGenerator generator(futureInterface, fullProjectUpdateInfo);
- futureInterface.reportResult(generator.generate());
- });
- m_generateFutureWatcher.setFuture(generateFuture);
- m_futureSynchronizer.addFuture(generateFuture);
-
- // extra compilers
- for (QPointer<ExtraCompiler> compiler : qAsConst(m_extraCompilers)) {
- if (compiler->isDirty()) {
- auto watcher = new QFutureWatcher<void>;
- // queued connection to delay after the extra compiler updated its result contents,
- // which is also done in the main thread when compiler->run() finished
- connect(watcher, &QFutureWatcherBase::finished,
- this, [this, watcher] {
- m_projectUpdateFutureInterface->setProgressValue(
- m_projectUpdateFutureInterface->progressValue() + 1);
- m_extraCompilersFutureWatchers.remove(watcher);
- watcher->deleteLater();
- if (!watcher->isCanceled())
- checkForExtraCompilersFinished();
- },
- Qt::QueuedConnection);
- m_extraCompilersFutureWatchers += watcher;
- watcher->setFuture(QFuture<void>(compiler->run()));
- m_futureSynchronizer.addFuture(watcher->future());
- }
- }
-
- m_projectUpdateFutureInterface.reset(new QFutureInterface<void>);
- m_projectUpdateFutureInterface->setProgressRange(0, m_extraCompilersFutureWatchers.size()
- + 1 /*generateFuture*/);
- m_projectUpdateFutureInterface->setProgressValue(0);
- m_projectUpdateFutureInterface->reportStarted();
- Core::ProgressManager::addTask(m_projectUpdateFutureInterface->future(),
- tr("Preparing C++ Code Model"),
- "CppProjectUpdater");
-}
-
-void CppProjectUpdater::cancel()
-{
- if (m_projectUpdateFutureInterface && m_projectUpdateFutureInterface->isRunning())
- m_projectUpdateFutureInterface->reportFinished();
- m_generateFutureWatcher.setFuture({});
- m_isProjectInfoGenerated = false;
- qDeleteAll(m_extraCompilersFutureWatchers);
- m_extraCompilersFutureWatchers.clear();
- m_extraCompilers.clear();
- m_futureSynchronizer.cancelAllFutures();
-}
-
-void CppProjectUpdater::onProjectInfoGenerated()
-{
- if (m_generateFutureWatcher.isCanceled() || m_generateFutureWatcher.future().resultCount() < 1)
- return;
-
- m_projectUpdateFutureInterface->setProgressValue(m_projectUpdateFutureInterface->progressValue()
- + 1);
- m_isProjectInfoGenerated = true;
- checkForExtraCompilersFinished();
-}
-
-void CppProjectUpdater::checkForExtraCompilersFinished()
-{
- if (!m_extraCompilersFutureWatchers.isEmpty() || !m_isProjectInfoGenerated)
- return; // still need to wait
-
- m_projectUpdateFutureInterface->reportFinished();
- m_projectUpdateFutureInterface.reset();
-
- QList<ExtraCompiler *> extraCompilers;
- QSet<QString> compilerFiles;
- for (const QPointer<ExtraCompiler> &compiler : qAsConst(m_extraCompilers)) {
- if (compiler) {
- extraCompilers += compiler.data();
- compilerFiles += Utils::transform<QSet>(compiler->targets(), &Utils::FilePath::toString);
- }
- }
- GeneratedCodeModelSupport::update(extraCompilers);
- m_extraCompilers.clear();
-
- auto updateFuture = CppModelManager::instance()
- ->updateProjectInfo(m_generateFutureWatcher.result(), compilerFiles);
- m_futureSynchronizer.addFuture(updateFuture);
-}
-
-CppProjectUpdaterFactory::CppProjectUpdaterFactory()
-{
- setObjectName("CppProjectUpdaterFactory");
-}
-
-CppProjectUpdaterInterface *CppProjectUpdaterFactory::create()
-{
- return new CppProjectUpdater;
-}
-
-} // namespace CppTools