##// END OF EJS Templates
commands: add admin namespace...
commands: add admin namespace In order to stop abusing the 'debug' namespace for non-debug command, it adds a new 'admin' namespace dedicated to 'admin' operations on a repository (i.e commands suitable for administration tasks). This namespace entry would be used to migrate in the future some existing commands from the 'debug' namespace, or other top level commands that may not be directly exposed to end users. (verify command is a perfect candidate for this case)

File last commit:

r50534:37bc3ede default
r51880:727428c7 default
Show More
config.rs
37 lines | 1.0 KiB | application/rls-services+xml | RustLexer
Simon Sapin
rhg: add limited support for the `config` sub-command...
r47255 use crate::error::CommandError;
use clap::Arg;
use format_bytes::format_bytes;
use hg::errors::HgError;
use hg::utils::SliceExt;
pub const HELP_TEXT: &str = "
With one argument of the form section.name, print just the value of that config item.
";
Raphaël Gomès
rhg: upgrade `clap` dependency...
r50534 pub fn args() -> clap::Command {
clap::command!("config")
Simon Sapin
rhg: add limited support for the `config` sub-command...
r47255 .arg(
Raphaël Gomès
rhg: upgrade `clap` dependency...
r50534 Arg::new("name")
Simon Sapin
rhg: add limited support for the `config` sub-command...
r47255 .help("the section.name to print")
.value_name("NAME")
Raphaël Gomès
rhg: upgrade `clap` dependency...
r50534 .required(true),
Simon Sapin
rhg: add limited support for the `config` sub-command...
r47255 )
.about(HELP_TEXT)
}
Simon Sapin
rhg: Group values passed to every sub-command into a struct...
r47334 pub fn run(invocation: &crate::CliInvocation) -> Result<(), CommandError> {
let (section, name) = invocation
.subcommand_args
Raphaël Gomès
rhg: upgrade `clap` dependency...
r50534 .get_one::<String>("name")
Simon Sapin
rhg: add limited support for the `config` sub-command...
r47255 .expect("missing required CLI argument")
.as_bytes()
.split_2(b'.')
Simon Sapin
rhg: Fall back to Python on unsupported `rhg config <section>`...
r47460 .ok_or_else(|| HgError::unsupported("hg config <section>"))?;
Simon Sapin
rhg: add limited support for the `config` sub-command...
r47255
Simon Sapin
rhg: Return an error code for `rhg config Section.idontexist`...
r47481 if let Some(value) = invocation.config.get(section, name) {
invocation.ui.write_stdout(&format_bytes!(b"{}\n", value))?;
Ok(())
} else {
Err(CommandError::Unsuccessful)
}
Simon Sapin
rhg: add limited support for the `config` sub-command...
r47255 }