From 34558f61e38cb4bb2123b591a80af3ab9e60199d Mon Sep 17 00:00:00 2001 From: Marcelo Date: Wed, 12 Jun 2024 20:00:55 -0400 Subject: [PATCH] src: simplify generate_completions --- src/main.rs | 2 +- src/opts.rs | 18 ++++-------------- 2 files changed, 5 insertions(+), 15 deletions(-) diff --git a/src/main.rs b/src/main.rs index 8cc6c36..2a2db5e 100644 --- a/src/main.rs +++ b/src/main.rs @@ -14,7 +14,7 @@ fn main() -> anyhow::Result<()> { let args = DimOpts::parse(); if let Some(path) = args.gen_completions { - DimOpts::generate_completions(Some(&path))?; + DimOpts::generate_completions(&path)?; return Ok(()); } diff --git a/src/opts.rs b/src/opts.rs index 2419fc8..efff1b8 100644 --- a/src/opts.rs +++ b/src/opts.rs @@ -1,9 +1,4 @@ -use std::{ - borrow::Cow, - env, - ops::Deref, - path::{Path, PathBuf}, -}; +use std::path::{Path, PathBuf}; use clap::{CommandFactory, Parser, ValueEnum}; use clap_complete::{generate_to, Shell}; @@ -35,17 +30,12 @@ pub struct DimOpts { } impl DimOpts { - pub fn generate_completions(at: Option<&Path>) -> anyhow::Result<()> { + pub fn generate_completions(dir: &Path) -> anyhow::Result<()> { let mut cli = Self::command(); - let dir = match at { - Some(dir) => Cow::Borrowed(dir), - None => Cow::Owned(env::current_dir()?), - }; - for &shell in Shell::value_variants() { - let comp_file = generate_to(shell, &mut cli, "dim", dir.deref())?; - println!("cargo:warning=generated completion for {shell}: {comp_file:?}"); + let comp_file = generate_to(shell, &mut cli, "dim", dir)?; + println!("Generated completion for {shell} at {comp_file:?}"); } Ok(())