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
use serde::{Deserialize, Serialize};
#[derive(Debug, Default, Clone, PartialEq, Eq, PartialOrd, Ord, Hash, Serialize, Deserialize)]
pub struct TscError {
#[serde(default)]
pub file: Option<String>,
pub line: usize,
pub col: usize,
pub code: usize,
}
impl TscError {
pub fn ts_error_code(&self) -> String {
format!("TS{}", self.code)
}
pub fn parse_all(output: &str) -> Vec<Self> {
let mut errors = vec![];
'outer: for line in output.lines() {
if line.trim().is_empty() || line.starts_with(|c: char| c.is_whitespace()) {
continue;
}
let mut error = TscError::default();
for (idx, item) in line.split(':').enumerate() {
match idx {
0 => {
let item = item.strip_prefix("\u{001b}[96m");
let item = match item {
Some(v) => v,
None => continue 'outer,
};
let item = item.strip_suffix("\u{001b}[0m").expect("expected colored output");
error.file = Some(item.to_string());
}
1 => {
let item = item
.strip_prefix("\u{001b}[93m")
.expect("expected colored output")
.strip_suffix("\u{001b}[0m")
.expect("expected colored output");
error.line = item.parse().expect("failed to parse line");
}
2 => {
for (j, item) in item.split(' ').enumerate() {
if let Some(item) = item.strip_prefix("TS") {
error.code = item.parse().expect("failed to parse ts error code");
continue;
}
if j == 0 {
let item = item
.strip_prefix("\u{001b}[93m")
.expect("expected colored output")
.strip_suffix("\u{001b}[0m")
.expect("expected colored output");
error.col = item.parse().expect("failed to parse column");
}
}
}
3 => {
}
_ => {}
}
}
errors.push(error);
}
errors
}
}