From 18c843b5509b76a661dbf141da7cb900401f5074 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Henrik=20Tj=C3=A4der?= Date: Fri, 24 Feb 2023 00:10:01 +0100 Subject: xtask: Add format and format-check --- xtask/src/command.rs | 28 +++++++++++++++++++++++++++- 1 file changed, 27 insertions(+), 1 deletion(-) (limited to 'xtask/src/command.rs') diff --git a/xtask/src/command.rs b/xtask/src/command.rs index d894fae..b1f885c 100644 --- a/xtask/src/command.rs +++ b/xtask/src/command.rs @@ -61,6 +61,11 @@ pub enum CargoCommand<'a> { target: &'a str, features: Option<&'a str>, }, + Format { + cargoarg: &'a Option<&'a str>, + package: Vec, + check_only: bool, + }, ExampleSize { cargoarg: &'a Option<&'a str>, example: &'a str, @@ -79,8 +84,8 @@ impl<'a> CargoCommand<'a> { CargoCommand::ExampleBuild { .. } | CargoCommand::Build { .. } => "build", CargoCommand::ExampleSize { .. } => "size", CargoCommand::Clippy { .. } => "clippy", + CargoCommand::Format { .. } => "fmt", // TODO - // CargoCommand::Fmt { .. } => "fmt", // CargoCommand::Test { .. } => "test", // CargoCommand::Doc { .. } => "doc", } @@ -203,6 +208,27 @@ impl<'a> CargoCommand<'a> { } args } + CargoCommand::Format { + cargoarg, + package, + check_only, + } => { + let mut args = vec!["+nightly", self.name()]; + if let Some(cargoarg) = cargoarg { + args.extend_from_slice(&[cargoarg]); + } + + if !package.is_empty() { + for package in package { + args.extend_from_slice(&["--package", package]); + } + } + if *check_only { + args.extend_from_slice(&["--check"]); + } + + args + } CargoCommand::ExampleBuild { cargoarg, example, -- cgit v1.2.3