| // RUN: %clang_cc1 -fsyntax-only -Wunused-variable -verify %s |
| template<typename T> void f() { |
| T t; |
| t = 17; |
| } |
| |
| // PR5407 |
| struct A { A(); }; |
| struct B { ~B(); }; |
| void f() { |
| A a; |
| B b; |
| } |
| |
| // PR5531 |
| namespace PR5531 { |
| struct A { |
| }; |
| |
| struct B { |
| B(int); |
| }; |
| |
| struct C { |
| ~C(); |
| }; |
| |
| void test() { |
| A(); |
| B(17); |
| C(); |
| } |
| } |
| |
| template<typename T> |
| struct X0 { }; |
| |
| template<typename T> |
| void test_dependent_init(T *p) { |
| X0<int> i(p); |
| (void)i; |
| } |
| |
| namespace PR6948 { |
| template<typename T> class X; // expected-note{{template is declared here}} |
| |
| void f() { |
| X<char> str (read_from_file()); // expected-error{{use of undeclared identifier 'read_from_file'}} \ |
| expected-error{{implicit instantiation of undefined template 'PR6948::X<char>'}} |
| } |
| } |
| |
| void unused_local_static() { |
| static int x = 0; |
| static int y = 0; // expected-warning{{unused variable 'y'}} |
| #pragma unused(x) |
| } |
| |
| // PR10168 |
| namespace PR10168 { |
| // We expect a warning in the definition only for non-dependent variables, and |
| // a warning in the instantiation only for dependent variables. |
| template<typename T> |
| struct S { |
| void f() { |
| int a; // expected-warning {{unused variable 'a'}} |
| T b; // expected-warning 2{{unused variable 'b'}} |
| } |
| }; |
| |
| template<typename T> |
| void f() { |
| int a; // expected-warning {{unused variable 'a'}} |
| T b; // expected-warning 2{{unused variable 'b'}} |
| } |
| |
| void g() { |
| S<int>().f(); // expected-note {{here}} |
| S<char>().f(); // expected-note {{here}} |
| f<int>(); // expected-note {{here}} |
| f<char>(); // expected-note {{here}} |
| } |
| } |
| |
| namespace PR11550 { |
| struct S1 { |
| S1(); |
| }; |
| S1 makeS1(); |
| void testS1(S1 a) { |
| // This constructor call can be elided. |
| S1 x = makeS1(); // expected-warning {{unused variable 'x'}} |
| |
| // This one cannot, so no warning. |
| S1 y; |
| |
| // This call cannot, but the constructor is trivial. |
| S1 z = a; // expected-warning {{unused variable 'z'}} |
| } |
| |
| // The same is true even when we know thet constructor has side effects. |
| void foo(); |
| struct S2 { |
| S2() { |
| foo(); |
| } |
| }; |
| S2 makeS2(); |
| void testS2(S2 a) { |
| S2 x = makeS2(); // expected-warning {{unused variable 'x'}} |
| S2 y; |
| S2 z = a; // expected-warning {{unused variable 'z'}} |
| } |
| |
| // Or when the constructor is not declared by the user. |
| struct S3 { |
| S1 m; |
| }; |
| S3 makeS3(); |
| void testS3(S3 a) { |
| S3 x = makeS3(); // expected-warning {{unused variable 'x'}} |
| S3 y; |
| S3 z = a; // expected-warning {{unused variable 'z'}} |
| } |
| } |
| |
| namespace ctor_with_cleanups { |
| struct S1 { |
| ~S1(); |
| }; |
| struct S2 { |
| S2(const S1&); |
| }; |
| void func() { |
| S2 s((S1())); |
| } |
| } |