From: Douglas Gregor Date: Tue, 29 Jan 2013 01:26:43 +0000 (+0000) Subject: Don't crash while printing APValues that are lvalues casted to a X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=f727e1c6cc382c1b5fe23b38ba04df2d4a2f358a;p=clang Don't crash while printing APValues that are lvalues casted to a decidedly non-reference, non-pointer type. Fixes . git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@173747 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/AST/APValue.cpp b/lib/AST/APValue.cpp index 1676b7d400..98e825b3ba 100644 --- a/lib/AST/APValue.cpp +++ b/lib/AST/APValue.cpp @@ -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. diff --git a/test/CXX/expr/expr.const/p2-0x.cpp b/test/CXX/expr/expr.const/p2-0x.cpp index 9e6716d0b8..065a12b3f2 100644 --- a/test/CXX/expr/expr.const/p2-0x.cpp +++ b/test/CXX/expr/expr.const/p2-0x.cpp @@ -594,3 +594,16 @@ static const bool or_value = and_or::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)'}} +}