/**************************************************************************** ** ** 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 "cmakeprojectnodes.h" #include "cmakeprojectconstants.h" #include "cmakeprojectplugin.h" #include #include #include #include #include #include #include #include #include #include #include using namespace CMakeProjectManager; using namespace CMakeProjectManager::Internal; namespace { void copySourcePathToClipboard(Utils::optional srcPath, const ProjectExplorer::ProjectNode *node) { QClipboard *clip = QGuiApplication::clipboard(); QDir projDir{node->filePath().toFileInfo().absoluteFilePath()}; clip->setText(QDir::cleanPath(projDir.relativeFilePath(srcPath.value()))); } void noAutoAdditionNotify(const QStringList &filePaths, const ProjectExplorer::ProjectNode *node) { Utils::optional srcPath{}; for (const QString &file : filePaths) { if (Utils::mimeTypeForFile(file).name() == CppTools::Constants::CPP_SOURCE_MIMETYPE) { srcPath = file; break; } } if (srcPath) { CMakeSpecificSettings *settings = CMakeProjectPlugin::projectTypeSpecificSettings(); switch (settings->afterAddFileSetting()) { case CMakeProjectManager::Internal::ASK_USER: { bool checkValue{false}; QDialogButtonBox::StandardButton reply = Utils::CheckableMessageBox::question(nullptr, QMessageBox::tr("Copy to Clipboard?"), QMessageBox::tr("Files are not automatically added to the " "CMakeLists.txt file of the CMake project." "\nCopy the path to the source files to the clipboard?"), "Remember My Choice", &checkValue, QDialogButtonBox::Yes | QDialogButtonBox::No, QDialogButtonBox::Yes); if (true == checkValue) { if (QDialogButtonBox::Yes == reply) settings->setAfterAddFileSetting(AfterAddFileAction::COPY_FILE_PATH); else if (QDialogButtonBox::No == reply) settings->setAfterAddFileSetting(AfterAddFileAction::NEVER_COPY_FILE_PATH); settings->toSettings(Core::ICore::settings()); } if (QDialogButtonBox::Yes == reply) { copySourcePathToClipboard(srcPath, node); } break; } case CMakeProjectManager::Internal::COPY_FILE_PATH: { copySourcePathToClipboard(srcPath, node); break; } case CMakeProjectManager::Internal::NEVER_COPY_FILE_PATH: break; } } } } CMakeInputsNode::CMakeInputsNode(const Utils::FileName &cmakeLists) : ProjectExplorer::ProjectNode(cmakeLists, generateId(cmakeLists)) { setPriority(Node::DefaultPriority - 10); // Bottom most! setDisplayName(QCoreApplication::translate("CMakeFilesProjectNode", "CMake Modules")); setIcon(QIcon(":/projectexplorer/images/session.png")); // TODO: Use a better icon! setListInProject(false); } QByteArray CMakeInputsNode::generateId(const Utils::FileName &inputFile) { return inputFile.toString().toUtf8() + "/cmakeInputs"; } bool CMakeInputsNode::showInSimpleTree() const { return true; } CMakeListsNode::CMakeListsNode(const Utils::FileName &cmakeListPath) : ProjectExplorer::ProjectNode(cmakeListPath) { static QIcon folderIcon = Core::FileIconProvider::directoryIcon(Constants::FILEOVERLAY_CMAKE); setIcon(folderIcon); setListInProject(false); } bool CMakeListsNode::showInSimpleTree() const { return false; } bool CMakeListsNode::supportsAction(ProjectExplorer::ProjectAction action, const ProjectExplorer::Node *) const { return action == ProjectExplorer::ProjectAction::AddNewFile; } Utils::optional CMakeListsNode::visibleAfterAddFileAction() const { Utils::FileName projFile{filePath()}; return projFile.appendPath("CMakeLists.txt"); } CMakeProjectNode::CMakeProjectNode(const Utils::FileName &directory) : ProjectExplorer::ProjectNode(directory) { setPriority(Node::DefaultProjectPriority + 1000); setIcon(QIcon(":/projectexplorer/images/projectexplorer.png")); // TODO: Use proper icon! setListInProject(false); } bool CMakeProjectNode::showInSimpleTree() const { return true; } QString CMakeProjectNode::tooltip() const { return QString(); } bool CMakeProjectNode::addFiles(const QStringList &filePaths, QStringList *) { noAutoAdditionNotify(filePaths, this); return true; // Return always true as autoadd is not supported! } CMakeTargetNode::CMakeTargetNode(const Utils::FileName &directory, const QString &target) : ProjectExplorer::ProjectNode(directory, generateId(directory, target)) { setPriority(Node::DefaultProjectPriority + 900); setIcon(QIcon(":/projectexplorer/images/build.png")); // TODO: Use proper icon! setListInProject(false); } QByteArray CMakeTargetNode::generateId(const Utils::FileName &directory, const QString &target) { return directory.toString().toUtf8() + "///::///" + target.toUtf8(); } bool CMakeTargetNode::showInSimpleTree() const { return true; } QString CMakeTargetNode::tooltip() const { return m_tooltip; } QString CMakeTargetNode::buildKey() const { return QString::fromUtf8(id()); } bool CMakeTargetNode::supportsAction(ProjectExplorer::ProjectAction action, const ProjectExplorer::Node *) const { return action == ProjectExplorer::ProjectAction::AddNewFile; } bool CMakeTargetNode::addFiles(const QStringList &filePaths, QStringList *) { noAutoAdditionNotify(filePaths, this); return true; // Return always true as autoadd is not supported! } Utils::optional CMakeTargetNode::visibleAfterAddFileAction() const { Utils::FileName projFile{filePath()}; return projFile.appendPath("CMakeLists.txt"); } void CMakeTargetNode::setTargetInformation(const QList &artifacts, const QString &type) { m_tooltip = QCoreApplication::translate("CMakeTargetNode", "Target type: ") + type + "
"; if (artifacts.isEmpty()) { m_tooltip += QCoreApplication::translate("CMakeTargetNode", "No build artifacts"); } else { const QStringList tmp = Utils::transform(artifacts, &Utils::FileName::toUserOutput); m_tooltip += QCoreApplication::translate("CMakeTargetNode", "Build artifacts:") + "
" + tmp.join("
"); } }