From 08e246764fcd9ec0662e0d9dbf93d842f6b86a45 Mon Sep 17 00:00:00 2001 From: Charlie Marsh Date: Fri, 1 Sep 2023 14:15:38 +0100 Subject: [PATCH] Refactor ruff_cli's run method to return on each branch (#7040) ## Summary I think the fallthrough here for some branches is a little confusing. Now each branch either runs a command that returns `Result`, or runs a command that returns `Result<()>` and then explicitly returns `Ok(ExitStatus::SUCCESS)`. --- crates/ruff_cli/src/commands/config.rs | 10 +++++----- crates/ruff_cli/src/lib.rs | 23 ++++++++++++++++------- 2 files changed, 21 insertions(+), 12 deletions(-) diff --git a/crates/ruff_cli/src/commands/config.rs b/crates/ruff_cli/src/commands/config.rs index 0391dc5ed4bcc..042ea066f949b 100644 --- a/crates/ruff_cli/src/commands/config.rs +++ b/crates/ruff_cli/src/commands/config.rs @@ -1,19 +1,19 @@ -use crate::ExitStatus; +use anyhow::{anyhow, Result}; + use ruff_workspace::options::Options; #[allow(clippy::print_stdout)] -pub(crate) fn config(key: Option<&str>) -> ExitStatus { +pub(crate) fn config(key: Option<&str>) -> Result<()> { match key { None => print!("{}", Options::metadata()), Some(key) => match Options::metadata().get(key) { None => { - println!("Unknown option"); - return ExitStatus::Error; + return Err(anyhow!("Unknown option: {key}")); } Some(entry) => { print!("{entry}"); } }, } - ExitStatus::Success + Ok(()) } diff --git a/crates/ruff_cli/src/lib.rs b/crates/ruff_cli/src/lib.rs index 130631f0e9234..08057794b15e3 100644 --- a/crates/ruff_cli/src/lib.rs +++ b/crates/ruff_cli/src/lib.rs @@ -139,18 +139,27 @@ quoting the executed command, along with the relevant file contents and `pyproje if let Some(rule) = rule { commands::rule::rule(rule, format)?; } + Ok(ExitStatus::Success) + } + Command::Config { option } => { + commands::config::config(option.as_deref())?; + Ok(ExitStatus::Success) + } + Command::Linter { format } => { + commands::linter::linter(format)?; + Ok(ExitStatus::Success) + } + Command::Clean => { + commands::clean::clean(log_level)?; + Ok(ExitStatus::Success) } - Command::Config { option } => return Ok(commands::config::config(option.as_deref())), - Command::Linter { format } => commands::linter::linter(format)?, - Command::Clean => commands::clean::clean(log_level)?, Command::GenerateShellCompletion { shell } => { shell.generate(&mut Args::command(), &mut stdout()); + Ok(ExitStatus::Success) } - Command::Check(args) => return check(args, log_level), - Command::Format(args) => return format(args, log_level), + Command::Check(args) => check(args, log_level), + Command::Format(args) => format(args, log_level), } - - Ok(ExitStatus::Success) } fn format(args: FormatCommand, log_level: LogLevel) -> Result {