mirror of
https://github.com/Gericom/teak-llvm.git
synced 2025-06-20 12:05:48 -04:00

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
40 lines
1.5 KiB
C
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}}
|