forked from OSchip/llvm-project
Fix -Wunused-comparison for comparisons in arguments to function-like macros.
Previously, -Wunused-comparison ignored comparisons in both macro bodies and macro arguments, but we would still emit a -Wunused-value warning for either. Now we correctly emit -Wunused-comparison for expressions in macro arguments. Also, add isMacroBodyExpansion to SourceManager, to go along with isMacroArgExpansion. llvm-svn: 172279
This commit is contained in:
parent
37494a176c
commit
b1e71a7d0c
|
@ -329,6 +329,11 @@ namespace SrcMgr {
|
||||||
SourceLocation::getFromRawEncoding(ExpansionLocEnd).isInvalid();
|
SourceLocation::getFromRawEncoding(ExpansionLocEnd).isInvalid();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool isMacroBodyExpansion() const {
|
||||||
|
return getExpansionLocStart().isValid() &&
|
||||||
|
SourceLocation::getFromRawEncoding(ExpansionLocEnd).isValid();
|
||||||
|
}
|
||||||
|
|
||||||
bool isFunctionMacroExpansion() const {
|
bool isFunctionMacroExpansion() const {
|
||||||
return getExpansionLocStart().isValid() &&
|
return getExpansionLocStart().isValid() &&
|
||||||
getExpansionLocStart() != getExpansionLocEnd();
|
getExpansionLocStart() != getExpansionLocEnd();
|
||||||
|
@ -1126,6 +1131,13 @@ public:
|
||||||
/// expanded.
|
/// expanded.
|
||||||
bool isMacroArgExpansion(SourceLocation Loc) const;
|
bool isMacroArgExpansion(SourceLocation Loc) const;
|
||||||
|
|
||||||
|
/// \brief Tests whether the given source location represents the expansion of
|
||||||
|
/// a macro body.
|
||||||
|
///
|
||||||
|
/// This is equivalent to testing whether the location is part of a macro
|
||||||
|
/// expansion but not the expansion of an argument to a function-like macro.
|
||||||
|
bool isMacroBodyExpansion(SourceLocation Loc) const;
|
||||||
|
|
||||||
/// \brief Returns true if \p Loc is inside the [\p Start, +\p Length)
|
/// \brief Returns true if \p Loc is inside the [\p Start, +\p Length)
|
||||||
/// chunk of the source location address space.
|
/// chunk of the source location address space.
|
||||||
///
|
///
|
||||||
|
|
|
@ -974,11 +974,18 @@ bool SourceManager::isMacroArgExpansion(SourceLocation Loc) const {
|
||||||
if (!Loc.isMacroID()) return false;
|
if (!Loc.isMacroID()) return false;
|
||||||
|
|
||||||
FileID FID = getFileID(Loc);
|
FileID FID = getFileID(Loc);
|
||||||
const SrcMgr::SLocEntry *E = &getSLocEntry(FID);
|
const SrcMgr::ExpansionInfo &Expansion = getSLocEntry(FID).getExpansion();
|
||||||
const SrcMgr::ExpansionInfo &Expansion = E->getExpansion();
|
|
||||||
return Expansion.isMacroArgExpansion();
|
return Expansion.isMacroArgExpansion();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool SourceManager::isMacroBodyExpansion(SourceLocation Loc) const {
|
||||||
|
if (!Loc.isMacroID()) return false;
|
||||||
|
|
||||||
|
FileID FID = getFileID(Loc);
|
||||||
|
const SrcMgr::ExpansionInfo &Expansion = getSLocEntry(FID).getExpansion();
|
||||||
|
return Expansion.isMacroBodyExpansion();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
// Queries about the code at a SourceLocation.
|
// Queries about the code at a SourceLocation.
|
||||||
|
|
|
@ -126,7 +126,7 @@ static bool DiagnoseUnusedComparison(Sema &S, const Expr *E) {
|
||||||
|
|
||||||
// Suppress warnings when the operator, suspicious as it may be, comes from
|
// Suppress warnings when the operator, suspicious as it may be, comes from
|
||||||
// a macro expansion.
|
// a macro expansion.
|
||||||
if (Loc.isMacroID())
|
if (S.SourceMgr.isMacroBodyExpansion(Loc))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
S.Diag(Loc, diag::warn_unused_comparison)
|
S.Diag(Loc, diag::warn_unused_comparison)
|
||||||
|
|
|
@ -3,8 +3,10 @@
|
||||||
void f(int i1, int i2) {
|
void f(int i1, int i2) {
|
||||||
POSSIBLY_BAD_MACRO(5);
|
POSSIBLY_BAD_MACRO(5);
|
||||||
STATEMENT_EXPR_MACRO(5);
|
STATEMENT_EXPR_MACRO(5);
|
||||||
COMMA_MACRO_1(i1 == i2, f(i1, i2)); // expected-warning {{expression result unused}}
|
COMMA_MACRO_1(i1 == i2, f(i1, i2)); // expected-warning {{comparison result unused}} \
|
||||||
|
// expected-note {{equality comparison}}
|
||||||
COMMA_MACRO_2(i1 == i2, f(i1, i2));
|
COMMA_MACRO_2(i1 == i2, f(i1, i2));
|
||||||
COMMA_MACRO_3(i1 == i2, f(i1, i2)); // expected-warning {{expression result unused}}
|
COMMA_MACRO_3(i1 == i2, f(i1, i2)); // expected-warning {{comparison result unused}} \
|
||||||
|
// expected-note {{equality comparison}}
|
||||||
COMMA_MACRO_4(i1 == i2, f(i1, i2));
|
COMMA_MACRO_4(i1 == i2, f(i1, i2));
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue