From c10eedb6af1c8e77fcd4d584d3783f92dfaf85f2f9ec3a1317eb44ae40ec6293 Mon Sep 17 00:00:00 2001 From: Nicholas Johnson Date: Mon, 22 Apr 2024 00:00:00 +0000 Subject: Move cli functionality out of main.rs --- src/main.rs | 57 +-------------------------------------------------------- 1 file changed, 1 insertion(+), 56 deletions(-) (limited to 'src/main.rs') diff --git a/src/main.rs b/src/main.rs index c936dc1..f516586 100644 --- a/src/main.rs +++ b/src/main.rs @@ -16,28 +16,9 @@ along with this program. If not, see . */ -use clap::Parser; -use std::ops::RangeInclusive; - use hitomezashi_rs; -#[derive(Parser)] -#[command(version, about, long_about = None)] // Read from `Cargo.toml` -struct Cli { - /// Pattern width - #[arg(value_parser = dimension_in_range)] - width: usize, - - /// Pattern height - #[arg(value_parser = dimension_in_range)] - height: usize, - - /// Set skew - #[arg(short, long)] - #[arg(default_value_t = 0.5)] - #[arg(value_parser = skew_in_range)] - skew: f64, -} +include!("cli.rs"); // CLI for hitomezashi fn main() { @@ -45,39 +26,3 @@ fn main() { hitomezashi_rs::generate(cli.width, cli.height, Some(cli.skew)); } - -const DIMENSION_RANGE: RangeInclusive = 1..=std::usize::MAX; - -fn dimension_in_range(s: &str) -> Result { - let dimension: usize = s - .parse() - .map_err(|_| format!("`{s}` isn't a dimension value!"))?; - - if DIMENSION_RANGE.contains(&dimension) { - Ok(dimension) - } else { - Err(format!( - "Dimension not in range {}-{}", - DIMENSION_RANGE.start(), - DIMENSION_RANGE.end() - )) - } -} - -const SKEW_RANGE: RangeInclusive = 0.0..=1.0; - -fn skew_in_range(s: &str) -> Result { - let skew: f64 = s - .parse() - .map_err(|_| format!("`{s}` isn't a skew value!"))?; - - if SKEW_RANGE.contains(&skew) { - Ok(skew) - } else { - Err(format!( - "Skew not in range {}-{}", - SKEW_RANGE.start(), - SKEW_RANGE.end() - )) - } -} -- cgit v1.2.3