1 //===- DiagnosticHandler.h - DiagnosticHandler class for LLVM -------------===//
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 //
10 //
11 //===----------------------------------------------------------------------===//
12 #include "llvm/IR/DiagnosticHandler.h"
13 #include "llvm/Support/CommandLine.h"
14 #include "llvm/Support/Regex.h"
15
16 using namespace llvm;
17
18 namespace {
19
20 /// Regular expression corresponding to the value given in one of the
21 /// -pass-remarks* command line flags. Passes whose name matches this regexp
22 /// will emit a diagnostic when calling the associated diagnostic function
23 /// (emitOptimizationRemark, emitOptimizationRemarkMissed or
24 /// emitOptimizationRemarkAnalysis).
25 struct PassRemarksOpt {
26 std::shared_ptr<Regex> Pattern;
27
operator =__anon2a80c7970111::PassRemarksOpt28 void operator=(const std::string &Val) {
29 // Create a regexp object to match pass names for emitOptimizationRemark.
30 if (!Val.empty()) {
31 Pattern = std::make_shared<Regex>(Val);
32 std::string RegexError;
33 if (!Pattern->isValid(RegexError))
34 report_fatal_error("Invalid regular expression '" + Val +
35 "' in -pass-remarks: " + RegexError,
36 false);
37 }
38 }
39 };
40
41 static PassRemarksOpt PassRemarksPassedOptLoc;
42 static PassRemarksOpt PassRemarksMissedOptLoc;
43 static PassRemarksOpt PassRemarksAnalysisOptLoc;
44
45 // -pass-remarks
46 // Command line flag to enable emitOptimizationRemark()
47 static cl::opt<PassRemarksOpt, true, cl::parser<std::string>> PassRemarks(
48 "pass-remarks", cl::value_desc("pattern"),
49 cl::desc("Enable optimization remarks from passes whose name match "
50 "the given regular expression"),
51 cl::Hidden, cl::location(PassRemarksPassedOptLoc), cl::ValueRequired,
52 cl::ZeroOrMore);
53
54 // -pass-remarks-missed
55 // Command line flag to enable emitOptimizationRemarkMissed()
56 static cl::opt<PassRemarksOpt, true, cl::parser<std::string>> PassRemarksMissed(
57 "pass-remarks-missed", cl::value_desc("pattern"),
58 cl::desc("Enable missed optimization remarks from passes whose name match "
59 "the given regular expression"),
60 cl::Hidden, cl::location(PassRemarksMissedOptLoc), cl::ValueRequired,
61 cl::ZeroOrMore);
62
63 // -pass-remarks-analysis
64 // Command line flag to enable emitOptimizationRemarkAnalysis()
65 static cl::opt<PassRemarksOpt, true, cl::parser<std::string>>
66 PassRemarksAnalysis(
67 "pass-remarks-analysis", cl::value_desc("pattern"),
68 cl::desc(
69 "Enable optimization analysis remarks from passes whose name match "
70 "the given regular expression"),
71 cl::Hidden, cl::location(PassRemarksAnalysisOptLoc), cl::ValueRequired,
72 cl::ZeroOrMore);
73 }
74
isAnalysisRemarkEnabled(StringRef PassName) const75 bool DiagnosticHandler::isAnalysisRemarkEnabled(StringRef PassName) const {
76 return (PassRemarksAnalysisOptLoc.Pattern &&
77 PassRemarksAnalysisOptLoc.Pattern->match(PassName));
78 }
isMissedOptRemarkEnabled(StringRef PassName) const79 bool DiagnosticHandler::isMissedOptRemarkEnabled(StringRef PassName) const {
80 return (PassRemarksMissedOptLoc.Pattern &&
81 PassRemarksMissedOptLoc.Pattern->match(PassName));
82 }
isPassedOptRemarkEnabled(StringRef PassName) const83 bool DiagnosticHandler::isPassedOptRemarkEnabled(StringRef PassName) const {
84 return (PassRemarksPassedOptLoc.Pattern &&
85 PassRemarksPassedOptLoc.Pattern->match(PassName));
86 }
87
isAnyRemarkEnabled() const88 bool DiagnosticHandler::isAnyRemarkEnabled() const {
89 return (PassRemarksPassedOptLoc.Pattern || PassRemarksMissedOptLoc.Pattern ||
90 PassRemarksAnalysisOptLoc.Pattern);
91 }
92