// REQUIRES: plugins // RUN: clang-tidy -checks='-*,mytest*' --list-checks -load %llvmshlibdir/CTTestTidyModule%pluginext | FileCheck --check-prefix=CHECK-LIST %s // CHECK-LIST: Enabled checks: // CHECK-LIST-NEXT: mytest1 // CHECK-LIST-NEXT: mytest2 // RUN: clang-tidy -checks='-*,mytest*,misc-definitions-in-headers' -load %llvmshlibdir/CTTestTidyModule%pluginext /dev/null -- -xc 2>&1 | FileCheck %s // CHECK: 3 warnings generated. // CHECK-NEXT: warning: mytest success [misc-definitions-in-headers,mytest1,mytest2] #include "clang-tidy/ClangTidy.h" #include "clang-tidy/ClangTidyCheck.h" #include "clang-tidy/ClangTidyModule.h" #include "clang-tidy/ClangTidyModuleRegistry.h" #include "clang/AST/ASTContext.h" #include "clang/ASTMatchers/ASTMatchFinder.h" using namespace clang; using namespace clang::tidy; using namespace clang::ast_matchers; namespace { class MyTestCheck : public ClangTidyCheck { public: MyTestCheck(StringRef Name, ClangTidyContext *Context) : ClangTidyCheck(Name, Context) {} void registerMatchers(ast_matchers::MatchFinder *Finder) override { Finder->addMatcher(translationUnitDecl().bind("tu"), this); } void check(const ast_matchers::MatchFinder::MatchResult &Result) override { auto S = Result.Nodes.getNodeAs("tu"); if (S) diag("mytest success"); } private: }; class CTTestModule : public ClangTidyModule { public: void addCheckFactories(ClangTidyCheckFactories &CheckFactories) override { CheckFactories.registerCheck("mytest1"); CheckFactories.registerCheck("mytest2"); // intentionally collide with an existing test name, overriding it CheckFactories.registerCheck("misc-definitions-in-headers"); } }; } // namespace namespace tidy1 { // Register the CTTestTidyModule using this statically initialized variable. static ClangTidyModuleRegistry::Add<::CTTestModule> X("mytest-module", "Adds my checks."); } // namespace tidy1 namespace tidy2 { // intentionally collide with an existing test group name, merging with it static ClangTidyModuleRegistry::Add<::CTTestModule> X("misc-module", "Adds miscellaneous lint checks."); } // namespace tidy2 // This anchor is used to force the linker to link in the generated object file // and thus register the CTTestModule. volatile int CTTestModuleAnchorSource = 0;