From 30bfa3623b6ec59fc03cba486040eef77cd5f847 Mon Sep 17 00:00:00 2001 From: Richard Trieu Date: Sat, 2 Nov 2013 02:11:23 +0000 Subject: [PATCH] Change the other -Wtautological-compare warnings to not trigger in template specializations. Also switch to -Wuninitialized for a test case that depended on a warning firing in template specializations. llvm-svn: 193906 --- clang/lib/Sema/SemaExpr.cpp | 6 ++++-- clang/test/PCH/pragma-diag-section.cpp | 16 +++++++++------- clang/test/SemaCXX/compare.cpp | 16 ++++++++++++++++ 3 files changed, 29 insertions(+), 9 deletions(-) diff --git a/clang/lib/Sema/SemaExpr.cpp b/clang/lib/Sema/SemaExpr.cpp index 77cf986351dd..edae0147d505 100644 --- a/clang/lib/Sema/SemaExpr.cpp +++ b/clang/lib/Sema/SemaExpr.cpp @@ -7665,7 +7665,8 @@ QualType Sema::CheckCompareOperands(ExprResult &LHS, ExprResult &RHS, if (!LHSType->hasFloatingRepresentation() && !(LHSType->isBlockPointerType() && IsRelational) && !LHS.get()->getLocStart().isMacroID() && - !RHS.get()->getLocStart().isMacroID()) { + !RHS.get()->getLocStart().isMacroID() && + ActiveTemplateInstantiations.empty()) { // For non-floating point types, check for self-comparisons of the form // x == x, x != x, x < x, etc. These always evaluate to a constant, and // often indicate logic errors in the program. @@ -8051,7 +8052,8 @@ QualType Sema::CheckVectorCompareOperands(ExprResult &LHS, ExprResult &RHS, // For non-floating point types, check for self-comparisons of the form // x == x, x != x, x < x, etc. These always evaluate to a constant, and // often indicate logic errors in the program. - if (!LHSType->hasFloatingRepresentation()) { + if (!LHSType->hasFloatingRepresentation() && + ActiveTemplateInstantiations.empty()) { if (DeclRefExpr* DRL = dyn_cast(LHS.get()->IgnoreParenImpCasts())) if (DeclRefExpr* DRR diff --git a/clang/test/PCH/pragma-diag-section.cpp b/clang/test/PCH/pragma-diag-section.cpp index 627156f15398..eea6bd73f546 100644 --- a/clang/test/PCH/pragma-diag-section.cpp +++ b/clang/test/PCH/pragma-diag-section.cpp @@ -1,20 +1,20 @@ // Test this without pch. -// RUN: %clang_cc1 %s -include %s -verify -fsyntax-only +// RUN: %clang_cc1 %s -include %s -verify -fsyntax-only -Wuninitialized // Test with pch. // RUN: %clang_cc1 %s -emit-pch -o %t -// RUN: %clang_cc1 %s -include-pch %t -verify -fsyntax-only +// RUN: %clang_cc1 %s -include-pch %t -verify -fsyntax-only -Wuninitialized #ifndef HEADER #define HEADER #pragma clang diagnostic push -#pragma clang diagnostic ignored "-Wtautological-compare" +#pragma clang diagnostic ignored "-Wuninitialized" template struct TS1 { void m() { - T a = 0; - T b = a==a; + T a; + T b = a; } }; #pragma clang diagnostic pop @@ -25,8 +25,10 @@ struct TS1 { template struct TS2 { void m() { - T a = 0; - T b = a==a; // expected-warning {{self-comparison always evaluates to true}} expected-note@39 {{in instantiation of member function}} + T a; + T b = a; // expected-warning {{variable 'a' is uninitialized}} \ + expected-note@41 {{in instantiation of member function}} \ + expected-note@28 {{initialize the variable 'a' to silence}} } }; diff --git a/clang/test/SemaCXX/compare.cpp b/clang/test/SemaCXX/compare.cpp index 02b029a7762f..8214f7899ecf 100644 --- a/clang/test/SemaCXX/compare.cpp +++ b/clang/test/SemaCXX/compare.cpp @@ -405,4 +405,20 @@ namespace templates { void test12() { compare<0>(42); } + + struct A { static int x; }; + struct B { static int x; }; + typedef A otherA; + + template + void testx() { + if (A::x == T::x && // no warning + A::x == otherA::x) // expected-warning{{self-comparison always evaluates to true}} + return; + } + + void test13() { + testx(); + testx(); + } }