Mercurial > public > mercurial-scm > hg-stable
annotate rust/chg/src/main.rs @ 47408:f7f082bc0e7c
revlog: allow to pass an existing docket to `_loadindex()`
This will be when switching undelying files, for examples during censors and strip operation with rvlog-v2.
Differential Revision: https://phab.mercurial-scm.org/D10800
author | Pierre-Yves David <pierre-yves.david@octobus.net> |
---|---|
date | Sun, 30 May 2021 18:09:29 +0200 |
parents | 4b0185841058 |
children |
rev | line source |
---|---|
39968 | 1 // Copyright 2018 Yuya Nishihara <yuya@tcha.org> |
2 // | |
3 // This software may be used and distributed according to the terms of the | |
4 // GNU General Public License version 2 or any later version. | |
5 | |
44682
00ac60658654
rust-chg: collect server flags from command arguments
Yuya Nishihara <yuya@tcha.org>
parents:
44674
diff
changeset
|
6 use chg::locator::{self, Locator}; |
40121
89742f1fa6cb
rust-chg: install signal handlers to forward signals to server
Yuya Nishihara <yuya@tcha.org>
parents:
39980
diff
changeset
|
7 use chg::procutil; |
44854
9fc9526e283a
rust-chg: modernize entry function
Yuya Nishihara <yuya@tcha.org>
parents:
44694
diff
changeset
|
8 use chg::ChgUiHandler; |
39980
6bdee4bc181a
rust-chg: add main program
Yuya Nishihara <yuya@tcha.org>
parents:
39968
diff
changeset
|
9 use std::env; |
6bdee4bc181a
rust-chg: add main program
Yuya Nishihara <yuya@tcha.org>
parents:
39968
diff
changeset
|
10 use std::io; |
44854
9fc9526e283a
rust-chg: modernize entry function
Yuya Nishihara <yuya@tcha.org>
parents:
44694
diff
changeset
|
11 use std::io::Write; |
39980
6bdee4bc181a
rust-chg: add main program
Yuya Nishihara <yuya@tcha.org>
parents:
39968
diff
changeset
|
12 use std::process; |
40288
87c76e5f3427
rust-chg: install logger if $CHGDEBUG is set
Yuya Nishihara <yuya@tcha.org>
parents:
40286
diff
changeset
|
13 use std::time::Instant; |
39980
6bdee4bc181a
rust-chg: add main program
Yuya Nishihara <yuya@tcha.org>
parents:
39968
diff
changeset
|
14 |
40288
87c76e5f3427
rust-chg: install logger if $CHGDEBUG is set
Yuya Nishihara <yuya@tcha.org>
parents:
40286
diff
changeset
|
15 struct DebugLogger { |
87c76e5f3427
rust-chg: install logger if $CHGDEBUG is set
Yuya Nishihara <yuya@tcha.org>
parents:
40286
diff
changeset
|
16 start: Instant, |
87c76e5f3427
rust-chg: install logger if $CHGDEBUG is set
Yuya Nishihara <yuya@tcha.org>
parents:
40286
diff
changeset
|
17 } |
87c76e5f3427
rust-chg: install logger if $CHGDEBUG is set
Yuya Nishihara <yuya@tcha.org>
parents:
40286
diff
changeset
|
18 |
87c76e5f3427
rust-chg: install logger if $CHGDEBUG is set
Yuya Nishihara <yuya@tcha.org>
parents:
40286
diff
changeset
|
19 impl DebugLogger { |
87c76e5f3427
rust-chg: install logger if $CHGDEBUG is set
Yuya Nishihara <yuya@tcha.org>
parents:
40286
diff
changeset
|
20 pub fn new() -> DebugLogger { |
87c76e5f3427
rust-chg: install logger if $CHGDEBUG is set
Yuya Nishihara <yuya@tcha.org>
parents:
40286
diff
changeset
|
21 DebugLogger { |
87c76e5f3427
rust-chg: install logger if $CHGDEBUG is set
Yuya Nishihara <yuya@tcha.org>
parents:
40286
diff
changeset
|
22 start: Instant::now(), |
87c76e5f3427
rust-chg: install logger if $CHGDEBUG is set
Yuya Nishihara <yuya@tcha.org>
parents:
40286
diff
changeset
|
23 } |
87c76e5f3427
rust-chg: install logger if $CHGDEBUG is set
Yuya Nishihara <yuya@tcha.org>
parents:
40286
diff
changeset
|
24 } |
87c76e5f3427
rust-chg: install logger if $CHGDEBUG is set
Yuya Nishihara <yuya@tcha.org>
parents:
40286
diff
changeset
|
25 } |
87c76e5f3427
rust-chg: install logger if $CHGDEBUG is set
Yuya Nishihara <yuya@tcha.org>
parents:
40286
diff
changeset
|
26 |
87c76e5f3427
rust-chg: install logger if $CHGDEBUG is set
Yuya Nishihara <yuya@tcha.org>
parents:
40286
diff
changeset
|
27 impl log::Log for DebugLogger { |
87c76e5f3427
rust-chg: install logger if $CHGDEBUG is set
Yuya Nishihara <yuya@tcha.org>
parents:
40286
diff
changeset
|
28 fn enabled(&self, metadata: &log::Metadata) -> bool { |
87c76e5f3427
rust-chg: install logger if $CHGDEBUG is set
Yuya Nishihara <yuya@tcha.org>
parents:
40286
diff
changeset
|
29 metadata.target().starts_with("chg::") |
87c76e5f3427
rust-chg: install logger if $CHGDEBUG is set
Yuya Nishihara <yuya@tcha.org>
parents:
40286
diff
changeset
|
30 } |
87c76e5f3427
rust-chg: install logger if $CHGDEBUG is set
Yuya Nishihara <yuya@tcha.org>
parents:
40286
diff
changeset
|
31 |
87c76e5f3427
rust-chg: install logger if $CHGDEBUG is set
Yuya Nishihara <yuya@tcha.org>
parents:
40286
diff
changeset
|
32 fn log(&self, record: &log::Record) { |
87c76e5f3427
rust-chg: install logger if $CHGDEBUG is set
Yuya Nishihara <yuya@tcha.org>
parents:
40286
diff
changeset
|
33 if self.enabled(record.metadata()) { |
87c76e5f3427
rust-chg: install logger if $CHGDEBUG is set
Yuya Nishihara <yuya@tcha.org>
parents:
40286
diff
changeset
|
34 // just make the output looks similar to chg of C |
87c76e5f3427
rust-chg: install logger if $CHGDEBUG is set
Yuya Nishihara <yuya@tcha.org>
parents:
40286
diff
changeset
|
35 let l = format!("{}", record.level()).to_lowercase(); |
87c76e5f3427
rust-chg: install logger if $CHGDEBUG is set
Yuya Nishihara <yuya@tcha.org>
parents:
40286
diff
changeset
|
36 let t = self.start.elapsed(); |
43836
ce088b38f92b
rust: run rustfmt
Gregory Szorc <gregory.szorc@gmail.com>
parents:
40288
diff
changeset
|
37 writeln!( |
ce088b38f92b
rust: run rustfmt
Gregory Szorc <gregory.szorc@gmail.com>
parents:
40288
diff
changeset
|
38 io::stderr(), |
ce088b38f92b
rust: run rustfmt
Gregory Szorc <gregory.szorc@gmail.com>
parents:
40288
diff
changeset
|
39 "chg: {}: {}.{:06} {}", |
ce088b38f92b
rust: run rustfmt
Gregory Szorc <gregory.szorc@gmail.com>
parents:
40288
diff
changeset
|
40 l, |
ce088b38f92b
rust: run rustfmt
Gregory Szorc <gregory.szorc@gmail.com>
parents:
40288
diff
changeset
|
41 t.as_secs(), |
ce088b38f92b
rust: run rustfmt
Gregory Szorc <gregory.szorc@gmail.com>
parents:
40288
diff
changeset
|
42 t.subsec_micros(), |
ce088b38f92b
rust: run rustfmt
Gregory Szorc <gregory.szorc@gmail.com>
parents:
40288
diff
changeset
|
43 record.args() |
ce088b38f92b
rust: run rustfmt
Gregory Szorc <gregory.szorc@gmail.com>
parents:
40288
diff
changeset
|
44 ) |
ce088b38f92b
rust: run rustfmt
Gregory Szorc <gregory.szorc@gmail.com>
parents:
40288
diff
changeset
|
45 .unwrap_or(()); |
40288
87c76e5f3427
rust-chg: install logger if $CHGDEBUG is set
Yuya Nishihara <yuya@tcha.org>
parents:
40286
diff
changeset
|
46 } |
87c76e5f3427
rust-chg: install logger if $CHGDEBUG is set
Yuya Nishihara <yuya@tcha.org>
parents:
40286
diff
changeset
|
47 } |
87c76e5f3427
rust-chg: install logger if $CHGDEBUG is set
Yuya Nishihara <yuya@tcha.org>
parents:
40286
diff
changeset
|
48 |
43836
ce088b38f92b
rust: run rustfmt
Gregory Szorc <gregory.szorc@gmail.com>
parents:
40288
diff
changeset
|
49 fn flush(&self) {} |
40288
87c76e5f3427
rust-chg: install logger if $CHGDEBUG is set
Yuya Nishihara <yuya@tcha.org>
parents:
40286
diff
changeset
|
50 } |
87c76e5f3427
rust-chg: install logger if $CHGDEBUG is set
Yuya Nishihara <yuya@tcha.org>
parents:
40286
diff
changeset
|
51 |
39968 | 52 fn main() { |
40288
87c76e5f3427
rust-chg: install logger if $CHGDEBUG is set
Yuya Nishihara <yuya@tcha.org>
parents:
40286
diff
changeset
|
53 if env::var_os("CHGDEBUG").is_some() { |
87c76e5f3427
rust-chg: install logger if $CHGDEBUG is set
Yuya Nishihara <yuya@tcha.org>
parents:
40286
diff
changeset
|
54 log::set_boxed_logger(Box::new(DebugLogger::new())) |
87c76e5f3427
rust-chg: install logger if $CHGDEBUG is set
Yuya Nishihara <yuya@tcha.org>
parents:
40286
diff
changeset
|
55 .expect("any logger should not be installed yet"); |
87c76e5f3427
rust-chg: install logger if $CHGDEBUG is set
Yuya Nishihara <yuya@tcha.org>
parents:
40286
diff
changeset
|
56 log::set_max_level(log::LevelFilter::Debug); |
87c76e5f3427
rust-chg: install logger if $CHGDEBUG is set
Yuya Nishihara <yuya@tcha.org>
parents:
40286
diff
changeset
|
57 } |
87c76e5f3427
rust-chg: install logger if $CHGDEBUG is set
Yuya Nishihara <yuya@tcha.org>
parents:
40286
diff
changeset
|
58 |
44672
bb936e25a84a
rust-chg: spawn server process if not running
Yuya Nishihara <yuya@tcha.org>
parents:
43836
diff
changeset
|
59 // TODO: add loop detection by $CHGINTERNALMARK |
bb936e25a84a
rust-chg: spawn server process if not running
Yuya Nishihara <yuya@tcha.org>
parents:
43836
diff
changeset
|
60 |
44694
5ac5c25ea97b
rust-chg: move get_umask() call out of run() function
Yuya Nishihara <yuya@tcha.org>
parents:
44689
diff
changeset
|
61 let umask = unsafe { procutil::get_umask() }; // not thread safe |
5ac5c25ea97b
rust-chg: move get_umask() call out of run() function
Yuya Nishihara <yuya@tcha.org>
parents:
44689
diff
changeset
|
62 let code = run(umask).unwrap_or_else(|err| { |
40286
af52181f71ff
rust-chg: suppress panic while writing chg error to stderr
Yuya Nishihara <yuya@tcha.org>
parents:
40121
diff
changeset
|
63 writeln!(io::stderr(), "chg: abort: {}", err).unwrap_or(()); |
39980
6bdee4bc181a
rust-chg: add main program
Yuya Nishihara <yuya@tcha.org>
parents:
39968
diff
changeset
|
64 255 |
6bdee4bc181a
rust-chg: add main program
Yuya Nishihara <yuya@tcha.org>
parents:
39968
diff
changeset
|
65 }); |
6bdee4bc181a
rust-chg: add main program
Yuya Nishihara <yuya@tcha.org>
parents:
39968
diff
changeset
|
66 process::exit(code); |
39968 | 67 } |
39980
6bdee4bc181a
rust-chg: add main program
Yuya Nishihara <yuya@tcha.org>
parents:
39968
diff
changeset
|
68 |
44854
9fc9526e283a
rust-chg: modernize entry function
Yuya Nishihara <yuya@tcha.org>
parents:
44694
diff
changeset
|
69 #[tokio::main] |
9fc9526e283a
rust-chg: modernize entry function
Yuya Nishihara <yuya@tcha.org>
parents:
44694
diff
changeset
|
70 async fn run(umask: u32) -> io::Result<i32> { |
44682
00ac60658654
rust-chg: collect server flags from command arguments
Yuya Nishihara <yuya@tcha.org>
parents:
44674
diff
changeset
|
71 let mut loc = Locator::prepare_from_env()?; |
00ac60658654
rust-chg: collect server flags from command arguments
Yuya Nishihara <yuya@tcha.org>
parents:
44674
diff
changeset
|
72 loc.set_early_args(locator::collect_early_args(env::args_os().skip(1))); |
44854
9fc9526e283a
rust-chg: modernize entry function
Yuya Nishihara <yuya@tcha.org>
parents:
44694
diff
changeset
|
73 let mut handler = ChgUiHandler::new(); |
9fc9526e283a
rust-chg: modernize entry function
Yuya Nishihara <yuya@tcha.org>
parents:
44694
diff
changeset
|
74 let mut client = loc.connect().await?; |
9fc9526e283a
rust-chg: modernize entry function
Yuya Nishihara <yuya@tcha.org>
parents:
44694
diff
changeset
|
75 client |
9fc9526e283a
rust-chg: modernize entry function
Yuya Nishihara <yuya@tcha.org>
parents:
44694
diff
changeset
|
76 .attach_io(&io::stdin(), &io::stdout(), &io::stderr()) |
9fc9526e283a
rust-chg: modernize entry function
Yuya Nishihara <yuya@tcha.org>
parents:
44694
diff
changeset
|
77 .await?; |
9fc9526e283a
rust-chg: modernize entry function
Yuya Nishihara <yuya@tcha.org>
parents:
44694
diff
changeset
|
78 client.set_umask(umask).await?; |
9fc9526e283a
rust-chg: modernize entry function
Yuya Nishihara <yuya@tcha.org>
parents:
44694
diff
changeset
|
79 let pid = client.server_spec().process_id.unwrap(); |
9fc9526e283a
rust-chg: modernize entry function
Yuya Nishihara <yuya@tcha.org>
parents:
44694
diff
changeset
|
80 let pgid = client.server_spec().process_group_id; |
9fc9526e283a
rust-chg: modernize entry function
Yuya Nishihara <yuya@tcha.org>
parents:
44694
diff
changeset
|
81 procutil::setup_signal_handler_once(pid, pgid)?; |
9fc9526e283a
rust-chg: modernize entry function
Yuya Nishihara <yuya@tcha.org>
parents:
44694
diff
changeset
|
82 let code = client |
9fc9526e283a
rust-chg: modernize entry function
Yuya Nishihara <yuya@tcha.org>
parents:
44694
diff
changeset
|
83 .run_command_chg(&mut handler, env::args_os().skip(1)) |
9fc9526e283a
rust-chg: modernize entry function
Yuya Nishihara <yuya@tcha.org>
parents:
44694
diff
changeset
|
84 .await?; |
9fc9526e283a
rust-chg: modernize entry function
Yuya Nishihara <yuya@tcha.org>
parents:
44694
diff
changeset
|
85 procutil::restore_signal_handler_once()?; |
44855
4b0185841058
rust-chg: do not terminate tokio runtime until pager exits
Yuya Nishihara <yuya@tcha.org>
parents:
44854
diff
changeset
|
86 handler.wait_pager().await?; |
44854
9fc9526e283a
rust-chg: modernize entry function
Yuya Nishihara <yuya@tcha.org>
parents:
44694
diff
changeset
|
87 Ok(code) |
39980
6bdee4bc181a
rust-chg: add main program
Yuya Nishihara <yuya@tcha.org>
parents:
39968
diff
changeset
|
88 } |