From 54b26985878b03def5f53e09270c9320a337a1de Mon Sep 17 00:00:00 2001 From: Anders Carlsson Date: Sat, 14 Mar 2009 00:33:21 +0000 Subject: Handle dependent types/exprs in static_assert expressions. llvm-svn: 66997 --- clang/lib/Sema/SemaDeclCXX.cpp | 25 ++++++++++++++----------- 1 file changed, 14 insertions(+), 11 deletions(-) (limited to 'clang/lib/Sema/SemaDeclCXX.cpp') diff --git a/clang/lib/Sema/SemaDeclCXX.cpp b/clang/lib/Sema/SemaDeclCXX.cpp index 57a6c624616..37035b98c75 100644 --- a/clang/lib/Sema/SemaDeclCXX.cpp +++ b/clang/lib/Sema/SemaDeclCXX.cpp @@ -2243,20 +2243,23 @@ Sema::DeclTy *Sema::ActOnStaticAssertDeclaration(SourceLocation AssertLoc, StringLiteral *AssertMessage = cast((Expr *)assertmessageexpr.get()); - llvm::APSInt Value(32); - if (!AssertExpr->isIntegerConstantExpr(Value, Context)) { - Diag(AssertLoc, diag::err_static_assert_expression_is_not_constant) << - AssertExpr->getSourceRange(); - return 0; - } + if (!AssertExpr->isTypeDependent() && !AssertExpr->isValueDependent()) { + llvm::APSInt Value(32); + if (!AssertExpr->isIntegerConstantExpr(Value, Context)) { + Diag(AssertLoc, diag::err_static_assert_expression_is_not_constant) << + AssertExpr->getSourceRange(); + return 0; + } + if (Value == 0) { + std::string str(AssertMessage->getStrData(), + AssertMessage->getByteLength()); + Diag(AssertLoc, diag::err_static_assert_failed) << str; + } + } + Decl *Decl = StaticAssertDecl::Create(Context, CurContext, AssertLoc, AssertExpr, AssertMessage); - if (Value == 0) { - std::string str(AssertMessage->getStrData(), - AssertMessage->getByteLength()); - Diag(AssertLoc, diag::err_static_assert_failed) << str; - } CurContext->addDecl(Decl); return Decl; -- cgit v1.2.3