diff options
| author | Anders Carlsson <andersca@mac.com> | 2009-06-24 00:28:53 +0000 |
|---|---|---|
| committer | Anders Carlsson <andersca@mac.com> | 2009-06-24 00:28:53 +0000 |
| commit | d2e8adfc75996140ace5e19f65c7e098ba771054 (patch) | |
| tree | 938b233902ee739617fe7a2d3d774ae50bd33a24 /clang/lib | |
| parent | ecdab5406d373a52db9c75a775ed864d556799b5 (diff) | |
| download | bcm5719-llvm-d2e8adfc75996140ace5e19f65c7e098ba771054.tar.gz bcm5719-llvm-d2e8adfc75996140ace5e19f65c7e098ba771054.zip | |
Support for [class.local]p4.
llvm-svn: 74030
Diffstat (limited to 'clang/lib')
| -rw-r--r-- | clang/lib/Sema/SemaDecl.cpp | 9 | ||||
| -rw-r--r-- | clang/lib/Sema/SemaStmt.cpp | 1 |
2 files changed, 9 insertions, 1 deletions
diff --git a/clang/lib/Sema/SemaDecl.cpp b/clang/lib/Sema/SemaDecl.cpp index 48d1d64de14..7c4cb60fd58 100644 --- a/clang/lib/Sema/SemaDecl.cpp +++ b/clang/lib/Sema/SemaDecl.cpp @@ -1807,6 +1807,15 @@ Sema::ActOnVariableDeclarator(Scope* S, Declarator& D, DeclContext* DC, } else if (SC == VarDecl::None) SC = VarDecl::Static; } + if (SC == VarDecl::Static) { + if (const CXXRecordDecl *RD = dyn_cast<CXXRecordDecl>(DC)) { + if (RD->isLocalClass()) + Diag(D.getIdentifierLoc(), + diag::err_static_data_member_not_allowed_in_local_class) + << Name << RD->getDeclName(); + } + } + // The variable can not NewVD = VarDecl::Create(Context, DC, D.getIdentifierLoc(), diff --git a/clang/lib/Sema/SemaStmt.cpp b/clang/lib/Sema/SemaStmt.cpp index 5a91496db1a..914839cbf79 100644 --- a/clang/lib/Sema/SemaStmt.cpp +++ b/clang/lib/Sema/SemaStmt.cpp @@ -835,7 +835,6 @@ static bool IsReturnCopyElidable(ASTContext &Ctx, QualType RetType, Action::OwningStmtResult Sema::ActOnReturnStmt(SourceLocation ReturnLoc, FullExprArg rex) { - bool RetValExprIsValid = !rex->isInvalid(); Expr *RetValExp = rex->takeAs<Expr>(); if (CurBlock) return ActOnBlockReturnStmt(ReturnLoc, RetValExp); |

