summaryrefslogtreecommitdiffstats
path: root/clang-tools-extra/clang-tidy/google/UnnamedNamespaceInHeaderCheck.cpp
diff options
context:
space:
mode:
authorBenjamin Kramer <benny.kra@googlemail.com>2014-07-16 14:16:56 +0000
committerBenjamin Kramer <benny.kra@googlemail.com>2014-07-16 14:16:56 +0000
commit2252cbf4e89d76b1c39da89b01d67b3e2b73154b (patch)
tree972a4a9393e381d401b0fd4acd64c20e6e1c0cb5 /clang-tools-extra/clang-tidy/google/UnnamedNamespaceInHeaderCheck.cpp
parent73ef216c73164e1012c22a8813e7543637163996 (diff)
downloadbcm5719-llvm-2252cbf4e89d76b1c39da89b01d67b3e2b73154b.tar.gz
bcm5719-llvm-2252cbf4e89d76b1c39da89b01d67b3e2b73154b.zip
[clang-tidy] Add namespaces checkers.
This change contains of two checkers that warn about 1. anonymous namespaces in header files. 2. 'using namespace' directives everywhere. Differential Revision: http://reviews.llvm.org/D4523 llvm-svn: 213153
Diffstat (limited to 'clang-tools-extra/clang-tidy/google/UnnamedNamespaceInHeaderCheck.cpp')
-rw-r--r--clang-tools-extra/clang-tidy/google/UnnamedNamespaceInHeaderCheck.cpp51
1 files changed, 51 insertions, 0 deletions
diff --git a/clang-tools-extra/clang-tidy/google/UnnamedNamespaceInHeaderCheck.cpp b/clang-tools-extra/clang-tidy/google/UnnamedNamespaceInHeaderCheck.cpp
new file mode 100644
index 00000000000..dc2d17093b3
--- /dev/null
+++ b/clang-tools-extra/clang-tidy/google/UnnamedNamespaceInHeaderCheck.cpp
@@ -0,0 +1,51 @@
+//===--- UnnamedNamespaceInHeaderCheck.cpp - clang-tidy ---------*- C++ -*-===//
+//
+// The LLVM Compiler Infrastructure
+//
+// This file is distributed under the University of Illinois Open Source
+// License. See LICENSE.TXT for details.
+//
+//===----------------------------------------------------------------------===//
+
+#include "UnnamedNamespaceInHeaderCheck.h"
+#include "clang/ASTMatchers/ASTMatchFinder.h"
+#include "clang/ASTMatchers/ASTMatchers.h"
+#include "clang/AST/ASTContext.h"
+
+using namespace clang::ast_matchers;
+
+namespace clang {
+namespace ast_matchers {
+AST_MATCHER(NamespaceDecl, isAnonymousNamespace) {
+ return Node.isAnonymousNamespace();
+}
+} // namespace ast_matchers
+
+namespace tidy {
+namespace build {
+
+void UnnamedNamespaceInHeaderCheck::registerMatchers(
+ ast_matchers::MatchFinder *Finder) {
+ Finder->addMatcher(
+ namespaceDecl(isAnonymousNamespace()).bind("anonymousNamespace"), this);
+}
+
+void
+UnnamedNamespaceInHeaderCheck::check(const MatchFinder::MatchResult &Result) {
+ SourceManager *SM = Result.SourceManager;
+ const auto *N = Result.Nodes.getNodeAs<NamespaceDecl>("anonymousNamespace");
+ SourceLocation Loc = N->getLocStart();
+ if (!Loc.isValid())
+ return;
+
+ // Look if we're inside a header, check for common suffixes only.
+ // TODO: Allow configuring the set of file extensions.
+ StringRef FileName = SM->getPresumedLoc(Loc).getFilename();
+ if (FileName.endswith(".h") || FileName.endswith(".hh") ||
+ FileName.endswith(".hpp") || FileName.endswith(".hxx"))
+ diag(Loc, "do not use unnamed namespaces in header files.");
+}
+
+} // namespace build
+} // namespace tidy
+} // namespace clang
OpenPOWER on IntegriCloud