/**************************************************************************** ** ** 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 "dynamicmatcherdiagnostics.h" #include "sourcerangecontainerv2.h" #include namespace ClangBackEnd { class DynamicASTMatcherDiagnosticContextContainer { public: DynamicASTMatcherDiagnosticContextContainer() = default; DynamicASTMatcherDiagnosticContextContainer(V2::SourceRangeContainer &&sourceRange, ClangQueryDiagnosticContextType contextType, Utils::SmallStringVector &&arguments) : sourceRange(sourceRange), contextType(contextType), arguments(std::move(arguments)) { } CLANGSUPPORT_EXPORT Utils::SmallString contextTypeText() const; friend QDataStream &operator<<(QDataStream &out, const DynamicASTMatcherDiagnosticContextContainer &container) { out << container.sourceRange; out << quint32(container.contextType); out << container.arguments; return out; } friend QDataStream &operator>>(QDataStream &in, DynamicASTMatcherDiagnosticContextContainer &container) { quint32 contextType; in >> container.sourceRange; in >> contextType; in >> container.arguments; container.contextType = static_cast(contextType); return in; } friend bool operator==(const DynamicASTMatcherDiagnosticContextContainer &first, const DynamicASTMatcherDiagnosticContextContainer &second) { return first.contextType == second.contextType && first.sourceRange == second.sourceRange && first.arguments == second.arguments; } DynamicASTMatcherDiagnosticContextContainer clone() const { return DynamicASTMatcherDiagnosticContextContainer(sourceRange.clone(), contextType, arguments.clone()); } public: V2::SourceRangeContainer sourceRange; ClangQueryDiagnosticContextType contextType = ClangQueryDiagnosticContextType::MatcherArg; Utils::SmallStringVector arguments; }; using DynamicASTMatcherDiagnosticContextContainers = std::vector; CLANGSUPPORT_EXPORT QDebug operator<<(QDebug debug, const DynamicASTMatcherDiagnosticContextContainer &container); } // namespace ClangBackEnd