Clang Project

clang_source_code/test/SemaCXX/attr-weak.cpp
1// RUN: %clang_cc1 -triple x86_64-pc-linux-gnu -fsyntax-only -verify -std=c++11 %s
2
3static int test0 __attribute__((weak)); // expected-error {{weak declaration cannot have internal linkage}}
4static void test1() __attribute__((weak)); // expected-error {{weak declaration cannot have internal linkage}}
5
6namespace test2 __attribute__((weak)) { // expected-warning {{'weak' attribute only applies to variables, functions, and classes}}
7}
8
9namespace {
10  int test3 __attribute__((weak)); // expected-error {{weak declaration cannot have internal linkage}}
11  void test4() __attribute__((weak)); // expected-error {{weak declaration cannot have internal linkage}}
12}
13
14struct Test5 {
15  static void test5() __attribute__((weak)); // no error
16};
17
18namespace {
19  struct Test6 {
20    static void test6() __attribute__((weak)); // expected-error {{weak declaration cannot have internal linkage}}
21  };
22}
23
24// GCC rejects the instantiation with the internal type, but some existing
25// code expects it. It is also not that different from giving hidden visibility
26// to parts of a template that have explicit default visibility, so we accept
27// this.
28template <class T> struct Test7 {
29  void test7() __attribute__((weak)) {}
30  static int var __attribute__((weak));
31};
32template <class T>
33int Test7<T>::var;
34namespace { class Internal {}; }
35template struct Test7<Internal>;
36template struct Test7<int>;
37
38class __attribute__((weak)) Test8 {}; // OK
39
40__attribute__((weak)) auto Test9 = Internal(); // expected-error {{weak declaration cannot have internal linkage}}
41