forked from OSchip/llvm-project
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:
parent
4fd69975aa
commit
22c460a051
|
@ -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?");
|
||||
|
|
|
@ -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;
|
Loading…
Reference in New Issue