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
mod helper;
mod setup_guard;
mod subcommand;
use ckb_app_config::{cli, ExitCode, Setup};
use ckb_async_runtime::new_global_runtime;
use ckb_build_info::Version;
use helper::raise_fd_limit;
use setup_guard::SetupGuard;
#[cfg(feature = "with_sentry")]
pub(crate) const LOG_TARGET_SENTRY: &str = "sentry";
pub fn run_app(version: Version) -> Result<(), ExitCode> {
::std::env::set_var("RUST_BACKTRACE", "full");
let (bin_name, app_matches) = cli::get_bin_name_and_matches(&version);
match app_matches.subcommand() {
(cli::CMD_INIT, Some(matches)) => {
return subcommand::init(Setup::init(&matches)?);
}
(cli::CMD_LIST_HASHES, Some(matches)) => {
return subcommand::list_hashes(Setup::root_dir_from_matches(&matches)?, matches);
}
(cli::CMD_PEERID, Some(matches)) => match matches.subcommand() {
(cli::CMD_GEN_SECRET, Some(matches)) => return Setup::gen(&matches),
(cli::CMD_FROM_SECRET, Some(matches)) => {
return subcommand::peer_id(Setup::peer_id(&matches)?);
}
_ => {}
},
_ => {
}
}
let (cmd, matches) = app_matches.subcommand();
let matches = matches.expect("SubcommandRequiredElseHelp");
let is_silent_logging = is_silent_logging(cmd);
let (handle, mut rt_stop) = new_global_runtime();
let setup = Setup::from_matches(bin_name, &app_matches)?;
let _guard = SetupGuard::from_setup(&setup, &version, handle.clone(), is_silent_logging)?;
raise_fd_limit();
let ret = match cmd {
cli::CMD_RUN => subcommand::run(setup.run(&matches)?, version, handle),
cli::CMD_MINER => subcommand::miner(setup.miner(&matches)?, handle),
cli::CMD_REPLAY => subcommand::replay(setup.replay(&matches)?, handle),
cli::CMD_EXPORT => subcommand::export(setup.export(&matches)?, handle),
cli::CMD_IMPORT => subcommand::import(setup.import(&matches)?, handle),
cli::CMD_STATS => subcommand::stats(setup.stats(&matches)?, handle),
cli::CMD_RESET_DATA => subcommand::reset_data(setup.reset_data(&matches)?),
cli::CMD_MIGRATE => subcommand::migrate(setup.migrate(&matches)?),
cli::CMD_DB_REPAIR => subcommand::db_repair(setup.db_repair(&matches)?),
_ => unreachable!(),
};
rt_stop.try_send(());
ret
}
type Silent = bool;
fn is_silent_logging(cmd: &str) -> Silent {
matches!(
cmd,
cli::CMD_EXPORT
| cli::CMD_IMPORT
| cli::CMD_STATS
| cli::CMD_MIGRATE
| cli::CMD_DB_REPAIR
| cli::CMD_RESET_DATA
)
}