PR16091: Error when attempting to emit debug info for undeduced auto return types

Perhaps we should just suppress this, rather than erroring, but since we
have the infrastructure for it I figured I'd use it - if this is
determined to be not the right thing we should probably remove that
infrastructure entirely. I guess it's lying around from the early days
of implementing debug info support.

llvm-svn: 182673
This commit is contained in:
David Blaikie 2013-05-24 21:24:35 +00:00
parent 4fd69975aa
commit 22c460a051
2 changed files with 14 additions and 2 deletions

View File

@ -1827,7 +1827,10 @@ static QualType UnwrapTypeForDebugInfo(QualType T, const ASTContext &C) {
T = cast<SubstTemplateTypeParmType>(T)->getReplacementType();
break;
case Type::Auto:
T = cast<AutoType>(T)->getDeducedType();
QualType DT = cast<AutoType>(T)->getDeducedType();
if (DT.isNull())
return T;
T = DT;
break;
}
@ -2044,8 +2047,10 @@ llvm::DIType CGDebugInfo::CreateTypeNode(QualType Ty, llvm::DIFile Unit) {
case Type::TypeOf:
case Type::Decltype:
case Type::UnaryTransform:
case Type::Auto:
llvm_unreachable("type should have been unwrapped!");
case Type::Auto:
Diag = "auto";
break;
}
assert(Diag && "Fall through without a diagnostic?");

View File

@ -0,0 +1,7 @@
// RUN: %clang_cc1 -emit-llvm-only -std=c++1y -g %s 2>&1 | FileCheck %s
struct foo {
auto func(); // CHECK: error: debug information for auto is not yet supported
};
foo f;