* g++.dg/ext/attrib5.C,

* g++.dg/lookup/struct1.C: New tests.

From-SVN: r52215
This commit is contained in:
Richard Sandiford 2002-04-12 10:59:33 +00:00 committed by Richard Sandiford
parent 18778292a0
commit 4b72e8edac
3 changed files with 40 additions and 0 deletions

View File

@ -1,3 +1,8 @@
2002-04-12 Richard Sandiford <rsandifo@redhat.com>
* g++.dg/ext/attrib5.C,
* g++.dg/lookup/struct1.C: New tests.
2002-04-11 Jakub Jelinek <jakub@redhat.com>
* gcc.dg/20020411-1.c: New test.

View File

@ -0,0 +1,21 @@
// There were two related problems here, depending on the vintage. At
// one time:
//
// typedef struct A { ... } A __attribute__ ((aligned (16)));
//
// would cause original_types to go into an infinite loop. At other
// times, the attributes applied to an explicit typedef would be lost
// (check_b3 would have a negative size).
// First check that the declaration is accepted and has an effect.
typedef struct A { int i; } A __attribute__ ((aligned (16)));
int check_A[__alignof__ (A) >= 16 ? 1 : -1];
// Check that the alignment is only applied to the typedef.
struct B { int i; };
struct B b1;
typedef struct B B __attribute__((aligned (16)));
struct B b2;
B b3;
int check_b1[__alignof__ (b1) == __alignof__ (b2) ? 1 : -1];
int check_b3[__alignof__ (b3) >= 16 ? 1 : -1];

View File

@ -0,0 +1,14 @@
// Various struct lookup tests. We didn't used to complain about
// the definition of C.
struct A;
typedef struct A B; // { dg-error "previous declaration" }
struct B; // { dg-error "conflicting types" }
typedef struct { int i; } C; // { dg-error "previous declaration" }
struct C; // { dg-error "conflicting types" }
struct D;
typedef struct D D;
typedef struct D { int i; } D;
typedef struct D D;