]> granicus.if.org Git - clang/commitdiff
Don't crash while printing APValues that are lvalues casted to a
authorDouglas Gregor <dgregor@apple.com>
Tue, 29 Jan 2013 01:26:43 +0000 (01:26 +0000)
committerDouglas Gregor <dgregor@apple.com>
Tue, 29 Jan 2013 01:26:43 +0000 (01:26 +0000)
decidedly non-reference, non-pointer type. Fixes <rdar://problem/13090123>.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@173747 91177308-0d34-0410-b5e6-96231b3b80d8

lib/AST/APValue.cpp
test/CXX/expr/expr.const/p2-0x.cpp

index 1676b7d40058f41d4b7189f8756c0d8d675048f3..98e825b3bafb8d100ddeefecfb794ca74a2d05d7 100644 (file)
@@ -348,6 +348,8 @@ void APValue::printPretty(raw_ostream &Out, ASTContext &Ctx, QualType Ty) const{
     bool IsReference = Ty->isReferenceType();
     QualType InnerTy
       = IsReference ? Ty.getNonReferenceType() : Ty->getPointeeType();
+    if (InnerTy.isNull())
+      InnerTy = Ty;
 
     if (!hasLValuePath()) {
       // No lvalue path: just print the offset.
index 9e6716d0b8ecfa94be0dac107260dcfa7b2eee83..065a12b3f235b01fc94f27497950cfc483b003b4 100644 (file)
@@ -594,3 +594,16 @@ static const bool or_value = and_or<true>::or_value;
 
 static_assert(and_value == false, "");
 static_assert(or_value == true, "");
+
+namespace rdar13090123 {
+  typedef __INTPTR_TYPE__ intptr_t;
+
+  constexpr intptr_t f(intptr_t x) {
+    return (((x) >> 21) * 8); // expected-note{{subexpression not valid in a constant expression}}
+  }
+
+  extern "C" int foo;
+
+  constexpr intptr_t i = f((intptr_t)&foo - 10); // expected-error{{constexpr variable 'i' must be initialized by a constant expression}} \
+  // expected-note{{in call to 'f((char*)&foo + -10)'}}
+}