1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef TOOLS_CLANG_PLUGINS_CHROMECLASSTESTER_H_
6 #define TOOLS_CLANG_PLUGINS_CHROMECLASSTESTER_H_
11 #include "clang/AST/ASTConsumer.h"
12 #include "clang/AST/TypeLoc.h"
13 #include "clang/Frontend/CompilerInstance.h"
15 // A class on top of ASTConsumer that forwards classes defined in Chromium
16 // headers to subclasses which implement CheckChromeClass().
17 class ChromeClassTester
: public clang::ASTConsumer
{
19 explicit ChromeClassTester(clang::CompilerInstance
& instance
);
20 virtual ~ChromeClassTester();
22 // clang::ASTConsumer:
23 virtual void HandleTagDeclDefinition(clang::TagDecl
* tag
);
24 virtual bool HandleTopLevelDecl(clang::DeclGroupRef group_ref
);
26 void CheckTag(clang::TagDecl
*);
29 clang::CompilerInstance
& instance() { return instance_
; }
30 clang::DiagnosticsEngine
& diagnostic() { return diagnostic_
; }
32 // Emits a simple warning; this shouldn't be used if you require printf-style
34 void emitWarning(clang::SourceLocation loc
, const char* error
);
36 // Utility method for subclasses to check if this class is in a banned
38 bool InBannedNamespace(const clang::Decl
* record
);
40 // Utility method for subclasses to determine the namespace of the
41 // specified record, if any. Unnamed namespaces will be identified as
42 // "<anonymous namespace>".
43 std::string
GetNamespace(const clang::Decl
* record
);
45 // Utility method for subclasses to check if this class is within an
46 // implementation (.cc, .cpp, .mm) file.
47 bool InImplementationFile(clang::SourceLocation location
);
50 void BuildBannedLists();
52 // Filtered versions of tags that are only called with things defined in
53 // chrome header files.
54 virtual void CheckChromeClass(clang::SourceLocation record_location
,
55 clang::CXXRecordDecl
* record
) = 0;
57 // Filtered versions of enum type that are only called with things defined
58 // in chrome header files.
59 virtual void CheckChromeEnum(clang::SourceLocation enum_location
,
60 clang::EnumDecl
* enum_decl
) {
63 // Utility methods used for filtering out non-chrome classes (and ones we
64 // deliberately ignore) in HandleTagDeclDefinition().
65 std::string
GetNamespaceImpl(const clang::DeclContext
* context
,
66 const std::string
& candidate
);
67 bool InBannedDirectory(clang::SourceLocation loc
);
68 bool IsIgnoredType(const std::string
& base_name
);
70 // Attempts to determine the filename for the given SourceLocation.
71 // Returns false if the filename could not be determined.
72 bool GetFilename(clang::SourceLocation loc
, std::string
* filename
);
74 clang::CompilerInstance
& instance_
;
75 clang::DiagnosticsEngine
& diagnostic_
;
77 // List of banned namespaces.
78 std::vector
<std::string
> banned_namespaces_
;
80 // List of banned directories.
81 std::vector
<std::string
> banned_directories_
;
83 // List of types that we don't check.
84 std::set
<std::string
> ignored_record_names_
;
86 // List of decls to check once the current top-level decl is parsed.
87 std::vector
<clang::TagDecl
*> pending_class_decls_
;
90 #endif // TOOLS_CLANG_PLUGINS_CHROMECLASSTESTER_H_