1 // RUN: %clang_cc1 -triple x86_64-pc-linux-gnu -fsyntax-only -verify -std=c++11 %s 2 3 static int test0 __attribute__((weak)); // expected-error {{weak declaration cannot have internal linkage}} 4 static void test1() __attribute__((weak)); // expected-error {{weak declaration cannot have internal linkage}} 5 6 namespace test2 __attribute__((weak)) { // expected-warning {{'weak' attribute only applies to variables, functions and classes}} 7 } 8 9 namespace { 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 14 struct Test5 { 15 static void test5() __attribute__((weak)); // no error 16 }; 17 18 namespace { 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. 28 template <class T> struct Test7 { 29 void test7() __attribute__((weak)) {} 30 static int var __attribute__((weak)); 31 }; 32 template <class T> 33 int Test7<T>::var; 34 namespace { class Internal {}; } 35 template struct Test7<Internal>; 36 template struct Test7<int>; 37 38 class __attribute__((weak)) Test8 {}; // OK 39 40 __attribute__((weak)) auto Test9 = Internal(); // expected-error {{weak declaration cannot have internal linkage}} 41