diff options
author | Chris Lattner <sabre@nondot.org> | 2011-07-10 00:18:59 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2011-07-10 00:18:59 +0000 |
commit | f742eb0196e1b25c0b71e91da4a2b856d16a1dab (patch) | |
tree | fa2b972c4e1347146faa911b689d7d79e65b0306 /test/CodeGen/init.c | |
parent | 064fa99dbe0a7c5828cefb7d46b922594e958589 (diff) |
Rename CGT::VerifyFuncTypeComplete to isFuncTypeConvertible since
it is a predicate, not an action. Change the return type to be a bool,
not the incomplete member. Enhace it to detect the recursive compilation
case, allowing us to compile Eli's testcase on llvmdev:
struct T {
struct T (*p)(void);
} t;
into:
%struct.T = type { {}* }
@t = common global %struct.T zeroinitializer, align 8
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@134853 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/CodeGen/init.c')
-rw-r--r-- | test/CodeGen/init.c | 8 |
1 files changed, 8 insertions, 0 deletions
diff --git a/test/CodeGen/init.c b/test/CodeGen/init.c index 0f94729a94..599b4f23db 100644 --- a/test/CodeGen/init.c +++ b/test/CodeGen/init.c @@ -115,3 +115,11 @@ void test11(struct test11S *P) { // CHECK: store i32 4 // CHECK: ret void } + + +// Verify that we can convert a recursive struct with a memory that returns +// an instance of the struct we're converting. +struct test12 { + struct test12 (*p)(void); +} test12g; + |