// Copyright (c) 2012 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef TOOLS_CLANG_PLUGINS_CHROMECLASSTESTER_H_ #define TOOLS_CLANG_PLUGINS_CHROMECLASSTESTER_H_ #include <set> #include <vector> #include "Options.h" #include "clang/AST/ASTConsumer.h" #include "clang/AST/TypeLoc.h" #include "clang/Frontend/CompilerInstance.h" // A class on top of ASTConsumer that forwards classes defined in Chromium // headers to subclasses which implement CheckChromeClass(). // TODO(vmpstr): Fold this class into FindBadConstructsConsumer. class ChromeClassTester { public: ChromeClassTester(clang::CompilerInstance& instance, const chrome_checker::Options& options); virtual ~ChromeClassTester(); void CheckTag(clang::TagDecl*); clang::DiagnosticsEngine::Level getErrorLevel(); protected: clang::CompilerInstance& instance() { return instance_; } clang::DiagnosticsEngine& diagnostic() { return diagnostic_; } // Utility method for subclasses to check how a certain SourceLocation should // be handled. The main criteria for classification is the SourceLocation's // path (e.g. whether it's in //third_party). enum class LocationType { // Enforce all default checks. kChrome, // Enforces a subset of checks for Blink code. This is hopefully a // transitional stage, as more plugin checks are gradually enabled in Blink. kBlink, // Skip all checks. Typically, this is third-party or generated code where // it doesn't make sense to enforce Chrome's custom diagnostics. kThirdParty, }; LocationType ClassifyLocation(clang::SourceLocation loc); // Utility method to check whether the given record has any of the ignored // base classes. bool HasIgnoredBases(const clang::CXXRecordDecl* record); // Utility method for subclasses to check if this class is within an // implementation (.cc, .cpp, .mm) file. bool InImplementationFile(clang::SourceLocation location); // Options. const chrome_checker::Options options_; private: void BuildBannedLists(); // Filtered versions of tags that are only called with things defined in // chrome header files. virtual void CheckChromeClass(LocationType location_type, clang::SourceLocation record_location, clang::CXXRecordDecl* record) = 0; // Utility methods used for filtering out non-chrome classes (and ones we // deliberately ignore) in HandleTagDeclDefinition(). bool IsIgnoredType(const std::string& base_name); // Attempts to determine the filename for the given SourceLocation. // Returns false if the filename could not be determined. bool GetFilename(clang::SourceLocation loc, std::string* filename); clang::CompilerInstance& instance_; clang::DiagnosticsEngine& diagnostic_; // List of banned directories. std::set<std::string> banned_directories_; // List of types that we don't check. std::set<std::string> ignored_record_names_; // List of base classes that we skip when checking complex class ctors/dtors. std::set<std::string> ignored_base_classes_; }; #endif // TOOLS_CLANG_PLUGINS_CHROMECLASSTESTER_H_