From 4de6b1586807285e20a5db6596519c2336a64568 Mon Sep 17 00:00:00 2001 From: Vladimir Plyashkun Date: Wed, 30 Oct 2019 14:07:49 -0400 Subject: [PATCH] Add an option to hicpp-signed-bitwise for positive integer literals. This gives developers a way to deviate from the coding standard to reduce the chattiness of the check. --- .../clang-tidy/hicpp/SignedBitwiseCheck.cpp | 17 ++++++++++++++++- clang-tools-extra/clang-tidy/hicpp/SignedBitwiseCheck.h | 7 +++++-- clang-tools-extra/docs/ReleaseNotes.rst | 5 +++++ .../docs/clang-tidy/checks/hicpp-signed-bitwise.rst | 8 ++++++++ 4 files changed, 34 insertions(+), 3 deletions(-) diff --git a/clang-tools-extra/clang-tidy/hicpp/SignedBitwiseCheck.cpp b/clang-tools-extra/clang-tidy/hicpp/SignedBitwiseCheck.cpp index 781a443..b9c6077 100644 --- a/clang-tools-extra/clang-tidy/hicpp/SignedBitwiseCheck.cpp +++ b/clang-tools-extra/clang-tidy/hicpp/SignedBitwiseCheck.cpp @@ -17,9 +17,24 @@ namespace clang { namespace tidy { namespace hicpp { +SignedBitwiseCheck::SignedBitwiseCheck(StringRef Name, + ClangTidyContext *Context) + : ClangTidyCheck(Name, Context), + IgnorePositiveIntegerLiterals( + Options.get("IgnorePositiveIntegerLiterals", false)) {} + +void SignedBitwiseCheck::storeOptions(ClangTidyOptions::OptionMap &Opts) { + Options.store(Opts, "IgnorePositiveIntegerLiterals", + IgnorePositiveIntegerLiterals); +} + void SignedBitwiseCheck::registerMatchers(MatchFinder *Finder) { const auto SignedIntegerOperand = - expr(ignoringImpCasts(hasType(isSignedInteger()))).bind("signed-operand"); + (IgnorePositiveIntegerLiterals + ? expr(ignoringImpCasts(hasType(isSignedInteger())), + unless(integerLiteral())) + : expr(ignoringImpCasts(hasType(isSignedInteger())))) + .bind("signed-operand"); // The standard [bitmask.types] allows some integral types to be implemented // as signed types. Exclude these types from diagnosing for bitwise or(|) and diff --git a/clang-tools-extra/clang-tidy/hicpp/SignedBitwiseCheck.h b/clang-tools-extra/clang-tidy/hicpp/SignedBitwiseCheck.h index 34d5f09..74b3f0e 100644 --- a/clang-tools-extra/clang-tidy/hicpp/SignedBitwiseCheck.h +++ b/clang-tools-extra/clang-tidy/hicpp/SignedBitwiseCheck.h @@ -22,10 +22,13 @@ namespace hicpp { /// http://clang.llvm.org/extra/clang-tidy/checks/hicpp-signed-bitwise.html class SignedBitwiseCheck : public ClangTidyCheck { public: - SignedBitwiseCheck(StringRef Name, ClangTidyContext *Context) - : ClangTidyCheck(Name, Context) {} + SignedBitwiseCheck(StringRef Name, ClangTidyContext *Context); void registerMatchers(ast_matchers::MatchFinder *Finder) override; void check(const ast_matchers::MatchFinder::MatchResult &Result) override; + void storeOptions(ClangTidyOptions::OptionMap &Options) override; + +private: + bool IgnorePositiveIntegerLiterals; }; } // namespace hicpp diff --git a/clang-tools-extra/docs/ReleaseNotes.rst b/clang-tools-extra/docs/ReleaseNotes.rst index e6ef3cd..c706ae1 100644 --- a/clang-tools-extra/docs/ReleaseNotes.rst +++ b/clang-tools-extra/docs/ReleaseNotes.rst @@ -103,6 +103,11 @@ Improvements to clang-tidy Finds uses of deprecated Googletest APIs with names containing ``case`` and replaces them with equivalent APIs with ``suite``. +- Improved :doc:`hicpp-signed-bitwise + ` check. + + The check now supports the ``IgnorePositiveIntegerLiterals`` option. + - New :doc:`linuxkernel-must-use-errs ` check. diff --git a/clang-tools-extra/docs/clang-tidy/checks/hicpp-signed-bitwise.rst b/clang-tools-extra/docs/clang-tidy/checks/hicpp-signed-bitwise.rst index 59b19b6..4c6bc00 100644 --- a/clang-tools-extra/docs/clang-tidy/checks/hicpp-signed-bitwise.rst +++ b/clang-tools-extra/docs/clang-tidy/checks/hicpp-signed-bitwise.rst @@ -7,3 +7,11 @@ Finds uses of bitwise operations on signed integer types, which may lead to undefined or implementation defined behaviour. The according rule is defined in the `High Integrity C++ Standard, Section 5.6.1 `_. + +Options +------- + +.. option:: IgnorePositiveIntegerLiterals + + If this option is set to `true`, the check will not warn on bitwise operations with positive integer literals, e.g. `~0`, `2 << 1`, etc. + Default value is `false`. -- 2.7.4