瀏覽代碼

clang-tidy: Enable checks from bugprone set

Regina Pfeifer 7 年之前
父節點
當前提交
ce2570b207
共有 3 個文件被更改,包括 9 次插入5 次删除
  1. 3 0
      .clang-tidy
  2. 2 2
      Source/CTest/cmCTestTestHandler.cxx
  3. 4 3
      Source/cmFileCommand.cxx

+ 3 - 0
.clang-tidy

@@ -1,5 +1,8 @@
 ---
 ---
 Checks: "-*,\
 Checks: "-*,\
+bugprone-*,\
+-bugprone-macro-parentheses,\
+-bugprone-misplaced-widening-cast,\
 google-readability-casting,\
 google-readability-casting,\
 misc-*,\
 misc-*,\
 -misc-incorrect-roundings,\
 -misc-incorrect-roundings,\

+ 2 - 2
Source/CTest/cmCTestTestHandler.cxx

@@ -3,6 +3,7 @@
 #include "cmCTestTestHandler.h"
 #include "cmCTestTestHandler.h"
 #include <algorithm>
 #include <algorithm>
 #include <chrono>
 #include <chrono>
+#include <cmath>
 #include <cmsys/Base64.h>
 #include <cmsys/Base64.h>
 #include <cmsys/Directory.hxx>
 #include <cmsys/Directory.hxx>
 #include <cmsys/RegularExpression.hxx>
 #include <cmsys/RegularExpression.hxx>
@@ -544,8 +545,7 @@ int cmCTestTestHandler::ProcessHandler()
     }
     }
     cmCTestLog(this->CTest, HANDLER_OUTPUT,
     cmCTestLog(this->CTest, HANDLER_OUTPUT,
                std::endl
                std::endl
-                 << passColorCode << static_cast<int>(percent + .5f)
-                 << "% tests passed"
+                 << passColorCode << std::lround(percent) << "% tests passed"
                  << this->CTest->GetColorCode(cmCTest::Color::CLEAR_COLOR)
                  << this->CTest->GetColorCode(cmCTest::Color::CLEAR_COLOR)
                  << ", " << failedColorCode << failed.size() << " tests failed"
                  << ", " << failedColorCode << failed.size() << " tests failed"
                  << this->CTest->GetColorCode(cmCTest::Color::CLEAR_COLOR)
                  << this->CTest->GetColorCode(cmCTest::Color::CLEAR_COLOR)

+ 4 - 3
Source/cmFileCommand.cxx

@@ -10,6 +10,7 @@
 
 
 #include <algorithm>
 #include <algorithm>
 #include <assert.h>
 #include <assert.h>
+#include <cmath>
 #include <ctype.h>
 #include <ctype.h>
 #include <memory> // IWYU pragma: keep
 #include <memory> // IWYU pragma: keep
 #include <sstream>
 #include <sstream>
@@ -2602,10 +2603,10 @@ public:
 
 
   bool UpdatePercentage(double value, double total, std::string& status)
   bool UpdatePercentage(double value, double total, std::string& status)
   {
   {
-    int OldPercentage = this->CurrentPercentage;
+    long OldPercentage = this->CurrentPercentage;
 
 
     if (total > 0.0) {
     if (total > 0.0) {
-      this->CurrentPercentage = static_cast<int>(value / total * 100.0 + 0.5);
+      this->CurrentPercentage = std::lround(value / total * 100.0);
       if (this->CurrentPercentage > 100) {
       if (this->CurrentPercentage > 100) {
         // Avoid extra progress reports for unexpected data beyond total.
         // Avoid extra progress reports for unexpected data beyond total.
         this->CurrentPercentage = 100;
         this->CurrentPercentage = 100;
@@ -2627,7 +2628,7 @@ public:
   cmFileCommand* GetFileCommand() { return this->FileCommand; }
   cmFileCommand* GetFileCommand() { return this->FileCommand; }
 
 
 private:
 private:
-  int CurrentPercentage;
+  long CurrentPercentage;
   cmFileCommand* FileCommand;
   cmFileCommand* FileCommand;
   std::string Text;
   std::string Text;
 };
 };