/**************************************************************************** ** ** Copyright (C) 2016 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. ** ****************************************************************************/ #pragma once #include #include #include #include #include QT_BEGIN_NAMESPACE class QTextBlock; QT_END_NAMESPACE namespace CppTools { class ClangDiagnosticConfig; class CppEditorDocumentHandle; } namespace ClangBackEnd { class TokenInfoContainer; } namespace ProjectExplorer { class Project; } namespace ClangCodeModel { namespace Internal { CppTools::CppEditorDocumentHandle *cppDocument(const QString &filePath); void setLastSentDocumentRevision(const QString &filePath, uint revision); CppTools::ClangDiagnosticConfig warningsConfigForProject(ProjectExplorer::Project *project); const QStringList optionsForProject(ProjectExplorer::Project *project); QStringList createClangOptions(const CppTools::ProjectPart &projectPart, const QString &filePath, const CppTools::ClangDiagnosticConfig &warningsConfig, const QStringList &projectOptions); CppTools::ProjectPart::Ptr projectPartForFile(const QString &filePath); CppTools::ProjectPart::Ptr projectPartForFileBasedOnProcessor(const QString &filePath); bool isProjectPartLoaded(const CppTools::ProjectPart::Ptr projectPart); QString projectPartIdForFile(const QString &filePath); int clangColumn(const QTextBlock &line, int cppEditorColumn); int cppEditorColumn(const QTextBlock &line, int clangColumn); QString currentCppEditorDocumentFilePath(); QString diagnosticCategoryPrefixRemoved(const QString &text); Utils::CodeModelIcon::Type iconTypeForToken(const ClangBackEnd::TokenInfoContainer &token); class GenerateCompilationDbResult { public: GenerateCompilationDbResult() = default; GenerateCompilationDbResult(const QString &filePath, const QString &error) : filePath(filePath), error(error) {} QString filePath; QString error; }; enum class CompilationDbPurpose { Project, CodeModel }; GenerateCompilationDbResult generateCompilationDB(const CppTools::ProjectInfo::Ptr projectInfo, CompilationDbPurpose purpose, const CppTools::ClangDiagnosticConfig &warningsConfig, const QStringList &projectOptions); class DiagnosticTextInfo { public: DiagnosticTextInfo(const QString &text); QString textWithoutOption() const; QString option() const; QString category() const; static bool isClazyOption(const QString &option); static QString clazyCheckName(const QString &option); private: const QString m_text; const int m_squareBracketStartIndex; }; template void moveToPreviousChar(CharacterProvider &provider, QTextCursor &cursor) { cursor.movePosition(QTextCursor::PreviousCharacter); while (provider.characterAt(cursor.position()).isSpace()) cursor.movePosition(QTextCursor::PreviousCharacter); } template void moveToPreviousWord(CharacterProvider &provider, QTextCursor &cursor) { cursor.movePosition(QTextCursor::PreviousWord); while (provider.characterAt(cursor.position()) == ':') cursor.movePosition(QTextCursor::PreviousWord, QTextCursor::MoveAnchor, 2); } template bool matchPreviousWord(CharacterProvider &provider, QTextCursor cursor, QString pattern) { cursor.movePosition(QTextCursor::PreviousWord); while (provider.characterAt(cursor.position()) == ':') cursor.movePosition(QTextCursor::PreviousWord, QTextCursor::MoveAnchor, 2); int previousWordStart = cursor.position(); cursor.movePosition(QTextCursor::NextWord); moveToPreviousChar(provider, cursor); QString toMatch = provider.textAt(previousWordStart, cursor.position() - previousWordStart + 1); pattern = pattern.simplified(); while (!pattern.isEmpty() && pattern.endsWith(toMatch)) { pattern.chop(toMatch.length()); if (pattern.endsWith(' ')) pattern.chop(1); if (!pattern.isEmpty()) { cursor.movePosition(QTextCursor::StartOfWord); cursor.movePosition(QTextCursor::PreviousWord); previousWordStart = cursor.position(); cursor.movePosition(QTextCursor::NextWord); moveToPreviousChar(provider, cursor); toMatch = provider.textAt(previousWordStart, cursor.position() - previousWordStart + 1); } } return pattern.isEmpty(); } } // namespace Internal } // namespace Clang