/**************************************************************************** ** ** Copyright (C) 2018 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 "clangtool.h" #include "clangselectablefilesdialog.h" #include "clangtoolsconstants.h" #include "clangtoolsdiagnostic.h" #include "clangtoolsdiagnosticmodel.h" #include "clangtoolsutils.h" #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include using namespace Core; using namespace Debugger; using namespace ProjectExplorer; using namespace Utils; namespace ClangTools { namespace Internal { static FileInfos sortedFileInfos(const QVector &projectParts) { FileInfos fileInfos; for (CppTools::ProjectPart::Ptr projectPart : projectParts) { QTC_ASSERT(projectPart, continue); if (!projectPart->selectedForBuilding) continue; for (const CppTools::ProjectFile &file : projectPart->files) { QTC_ASSERT(file.kind != CppTools::ProjectFile::Unclassified, continue); QTC_ASSERT(file.kind != CppTools::ProjectFile::Unsupported, continue); if (file.path == CppTools::CppModelManager::configurationFileName()) continue; if (CppTools::ProjectFile::isSource(file.kind)) { const FileInfo info{Utils::FileName::fromString(file.path), file.kind, projectPart}; fileInfos.append(info); } } } Utils::sort(fileInfos, &FileInfo::file); return fileInfos; } ClangTool::ClangTool(const QString &name) : m_name(name) { m_diagnosticModel = new ClangToolsDiagnosticModel(this); m_startAction = Debugger::createStartAction(); m_stopAction = Debugger::createStopAction(); } FileInfos ClangTool::collectFileInfos(Project *project, bool askUserForFileSelection) const { auto projectInfo = CppTools::CppModelManager::instance()->projectInfo(project); QTC_ASSERT(projectInfo.isValid(), return FileInfos()); const FileInfos allFileInfos = sortedFileInfos(projectInfo.projectParts()); if (askUserForFileSelection) { SelectableFilesDialog dialog(projectInfo, allFileInfos); if (dialog.exec() == QDialog::Rejected) return FileInfos(); return dialog.filteredFileInfos(); } else { return allFileInfos; } } const QString &ClangTool::name() const { return m_name; } void ClangTool::initDiagnosticView() { m_diagnosticView->setFrameStyle(QFrame::NoFrame); m_diagnosticView->setAttribute(Qt::WA_MacShowFocusRect, false); m_diagnosticView->setVerticalScrollMode(QAbstractItemView::ScrollPerPixel); m_diagnosticView->setAutoScroll(false); } QList ClangTool::diagnostics() const { return m_diagnosticModel->diagnostics(); } void ClangTool::onNewDiagnosticsAvailable(const QList &diagnostics) { QTC_ASSERT(m_diagnosticModel, return); m_diagnosticModel->addDiagnostics(diagnostics); } void ClangTool::setToolBusy(bool busy) { QTC_ASSERT(m_diagnosticView, return); QCursor cursor(busy ? Qt::BusyCursor : Qt::ArrowCursor); m_diagnosticView->setCursor(cursor); m_toolBusy = busy; } } // namespace Internal } // namespace ClangTools