mirror of
https://github.com/martinvonz/jj.git
synced 2025-01-28 15:26:25 +00:00
cli: split up cmd_util()
into one function per subcommand
This matches how most other commands with subcommands are handled.
This commit is contained in:
parent
35f718f212
commit
5e0b14a8bd
1 changed files with 44 additions and 24 deletions
|
@ -71,30 +71,50 @@ pub(crate) fn cmd_util(
|
|||
subcommand: &UtilCommand,
|
||||
) -> Result<(), CommandError> {
|
||||
match subcommand {
|
||||
UtilCommand::Completion(completion_args) => {
|
||||
UtilCommand::Completion(args) => cmd_util_completion(ui, command, args),
|
||||
UtilCommand::Mangen(args) => cmd_util_mangen(ui, command, args),
|
||||
UtilCommand::ConfigSchema(args) => cmd_util_config_schema(ui, command, args),
|
||||
}
|
||||
}
|
||||
|
||||
fn cmd_util_completion(
|
||||
ui: &mut Ui,
|
||||
command: &CommandHelper,
|
||||
args: &UtilCompletionArgs,
|
||||
) -> Result<(), CommandError> {
|
||||
let mut app = command.app().clone();
|
||||
let mut buf = vec![];
|
||||
let shell = if completion_args.zsh {
|
||||
let shell = if args.zsh {
|
||||
clap_complete::Shell::Zsh
|
||||
} else if completion_args.fish {
|
||||
} else if args.fish {
|
||||
clap_complete::Shell::Fish
|
||||
} else {
|
||||
clap_complete::Shell::Bash
|
||||
};
|
||||
clap_complete::generate(shell, &mut app, "jj", &mut buf);
|
||||
ui.stdout_formatter().write_all(&buf)?;
|
||||
}
|
||||
UtilCommand::Mangen(_mangen_args) => {
|
||||
Ok(())
|
||||
}
|
||||
|
||||
fn cmd_util_mangen(
|
||||
ui: &mut Ui,
|
||||
command: &CommandHelper,
|
||||
_args: &UtilMangenArgs,
|
||||
) -> Result<(), CommandError> {
|
||||
let mut buf = vec![];
|
||||
let man = clap_mangen::Man::new(command.app().clone());
|
||||
man.render(&mut buf)?;
|
||||
ui.stdout_formatter().write_all(&buf)?;
|
||||
}
|
||||
UtilCommand::ConfigSchema(_config_schema_args) => {
|
||||
Ok(())
|
||||
}
|
||||
|
||||
fn cmd_util_config_schema(
|
||||
ui: &mut Ui,
|
||||
_command: &CommandHelper,
|
||||
_args: &UtilConfigSchemaArgs,
|
||||
) -> Result<(), CommandError> {
|
||||
// TODO(#879): Consider generating entire schema dynamically vs. static file.
|
||||
let buf = include_bytes!("../config-schema.json");
|
||||
ui.stdout_formatter().write_all(buf)?;
|
||||
}
|
||||
}
|
||||
Ok(())
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue