diff options
| author | Douglas Gregor <dgregor@apple.com> | 2011-01-14 17:04:44 +0000 | 
|---|---|---|
| committer | Douglas Gregor <dgregor@apple.com> | 2011-01-14 17:04:44 +0000 | 
| commit | 0dca5fdb4e039d0ae341814b7e5b2043a72acec0 (patch) | |
| tree | 716b3e1597625d5cb20835250654524b805b836b /clang/lib/Serialization | |
| parent | b1ebba9ec3d07e13227e3637948643092e8eb4ae (diff) | |
| download | bcm5719-llvm-0dca5fdb4e039d0ae341814b7e5b2043a72acec0.tar.gz bcm5719-llvm-0dca5fdb4e039d0ae341814b7e5b2043a72acec0.zip | |
Keep track of the number of expansions to be produced from a type pack
expansion, when it is known due to the substitution of an out
parameter pack. This allows us to properly handle substitution into
pack expansions that involve multiple parameter packs at different
template parameter levels, even when this substitution happens one
level at a time (as with partial specializations of member class
templates and the signatures of member function templates).
Note that the diagnostic we provide when there is an arity mismatch
between an outer parameter pack and an inner parameter pack in this
case isn't as clear as the normal diagnostic for an arity
mismatch. However, this doesn't matter because these cases are very,
very rare and (even then) only typically occur in a SFINAE context.
The other kinds of pack expansions (expression, template, etc.) still
need to support optional tracking of the number of expansions, and we
need the moral equivalent of SubstTemplateTypeParmPackType for
substituted argument packs of template template and non-type template
parameters.
llvm-svn: 123448
Diffstat (limited to 'clang/lib/Serialization')
| -rw-r--r-- | clang/lib/Serialization/ASTReader.cpp | 6 | ||||
| -rw-r--r-- | clang/lib/Serialization/ASTWriter.cpp | 4 | 
2 files changed, 8 insertions, 2 deletions
| diff --git a/clang/lib/Serialization/ASTReader.cpp b/clang/lib/Serialization/ASTReader.cpp index edb79ee808d..e7a3b0aebb0 100644 --- a/clang/lib/Serialization/ASTReader.cpp +++ b/clang/lib/Serialization/ASTReader.cpp @@ -2954,8 +2954,10 @@ QualType ASTReader::ReadTypeRecord(unsigned Index) {      QualType Pattern = GetType(Record[0]);      if (Pattern.isNull())        return QualType(); - -    return Context->getPackExpansionType(Pattern); +    llvm::Optional<unsigned> NumExpansions; +    if (Record[1]) +      NumExpansions = Record[1] - 1; +    return Context->getPackExpansionType(Pattern, NumExpansions);    }    case TYPE_ELABORATED: { diff --git a/clang/lib/Serialization/ASTWriter.cpp b/clang/lib/Serialization/ASTWriter.cpp index 52cf3829dc9..7582d1a4502 100644 --- a/clang/lib/Serialization/ASTWriter.cpp +++ b/clang/lib/Serialization/ASTWriter.cpp @@ -316,6 +316,10 @@ ASTTypeWriter::VisitDependentTemplateSpecializationType(  void ASTTypeWriter::VisitPackExpansionType(const PackExpansionType *T) {    Writer.AddTypeRef(T->getPattern(), Record); +  if (llvm::Optional<unsigned> NumExpansions = T->getNumExpansions()) +    Record.push_back(*NumExpansions + 1); +  else +    Record.push_back(0);    Code = TYPE_PACK_EXPANSION;  } | 

