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
#![feature(bool_to_option)]
#![feature(exhaustive_patterns)]
#![feature(generator_trait)]
#![feature(generators)]
#![feature(never_type)]
#![warn(missing_docs, unsafe_op_in_unsafe_fn)]
#![warn(clippy::pedantic)]
#![allow(
clippy::cast_possible_truncation,
clippy::cast_precision_loss,
clippy::cast_sign_loss,
clippy::doc_markdown,
clippy::missing_errors_doc,
clippy::missing_panics_doc,
clippy::module_name_repetitions,
clippy::must_use_candidate,
clippy::needless_pass_by_value,
clippy::similar_names,
clippy::unneeded_field_pattern,
clippy::wildcard_imports
)]
pub mod cli;
pub mod cmd;
pub mod color;
pub mod crates;
pub mod devices;
pub mod heap;
pub mod log;
pub mod probe;
pub mod templates;
pub mod utils;
use self::cli::{Cli, Cmd};
use ::log::Level;
use anyhow::Result;
use env_logger::Builder as LoggerBuilder;
impl Cli {
pub fn run(self) -> Result<()> {
let Self { cmd, color, verbosity } = self;
let log_level = match verbosity {
0 => Level::Error,
1 => Level::Warn,
2 => Level::Info,
3 => Level::Debug,
_ => Level::Trace,
};
LoggerBuilder::new()
.filter(Some(env!("CARGO_PKG_NAME")), log_level.to_level_filter())
.filter(None, Level::Warn.to_level_filter())
.try_init()?;
match cmd {
Cmd::Flash(cmd) => cmd::flash(cmd),
Cmd::Gdb(cmd) => cmd::gdb(cmd),
Cmd::Heap(cmd) => cmd::heap(cmd, color),
Cmd::Log(cmd) => cmd::log(cmd, color),
Cmd::New(cmd) => cmd::new(cmd, color),
Cmd::Reset(cmd) => cmd::reset(cmd),
Cmd::Print(cmd) => cmd::print(cmd, color),
}
}
}