summaryrefslogtreecommitdiff
path: root/Utilities/ClangTidyModule/UseCmstrlenCheck.cxx
diff options
context:
space:
mode:
authorKyle Edwards <kyle.edwards@kitware.com>2022-09-14 14:24:16 -0400
committerKyle Edwards <kyle.edwards@kitware.com>2022-10-19 13:51:11 -0400
commit43a88b56afd9224d2810d9b6d22004e137dc02e6 (patch)
tree67ca4c08051a5b12fada0ecb66cef84b7c710ddf /Utilities/ClangTidyModule/UseCmstrlenCheck.cxx
parent76ab7db5a1b826a6df05daf32728816aecd25b7d (diff)
downloadcmake-43a88b56afd9224d2810d9b6d22004e137dc02e6.tar.gz
clang-tidy module: add check for cmStrLen()
Co-Authored-by: Joe Blaauboer <jblaauboer67@gmail.com>
Diffstat (limited to 'Utilities/ClangTidyModule/UseCmstrlenCheck.cxx')
-rw-r--r--Utilities/ClangTidyModule/UseCmstrlenCheck.cxx34
1 files changed, 34 insertions, 0 deletions
diff --git a/Utilities/ClangTidyModule/UseCmstrlenCheck.cxx b/Utilities/ClangTidyModule/UseCmstrlenCheck.cxx
new file mode 100644
index 0000000000..590d260b4e
--- /dev/null
+++ b/Utilities/ClangTidyModule/UseCmstrlenCheck.cxx
@@ -0,0 +1,34 @@
+/* Distributed under the OSI-approved BSD 3-Clause License. See accompanying
+ file Copyright.txt or https://cmake.org/licensing for details. */
+#include "UseCmstrlenCheck.h"
+
+#include <clang/ASTMatchers/ASTMatchFinder.h>
+
+namespace clang {
+namespace tidy {
+namespace cmake {
+using namespace ast_matchers;
+
+UseCmstrlenCheck::UseCmstrlenCheck(StringRef Name, ClangTidyContext* Context)
+ : ClangTidyCheck(Name, Context)
+{
+}
+
+void UseCmstrlenCheck::registerMatchers(MatchFinder* Finder)
+{
+ Finder->addMatcher(callExpr(callee(functionDecl(hasName("::strlen"))),
+ callee(expr().bind("callee")),
+ hasArgument(0, stringLiteral())),
+ this);
+}
+
+void UseCmstrlenCheck::check(const MatchFinder::MatchResult& Result)
+{
+ const Expr* Node = Result.Nodes.getNodeAs<Expr>("callee");
+
+ this->diag(Node->getBeginLoc(), "use cmStrLen() for string literals")
+ << FixItHint::CreateReplacement(Node->getSourceRange(), "cmStrLen");
+}
+}
+}
+}