blob: 549088ad4a8a87b0d4e107149386af06fa162a6f [file] [log] [blame]
Saar Razfdf80e82019-12-06 01:30:21 +02001//===--- ASTConcept.cpp - Concepts Related AST Data Structures --*- C++ -*-===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9///
10/// \file
11/// \brief This file defines AST data structures related to concepts.
12///
13//===----------------------------------------------------------------------===//
14
15#include "clang/AST/ASTConcept.h"
16#include "clang/AST/ASTContext.h"
Saar Razbb9b9642020-01-22 04:06:51 +020017#include "clang/AST/Decl.h"
18#include "clang/AST/TemplateBase.h"
19#include "llvm/ADT/ArrayRef.h"
20#include "llvm/ADT/FoldingSet.h"
Saar Razfdf80e82019-12-06 01:30:21 +020021using namespace clang;
22
23ASTConstraintSatisfaction::ASTConstraintSatisfaction(const ASTContext &C,
24 const ConstraintSatisfaction &Satisfaction):
25 NumRecords{Satisfaction.Details.size()},
26 IsSatisfied{Satisfaction.IsSatisfied} {
27 for (unsigned I = 0; I < NumRecords; ++I) {
28 auto &Detail = Satisfaction.Details[I];
29 if (Detail.second.is<Expr *>())
30 new (getTrailingObjects<UnsatisfiedConstraintRecord>() + I)
31 UnsatisfiedConstraintRecord{Detail.first,
32 UnsatisfiedConstraintRecord::second_type(
33 Detail.second.get<Expr *>())};
34 else {
35 auto &SubstitutionDiagnostic =
Saar Raze7c24662019-12-06 01:53:18 +020036 *Detail.second.get<std::pair<SourceLocation, StringRef> *>();
Saar Razfdf80e82019-12-06 01:30:21 +020037 unsigned MessageSize = SubstitutionDiagnostic.second.size();
38 char *Mem = new (C) char[MessageSize];
Saar Raze7c24662019-12-06 01:53:18 +020039 memcpy(Mem, SubstitutionDiagnostic.second.data(), MessageSize);
Saar Razfdf80e82019-12-06 01:30:21 +020040 auto *NewSubstDiag = new (C) std::pair<SourceLocation, StringRef>(
41 SubstitutionDiagnostic.first, StringRef(Mem, MessageSize));
42 new (getTrailingObjects<UnsatisfiedConstraintRecord>() + I)
43 UnsatisfiedConstraintRecord{Detail.first,
44 UnsatisfiedConstraintRecord::second_type(
45 NewSubstDiag)};
46 }
47 }
48}
49
50
51ASTConstraintSatisfaction *
52ASTConstraintSatisfaction::Create(const ASTContext &C,
53 const ConstraintSatisfaction &Satisfaction) {
54 std::size_t size =
55 totalSizeToAlloc<UnsatisfiedConstraintRecord>(
56 Satisfaction.Details.size());
57 void *Mem = C.Allocate(size, alignof(ASTConstraintSatisfaction));
58 return new (Mem) ASTConstraintSatisfaction(C, Satisfaction);
59}
Saar Razb933d372020-01-22 02:50:12 +020060
61void ConstraintSatisfaction::Profile(
Saar Raz713562f2020-01-25 22:54:27 +020062 llvm::FoldingSetNodeID &ID, const ASTContext &C,
63 const NamedDecl *ConstraintOwner, ArrayRef<TemplateArgument> TemplateArgs) {
Saar Razb933d372020-01-22 02:50:12 +020064 ID.AddPointer(ConstraintOwner);
65 ID.AddInteger(TemplateArgs.size());
66 for (auto &Arg : TemplateArgs)
67 Arg.Profile(ID, C);
68}