ccf7f6397f256d0c5dab4199213b12e79f4c4b77
[platform/framework/web/crosswalk.git] / src / tools / clang / plugins / FindBadConstructsAction.cpp
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.
4
5 #include "FindBadConstructsAction.h"
6
7 #include "clang/Frontend/FrontendPluginRegistry.h"
8
9 #include "FindBadConstructsConsumer.h"
10
11 using namespace clang;
12
13 namespace chrome_checker {
14
15 FindBadConstructsAction::FindBadConstructsAction() {
16 }
17
18 std::unique_ptr<ASTConsumer> FindBadConstructsAction::CreateASTConsumer(
19     CompilerInstance& instance,
20     llvm::StringRef ref) {
21   return llvm::make_unique<FindBadConstructsConsumer>(instance, options_);
22 }
23
24 bool FindBadConstructsAction::ParseArgs(const CompilerInstance& instance,
25                                         const std::vector<std::string>& args) {
26   bool parsed = true;
27
28   for (size_t i = 0; i < args.size() && parsed; ++i) {
29     if (args[i] == "check-base-classes") {
30       // TODO(rsleevi): Remove this once http://crbug.com/123295 is fixed.
31       options_.check_base_classes = true;
32     } else if (args[i] == "check-weak-ptr-factory-order") {
33       // TODO(dmichael): Remove this once http://crbug.com/303818 is fixed.
34       options_.check_weak_ptr_factory_order = true;
35     } else if (args[i] == "check-enum-last-value") {
36       // TODO(tsepez): Enable this by default once http://crbug.com/356815
37       // and http://crbug.com/356816 are fixed.
38       options_.check_enum_last_value = true;
39     } else {
40       parsed = false;
41       llvm::errs() << "Unknown clang plugin argument: " << args[i] << "\n";
42     }
43   }
44
45   return parsed;
46 }
47
48 }  // namespace chrome_checker
49
50 static FrontendPluginRegistry::Add<chrome_checker::FindBadConstructsAction> X(
51     "find-bad-constructs",
52     "Finds bad C++ constructs");