Add a test case to showcase a difference in #pragma pack handling

compared to gcc. This is worrisome, but I believe we are doing the
"correct" thing, and if I recall correctly I previously verified this
versus MSVC.

llvm-svn: 71723
This commit is contained in:
Daniel Dunbar 2009-05-13 21:34:08 +00:00
parent f7b83c7ae7
commit 0aef72c697
1 changed files with 34 additions and 0 deletions

View File

@ -0,0 +1,34 @@
// RUN: clang-cc -triple i686-apple-darwin9 %s -fsyntax-only -verify
// Stack: [], Alignment: 8
#pragma pack(push, 1)
// Stack: [8], Alignment: 1
#pragma pack(push, 4)
// Stack: [8, 1], Alignment: 4
// Note that this differs from gcc; pack() in gcc appears to pop the
// top stack entry and resets the current alignment. This is both
// inconsistent with MSVC, and the gcc documentation. In other cases,
// for example changing this to pack(8), I don't even understand what gcc
// is doing.
#pragma pack()
// Stack: [8, 1], Alignment: 8
#pragma pack(pop)
// Stack: [8], Alignment: 1
struct s0 {
char f0;
short f1;
};
int a[sizeof(struct s0) == 3 ? 1 : -1];
#pragma pack(pop)
// Stack: [], Alignment: 8
struct s1 {
char f0;
short f1;
};
int b[sizeof(struct s1) == 4 ? 1 : -1];