Mercurial > public > mercurial-scm > hg-stable
diff rust/rhg/src/commands/debugrequirements.rs @ 46552:184e46550dc8
rhg: replace command structs with functions
The `Command` trait was not used in any generic context,
and the struct where nothing more than holders for values parsed from CLI
arguments to be available to a `run` method.
Differential Revision: https://phab.mercurial-scm.org/D9967
author | Simon Sapin <simon.sapin@octobus.net> |
---|---|
date | Mon, 08 Feb 2021 20:33:04 +0100 |
parents | a6e4e4650bac |
children | 1ecaf09d9964 |
line wrap: on
line diff
--- a/rust/rhg/src/commands/debugrequirements.rs Mon Feb 08 11:13:56 2021 +0100 +++ b/rust/rhg/src/commands/debugrequirements.rs Mon Feb 08 20:33:04 2021 +0100 @@ -1,6 +1,6 @@ -use crate::commands::Command; use crate::error::CommandError; use crate::ui::Ui; +use clap::ArgMatches; use hg::config::Config; use hg::repo::Repo; @@ -8,25 +8,19 @@ Print the current repo requirements. "; -pub struct DebugRequirementsCommand {} - -impl DebugRequirementsCommand { - pub fn new() -> Self { - DebugRequirementsCommand {} +pub fn run( + ui: &Ui, + config: &Config, + _args: &ArgMatches, +) -> Result<(), CommandError> { + let repo = Repo::find(config)?; + let mut output = String::new(); + let mut requirements: Vec<_> = repo.requirements().iter().collect(); + requirements.sort(); + for req in requirements { + output.push_str(req); + output.push('\n'); } + ui.write_stdout(output.as_bytes())?; + Ok(()) } - -impl Command for DebugRequirementsCommand { - fn run(&self, ui: &Ui, config: &Config) -> Result<(), CommandError> { - let repo = Repo::find(config)?; - let mut output = String::new(); - let mut requirements: Vec<_> = repo.requirements().iter().collect(); - requirements.sort(); - for req in requirements { - output.push_str(req); - output.push('\n'); - } - ui.write_stdout(output.as_bytes())?; - Ok(()) - } -}