From: Eli Friedman Date: Thu, 9 Feb 2012 20:13:14 +0000 (+0000) Subject: Make sure a variable with a C++ direct initializer triggers jump scope checking.... X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=7badd2467a1650c0c2a5fdef974f590fc32c3694;p=clang Make sure a variable with a C++ direct initializer triggers jump scope checking. Fixes PR10620 / . git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@150204 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Sema/SemaDeclCXX.cpp b/lib/Sema/SemaDeclCXX.cpp index 8ba84fe86a..ec92470ae1 100644 --- a/lib/Sema/SemaDeclCXX.cpp +++ b/lib/Sema/SemaDeclCXX.cpp @@ -16,6 +16,7 @@ #include "clang/Sema/Scope.h" #include "clang/Sema/Initialization.h" #include "clang/Sema/Lookup.h" +#include "clang/Sema/ScopeInfo.h" #include "clang/AST/ASTConsumer.h" #include "clang/AST/ASTContext.h" #include "clang/AST/ASTMutationListener.h" @@ -9223,6 +9224,9 @@ void Sema::AddCXXDirectInitializerToDecl(Decl *RealDecl, return; } + if (VDecl->hasLocalStorage()) + getCurFunction()->setHasBranchProtectedScope(); + bool IsDependent = false; for (unsigned I = 0, N = Exprs.size(); I != N; ++I) { if (DiagnoseUnexpandedParameterPack(Exprs.get()[I], UPPC_Expression)) { diff --git a/test/SemaCXX/goto.cpp b/test/SemaCXX/goto.cpp index d8d5ec51f6..e55e880723 100644 --- a/test/SemaCXX/goto.cpp +++ b/test/SemaCXX/goto.cpp @@ -103,3 +103,15 @@ void f() { exit: return; } + +namespace PR10620 { + struct S { + ~S() {} + }; + void g(const S& s) { + goto done; // expected-error {{goto into protected scope}} + const S s2(s); // expected-note {{jump bypasses variable initialization}} + done: + ; + } +}