/**************************************************************************** ** ** 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. ** ****************************************************************************/ #include "clangtool.h" #include #include namespace ClangBackEnd { namespace { // use std::filesystem::path if it is supported by all compilers template String toNativePath(String &&path) { #ifdef _WIN32 std::replace(path.begin(), path.end(), '/', '\\'); #endif return std::move(path); } } void ClangTool::addFile(FilePath &&filePath, Utils::SmallString &&content, Utils::SmallStringVector &&commandLine) { NativeFilePath nativeFilePath{filePath}; m_compilationDatabase.addFile(nativeFilePath, std::move(commandLine)); m_sourceFilePaths.push_back(Utils::SmallStringView{nativeFilePath}); m_fileContents.emplace_back(std::move(nativeFilePath), std::move(content)); } void ClangTool::addFiles(const FilePaths &filePaths, const Utils::SmallStringVector &arguments) { for (const FilePath &filePath : filePaths) { std::string filePathStr(filePath.path()); auto commandLine = arguments; NativeFilePath nativeFilePath{filePath}; commandLine.push_back(nativeFilePath.path()); addFile(filePath.clone(), {}, std::move(commandLine)); } } void ClangTool::addUnsavedFiles(const V2::FileContainers &unsavedFiles) { m_unsavedFileContents.reserve(m_unsavedFileContents.size() + unsavedFiles.size()); auto convertToUnsavedFileContent = [](const V2::FileContainer &unsavedFile) { return UnsavedFileContent{NativeFilePath{unsavedFile.filePath}, unsavedFile.unsavedFileContent.clone()}; }; std::transform(unsavedFiles.begin(), unsavedFiles.end(), std::back_inserter(m_unsavedFileContents), convertToUnsavedFileContent); } namespace { template llvm::StringRef toStringRef(const String &string) { return llvm::StringRef(string.data(), string.size()); } llvm::StringRef toStringRef(const NativeFilePath &path) { return llvm::StringRef(path.path().data(), path.path().size()); } } // namespace clang::tooling::ClangTool ClangTool::createTool() const { clang::tooling::ClangTool tool(m_compilationDatabase, m_sourceFilePaths); for (const auto &fileContent : m_fileContents) { if (!fileContent.content.empty()) tool.mapVirtualFile(toStringRef(fileContent.filePath), fileContent.content); } for (const auto &unsavedFileContent : m_unsavedFileContents) tool.mapVirtualFile(toStringRef(unsavedFileContent.filePath), toStringRef(unsavedFileContent.content)); tool.mapVirtualFile("/dummyFile", "#pragma once"); return tool; } clang::tooling::ClangTool ClangTool::createOutputTool() const { clang::tooling::ClangTool tool = createTool(); tool.clearArgumentsAdjusters(); return tool; } bool ClangTool::isClean() const { return m_sourceFilePaths.empty() && m_fileContents.empty() && m_compilationDatabase.getAllFiles().empty() && m_unsavedFileContents.empty(); } } // namespace ClangBackEnd