diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2017-04-16 16:01:22 +0000 | 
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2017-04-16 16:01:22 +0000 | 
| commit | 71d5a2540a98c81f5bcaeb48805e0e2881f530ef (patch) | |
| tree | 5343938942df402b49ec7300a1c25a2d4ccd5821 /test/tools/llvm-pdbdump/simple-padding-text.test | |
| parent | 31bbf64f3a4974a2d6c8b3b27ad2f519caf74057 (diff) | |
Diffstat (limited to 'test/tools/llvm-pdbdump/simple-padding-text.test')
| -rw-r--r-- | test/tools/llvm-pdbdump/simple-padding-text.test | 94 | 
1 files changed, 94 insertions, 0 deletions
diff --git a/test/tools/llvm-pdbdump/simple-padding-text.test b/test/tools/llvm-pdbdump/simple-padding-text.test new file mode 100644 index 000000000000..b33af565f65a --- /dev/null +++ b/test/tools/llvm-pdbdump/simple-padding-text.test @@ -0,0 +1,94 @@ +; RUN: llvm-pdbdump pretty -classes -class-definitions=layout-members \ +; RUN:     -include-types=SimplePad %p/Inputs/SimplePaddingTest.pdb > %t + +; RUN: FileCheck -input-file=%t %s -check-prefix=NO_PADDING +; RUN: FileCheck -input-file=%t %s -check-prefix=UNION +; RUN: FileCheck -input-file=%t %s -check-prefix=NESTED_UNION +; RUN: FileCheck -input-file=%t %s -check-prefix=PAD_FROM_FIELDS1 +; RUN: FileCheck -input-file=%t %s -check-prefix=PAD_FROM_FIELDS2 +; RUN: FileCheck -input-file=%t %s -check-prefix=NO_PAD_IN_BASE +; RUN: FileCheck -input-file=%t %s -check-prefix=PAD_IN_DERIVED +; RUN: FileCheck -input-file=%t %s -check-prefix=EMPTY_BASE +; RUN: FileCheck -input-file=%t %s -check-prefix=VFPTR +; RUN: FileCheck -input-file=%t %s -check-prefix=MULTIPLE_INHERIT +; RUN: FileCheck -input-file=%t %s -check-prefix=MULTIPLE_INHERIT2 +; RUN: FileCheck -input-file=%t %s -check-prefix=DEEP_INHERIT +; RUN: FileCheck -input-file=%t %s -check-prefix=AGGREGATE + +; NO_PADDING:      struct SimplePadNoPadding [sizeof = 8] { +; NO_PADDING-NEXT:   data +0x00 [sizeof=4] int X +; NO_PADDING-NEXT:   data +0x04 [sizeof=4] int Y +; NO_PADDING-NEXT: } + +; UNION:      struct SimplePadUnion [sizeof = 16] { +; UNION-NEXT:   data +0x00 [sizeof=4] int X +; UNION-NEXT:   data +0x00 [sizeof=8] __int64 Y +; UNION-NEXT:   data +0x00 [sizeof=16] SimplePadUnion:: +; UNION-NEXT: } + +; NESTED_UNION:      struct {{SimplePadUnion::.*}} [sizeof = 16] { +; NESTED_UNION-NEXT:   data +0x00 [sizeof=4] int X +; NESTED_UNION-NEXT:   <padding> (4 bytes) +; NESTED_UNION-NEXT:   data +0x08 [sizeof=8] __int64 Y +; NESTED_UNION-NEXT: } + +; PAD_FROM_FIELDS1:      struct SimplePadFields1 [sizeof = 4] { +; PAD_FROM_FIELDS1-NEXT:   data +0x00 [sizeof=1] char A +; PAD_FROM_FIELDS1-NEXT:   data +0x01 [sizeof=1] char B +; PAD_FROM_FIELDS1-NEXT:   data +0x02 [sizeof=1] char C +; PAD_FROM_FIELDS1-NEXT:   <padding> (1 bytes) +; PAD_FROM_FIELDS1-NEXT: } + +; PAD_FROM_FIELDS2:      struct SimplePadFields2 [sizeof = 8] { +; PAD_FROM_FIELDS2-NEXT:   data +0x00 [sizeof=4] int Y +; PAD_FROM_FIELDS2-NEXT:   data +0x04 [sizeof=1] char X +; PAD_FROM_FIELDS2-NEXT:   <padding> (3 bytes) +; PAD_FROM_FIELDS2-NEXT: } + +; NO_PAD_IN_BASE:      struct SimplePadBase [sizeof = 4] { +; NO_PAD_IN_BASE-NEXT:   data +0x00 [sizeof=4] int X +; NO_PAD_IN_BASE-NEXT: } + +; PAD_IN_DERIVED:      struct SimplePadDerived [sizeof = 16] +; PAD_IN_DERIVED-NEXT:   public SimplePadBase { +; PAD_IN_DERIVED-NEXT:   <padding> (4 bytes) +; PAD_IN_DERIVED-NEXT:   data +0x08 [sizeof=8] __int64 Y +; PAD_IN_DERIVED-NEXT: } + +; EMPTY_BASE:      struct SimplePadEmpty [sizeof = 8] +; EMPTY_BASE-NEXT:   : public SimplePadEmptyBase1 +; EMPTY_BASE-NEXT:   , public SimplePadEmptyBase2 { +; EMPTY_BASE-NEXT:   <padding> (2 bytes) +; EMPTY_BASE-NEXT:   data +0x04 [sizeof=4] int X +; EMPTY_BASE-NEXT: } + +; VFPTR:      struct SimplePadVfptr [sizeof = 8] { +; VFPTR-NEXT:   vfptr +0x00 [sizeof=4] +; VFPTR-NEXT:   data +0x04 [sizeof=4] int X +; VFPTR-NEXT: } + +; MULTIPLE_INHERIT:      struct SimplePadMultiInherit [sizeof = 8] +; MULTIPLE_INHERIT-NEXT:   : public NonEmptyBase1 +; MULTIPLE_INHERIT-NEXT:   , public NonEmptyBase2 { +; MULTIPLE_INHERIT-NEXT:   <padding> (2 bytes) +; MULTIPLE_INHERIT-NEXT:   data +0x04 [sizeof=4] int X +; MULTIPLE_INHERIT-NEXT: } + +; MULTIPLE_INHERIT2:      SimplePadMultiInherit2 [sizeof = 16] +; MULTIPLE_INHERIT2-NEXT:   : public SimplePadFields1 +; MULTIPLE_INHERIT2-NEXT:   , public SimplePadFields2 { +; MULTIPLE_INHERIT2-NEXT:   data +0x0c [sizeof=4] int X +; MULTIPLE_INHERIT2-NEXT: } + +; DEEP_INHERIT:      struct SimplePadTwoLevelInherit [sizeof = 16] +; DEEP_INHERIT-NEXT:   : public OneLevelInherit { +; DEEP_INHERIT-NEXT:   <padding> (4 bytes) +; DEEP_INHERIT-NEXT:   data +0x08 [sizeof=8] __int64 Z +; DEEP_INHERIT-NEXT: } + + +; AGGREGATE:      struct SimplePadAggregate [sizeof = 8] { +; AGGREGATE-NEXT:   data +0x00 [sizeof=1] NonEmptyBase1 X +; AGGREGATE-NEXT:   <padding> (3 bytes) +; AGGREGATE-NEXT:   data +0x04 [sizeof=4] int Y +; AGGREGATE-NEXT: }  | 
