forked from OSchip/llvm-project
				
			
		
			
				
	
	
		
			70 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			C++
		
	
	
	
			
		
		
	
	
			70 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			C++
		
	
	
	
| // RUN: %clang_cc1 -std=c++0x -fsyntax-only -verify %s
 | |
| 
 | |
| struct non_copiable {
 | |
|   non_copiable(const non_copiable&) = delete; // expected-note {{marked deleted here}}
 | |
|   non_copiable& operator = (const non_copiable&) = delete; // expected-note {{explicitly deleted}}
 | |
|   non_copiable() = default;
 | |
| };
 | |
| 
 | |
| struct non_const_copy {
 | |
|   non_const_copy(non_const_copy&) = default; // expected-note {{not viable}}
 | |
|   non_const_copy& operator = (non_const_copy&) & = default; // expected-note {{not viable}}
 | |
|   non_const_copy& operator = (non_const_copy&) && = default; // expected-note {{not viable}}
 | |
|   non_const_copy() = default; // expected-note {{not viable}}
 | |
| };
 | |
| 
 | |
| void fn1 () {
 | |
|   non_copiable nc;
 | |
|   non_copiable nc2 = nc; // expected-error {{deleted constructor}}
 | |
|   nc = nc; // expected-error {{deleted operator}}
 | |
| 
 | |
|   non_const_copy ncc;
 | |
|   non_const_copy ncc2 = ncc;
 | |
|   ncc = ncc2;
 | |
|   const non_const_copy cncc;
 | |
|   non_const_copy ncc3 = cncc; // expected-error {{no matching}}
 | |
|   ncc = cncc; // expected-error {{no viable overloaded}}
 | |
| };
 | |
| 
 | |
| struct non_const_derived : non_const_copy {
 | |
|   non_const_derived(const non_const_derived&) = default; // expected-error {{requires it to be non-const}}
 | |
|   non_const_derived& operator =(non_const_derived&) = default;
 | |
| };
 | |
| 
 | |
| struct bad_decls {
 | |
|   bad_decls(volatile bad_decls&) = default; // expected-error {{may not be volatile}}
 | |
|   bad_decls&& operator = (bad_decls) = default; // expected-error 2{{lvalue reference}}
 | |
|   bad_decls& operator = (volatile bad_decls&) = default; // expected-error {{may not be volatile}}
 | |
|   bad_decls& operator = (const bad_decls&) const = default; // expected-error {{may not have 'const' or 'volatile' qualifiers}}
 | |
| };
 | |
| 
 | |
| struct A {}; struct B {};
 | |
| 
 | |
| struct except_spec_a {
 | |
|   virtual ~except_spec_a() throw(A);
 | |
|   except_spec_a() throw(A);
 | |
| };
 | |
| struct except_spec_b {
 | |
|   virtual ~except_spec_b() throw(B);
 | |
|   except_spec_b() throw(B);
 | |
| };
 | |
| 
 | |
| struct except_spec_d_good : except_spec_a, except_spec_b {
 | |
|   ~except_spec_d_good();
 | |
| };
 | |
| except_spec_d_good::~except_spec_d_good() = default;
 | |
| // FIXME: This should error in the virtual override check.
 | |
| // It doesn't because we generate the implicit specification later than
 | |
| // appropriate.
 | |
| struct except_spec_d_bad : except_spec_a, except_spec_b {
 | |
|   ~except_spec_d_bad() = default;
 | |
| };
 | |
| 
 | |
| // FIXME: This should error because the exceptions spec doesn't match.
 | |
| struct except_spec_d_mismatch : except_spec_a, except_spec_b {
 | |
|   except_spec_d_mismatch() throw(A) = default;
 | |
| };
 | |
| struct except_spec_d_match : except_spec_a, except_spec_b {
 | |
|   except_spec_d_match() throw(A, B) = default;
 | |
| };  
 |