1 //===--- IncorrectRoundingsCheck.h - clang-tidy -----------------*- C++ -*-===// 2 // 3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 4 // See https://llvm.org/LICENSE.txt for license information. 5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 6 // 7 //===----------------------------------------------------------------------===// 8 9 #ifndef LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_BUGPRONE_INCORRECTROUNDINGSCHECK_H_ 10 #define LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_BUGPRONE_INCORRECTROUNDINGSCHECK_H_ 11 12 #include "../ClangTidyCheck.h" 13 14 namespace clang { 15 namespace tidy { 16 namespace bugprone { 17 18 /// Checks the usage of patterns known to produce incorrect rounding. 19 /// Programmers often use 20 /// (int)(double_expression + 0.5) 21 /// to round the double expression to an integer. The problem with this 22 /// 1. It is unnecessarily slow. 23 /// 2. It is incorrect. The number 0.499999975 (smallest representable float 24 /// number below 0.5) rounds to 1.0. Even worse behavior for negative 25 /// numbers where both -0.5f and -1.4f both round to 0.0. 26 class IncorrectRoundingsCheck : public ClangTidyCheck { 27 public: IncorrectRoundingsCheck(StringRef Name,ClangTidyContext * Context)28 IncorrectRoundingsCheck(StringRef Name, ClangTidyContext *Context) 29 : ClangTidyCheck(Name, Context) {} 30 void registerMatchers(ast_matchers::MatchFinder *Finder) override; 31 void check(const ast_matchers::MatchFinder::MatchResult &Result) override; 32 }; 33 34 } // namespace bugprone 35 } // namespace tidy 36 } // namespace clang 37 38 #endif // LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_BUGPRONE_INCORRECTROUNDINGSCHECK_H_ 39