/**************************************************************************** ** ** Copyright (C) 2016 The Qt Company Ltd. ** Contact: https://www.qt.io/licensing/ ** ** This file is part of Qbs. ** ** $QT_BEGIN_LICENSE:LGPL$ ** 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 Lesser General Public License Usage ** Alternatively, this file may be used under the terms of the GNU Lesser ** General Public License version 3 as published by the Free Software ** Foundation and appearing in the file LICENSE.LGPL3 included in the ** packaging of this file. Please review the following information to ** ensure the GNU Lesser General Public License version 3 requirements ** will be met: https://www.gnu.org/licenses/lgpl-3.0.html. ** ** GNU General Public License Usage ** Alternatively, this file may be used under the terms of the GNU ** General Public License version 2.0 or (at your option) the GNU General ** Public license version 3 or any later version approved by the KDE Free ** Qt Foundation. The licenses are as published by the Free Software ** Foundation and appearing in the file LICENSE.GPL2 and LICENSE.GPL3 ** 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-2.0.html and ** https://www.gnu.org/licenses/gpl-3.0.html. ** ** $QT_END_LICENSE$ ** ****************************************************************************/ #include "artifact.h" #include "transformer.h" #include "buildgraphvisitor.h" #include "productbuilddata.h" #include #include #include #include namespace qbs { namespace Internal { Artifact::Artifact() { initialize(); } Artifact::~Artifact() { for (Artifact *p : parentArtifacts()) p->childrenAddedByScanner.remove(this); } void Artifact::accept(BuildGraphVisitor *visitor) { if (visitor->visit(this)) acceptChildren(visitor); visitor->endVisit(this); } QString Artifact::toString() const { return QLatin1String("ARTIFACT ") + filePath() + QLatin1String(" [") + (!product.expired() ? product->name : QLatin1String("")) + QLatin1Char(']'); } void Artifact::addFileTag(const FileTag &t) { m_fileTags += t; if (!product.expired() && product->buildData) product->buildData->addFileTagToArtifact(this, t); } void Artifact::removeFileTag(const FileTag &t) { m_fileTags -= t; if (!product.expired() && product->buildData) product->buildData->removeArtifactFromSetByFileTag(this, t); } void Artifact::setFileTags(const FileTags &newFileTags) { if (product.expired() || !product->buildData) { m_fileTags = newFileTags; return; } for (const FileTag &t : qAsConst(m_fileTags)) product->buildData->removeArtifactFromSetByFileTag(this, t); m_fileTags = newFileTags; product->buildData->addArtifactToSet(this); } void Artifact::initialize() { artifactType = Unknown; inputsScanned = false; timestampRetrieved = false; alwaysUpdated = true; oldDataPossiblyPresent = true; } const TypeFilter Artifact::parentArtifacts() const { return TypeFilter(parents); } const TypeFilter Artifact::childArtifacts() const { return TypeFilter(children); } void Artifact::onChildDisconnected(BuildGraphNode *child) { if (child->type() != BuildGraphNode::ArtifactNodeType) return; childrenAddedByScanner.remove(static_cast(child)); } void Artifact::load(PersistentPool &pool) { FileResourceBase::load(pool); BuildGraphNode::load(pool); children.load(pool); // restore parents of the loaded children for (NodeSet::const_iterator it = children.constBegin(); it != children.constEnd(); ++it) (*it)->parents.insert(this); pool.load(childrenAddedByScanner); pool.load(fileDependencies); pool.load(properties); pool.load(targetOfModule); pool.load(transformer); pool.load(m_fileTags); artifactType = static_cast(pool.load()); alwaysUpdated = pool.load(); oldDataPossiblyPresent = pool.load(); pool.load(knownOutOfDate); } void Artifact::store(PersistentPool &pool) { FileResourceBase::store(pool); BuildGraphNode::store(pool); // Do not store parents to avoid recursion. children.store(pool); pool.store(childrenAddedByScanner); pool.store(fileDependencies); pool.store(properties); pool.store(targetOfModule); pool.store(transformer); pool.store(m_fileTags); pool.store(static_cast(artifactType)); pool.store(alwaysUpdated); pool.store(oldDataPossiblyPresent); pool.store(knownOutOfDate); } } // namespace Internal } // namespace qbs