diff options
author | David Blaikie <dblaikie@gmail.com> | 2013-01-29 21:40:37 +0000 |
---|---|---|
committer | David Blaikie <dblaikie@gmail.com> | 2013-01-29 21:40:37 +0000 |
commit | 6933e3b037fcb15b68f41d2b91ee01db45a2d43a (patch) | |
tree | 115f10b3c39bb2b64aa906e49d3bf305007c5578 /lib/Sema/SemaDecl.cpp | |
parent | 32d28ee6061930b2a9c170cbaaeea028c88a7b89 (diff) |
Don't fixit/recover from -Wstatic-float-init when it's not an error.
Fix to change r173414 that lead to Clang changing const to constexpr even under
-Wno-static-float-init.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@173835 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Sema/SemaDecl.cpp')
-rw-r--r-- | lib/Sema/SemaDecl.cpp | 14 |
1 files changed, 9 insertions, 5 deletions
diff --git a/lib/Sema/SemaDecl.cpp b/lib/Sema/SemaDecl.cpp index 33506401cf..702d38280a 100644 --- a/lib/Sema/SemaDecl.cpp +++ b/lib/Sema/SemaDecl.cpp @@ -7203,11 +7203,15 @@ void Sema::AddInitializerToDecl(Decl *RealDecl, Expr *Init, // In C++98, this is a GNU extension. In C++11, it is not, but we support // it anyway and provide a fixit to add the 'constexpr'. if (getLangOpts().CPlusPlus11) { - Diag(VDecl->getLocation(), - diag::ext_in_class_initializer_float_type_cxx11) - << DclT << Init->getSourceRange() - << FixItHint::CreateInsertion(VDecl->getLocStart(), "constexpr "); - VDecl->setConstexpr(true); + SemaDiagnosticBuilder D = Diag(VDecl->getLocation(), + diag::ext_in_class_initializer_float_type_cxx11); + D << DclT << Init->getSourceRange(); + if (Diags.getDiagnosticLevel(diag::warn_initializer_out_of_order, + VDecl->getLocation()) >= + DiagnosticsEngine::Error) { + D << FixItHint::CreateInsertion(VDecl->getLocStart(), "constexpr "); + VDecl->setConstexpr(true); + } } else { Diag(VDecl->getLocation(), diag::ext_in_class_initializer_float_type) << DclT << Init->getSourceRange(); |