diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2011-02-26 22:09:03 +0000 | 
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2011-02-26 22:09:03 +0000 | 
| commit | c3b054d250cdca485c71845089c316e10610ebad (patch) | |
| tree | abae0246ec9156cc1a7cbb947b2b0dfe95fa3189 /lib/Serialization | |
| parent | bca07a4524feb4edec581062d631a13116320a24 (diff) | |
Diffstat (limited to 'lib/Serialization')
| -rw-r--r-- | lib/Serialization/ASTReader.cpp | 128 | ||||
| -rw-r--r-- | lib/Serialization/ASTReaderDecl.cpp | 32 | ||||
| -rw-r--r-- | lib/Serialization/ASTReaderStmt.cpp | 20 | ||||
| -rw-r--r-- | lib/Serialization/ASTWriter.cpp | 71 | ||||
| -rw-r--r-- | lib/Serialization/ASTWriterDecl.cpp | 15 | ||||
| -rw-r--r-- | lib/Serialization/ASTWriterStmt.cpp | 6 | 
6 files changed, 216 insertions, 56 deletions
| diff --git a/lib/Serialization/ASTReader.cpp b/lib/Serialization/ASTReader.cpp index ce87b11c2695..c3953ba554dc 100644 --- a/lib/Serialization/ASTReader.cpp +++ b/lib/Serialization/ASTReader.cpp @@ -97,8 +97,9 @@ PCHValidator::ReadLanguageOptions(const LangOptions &LangOpts) {                            diag::warn_pch_lax_vector_conversions);    PARSE_LANGOPT_IMPORTANT(AltiVec, diag::warn_pch_altivec);    PARSE_LANGOPT_IMPORTANT(Exceptions, diag::warn_pch_exceptions); -  PARSE_LANGOPT_IMPORTANT(SjLjExceptions, diag::warn_pch_sjlj_exceptions);    PARSE_LANGOPT_IMPORTANT(ObjCExceptions, diag::warn_pch_objc_exceptions); +  PARSE_LANGOPT_IMPORTANT(CXXExceptions, diag::warn_pch_cxx_exceptions); +  PARSE_LANGOPT_IMPORTANT(SjLjExceptions, diag::warn_pch_sjlj_exceptions);    PARSE_LANGOPT_IMPORTANT(MSBitfields, diag::warn_pch_ms_bitfields);    PARSE_LANGOPT_IMPORTANT(NeXTRuntime, diag::warn_pch_objc_runtime);    PARSE_LANGOPT_IMPORTANT(Freestanding, diag::warn_pch_freestanding); @@ -243,14 +244,15 @@ FindMacro(const PCHPredefinesBlocks &Buffers, llvm::StringRef MacroDef) {  bool PCHValidator::ReadPredefinesBuffer(const PCHPredefinesBlocks &Buffers,                                          llvm::StringRef OriginalFileName, -                                        std::string &SuggestedPredefines) { +                                        std::string &SuggestedPredefines, +                                        FileManager &FileMgr) {    // We are in the context of an implicit include, so the predefines buffer will    // have a #include entry for the PCH file itself (as normalized by the    // preprocessor initialization). Find it and skip over it in the checking    // below.    llvm::SmallString<256> PCHInclude;    PCHInclude += "#include \""; -  PCHInclude += NormalizeDashIncludePath(OriginalFileName); +  PCHInclude += NormalizeDashIncludePath(OriginalFileName, FileMgr);    PCHInclude += "\"\n";    std::pair<llvm::StringRef,llvm::StringRef> Split =      llvm::StringRef(PP.getPredefines()).split(PCHInclude.str()); @@ -960,7 +962,8 @@ bool ASTReader::CheckPredefinesBuffers() {    if (Listener)      return Listener->ReadPredefinesBuffer(PCHPredefinesBuffers,                                            ActualOriginalFileName, -                                          SuggestedPredefines); +                                          SuggestedPredefines, +                                          FileMgr);    return false;  } @@ -2799,8 +2802,9 @@ bool ASTReader::ParseLanguageOptions(      PARSE_LANGOPT(LaxVectorConversions);      PARSE_LANGOPT(AltiVec);      PARSE_LANGOPT(Exceptions); -    PARSE_LANGOPT(SjLjExceptions);      PARSE_LANGOPT(ObjCExceptions); +    PARSE_LANGOPT(CXXExceptions); +    PARSE_LANGOPT(SjLjExceptions);      PARSE_LANGOPT(MSBitfields);      PARSE_LANGOPT(NeXTRuntime);      PARSE_LANGOPT(Freestanding); @@ -4476,8 +4480,7 @@ void ASTReader::ReadDeclarationNameInfo(PerFileData &F,  void ASTReader::ReadQualifierInfo(PerFileData &F, QualifierInfo &Info,                                    const RecordData &Record, unsigned &Idx) { -  Info.NNS = ReadNestedNameSpecifier(Record, Idx); -  Info.NNSRange = ReadSourceRange(F, Record, Idx); +  Info.QualifierLoc = ReadNestedNameSpecifierLoc(F, Record, Idx);    unsigned NumTPLists = Record[Idx++];    Info.NumTemplParamLists = NumTPLists;    if (NumTPLists) { @@ -4726,6 +4729,13 @@ ASTReader::ReadNestedNameSpecifier(const RecordData &Record, unsigned &Idx) {        break;      } +    case NestedNameSpecifier::NamespaceAlias: { +      NamespaceAliasDecl *Alias +        = cast<NamespaceAliasDecl>(GetDecl(Record[Idx++])); +      NNS = NestedNameSpecifier::Create(*Context, Prev, Alias); +      break; +    } +      case NestedNameSpecifier::TypeSpec:      case NestedNameSpecifier::TypeSpecWithTemplate: {        const Type *T = GetType(Record[Idx++]).getTypePtrOrNull(); @@ -4748,6 +4758,109 @@ ASTReader::ReadNestedNameSpecifier(const RecordData &Record, unsigned &Idx) {    return NNS;  } +NestedNameSpecifierLoc +ASTReader::ReadNestedNameSpecifierLoc(PerFileData &F, const RecordData &Record,  +                                      unsigned &Idx) { +  unsigned N = Record[Idx++]; +  NestedNameSpecifier *NNS = 0, *Prev = 0; +  llvm::SmallVector<char, 32> LocationData; +  for (unsigned I = 0; I != N; ++I) { +    NestedNameSpecifier::SpecifierKind Kind +      = (NestedNameSpecifier::SpecifierKind)Record[Idx++]; +    switch (Kind) { +    case NestedNameSpecifier::Identifier: { +      // Nested-name-specifier +      IdentifierInfo *II = GetIdentifierInfo(Record, Idx); +      NNS = NestedNameSpecifier::Create(*Context, Prev, II); +       +      // Location information +      SourceRange Range = ReadSourceRange(F, Record, Idx); +      unsigned RawStart = Range.getBegin().getRawEncoding(); +      unsigned RawEnd = Range.getEnd().getRawEncoding(); +      LocationData.append(reinterpret_cast<char*>(&RawStart), +                          reinterpret_cast<char*>(&RawStart) +sizeof(unsigned)); +      LocationData.append(reinterpret_cast<char*>(&RawEnd), +                          reinterpret_cast<char*>(&RawEnd) + sizeof(unsigned)); +      break; +    } + +    case NestedNameSpecifier::Namespace: { +      // Nested-name-specifier +      NamespaceDecl *NS = cast<NamespaceDecl>(GetDecl(Record[Idx++])); +      NNS = NestedNameSpecifier::Create(*Context, Prev, NS); + +      // Location information +      SourceRange Range = ReadSourceRange(F, Record, Idx); +      unsigned RawStart = Range.getBegin().getRawEncoding(); +      unsigned RawEnd = Range.getEnd().getRawEncoding(); +      LocationData.append(reinterpret_cast<char*>(&RawStart), +                          reinterpret_cast<char*>(&RawStart) +sizeof(unsigned)); +      LocationData.append(reinterpret_cast<char*>(&RawEnd), +                          reinterpret_cast<char*>(&RawEnd) + sizeof(unsigned)); +      break; +    } + +    case NestedNameSpecifier::NamespaceAlias: { +      // Nested-name-specifier +      NamespaceAliasDecl *Alias +        = cast<NamespaceAliasDecl>(GetDecl(Record[Idx++])); +      NNS = NestedNameSpecifier::Create(*Context, Prev, Alias); +       +      // Location information +      SourceRange Range = ReadSourceRange(F, Record, Idx); +      unsigned RawStart = Range.getBegin().getRawEncoding(); +      unsigned RawEnd = Range.getEnd().getRawEncoding(); +      LocationData.append(reinterpret_cast<char*>(&RawStart), +                          reinterpret_cast<char*>(&RawStart) +sizeof(unsigned)); +      LocationData.append(reinterpret_cast<char*>(&RawEnd), +                          reinterpret_cast<char*>(&RawEnd) + sizeof(unsigned)); + +      break; +    } + +    case NestedNameSpecifier::TypeSpec: +    case NestedNameSpecifier::TypeSpecWithTemplate: { +      // Nested-name-specifier +      bool Template = Record[Idx++]; +      TypeSourceInfo *T = GetTypeSourceInfo(F, Record, Idx); +      if (!T) +        return NestedNameSpecifierLoc(); +      NNS = NestedNameSpecifier::Create(*Context, Prev, Template,  +                                        T->getType().getTypePtr()); + +      // Location information. +      SourceLocation ColonColonLoc = ReadSourceLocation(F, Record, Idx); +      unsigned RawLocation = ColonColonLoc.getRawEncoding(); +      void *OpaqueTypeData = T->getTypeLoc().getOpaqueData(); +      LocationData.append(reinterpret_cast<char*>(&OpaqueTypeData), +                          (reinterpret_cast<char*>(&OpaqueTypeData)  +                             + sizeof(void *))); +      LocationData.append(reinterpret_cast<char*>(&RawLocation), +                          (reinterpret_cast<char*>(&RawLocation) + +                             sizeof(unsigned))); +      break; +    } + +    case NestedNameSpecifier::Global: { +      // Nested-name-specifier +      NNS = NestedNameSpecifier::GlobalSpecifier(*Context); + +      SourceLocation ColonColonLoc = ReadSourceLocation(F, Record, Idx); +      unsigned RawLocation = ColonColonLoc.getRawEncoding(); +      LocationData.append(reinterpret_cast<char*>(&RawLocation), +                          (reinterpret_cast<char*>(&RawLocation) + +                             sizeof(unsigned))); +      break; +    } +    } +    Prev = NNS; +  } +   +  void *Mem = Context->Allocate(LocationData.size(), llvm::alignOf<void*>()); +  memcpy(Mem, LocationData.data(), LocationData.size()); +  return NestedNameSpecifierLoc(NNS, Mem); +} +  SourceRange  ASTReader::ReadSourceRange(PerFileData &F, const RecordData &Record,                             unsigned &Idx) { @@ -4932,4 +5045,3 @@ ASTReader::PerFileData::~PerFileData() {    delete static_cast<HeaderFileInfoLookupTable *>(HeaderFileInfoTable);    delete static_cast<ASTSelectorLookupTable *>(SelectorLookupTable);  } - diff --git a/lib/Serialization/ASTReaderDecl.cpp b/lib/Serialization/ASTReaderDecl.cpp index dec15dd694f5..493ccbad8618 100644 --- a/lib/Serialization/ASTReaderDecl.cpp +++ b/lib/Serialization/ASTReaderDecl.cpp @@ -744,17 +744,15 @@ void ASTDeclReader::VisitNamespaceDecl(NamespaceDecl *D) {  void ASTDeclReader::VisitNamespaceAliasDecl(NamespaceAliasDecl *D) {    VisitNamedDecl(D);    D->NamespaceLoc = ReadSourceLocation(Record, Idx); -  D->setQualifierRange(ReadSourceRange(Record, Idx)); -  D->setQualifier(Reader.ReadNestedNameSpecifier(Record, Idx));    D->IdentLoc = ReadSourceLocation(Record, Idx); +  D->QualifierLoc = Reader.ReadNestedNameSpecifierLoc(F, Record, Idx);    D->Namespace = cast<NamedDecl>(Reader.GetDecl(Record[Idx++]));  }  void ASTDeclReader::VisitUsingDecl(UsingDecl *D) {    VisitNamedDecl(D);    D->setUsingLocation(ReadSourceLocation(Record, Idx)); -  D->setNestedNameRange(ReadSourceRange(Record, Idx)); -  D->setTargetNestedNameDecl(Reader.ReadNestedNameSpecifier(Record, Idx)); +  D->QualifierLoc = Reader.ReadNestedNameSpecifierLoc(F, Record, Idx);    ReadDeclarationNameLoc(D->DNLoc, D->getDeclName(), Record, Idx);    D->FirstUsingShadow = cast_or_null<UsingShadowDecl>(Reader.GetDecl(Record[Idx++]));    D->setTypeName(Record[Idx++]); @@ -777,27 +775,24 @@ void ASTDeclReader::VisitUsingDirectiveDecl(UsingDirectiveDecl *D) {    VisitNamedDecl(D);    D->UsingLoc = ReadSourceLocation(Record, Idx);    D->NamespaceLoc = ReadSourceLocation(Record, Idx); -  D->QualifierRange = ReadSourceRange(Record, Idx); -  D->Qualifier = Reader.ReadNestedNameSpecifier(Record, Idx); +  D->QualifierLoc = Reader.ReadNestedNameSpecifierLoc(F, Record, Idx);    D->NominatedNamespace = cast<NamedDecl>(Reader.GetDecl(Record[Idx++]));    D->CommonAncestor = cast_or_null<DeclContext>(Reader.GetDecl(Record[Idx++]));  }  void ASTDeclReader::VisitUnresolvedUsingValueDecl(UnresolvedUsingValueDecl *D) {    VisitValueDecl(D); -  D->setTargetNestedNameRange(ReadSourceRange(Record, Idx));    D->setUsingLoc(ReadSourceLocation(Record, Idx)); -  D->setTargetNestedNameSpecifier(Reader.ReadNestedNameSpecifier(Record, Idx)); +  D->QualifierLoc = Reader.ReadNestedNameSpecifierLoc(F, Record, Idx);    ReadDeclarationNameLoc(D->DNLoc, D->getDeclName(), Record, Idx);  }  void ASTDeclReader::VisitUnresolvedUsingTypenameDecl(                                                 UnresolvedUsingTypenameDecl *D) {    VisitTypeDecl(D); -  D->TargetNestedNameRange = ReadSourceRange(Record, Idx);    D->UsingLocation = ReadSourceLocation(Record, Idx);    D->TypenameLocation = ReadSourceLocation(Record, Idx); -  D->TargetNestedNameSpecifier = Reader.ReadNestedNameSpecifier(Record, Idx); +  D->QualifierLoc = Reader.ReadNestedNameSpecifierLoc(F, Record, Idx);  }  void ASTDeclReader::ReadCXXDefinitionData( @@ -1432,30 +1427,33 @@ Decl *ASTReader::ReadDeclRecord(unsigned Index, DeclID ID) {      break;    case DECL_NAMESPACE_ALIAS:      D = NamespaceAliasDecl::Create(*Context, 0, SourceLocation(), -                                   SourceLocation(), 0, SourceRange(), 0, +                                   SourceLocation(), 0,  +                                   NestedNameSpecifierLoc(),                                     SourceLocation(), 0);      break;    case DECL_USING: -    D = UsingDecl::Create(*Context, 0, SourceRange(), SourceLocation(), -                          0, DeclarationNameInfo(), false); +    D = UsingDecl::Create(*Context, 0, SourceLocation(), +                          NestedNameSpecifierLoc(), DeclarationNameInfo(),  +                          false);      break;    case DECL_USING_SHADOW:      D = UsingShadowDecl::Create(*Context, 0, SourceLocation(), 0, 0);      break;    case DECL_USING_DIRECTIVE:      D = UsingDirectiveDecl::Create(*Context, 0, SourceLocation(), -                                   SourceLocation(), SourceRange(), 0, +                                   SourceLocation(), NestedNameSpecifierLoc(),                                     SourceLocation(), 0, 0);      break;    case DECL_UNRESOLVED_USING_VALUE:      D = UnresolvedUsingValueDecl::Create(*Context, 0, SourceLocation(), -                                         SourceRange(), 0, +                                         NestedNameSpecifierLoc(),                                            DeclarationNameInfo());      break;    case DECL_UNRESOLVED_USING_TYPENAME:      D = UnresolvedUsingTypenameDecl::Create(*Context, 0, SourceLocation(), -                                            SourceLocation(), SourceRange(), -                                            0, SourceLocation(), +                                            SourceLocation(),  +                                            NestedNameSpecifierLoc(), +                                            SourceLocation(),                                              DeclarationName());      break;    case DECL_CXX_RECORD: diff --git a/lib/Serialization/ASTReaderStmt.cpp b/lib/Serialization/ASTReaderStmt.cpp index 4e91c989260d..42f0b1aacef3 100644 --- a/lib/Serialization/ASTReaderStmt.cpp +++ b/lib/Serialization/ASTReaderStmt.cpp @@ -1167,14 +1167,13 @@ void ASTStmtReader::VisitCXXDeleteExpr(CXXDeleteExpr *E) {  void ASTStmtReader::VisitCXXPseudoDestructorExpr(CXXPseudoDestructorExpr *E) {    VisitExpr(E); -  E->setBase(Reader.ReadSubExpr()); -  E->setArrow(Record[Idx++]); -  E->setOperatorLoc(ReadSourceLocation(Record, Idx)); -  E->setQualifier(Reader.ReadNestedNameSpecifier(Record, Idx)); -  E->setQualifierRange(ReadSourceRange(Record, Idx)); -  E->setScopeTypeInfo(GetTypeSourceInfo(Record, Idx)); -  E->setColonColonLoc(ReadSourceLocation(Record, Idx)); -  E->setTildeLoc(ReadSourceLocation(Record, Idx)); +  E->Base = Reader.ReadSubExpr(); +  E->IsArrow = Record[Idx++]; +  E->OperatorLoc = ReadSourceLocation(Record, Idx); +  E->QualifierLoc = Reader.ReadNestedNameSpecifierLoc(F, Record, Idx); +  E->ScopeType = GetTypeSourceInfo(Record, Idx); +  E->ColonColonLoc = ReadSourceLocation(Record, Idx); +  E->TildeLoc = ReadSourceLocation(Record, Idx);    IdentifierInfo *II = Reader.GetIdentifierInfo(Record, Idx);    if (II) @@ -1220,10 +1219,9 @@ ASTStmtReader::VisitDependentScopeDeclRefExpr(DependentScopeDeclRefExpr *E) {    if (Record[Idx++])      ReadExplicitTemplateArgumentList(E->getExplicitTemplateArgs(),                                        Record[Idx++]); -   + +  E->QualifierLoc = Reader.ReadNestedNameSpecifierLoc(F, Record, Idx);    ReadDeclarationNameInfo(E->NameInfo, Record, Idx); -  E->setQualifierRange(ReadSourceRange(Record, Idx)); -  E->setQualifier(Reader.ReadNestedNameSpecifier(Record, Idx));  }  void diff --git a/lib/Serialization/ASTWriter.cpp b/lib/Serialization/ASTWriter.cpp index 8fcb535a9c89..383ca3dffc6c 100644 --- a/lib/Serialization/ASTWriter.cpp +++ b/lib/Serialization/ASTWriter.cpp @@ -1023,8 +1023,9 @@ void ASTWriter::WriteLanguageOptions(const LangOptions &LangOpts) {    Record.push_back(LangOpts.LaxVectorConversions);    Record.push_back(LangOpts.AltiVec);    Record.push_back(LangOpts.Exceptions);  // Support exception handling. -  Record.push_back(LangOpts.SjLjExceptions);    Record.push_back(LangOpts.ObjCExceptions); +  Record.push_back(LangOpts.CXXExceptions); +  Record.push_back(LangOpts.SjLjExceptions);    Record.push_back(LangOpts.MSBitfields); // MS-compatible structure layout    Record.push_back(LangOpts.NeXTRuntime); // Use NeXT runtime. @@ -3275,15 +3276,21 @@ void ASTWriter::AddTemplateArgumentLoc(const TemplateArgumentLoc &Arg,                               Record);  } -void ASTWriter::AddTypeSourceInfo(TypeSourceInfo *TInfo, RecordDataImpl &Record) { +void ASTWriter::AddTypeSourceInfo(TypeSourceInfo *TInfo,  +                                  RecordDataImpl &Record) {    if (TInfo == 0) {      AddTypeRef(QualType(), Record);      return;    } -  AddTypeRef(TInfo->getType(), Record); +  AddTypeLoc(TInfo->getTypeLoc(), Record); +} + +void ASTWriter::AddTypeLoc(TypeLoc TL, RecordDataImpl &Record) { +  AddTypeRef(TL.getType(), Record); +    TypeLocWriter TLW(*this, Record); -  for (TypeLoc TL = TInfo->getTypeLoc(); !TL.isNull(); TL = TL.getNextTypeLoc()) +  for (; !TL.isNull(); TL = TL.getNextTypeLoc())      TLW.Visit(TL);  } @@ -3436,8 +3443,7 @@ void ASTWriter::AddDeclarationNameInfo(const DeclarationNameInfo &NameInfo,  void ASTWriter::AddQualifierInfo(const QualifierInfo &Info,                                   RecordDataImpl &Record) { -  AddNestedNameSpecifier(Info.NNS, Record); -  AddSourceRange(Info.NNSRange, Record); +  AddNestedNameSpecifierLoc(Info.QualifierLoc, Record);    Record.push_back(Info.NumTemplParamLists);    for (unsigned i=0, e=Info.NumTemplParamLists; i != e; ++i)      AddTemplateParameterList(Info.TemplParamLists[i], Record); @@ -3469,6 +3475,10 @@ void ASTWriter::AddNestedNameSpecifier(NestedNameSpecifier *NNS,        AddDeclRef(NNS->getAsNamespace(), Record);        break; +    case NestedNameSpecifier::NamespaceAlias: +      AddDeclRef(NNS->getAsNamespaceAlias(), Record); +      break; +      case NestedNameSpecifier::TypeSpec:      case NestedNameSpecifier::TypeSpecWithTemplate:        AddTypeRef(QualType(NNS->getAsType(), 0), Record); @@ -3482,6 +3492,55 @@ void ASTWriter::AddNestedNameSpecifier(NestedNameSpecifier *NNS,    }  } +void ASTWriter::AddNestedNameSpecifierLoc(NestedNameSpecifierLoc NNS, +                                          RecordDataImpl &Record) { +  // Nested name specifiers usually aren't too long. I think that 8 would +  // typically accomodate the vast majority. +  llvm::SmallVector<NestedNameSpecifierLoc , 8> NestedNames; + +  // Push each of the nested-name-specifiers's onto a stack for +  // serialization in reverse order. +  while (NNS) { +    NestedNames.push_back(NNS); +    NNS = NNS.getPrefix(); +  } + +  Record.push_back(NestedNames.size()); +  while(!NestedNames.empty()) { +    NNS = NestedNames.pop_back_val(); +    NestedNameSpecifier::SpecifierKind Kind +      = NNS.getNestedNameSpecifier()->getKind(); +    Record.push_back(Kind); +    switch (Kind) { +    case NestedNameSpecifier::Identifier: +      AddIdentifierRef(NNS.getNestedNameSpecifier()->getAsIdentifier(), Record); +      AddSourceRange(NNS.getLocalSourceRange(), Record); +      break; + +    case NestedNameSpecifier::Namespace: +      AddDeclRef(NNS.getNestedNameSpecifier()->getAsNamespace(), Record); +      AddSourceRange(NNS.getLocalSourceRange(), Record); +      break; + +    case NestedNameSpecifier::NamespaceAlias: +      AddDeclRef(NNS.getNestedNameSpecifier()->getAsNamespaceAlias(), Record); +      AddSourceRange(NNS.getLocalSourceRange(), Record); +      break; + +    case NestedNameSpecifier::TypeSpec: +    case NestedNameSpecifier::TypeSpecWithTemplate: +      Record.push_back(Kind == NestedNameSpecifier::TypeSpecWithTemplate); +      AddTypeLoc(NNS.getTypeLoc(), Record); +      AddSourceLocation(NNS.getLocalSourceRange().getEnd(), Record); +      break; + +    case NestedNameSpecifier::Global: +      AddSourceLocation(NNS.getLocalSourceRange().getEnd(), Record); +      break; +    } +  } +} +  void ASTWriter::AddTemplateName(TemplateName Name, RecordDataImpl &Record) {    TemplateName::NameKind Kind = Name.getKind();    Record.push_back(Kind); diff --git a/lib/Serialization/ASTWriterDecl.cpp b/lib/Serialization/ASTWriterDecl.cpp index ce07e1389b82..12d1226be94e 100644 --- a/lib/Serialization/ASTWriterDecl.cpp +++ b/lib/Serialization/ASTWriterDecl.cpp @@ -697,18 +697,16 @@ void ASTDeclWriter::VisitNamespaceDecl(NamespaceDecl *D) {  void ASTDeclWriter::VisitNamespaceAliasDecl(NamespaceAliasDecl *D) {    VisitNamedDecl(D);    Writer.AddSourceLocation(D->getNamespaceLoc(), Record); -  Writer.AddSourceRange(D->getQualifierRange(), Record); -  Writer.AddNestedNameSpecifier(D->getQualifier(), Record);    Writer.AddSourceLocation(D->getTargetNameLoc(), Record); +  Writer.AddNestedNameSpecifierLoc(D->getQualifierLoc(), Record);    Writer.AddDeclRef(D->getNamespace(), Record);    Code = serialization::DECL_NAMESPACE_ALIAS;  }  void ASTDeclWriter::VisitUsingDecl(UsingDecl *D) {    VisitNamedDecl(D); -  Writer.AddSourceRange(D->getNestedNameRange(), Record);    Writer.AddSourceLocation(D->getUsingLocation(), Record); -  Writer.AddNestedNameSpecifier(D->getTargetNestedNameDecl(), Record); +  Writer.AddNestedNameSpecifierLoc(D->getQualifierLoc(), Record);    Writer.AddDeclarationNameLoc(D->DNLoc, D->getDeclName(), Record);    Writer.AddDeclRef(D->FirstUsingShadow, Record);    Record.push_back(D->isTypeName()); @@ -728,8 +726,7 @@ void ASTDeclWriter::VisitUsingDirectiveDecl(UsingDirectiveDecl *D) {    VisitNamedDecl(D);    Writer.AddSourceLocation(D->getUsingLoc(), Record);    Writer.AddSourceLocation(D->getNamespaceKeyLocation(), Record); -  Writer.AddSourceRange(D->getQualifierRange(), Record); -  Writer.AddNestedNameSpecifier(D->getQualifier(), Record); +  Writer.AddNestedNameSpecifierLoc(D->getQualifierLoc(), Record);    Writer.AddDeclRef(D->getNominatedNamespace(), Record);    Writer.AddDeclRef(dyn_cast<Decl>(D->getCommonAncestor()), Record);    Code = serialization::DECL_USING_DIRECTIVE; @@ -737,9 +734,8 @@ void ASTDeclWriter::VisitUsingDirectiveDecl(UsingDirectiveDecl *D) {  void ASTDeclWriter::VisitUnresolvedUsingValueDecl(UnresolvedUsingValueDecl *D) {    VisitValueDecl(D); -  Writer.AddSourceRange(D->getTargetNestedNameRange(), Record);    Writer.AddSourceLocation(D->getUsingLoc(), Record); -  Writer.AddNestedNameSpecifier(D->getTargetNestedNameSpecifier(), Record); +  Writer.AddNestedNameSpecifierLoc(D->getQualifierLoc(), Record);    Writer.AddDeclarationNameLoc(D->DNLoc, D->getDeclName(), Record);    Code = serialization::DECL_UNRESOLVED_USING_VALUE;  } @@ -747,10 +743,9 @@ void ASTDeclWriter::VisitUnresolvedUsingValueDecl(UnresolvedUsingValueDecl *D) {  void ASTDeclWriter::VisitUnresolvedUsingTypenameDecl(                                                 UnresolvedUsingTypenameDecl *D) {    VisitTypeDecl(D); -  Writer.AddSourceRange(D->getTargetNestedNameRange(), Record);    Writer.AddSourceLocation(D->getUsingLoc(), Record);    Writer.AddSourceLocation(D->getTypenameLoc(), Record); -  Writer.AddNestedNameSpecifier(D->getTargetNestedNameSpecifier(), Record); +  Writer.AddNestedNameSpecifierLoc(D->getQualifierLoc(), Record);    Code = serialization::DECL_UNRESOLVED_USING_TYPENAME;  } diff --git a/lib/Serialization/ASTWriterStmt.cpp b/lib/Serialization/ASTWriterStmt.cpp index 8a5ffe96db17..af846a92800c 100644 --- a/lib/Serialization/ASTWriterStmt.cpp +++ b/lib/Serialization/ASTWriterStmt.cpp @@ -1150,8 +1150,7 @@ void ASTStmtWriter::VisitCXXPseudoDestructorExpr(CXXPseudoDestructorExpr *E) {    Writer.AddStmt(E->getBase());    Record.push_back(E->isArrow());    Writer.AddSourceLocation(E->getOperatorLoc(), Record); -  Writer.AddNestedNameSpecifier(E->getQualifier(), Record); -  Writer.AddSourceRange(E->getQualifierRange(), Record); +  Writer.AddNestedNameSpecifierLoc(E->getQualifierLoc(), Record);    Writer.AddTypeSourceInfo(E->getScopeTypeInfo(), Record);    Writer.AddSourceLocation(E->getColonColonLoc(), Record);    Writer.AddSourceLocation(E->getTildeLoc(), Record); @@ -1217,9 +1216,8 @@ ASTStmtWriter::VisitDependentScopeDeclRefExpr(DependentScopeDeclRefExpr *E) {      AddExplicitTemplateArgumentList(Args);    } +  Writer.AddNestedNameSpecifierLoc(E->getQualifierLoc(), Record);    Writer.AddDeclarationNameInfo(E->NameInfo, Record); -  Writer.AddSourceRange(E->getQualifierRange(), Record); -  Writer.AddNestedNameSpecifier(E->getQualifier(), Record);    Code = serialization::EXPR_CXX_DEPENDENT_SCOPE_DECL_REF;  } | 
