forked from OSchip/llvm-project
				
			
		
			
				
	
	
		
			41 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C++
		
	
	
	
			
		
		
	
	
			41 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C++
		
	
	
	
| // RUN: %clang_cc1 -triple x86_64-pc-linux-gnu -fsyntax-only -verify -std=c++11 %s
 | |
| 
 | |
| static int test0 __attribute__((weak)); // expected-error {{weak declaration cannot have internal linkage}}
 | |
| static void test1() __attribute__((weak)); // expected-error {{weak declaration cannot have internal linkage}}
 | |
| 
 | |
| namespace test2 __attribute__((weak)) { // expected-warning {{'weak' attribute only applies to variables, functions and classes}}
 | |
| }
 | |
| 
 | |
| namespace {
 | |
|   int test3 __attribute__((weak)); // expected-error {{weak declaration cannot have internal linkage}}
 | |
|   void test4() __attribute__((weak)); // expected-error {{weak declaration cannot have internal linkage}}
 | |
| }
 | |
| 
 | |
| struct Test5 {
 | |
|   static void test5() __attribute__((weak)); // no error
 | |
| };
 | |
| 
 | |
| namespace {
 | |
|   struct Test6 {
 | |
|     static void test6() __attribute__((weak)); // expected-error {{weak declaration cannot have internal linkage}}
 | |
|   };
 | |
| }
 | |
| 
 | |
| // GCC rejects the instantiation with the internal type, but some existing
 | |
| // code expects it. It is also not that different from giving hidden visibility
 | |
| // to parts of a template that have explicit default visibility, so we accept
 | |
| // this.
 | |
| template <class T> struct Test7 {
 | |
|   void test7() __attribute__((weak)) {}
 | |
|   static int var __attribute__((weak));
 | |
| };
 | |
| template <class T>
 | |
| int Test7<T>::var;
 | |
| namespace { class Internal {}; }
 | |
| template struct Test7<Internal>;
 | |
| template struct Test7<int>;
 | |
| 
 | |
| class __attribute__((weak)) Test8 {}; // OK
 | |
| 
 | |
| __attribute__((weak)) auto Test9 = Internal(); // expected-error {{weak declaration cannot have internal linkage}}
 |