teak-llvm/clang/test/Sema/attr-decl-after-definition.c
Rafael Espindola faf556b745 Without this patch clang warns on
struct __attribute__((visibility("hidden"))) zed {
};
struct __attribute__((visibility("hidden"))) zed;

Which is a bit silly and got a lot noisier now that we correctly handle
visibility pragmas. This patch fixes that and also has some extra quality
improvements:

* We now produce an error instead of a warning for

struct __attribute__((visibility("hidden"))) zed {
};
struct __attribute__((visibility("default"))) zed;

* The "after definition" warning now points to the new attribute that is
  ignored instead of pointing to the declaration.

llvm-svn: 160227
2012-07-15 01:33:40 +00:00

40 lines
1.5 KiB
C

// RUN: %clang_cc1 -fsyntax-only -verify %s
void foo();
void foo() __attribute__((unused));
void foo() __attribute__((unused));
void foo(){} // expected-note {{previous definition is here}}
void foo() __attribute__((constructor)); // expected-warning {{must precede definition}}
void foo();
int bar;
extern int bar;
int bar;
int bar __attribute__((weak));
int bar __attribute__((used));
extern int bar __attribute__((weak));
int bar = 0; // expected-note {{previous definition is here}}
int bar __attribute__((weak)); // no warning as it matches the existing
// attribute.
int bar __attribute__((used,
visibility("hidden"))); // expected-warning {{must precede definition}}
int bar;
struct zed { // expected-note {{previous definition is here}}
};
struct __attribute__((visibility("hidden"))) zed; // expected-warning {{must precede definition}}
struct __attribute__((visibility("hidden"))) zed2 {
};
struct __attribute__((visibility("hidden"))) zed2;
struct __attribute__((visibility("hidden"))) zed3 { // expected-note {{previous definition is here}}
};
struct __attribute__((visibility("hidden"),
packed // expected-warning {{must precede definition}}
)) zed3;
struct __attribute__((visibility("hidden"))) zed4 { // expected-note {{previous attribute is here}}
};
struct __attribute__((visibility("default"))) zed4; // expected-error {{visibility does not match previous declaration}}