From: Steve Naroff Date: Sat, 25 Aug 2007 14:02:58 +0000 (+0000) Subject: Give CXXBoolLiteralExpr a type (all expressions need a valid type). X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=210679cacc47640107e46090de1a138977a0431e;p=clang Give CXXBoolLiteralExpr a type (all expressions need a valid type). This fixes the following: ******************** TEST 'Parser/cxx-bool.cpp' FAILED! ******************** Command: clang -fsyntax-only Parser/cxx-bool.cpp Output: SemaExpr.cpp:731: failed assertion `!t.isNull() && "DefaultFunctionArrayConversion - missing type"' Output/cxx-bool.cpp.out.script: line 1: 22697 Abort trap clang -fsyntax-only Parser/cxx-bool.cpp git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@41401 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/Sema/SemaExprCXX.cpp b/Sema/SemaExprCXX.cpp index 74be79aadd..be1d551cd6 100644 --- a/Sema/SemaExprCXX.cpp +++ b/Sema/SemaExprCXX.cpp @@ -13,6 +13,7 @@ #include "Sema.h" #include "clang/AST/ExprCXX.h" +#include "clang/AST/ASTContext.h" using namespace clang; /// ParseCXXCasts - Parse {dynamic,static,reinterpret,const}_cast's. @@ -40,5 +41,5 @@ Action::ExprResult Sema::ParseCXXBoolLiteral(SourceLocation OpLoc, tok::TokenKind Kind) { assert((Kind != tok::kw_true || Kind != tok::kw_false) && "Unknown C++ Boolean value!"); - return new CXXBoolLiteralExpr(Kind == tok::kw_true, OpLoc); + return new CXXBoolLiteralExpr(Kind == tok::kw_true, Context.BoolTy, OpLoc); } diff --git a/include/clang/AST/ExprCXX.h b/include/clang/AST/ExprCXX.h index c863df4c76..14b1cc7d3a 100644 --- a/include/clang/AST/ExprCXX.h +++ b/include/clang/AST/ExprCXX.h @@ -78,8 +78,8 @@ namespace clang { bool Value; SourceLocation Loc; public: - CXXBoolLiteralExpr(bool val, SourceLocation l) : - Expr(CXXBoolLiteralExprClass, QualType()), Value(val), Loc(l) {} + CXXBoolLiteralExpr(bool val, QualType Ty, SourceLocation l) : + Expr(CXXBoolLiteralExprClass, Ty), Value(val), Loc(l) {} bool getValue() const { return Value; }