114 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			C++
		
	
	
	
			
		
		
	
	
			114 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			C++
		
	
	
	
| // RUN: %clang_cc1 -fsyntax-only -verify -Wunused %s
 | |
| // RUN: %clang_cc1 -fsyntax-only -verify -std=c++98 -Wunused %s
 | |
| // RUN: %clang_cc1 -fsyntax-only -verify -std=c++11 -Wunused %s
 | |
| // RUN: %clang_cc1 -fsyntax-only -verify -std=c++17 -Wunused %s
 | |
| 
 | |
| // PR4103 : Make sure we don't get a bogus unused expression warning
 | |
| namespace PR4103 {
 | |
|   class APInt {
 | |
|     char foo; // expected-warning {{private field 'foo' is not used}}
 | |
|   };
 | |
|   class APSInt : public APInt {
 | |
|     char bar; // expected-warning {{private field 'bar' is not used}}
 | |
|   public:
 | |
|     APSInt &operator=(const APSInt &RHS);
 | |
|   };
 | |
| 
 | |
|   APSInt& APSInt::operator=(const APSInt &RHS) {
 | |
|     APInt::operator=(RHS);
 | |
|     return *this;
 | |
|   }
 | |
| 
 | |
|   template<typename T>
 | |
|   struct X {
 | |
|     X();
 | |
|   };
 | |
| 
 | |
|   void test() {
 | |
|     X<int>();
 | |
|   }
 | |
| }
 | |
| 
 | |
| namespace derefvolatile {
 | |
|   void f(volatile char* x) {
 | |
|     *x;
 | |
| #if __cplusplus <= 199711L
 | |
|     // expected-warning@-2 {{expression result unused; assign into a variable to force a volatile load}}
 | |
| #endif
 | |
|     (void)*x;
 | |
| #if __cplusplus <= 199711L
 | |
|     // expected-warning@-2 {{expression result unused; assign into a variable to force a volatile load}}
 | |
| #endif
 | |
|     volatile char y = 10;
 | |
|     (void)y; // don't warn here, because it's a common pattern.
 | |
|   }
 | |
| }
 | |
| 
 | |
| // <rdar://problem/12359208>
 | |
| namespace AnonObject {
 | |
|   struct Foo {
 | |
|     Foo(const char* const message);
 | |
|     ~Foo();
 | |
|   };
 | |
|   void f() {
 | |
|     Foo("Hello World!");  // don't warn
 | |
|     int(1); // expected-warning {{expression result unused}}
 | |
|   }
 | |
| }
 | |
| 
 | |
| // Test that constructing an object (which may have side effects) with
 | |
| // constructor arguments which are dependent doesn't produce an unused value
 | |
| // warning.
 | |
| namespace UnresolvedLookup {
 | |
|   struct Foo {
 | |
|     Foo(int i, int j);
 | |
|   };
 | |
|   template <typename T>
 | |
|   struct Bar {
 | |
|     void f(T t) {
 | |
|       Foo(t, 0);  // no warning
 | |
|     }
 | |
|   };
 | |
| }
 | |
| 
 | |
| #if __cplusplus >= 201703L
 | |
| namespace PR33839 {
 | |
|   void a() {
 | |
|     struct X { int a, b; } x;
 | |
|     auto [a, b] = x; // expected-warning {{unused variable '[a, b]'}}
 | |
|     auto [c, d] = x;
 | |
|     (void)d;
 | |
|   }
 | |
| 
 | |
|   template<typename T> void f() {
 | |
|     struct A { int n; } a[1];
 | |
|     for (auto [x] : a) {
 | |
|       (void)x;
 | |
|     }
 | |
|     auto [y] = a[0]; // expected-warning {{unused}}
 | |
|   }
 | |
|   template<bool b> void g() {
 | |
|     struct A { int n; } a[1];
 | |
|     for (auto [x] : a) {
 | |
|       if constexpr (b)
 | |
|         (void)x;
 | |
|     }
 | |
| 
 | |
|     auto [y] = a[0];
 | |
|     if constexpr (b)
 | |
|       (void)y; // ok, even when b == false
 | |
|   }
 | |
|   template<typename T> void h() {
 | |
|     struct A { int n; } a[1];
 | |
|     for (auto [x] : a) { // expected-warning {{unused variable '[x]'}}
 | |
|     }
 | |
|   }
 | |
|   void use() { 
 | |
|     f<int>(); // expected-note {{instantiation of}}
 | |
|     g<true>();
 | |
|     g<false>();
 | |
|     h<int>(); // expected-note {{instantiation of}}
 | |
|   }
 | |
| }
 | |
| #endif
 |