1 //===--- UsingNamespaceDirectiveCheck.h - clang-tidy ------------*- C++ -*-===//
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
7 //===----------------------------------------------------------------------===//
9 #ifndef LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_GOOGLE_USINGNAMESPACEDIRECTIVECHECK_H
10 #define LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_GOOGLE_USINGNAMESPACEDIRECTIVECHECK_H
12 #include "../ClangTidyCheck.h"
14 namespace clang::tidy::google::build
{
16 /// Finds using namespace directives.
18 /// https://google.github.io/styleguide/cppguide.html#Namespaces
20 /// The check implements the following rule of the Google C++ Style Guide:
22 /// You may not use a using-directive to make all names from a namespace
26 /// // Forbidden -- This pollutes the namespace.
27 /// using namespace foo;
30 /// Corresponding cpplint.py check name: `build/namespaces`.
32 /// For the user-facing documentation see:
33 /// https://clang.llvm.org/extra/clang-tidy/checks/google/build-using-namespace.html
34 class UsingNamespaceDirectiveCheck
: public ClangTidyCheck
{
36 UsingNamespaceDirectiveCheck(StringRef Name
, ClangTidyContext
*Context
)
37 : ClangTidyCheck(Name
, Context
) {}
38 bool isLanguageVersionSupported(const LangOptions
&LangOpts
) const override
{
39 return LangOpts
.CPlusPlus
;
41 void registerMatchers(ast_matchers::MatchFinder
*Finder
) override
;
42 void check(const ast_matchers::MatchFinder::MatchResult
&Result
) override
;
45 static bool isStdLiteralsNamespace(const NamespaceDecl
*NS
);
48 } // namespace clang::tidy::google::build
50 #endif // LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_GOOGLE_USINGNAMESPACEDIRECTIVECHECK_H