phunix/external/bsd/llvm/dist/clang/test/CodeGenCXX/debug-info-template-fwd.cpp
Lionel Sambuc 0a6a1f1d05 NetBSD re-synchronization of the source tree
This brings our tree to NetBSD 7.0, as found on -current on the
10-10-2015.

This updates:
 - LLVM to 3.6.1
 - GCC to GCC 5.1
 - Replace minix/commands/zdump with usr.bin/zdump
 - external/bsd/libelf has moved to /external/bsd/elftoolchain/
 - Import ctwm
 - Drop sprintf from libminc

Change-Id: I149836ac18e9326be9353958bab9b266efb056f0
2016-01-13 20:32:14 +01:00

28 lines
1.1 KiB
C++

// RUN: %clang_cc1 %s -triple=x86_64-apple-darwin -g -emit-llvm -o - | FileCheck %s
// This test is for a crash when emitting debug info for not-yet-completed
// types.
// Test that we don't actually emit a forward decl for the offending class:
// CHECK: [ DW_TAG_structure_type ] [Derived<int>] {{.*}} [def]
// rdar://problem/15931354
template <class A> class Derived;
template <class A> class Base {
static Derived<A> *create();
};
template <class A> struct Derived : Base<A> {
};
Base<int> *f;
// During the instantiation of Derived<int>, Base<int> becomes required to be
// complete - since the declaration has already been emitted (due to 'f',
// above), we immediately try to build debug info for Base<int> which then
// requires the (incomplete definition) of Derived<int> which is problematic.
//
// (if 'f' is not present, the point at which Base<int> becomes required to be
// complete during the instantiation of Derived<int> is a no-op because
// Base<int> was never emitted so we ignore it and carry on until we
// wire up the base class of Derived<int> in the debug info later on)
Derived<int> d;