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/Sema/SemaDeclCXX.cpp | |
| parent | bca07a4524feb4edec581062d631a13116320a24 (diff) | |
Diffstat (limited to 'lib/Sema/SemaDeclCXX.cpp')
| -rw-r--r-- | lib/Sema/SemaDeclCXX.cpp | 54 | 
1 files changed, 26 insertions, 28 deletions
| diff --git a/lib/Sema/SemaDeclCXX.cpp b/lib/Sema/SemaDeclCXX.cpp index e8abab847654..f483262a8cf5 100644 --- a/lib/Sema/SemaDeclCXX.cpp +++ b/lib/Sema/SemaDeclCXX.cpp @@ -1078,6 +1078,8 @@ Sema::ActOnCXXMemberDeclarator(Scope *S, AccessSpecifier AS, Declarator &D,    if (Deleted) // FIXME: Source location is not very good.      SetDeclDeleted(Member, D.getSourceRange().getBegin()); +  FinalizeDeclaration(Member); +    if (isInstField)      FieldCollector->Add(cast<FieldDecl>(Member));    return Member; @@ -2586,6 +2588,9 @@ struct CheckAbstractUsage {    void Check(FunctionProtoTypeLoc TL, Sema::AbstractDiagSelID Sel) {      Visit(TL.getResultLoc(), Sema::AbstractReturnType);      for (unsigned I = 0, E = TL.getNumArgs(); I != E; ++I) { +      if (!TL.getArg(I)) +        continue; +              TypeSourceInfo *TSI = TL.getArg(I)->getTypeSourceInfo();        if (TSI) Visit(TSI->getTypeLoc(), Sema::AbstractParamType);      } @@ -3618,8 +3623,7 @@ Decl *Sema::ActOnStartNamespaceDef(Scope *NamespcScope,          = UsingDirectiveDecl::Create(Context, CurContext,                                       /* 'using' */ LBrace,                                       /* 'namespace' */ SourceLocation(), -                                     /* qualifier */ SourceRange(), -                                     /* NNS */ NULL, +                                     /* qualifier */ NestedNameSpecifierLoc(),                                       /* identifier */ SourceLocation(),                                       Namespc,                                       /* Ancestor */ CurContext); @@ -3763,8 +3767,7 @@ Decl *Sema::ActOnUsingDirective(Scope *S,        CommonAncestor = CommonAncestor->getParent();      UDir = UsingDirectiveDecl::Create(Context, CurContext, UsingLoc, NamespcLoc, -                                      SS.getRange(), -                                      (NestedNameSpecifier *)SS.getScopeRep(), +                                      SS.getWithLocInContext(Context),                                        IdentLoc, Named, CommonAncestor);      PushUsingDirective(S, UDir);    } else { @@ -3914,16 +3917,16 @@ bool Sema::CheckUsingShadowDecl(UsingDecl *Using, NamedDecl *Orig,        if (OrigDC == CurContext) {          Diag(Using->getLocation(),               diag::err_using_decl_nested_name_specifier_is_current_class) -          << Using->getNestedNameRange(); +          << Using->getQualifierLoc().getSourceRange();          Diag(Orig->getLocation(), diag::note_using_decl_target);          return true;        } -      Diag(Using->getNestedNameRange().getBegin(), +      Diag(Using->getQualifierLoc().getBeginLoc(),             diag::err_using_decl_nested_name_specifier_is_not_base_class) -        << Using->getTargetNestedNameDecl() +        << Using->getQualifier()          << cast<CXXRecordDecl>(CurContext) -        << Using->getNestedNameRange(); +        << Using->getQualifierLoc().getSourceRange();        Diag(Orig->getLocation(), diag::note_using_decl_target);        return true;      } @@ -4129,8 +4132,6 @@ NamedDecl *Sema::BuildUsingDeclaration(Scope *S, AccessSpecifier AS,      LookupQualifiedName(Previous, CurContext);    } -  NestedNameSpecifier *NNS = SS.getScopeRep(); -    // Check for invalid redeclarations.    if (CheckUsingDeclRedeclaration(UsingLoc, IsTypeName, SS, IdentLoc, Previous))      return 0; @@ -4141,22 +4142,21 @@ NamedDecl *Sema::BuildUsingDeclaration(Scope *S, AccessSpecifier AS,    DeclContext *LookupContext = computeDeclContext(SS);    NamedDecl *D; +  NestedNameSpecifierLoc QualifierLoc = SS.getWithLocInContext(Context);    if (!LookupContext) {      if (IsTypeName) {        // FIXME: not all declaration name kinds are legal here        D = UnresolvedUsingTypenameDecl::Create(Context, CurContext,                                                UsingLoc, TypenameLoc, -                                              SS.getRange(), NNS, +                                              QualifierLoc,                                                IdentLoc, NameInfo.getName());      } else { -      D = UnresolvedUsingValueDecl::Create(Context, CurContext, -                                           UsingLoc, SS.getRange(), -                                           NNS, NameInfo); +      D = UnresolvedUsingValueDecl::Create(Context, CurContext, UsingLoc,  +                                           QualifierLoc, NameInfo);      }    } else { -    D = UsingDecl::Create(Context, CurContext, -                          SS.getRange(), UsingLoc, NNS, NameInfo, -                          IsTypeName); +    D = UsingDecl::Create(Context, CurContext, UsingLoc, QualifierLoc, +                          NameInfo, IsTypeName);    }    D->setAccess(AS);    CurContext->addDecl(D); @@ -4247,7 +4247,7 @@ bool Sema::CheckInheritedConstructorUsingDecl(UsingDecl *UD) {      return true;    } -  const Type *SourceType = UD->getTargetNestedNameDecl()->getAsType(); +  const Type *SourceType = UD->getQualifier()->getAsType();    assert(SourceType &&           "Using decl naming constructor doesn't have type in scope spec.");    CXXRecordDecl *TargetClass = cast<CXXRecordDecl>(CurContext); @@ -4304,15 +4304,15 @@ bool Sema::CheckUsingDeclRedeclaration(SourceLocation UsingLoc,      NestedNameSpecifier *DQual;      if (UsingDecl *UD = dyn_cast<UsingDecl>(D)) {        DTypename = UD->isTypeName(); -      DQual = UD->getTargetNestedNameDecl(); +      DQual = UD->getQualifier();      } else if (UnresolvedUsingValueDecl *UD                   = dyn_cast<UnresolvedUsingValueDecl>(D)) {        DTypename = false; -      DQual = UD->getTargetNestedNameSpecifier(); +      DQual = UD->getQualifier();      } else if (UnresolvedUsingTypenameDecl *UD                   = dyn_cast<UnresolvedUsingTypenameDecl>(D)) {        DTypename = true; -      DQual = UD->getTargetNestedNameSpecifier(); +      DQual = UD->getQualifier();      } else continue;      // using decls differ if one says 'typename' and the other doesn't. @@ -4542,8 +4542,7 @@ Decl *Sema::ActOnNamespaceAliasDef(Scope *S,    NamespaceAliasDecl *AliasDecl =      NamespaceAliasDecl::Create(Context, CurContext, NamespaceLoc, AliasLoc, -                               Alias, SS.getRange(), -                               (NestedNameSpecifier *)SS.getScopeRep(), +                               Alias, SS.getWithLocInContext(Context),                                 IdentLoc, R.getFoundDecl());    PushOnScopeChains(AliasDecl, S); @@ -5080,9 +5079,10 @@ BuildSingleCopyAssign(Sema &S, SourceLocation Loc, QualType T,      // reference to operator=; this is required to suppress the virtual      // call mechanism.      CXXScopeSpec SS; -    SS.setRange(Loc); -    SS.setScopeRep(NestedNameSpecifier::Create(S.Context, 0, false,  -                                               T.getTypePtr())); +    SS.MakeTrivial(S.Context,  +                   NestedNameSpecifier::Create(S.Context, 0, false,  +                                               T.getTypePtr()), +                   Loc);      // Create the reference to operator=.      ExprResult OpEqualRef @@ -5972,8 +5972,6 @@ void Sema::AddCXXDirectInitializerToDecl(Decl *RealDecl,    // C++0x [decl.spec.auto]p6. Deduce the type which 'auto' stands in for.    if (TypeMayContainAuto && VDecl->getType()->getContainedAutoType()) { -    VDecl->setParsingAutoInit(false); -      // FIXME: n3225 doesn't actually seem to indicate this is ill-formed      if (Exprs.size() > 1) {        Diag(Exprs.get()[1]->getSourceRange().getBegin(), | 
