| // RUN: %clang_cc1 -fsyntax-only -Wunused-variable -Wunused-label -Wno-c++1y-extensions -verify %s |
| // RUN: %clang_cc1 -fsyntax-only -Wunused-variable -Wunused-label -Wno-c++1y-extensions -verify -std=c++11 %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; |
| } |
| |
| 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 PR19305 { |
| template<typename T> int n = 0; // no warning |
| int a = n<int>; |
| |
| template<typename T> const int l = 0; // no warning |
| int b = l<int>; |
| |
| // PR19558 |
| template<typename T> const int o = 0; // no warning |
| template<typename T> const int o<T*> = 0; // no warning |
| int c = o<int*>; |
| |
| template<> int o<void> = 0; // no warning |
| int d = o<void>; |
| |
| // FIXME: It'd be nice to warn here. |
| template<typename T> int m = 0; |
| template<typename T> int m<T*> = 0; |
| |
| template<> const int m<void> = 0; // expected-warning {{unused variable}} |
| } |
| |
| namespace ctor_with_cleanups { |
| struct S1 { |
| ~S1(); |
| }; |
| struct S2 { |
| S2(const S1&); |
| }; |
| void func() { |
| S2 s((S1())); |
| } |
| } |
| |
| #include "Inputs/warn-unused-variables.h" |
| |
| namespace arrayRecords { |
| |
| class NonTriviallyDestructible { |
| public: |
| ~NonTriviallyDestructible() {} |
| }; |
| |
| struct Foo { |
| int x; |
| Foo(int x) : x(x) {} |
| }; |
| |
| struct Elidable { |
| Elidable(); |
| }; |
| |
| void foo(int size) { |
| Elidable elidable; // no warning |
| Elidable elidableArray[2]; // no warning |
| Elidable elidableDynArray[size]; // no warning |
| Elidable elidableNestedArray[1][2][3]; // no warning |
| |
| NonTriviallyDestructible scalar; // no warning |
| NonTriviallyDestructible array[2]; // no warning |
| NonTriviallyDestructible nestedArray[2][2]; // no warning |
| |
| Foo fooScalar = 1; // expected-warning {{unused variable 'fooScalar'}} |
| Foo fooArray[] = {1,2}; // expected-warning {{unused variable 'fooArray'}} |
| Foo fooNested[2][2] = { {1,2}, {3,4} }; // expected-warning {{unused variable 'fooNested'}} |
| } |
| |
| template<int N> |
| void bar() { |
| NonTriviallyDestructible scaler; // no warning |
| NonTriviallyDestructible array[N]; // no warning |
| } |
| |
| void test() { |
| foo(10); |
| bar<2>(); |
| } |
| |
| } |
| |
| #if __cplusplus >= 201103L |
| namespace with_constexpr { |
| template <typename T> |
| struct Literal { |
| T i; |
| Literal() = default; |
| constexpr Literal(T i) : i(i) {} |
| }; |
| |
| struct NoLiteral { |
| int i; |
| NoLiteral() = default; |
| constexpr NoLiteral(int i) : i(i) {} |
| ~NoLiteral() {} |
| }; |
| |
| static Literal<int> gl1; // expected-warning {{unused variable 'gl1'}} |
| static Literal<int> gl2(1); // expected-warning {{unused variable 'gl2'}} |
| static const Literal<int> gl3(0); // expected-warning {{unused variable 'gl3'}} |
| |
| template <typename T> |
| void test(int i) { |
| Literal<int> l1; // expected-warning {{unused variable 'l1'}} |
| Literal<int> l2(42); // expected-warning {{unused variable 'l2'}} |
| Literal<int> l3(i); // no-warning |
| Literal<T> l4(0); // no-warning |
| NoLiteral nl1; // no-warning |
| NoLiteral nl2(42); // no-warning |
| } |
| } |
| |
| namespace crash { |
| struct a { |
| a(const char *); |
| }; |
| template <typename b> |
| void c() { |
| a d(b::e ? "" : ""); |
| } |
| } |
| #endif |