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
use std::io::Write;
#[derive(Debug, Clone, Hash, PartialEq, Eq)]
pub enum Outcome {
NoError,
OverrideNoForce(String),
RequiredFileFromSubsystemNonexistant {
subsys: &'static str,
fname: String,
},
RequiredDataFromSubsystemNonexistant {
subsys: &'static str,
desc: String,
},
TwitterAPIError(String),
FileParsingFailed {
desc: &'static str,
errors: Vec<String>,
},
}
impl Outcome {
pub fn print_error<W: Write>(&self, err_out: &mut W) {
match *self {
Outcome::NoError => (),
Outcome::OverrideNoForce(ref fname) => {
writeln!(err_out, "File \"{}\" was not overriden to prevent data loss.", fname).unwrap();
writeln!(err_out, "Pass --force to override it.").unwrap();
}
Outcome::RequiredFileFromSubsystemNonexistant { ref subsys, ref fname } => {
writeln!(err_out, "Run the {} subsystem first to produce \"{}\".", subsys, fname).unwrap()
}
Outcome::RequiredDataFromSubsystemNonexistant { ref subsys, ref desc } => {
writeln!(err_out, "Run the {} subsystem first to {}.", subsys, desc).unwrap()
}
Outcome::TwitterAPIError(ref error) => writeln!(err_out, "Twitter API error: {}", error).unwrap(),
Outcome::FileParsingFailed { ref desc, ref errors } => {
writeln!(err_out, "Failed to parse {}{}", desc, if errors.is_empty() { '.' } else { ':' }).unwrap();
for err in errors {
writeln!(err_out, " {}", err).unwrap()
}
}
}
}
pub fn exit_value(&self) -> i32 {
match *self {
Outcome::NoError => 0,
Outcome::OverrideNoForce(_) => 1,
Outcome::RequiredFileFromSubsystemNonexistant { .. } |
Outcome::RequiredDataFromSubsystemNonexistant { .. } => 2,
Outcome::TwitterAPIError(_) => 3,
Outcome::FileParsingFailed { .. } => 4,
}
}
}