summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAnders Carlsson <andersca@mac.com>2008-08-23 21:12:35 +0000
committerAnders Carlsson <andersca@mac.com>2008-08-23 21:12:35 +0000
commit4f177f803a625729f2a74238724f91a9f4304b63 (patch)
tree81954b1dff7bc9ee149128b24b486c6b98be1c6f
parenta3345a5d73157126beaa7e020b19c6d8d3f522b0 (diff)
downloadbcm5719-llvm-4f177f803a625729f2a74238724f91a9f4304b63.tar.gz
bcm5719-llvm-4f177f803a625729f2a74238724f91a9f4304b63.zip
treat bool literals as constatnt expressions.
llvm-svn: 55255
-rw-r--r--clang/lib/AST/Expr.cpp7
-rw-r--r--clang/test/SemaCXX/bool.cpp7
2 files changed, 14 insertions, 0 deletions
diff --git a/clang/lib/AST/Expr.cpp b/clang/lib/AST/Expr.cpp
index b004bde7bd2..5107a5643c9 100644
--- a/clang/lib/AST/Expr.cpp
+++ b/clang/lib/AST/Expr.cpp
@@ -720,6 +720,13 @@ bool Expr::isIntegerConstantExpr(llvm::APSInt &Result, ASTContext &Ctx,
Result.setIsUnsigned(!getType()->isSignedIntegerType());
break;
}
+ case CXXBoolLiteralExprClass: {
+ const CXXBoolLiteralExpr *BL = cast<CXXBoolLiteralExpr>(this);
+ Result.zextOrTrunc(static_cast<uint32_t>(Ctx.getTypeSize(getType())));
+ Result = BL->getValue();
+ Result.setIsUnsigned(!getType()->isSignedIntegerType());
+ break;
+ }
case CXXZeroInitValueExprClass:
Result.clear();
break;
diff --git a/clang/test/SemaCXX/bool.cpp b/clang/test/SemaCXX/bool.cpp
new file mode 100644
index 00000000000..e35495ababf
--- /dev/null
+++ b/clang/test/SemaCXX/bool.cpp
@@ -0,0 +1,7 @@
+// RUN: clang -fsyntax-only -verify %s
+
+// Bool literals can be enum values.
+enum {
+ ReadWrite = false,
+ ReadOnly = true
+};
OpenPOWER on IntegriCloud