summaryrefslogtreecommitdiffstats
path: root/clang-tools-extra/clang-tidy/cert/VariadicFunctionDefCheck.cpp
diff options
context:
space:
mode:
authorAaron Ballman <aaron@aaronballman.com>2015-10-05 20:08:59 +0000
committerAaron Ballman <aaron@aaronballman.com>2015-10-05 20:08:59 +0000
commit46bc30472bd98182562446be98c4f27133a59a74 (patch)
tree38b62e329e80dd4ec6e616c024fbf9183e2958d9 /clang-tools-extra/clang-tidy/cert/VariadicFunctionDefCheck.cpp
parent42fd9efa38e6f6e04824ede2cbb8bb1f73d0e9ad (diff)
downloadbcm5719-llvm-46bc30472bd98182562446be98c4f27133a59a74.tar.gz
bcm5719-llvm-46bc30472bd98182562446be98c4f27133a59a74.zip
Adding a checker (cert-dcl50-cpp) that detects the definition of a C-style variadic function in C++ code. Corresponds to the CERT C++ secure coding rule: https://www.securecoding.cert.org/confluence/display/cplusplus/DCL50-CPP.+Do+not+define+a+C-style+variadic+function
llvm-svn: 249343
Diffstat (limited to 'clang-tools-extra/clang-tidy/cert/VariadicFunctionDefCheck.cpp')
-rw-r--r--clang-tools-extra/clang-tidy/cert/VariadicFunctionDefCheck.cpp38
1 files changed, 38 insertions, 0 deletions
diff --git a/clang-tools-extra/clang-tidy/cert/VariadicFunctionDefCheck.cpp b/clang-tools-extra/clang-tidy/cert/VariadicFunctionDefCheck.cpp
new file mode 100644
index 00000000000..ac788a3aee5
--- /dev/null
+++ b/clang-tools-extra/clang-tidy/cert/VariadicFunctionDefCheck.cpp
@@ -0,0 +1,38 @@
+//===--- VariadicfunctiondefCheck.cpp - clang-tidy-------------------------===//
+//
+// The LLVM Compiler Infrastructure
+//
+// This file is distributed under the University of Illinois Open Source
+// License. See LICENSE.TXT for details.
+//
+//===----------------------------------------------------------------------===//
+
+#include "VariadicFunctionDefCheck.h"
+#include "clang/AST/ASTContext.h"
+#include "clang/ASTMatchers/ASTMatchFinder.h"
+
+using namespace clang::ast_matchers;
+
+namespace clang {
+namespace tidy {
+
+void VariadicFunctionDefCheck::registerMatchers(MatchFinder *Finder) {
+ if (!getLangOpts().CPlusPlus)
+ return;
+
+ // We only care about function *definitions* that are variadic.
+ Finder->addMatcher(functionDecl(isDefinition(), isVariadic()).bind("func"),
+ this);
+}
+
+void VariadicFunctionDefCheck::check(const MatchFinder::MatchResult &Result) {
+ const auto *FD = Result.Nodes.getNodeAs<FunctionDecl>("func");
+
+ diag(FD->getLocation(),
+ "do not define a C-style variadic function; consider using a function "
+ "parameter pack or currying instead");
+}
+
+} // namespace tidy
+} // namespace clang
+
OpenPOWER on IntegriCloud