From 952eddef9aff85b1e92626e89baaf7a360e2ac85 Mon Sep 17 00:00:00 2001 From: dim Date: Sun, 22 Dec 2013 00:07:40 +0000 Subject: Vendor import of clang release_34 branch r197841 (effectively, 3.4 RC3): https://llvm.org/svn/llvm-project/cfe/branches/release_34@197841 --- test/CodeGenCXX/debug-info-class-nolimit.cpp | 30 ++++++++++++++++++++++++++++ 1 file changed, 30 insertions(+) create mode 100644 test/CodeGenCXX/debug-info-class-nolimit.cpp (limited to 'test/CodeGenCXX/debug-info-class-nolimit.cpp') diff --git a/test/CodeGenCXX/debug-info-class-nolimit.cpp b/test/CodeGenCXX/debug-info-class-nolimit.cpp new file mode 100644 index 0000000..ce72bd3 --- /dev/null +++ b/test/CodeGenCXX/debug-info-class-nolimit.cpp @@ -0,0 +1,30 @@ +// RUN: %clang_cc1 -triple x86_64-unk-unk -fno-limit-debug-info -o - -emit-llvm -g %s | FileCheck %s + +namespace rdar14101097_1 { // see also PR16214 +// Check that we emit debug info for the definition of a struct if the +// definition is available, even if it's used via a pointer wrapped in a +// typedef. +// CHECK: [ DW_TAG_structure_type ] [foo] {{.*}}[def] +struct foo { +}; + +typedef foo *foop; + +void bar() { + foop f; +} +} + +namespace rdar14101097_2 { +// As above, except trickier because we first encounter only a declaration of +// the type and no debug-info related use after we see the definition of the +// type. +// CHECK: [ DW_TAG_structure_type ] [foo] {{.*}}[def] +struct foo; +void bar() { + foo *f; +} +struct foo { +}; +} + -- cgit v1.1