/**************************************************************************** ** ** Copyright (C) 2015 The Qt Company Ltd. ** Contact: http://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 Digia. For licensing terms and ** conditions see http://www.qt.io/licensing. For further information ** use the contact form at http://www.qt.io/contact-us. ** ** GNU Lesser General Public License Usage ** Alternatively, this file may be used under the terms of the GNU Lesser ** General Public License version 2.1 or version 3 as published by the Free ** Software Foundation and appearing in the file LICENSE.LGPLv21 and ** LICENSE.LGPLv3 included in the packaging of this file. Please review the ** following information to ensure the GNU Lesser General Public License ** requirements will be met: https://www.gnu.org/licenses/lgpl.html and ** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. ** ** In addition, as a special exception, Digia gives you certain additional ** rights. These rights are described in the Digia Qt LGPL Exception ** version 1.1, included in the file LGPL_EXCEPTION.txt in this package. ** ****************************************************************************/ #include "projects.h" #include #include "projectpartsdonotexistexception.h" namespace ClangBackEnd { void ProjectParts::createOrUpdate(const QVector &projectContainers) { for (const ProjectPartContainer &projectContainer : projectContainers) createOrUpdateProjectPart(projectContainer); } void ProjectParts::remove(const Utf8StringVector &projectPartIds) { Utf8StringVector processedProjectPartFilePaths = projectPartIds; auto removeBeginIterator = std::remove_if(projects_.begin(), projects_.end(), [&processedProjectPartFilePaths] (const ProjectPart &project) { return processedProjectPartFilePaths.removeFast(project.projectPartId()); }); std::for_each(removeBeginIterator, projects_.end(), [](ProjectPart &project) { project.clearProjectPartId(); }); projects_.erase(removeBeginIterator, projects_.end()); if (!processedProjectPartFilePaths.isEmpty()) throw ProjectPartDoNotExistException(processedProjectPartFilePaths); } bool ProjectParts::hasProjectPart(const Utf8String &projectPartId) const { return findProjectPart(projectPartId) != projects_.cend(); } const ProjectPart &ProjectParts::project(const Utf8String &projectPartId) const { const auto findIterator = findProjectPart(projectPartId); if (findIterator == projects_.cend()) throw ProjectPartDoNotExistException({projectPartId}); return *findIterator; } std::vector::const_iterator ProjectParts::findProjectPart(const Utf8String &projectPartId) const { return std::find_if(projects_.begin(), projects_.end(), [projectPartId] (const ProjectPart &project) { return project.projectPartId() == projectPartId; }); } std::vector::iterator ProjectParts::findProjectPart(const Utf8String &projectPartId) { return std::find_if(projects_.begin(), projects_.end(), [projectPartId] (const ProjectPart &project) { return project.projectPartId() == projectPartId; }); } const std::vector &ProjectParts::projects() const { return projects_; } void ProjectParts::createOrUpdateProjectPart(const ProjectPartContainer &projectContainer) { auto findIterator = findProjectPart(projectContainer.projectPartId()); if (findIterator == projects_.cend()) projects_.push_back(ProjectPart(projectContainer)); else findIterator->setArguments(projectContainer.arguments()); } } // namespace ClangBackEnd