blob: 47216368e15e19eeee8dba32bfa20622f5374ee2 [file] [log] [blame]
Daniel Jasperd07c8402013-07-29 08:19:24 +00001//===--- ClangTidyModule.h - clang-tidy -------------------------*- C++ -*-===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9
Alexander Kornienko66580552015-03-09 16:52:33 +000010#ifndef LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_CLANGTIDYMODULE_H
11#define LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_CLANGTIDYMODULE_H
Daniel Jasperd07c8402013-07-29 08:19:24 +000012
13#include "ClangTidy.h"
Daniel Jasperd07c8402013-07-29 08:19:24 +000014#include "llvm/ADT/StringRef.h"
Alexander Kornienkod3fdcf82014-09-10 11:25:43 +000015#include <functional>
16#include <map>
17#include <string>
Daniel Jasperd07c8402013-07-29 08:19:24 +000018#include <utility>
19
20namespace clang {
21namespace tidy {
22
Alexander Kornienkod3fdcf82014-09-10 11:25:43 +000023/// \brief A collection of \c ClangTidyCheckFactory instances.
Daniel Jasperd07c8402013-07-29 08:19:24 +000024///
Alexander Kornienkod3fdcf82014-09-10 11:25:43 +000025/// All clang-tidy modules register their check factories with an instance of
26/// this object.
27class ClangTidyCheckFactories {
Daniel Jasperd07c8402013-07-29 08:19:24 +000028public:
Mandeep Singh Grang7c7ea7d2016-11-08 07:50:19 +000029 typedef std::function<ClangTidyCheck *(StringRef Name,
30 ClangTidyContext *Context)>
31 CheckFactory;
Alexander Kornienko6e0cbc82014-09-12 08:53:36 +000032
Alexander Kornienkod3fdcf82014-09-10 11:25:43 +000033 /// \brief Registers check \p Factory with name \p Name.
34 ///
35 /// For all checks that have default constructors, use \c registerCheck.
Alexander Kornienko6e0cbc82014-09-12 08:53:36 +000036 void registerCheckFactory(StringRef Name, CheckFactory Factory);
Daniel Jasperd07c8402013-07-29 08:19:24 +000037
Alexander Kornienkod3fdcf82014-09-10 11:25:43 +000038 /// \brief Registers the \c CheckType with the name \p Name.
39 ///
40 /// This method should be used for all \c ClangTidyChecks that don't require
41 /// constructor parameters.
42 ///
43 /// For example, if have a clang-tidy check like:
44 /// \code
45 /// class MyTidyCheck : public ClangTidyCheck {
46 /// void registerMatchers(ast_matchers::MatchFinder *Finder) override {
47 /// ..
48 /// }
49 /// };
50 /// \endcode
51 /// you can register it with:
52 /// \code
53 /// class MyModule : public ClangTidyModule {
54 /// void addCheckFactories(ClangTidyCheckFactories &Factories) override {
55 /// Factories.registerCheck<MyTidyCheck>("myproject-my-check");
56 /// }
57 /// };
58 /// \endcode
Alexander Kornienko6e0cbc82014-09-12 08:53:36 +000059 template <typename CheckType> void registerCheck(StringRef CheckName) {
60 registerCheckFactory(CheckName,
61 [](StringRef Name, ClangTidyContext *Context) {
Mandeep Singh Grang7c7ea7d2016-11-08 07:50:19 +000062 return new CheckType(Name, Context);
63 });
Alexander Kornienkod3fdcf82014-09-10 11:25:43 +000064 }
Daniel Jasperd07c8402013-07-29 08:19:24 +000065
Alexander Kornienkod3fdcf82014-09-10 11:25:43 +000066 /// \brief Create instances of all checks matching \p CheckRegexString and
67 /// store them in \p Checks.
68 ///
69 /// The caller takes ownership of the return \c ClangTidyChecks.
Alexander Kornienko6e0cbc82014-09-12 08:53:36 +000070 void createChecks(ClangTidyContext *Context,
Alexander Kornienkod3fdcf82014-09-10 11:25:43 +000071 std::vector<std::unique_ptr<ClangTidyCheck>> &Checks);
72
Alexander Kornienko6e0cbc82014-09-12 08:53:36 +000073 typedef std::map<std::string, CheckFactory> FactoryMap;
Alexander Kornienkod3fdcf82014-09-10 11:25:43 +000074 FactoryMap::const_iterator begin() const { return Factories.begin(); }
75 FactoryMap::const_iterator end() const { return Factories.end(); }
76 bool empty() const { return Factories.empty(); }
77
78private:
79 FactoryMap Factories;
80};
Daniel Jasperd07c8402013-07-29 08:19:24 +000081
82/// \brief A clang-tidy module groups a number of \c ClangTidyChecks and gives
83/// them a prefixed name.
84class ClangTidyModule {
85public:
David Blaikiee04a3da2015-10-20 21:45:52 +000086 virtual ~ClangTidyModule() {}
Daniel Jasperd07c8402013-07-29 08:19:24 +000087
88 /// \brief Implement this function in order to register all \c CheckFactories
89 /// belonging to this module.
90 virtual void addCheckFactories(ClangTidyCheckFactories &CheckFactories) = 0;
Alexander Kornienko1efc4252014-10-16 11:27:57 +000091
92 /// \brief Gets default options for checks defined in this module.
93 virtual ClangTidyOptions getModuleOptions();
Daniel Jasperd07c8402013-07-29 08:19:24 +000094};
95
Daniel Jasperd07c8402013-07-29 08:19:24 +000096} // end namespace tidy
97} // end namespace clang
98
Alexander Kornienko66580552015-03-09 16:52:33 +000099#endif // LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_CLANGTIDYMODULE_H