summaryrefslogtreecommitdiffstats
path: root/clang-tools-extra/clang-tidy/misc/DefinitionsInHeadersCheck.cpp
diff options
context:
space:
mode:
authorHaojian Wu <hokein@google.com>2016-02-05 11:23:59 +0000
committerHaojian Wu <hokein@google.com>2016-02-05 11:23:59 +0000
commitc2d7577cc552b248857253f99a401800bc010100 (patch)
tree1146fd04b4d6781a76196f3e3aacad3006722396 /clang-tools-extra/clang-tidy/misc/DefinitionsInHeadersCheck.cpp
parent5990cd5a0c8fde4baceea0734ae9e086e987f577 (diff)
downloadbcm5719-llvm-c2d7577cc552b248857253f99a401800bc010100.tar.gz
bcm5719-llvm-c2d7577cc552b248857253f99a401800bc010100.zip
[clang-tdiy] Add header file extension configuration support.
Summary: * Add a `HeaderFileExtensions` check option in misc-definitions-in-headers, google-build-namespaces and google-global-names-in-headers. Reviewers: aaron.ballman, alexfh Subscribers: cfe-commits Differential Revision: http://reviews.llvm.org/D16113 llvm-svn: 259879
Diffstat (limited to 'clang-tools-extra/clang-tidy/misc/DefinitionsInHeadersCheck.cpp')
-rw-r--r--clang-tools-extra/clang-tidy/misc/DefinitionsInHeadersCheck.cpp40
1 files changed, 26 insertions, 14 deletions
diff --git a/clang-tools-extra/clang-tidy/misc/DefinitionsInHeadersCheck.cpp b/clang-tools-extra/clang-tidy/misc/DefinitionsInHeadersCheck.cpp
index 1b9cf29c041..e6d7567ec93 100644
--- a/clang-tools-extra/clang-tidy/misc/DefinitionsInHeadersCheck.cpp
+++ b/clang-tools-extra/clang-tidy/misc/DefinitionsInHeadersCheck.cpp
@@ -19,38 +19,50 @@ namespace misc {
namespace {
-AST_MATCHER(NamedDecl, isHeaderFileExtension) {
- SourceManager& SM = Finder->getASTContext().getSourceManager();
- SourceLocation ExpansionLoc = SM.getExpansionLoc(Node.getLocStart());
- StringRef Filename = SM.getFilename(ExpansionLoc);
- return Filename.endswith(".h") || Filename.endswith(".hh") ||
- Filename.endswith(".hpp") || Filename.endswith(".hxx") ||
- llvm::sys::path::extension(Filename).empty();
+AST_MATCHER_P(NamedDecl, usesHeaderFileExtension,
+ utils::HeaderFileExtensionsSet, HeaderFileExtensions) {
+ return utils::isExpansionLocInHeaderFile(
+ Node.getLocStart(), Finder->getASTContext().getSourceManager(),
+ HeaderFileExtensions);
}
} // namespace
-DefinitionsInHeadersCheck::DefinitionsInHeadersCheck(
- StringRef Name, ClangTidyContext *Context)
- : ClangTidyCheck(Name, Context),
- UseHeaderFileExtension(Options.get("UseHeaderFileExtension", true)) {}
+DefinitionsInHeadersCheck::DefinitionsInHeadersCheck(StringRef Name,
+ ClangTidyContext *Context)
+ : ClangTidyCheck(Name, Context),
+ UseHeaderFileExtension(Options.get("UseHeaderFileExtension", true)),
+ RawStringHeaderFileExtensions(
+ Options.getLocalOrGlobal("HeaderFileExtensions", ",h,hh,hpp,hxx")) {
+ if (!utils::parseHeaderFileExtensions(RawStringHeaderFileExtensions,
+ HeaderFileExtensions,
+ ',')) {
+ // FIXME: Find a more suitable way to handle invalid configuration
+ // options.
+ llvm::errs() << "Invalid header file extension: "
+ << RawStringHeaderFileExtensions << "\n";
+ }
+}
void DefinitionsInHeadersCheck::storeOptions(
ClangTidyOptions::OptionMap &Opts) {
Options.store(Opts, "UseHeaderFileExtension", UseHeaderFileExtension);
+ Options.store(Opts, "HeaderFileExtensions", RawStringHeaderFileExtensions);
}
void DefinitionsInHeadersCheck::registerMatchers(MatchFinder *Finder) {
if (UseHeaderFileExtension) {
Finder->addMatcher(
namedDecl(anyOf(functionDecl(isDefinition()), varDecl(isDefinition())),
- isHeaderFileExtension()).bind("name-decl"),
+ usesHeaderFileExtension(HeaderFileExtensions))
+ .bind("name-decl"),
this);
} else {
Finder->addMatcher(
namedDecl(anyOf(functionDecl(isDefinition()), varDecl(isDefinition())),
- anyOf(isHeaderFileExtension(),
- unless(isExpansionInMainFile()))).bind("name-decl"),
+ anyOf(usesHeaderFileExtension(HeaderFileExtensions),
+ unless(isExpansionInMainFile())))
+ .bind("name-decl"),
this);
}
}
OpenPOWER on IntegriCloud