1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
|
//===--- TextDiagnostic.cpp - Text Diagnostic Pretty-Printing -------------===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//
//
// Coding style: https://mlir.llvm.org/getting_started/DeveloperGuide/
//
//===----------------------------------------------------------------------===//
#include "flang/Frontend/TextDiagnostic.h"
#include "clang/Basic/DiagnosticOptions.h"
#include "llvm/Support/raw_ostream.h"
using namespace Fortran::frontend;
// TODO: Similar enums are defined in clang/lib/Frontend/TextDiagnostic.cpp.
// It would be best to share them
static const enum llvm::raw_ostream::Colors noteColor =
llvm::raw_ostream::BLACK;
static const enum llvm::raw_ostream::Colors remarkColor =
llvm::raw_ostream::BLUE;
static const enum llvm::raw_ostream::Colors warningColor =
llvm::raw_ostream::MAGENTA;
static const enum llvm::raw_ostream::Colors errorColor = llvm::raw_ostream::RED;
static const enum llvm::raw_ostream::Colors fatalColor = llvm::raw_ostream::RED;
// Used for changing only the bold attribute.
static const enum llvm::raw_ostream::Colors savedColor =
llvm::raw_ostream::SAVEDCOLOR;
TextDiagnostic::TextDiagnostic() {}
TextDiagnostic::~TextDiagnostic() {}
/*static*/ void
TextDiagnostic::printDiagnosticLevel(llvm::raw_ostream &os,
clang::DiagnosticsEngine::Level level,
bool showColors) {
if (showColors) {
// Print diagnostic category in bold and color
switch (level) {
case clang::DiagnosticsEngine::Ignored:
llvm_unreachable("Invalid diagnostic type");
case clang::DiagnosticsEngine::Note:
os.changeColor(noteColor, true);
break;
case clang::DiagnosticsEngine::Remark:
os.changeColor(remarkColor, true);
break;
case clang::DiagnosticsEngine::Warning:
os.changeColor(warningColor, true);
break;
case clang::DiagnosticsEngine::Error:
os.changeColor(errorColor, true);
break;
case clang::DiagnosticsEngine::Fatal:
os.changeColor(fatalColor, true);
break;
}
}
switch (level) {
case clang::DiagnosticsEngine::Ignored:
llvm_unreachable("Invalid diagnostic type");
case clang::DiagnosticsEngine::Note:
os << "note";
break;
case clang::DiagnosticsEngine::Remark:
os << "remark";
break;
case clang::DiagnosticsEngine::Warning:
os << "warning";
break;
case clang::DiagnosticsEngine::Error:
os << "error";
break;
case clang::DiagnosticsEngine::Fatal:
os << "fatal error";
break;
}
os << ": ";
if (showColors)
os.resetColor();
}
/*static*/
void TextDiagnostic::printDiagnosticMessage(llvm::raw_ostream &os,
bool isSupplemental,
llvm::StringRef message,
bool showColors) {
if (showColors && !isSupplemental) {
// Print primary diagnostic messages in bold and without color.
os.changeColor(savedColor, true);
}
os << message;
if (showColors)
os.resetColor();
os << '\n';
}
|