]> granicus.if.org Git - clang/commitdiff
Add a missing check before trying to evaluate a temporary. PR11595.
authorEli Friedman <eli.friedman@gmail.com>
Sat, 17 Dec 2011 02:24:21 +0000 (02:24 +0000)
committerEli Friedman <eli.friedman@gmail.com>
Sat, 17 Dec 2011 02:24:21 +0000 (02:24 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@146813 91177308-0d34-0410-b5e6-96231b3b80d8

lib/AST/ExprConstant.cpp
test/SemaCXX/constant-expression-cxx11.cpp

index 31b211eff6cedb6d6c29dbe26586d5fc2d856777..0d32ebf1c67718074652676500b5d19f45e54c71 100644 (file)
@@ -2066,6 +2066,9 @@ public:
         return false;
       BaseTy = E->getBase()->getType()->getAs<PointerType>()->getPointeeType();
     } else if (E->getBase()->isRValue()) {
+      if (!E->getBase()->getType()->isRecordType() ||
+          !E->getBase()->getType()->isLiteralType())
+        return false;
       if (!EvaluateTemporary(E->getBase(), Result, this->Info))
         return false;
       BaseTy = E->getBase()->getType();
index 5105418af17d9e38af4438a594f91ae62670120d..5b053e4ce6788ba43a1b8b6b26ab0fc4718696bf 100644 (file)
@@ -919,3 +919,9 @@ static_assert(makeComplexWrap(1,0) == complex(1), "");
 static_assert(makeComplexWrap(1,0) != complex(0, 1), "");
 
 }
+
+namespace PR11595 {
+  struct A { constexpr bool operator==(int x) { return true; } };
+  struct B { B(); ~B(); A& x; };
+  static_assert(B().x == 3, "");  // expected-error {{constant expression}}
+}