feat: Add nushell completions
This commit is contained in:
parent
2d150e3c93
commit
414c8546a0
4 changed files with 69 additions and 2 deletions
11
Cargo.lock
generated
11
Cargo.lock
generated
|
|
@ -362,6 +362,7 @@ dependencies = [
|
|||
"clap",
|
||||
"clap-verbosity-flag",
|
||||
"clap_complete",
|
||||
"clap_complete_nushell",
|
||||
"colored",
|
||||
"fuzzy-matcher",
|
||||
"indexmap 2.7.0",
|
||||
|
|
@ -698,6 +699,16 @@ dependencies = [
|
|||
"clap",
|
||||
]
|
||||
|
||||
[[package]]
|
||||
name = "clap_complete_nushell"
|
||||
version = "4.5.5"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "c6a8b1593457dfc2fe539002b795710d022dc62a65bf15023f039f9760c7b18a"
|
||||
dependencies = [
|
||||
"clap",
|
||||
"clap_complete",
|
||||
]
|
||||
|
||||
[[package]]
|
||||
name = "clap_derive"
|
||||
version = "4.5.18"
|
||||
|
|
|
|||
|
|
@ -69,6 +69,7 @@ blue-build-utils = { version = "=0.9.1", path = "./utils" }
|
|||
blue-build-process-management = { version = "=0.9.1", path = "./process" }
|
||||
clap-verbosity-flag = "3"
|
||||
clap_complete = "4"
|
||||
clap_complete_nushell = "4"
|
||||
fuzzy-matcher = "0.3"
|
||||
jsonschema = { version = "0.28", optional = true }
|
||||
open = "5"
|
||||
|
|
|
|||
|
|
@ -1,15 +1,18 @@
|
|||
use clap::{Args, CommandFactory};
|
||||
use clap_complete::{generate, Shell as CompletionShell};
|
||||
use clap_complete::generate;
|
||||
use miette::Result;
|
||||
use shells::Shells;
|
||||
|
||||
use crate::commands::BlueBuildArgs;
|
||||
|
||||
use super::BlueBuildCommand;
|
||||
|
||||
mod shells;
|
||||
|
||||
#[derive(Debug, Clone, Args)]
|
||||
pub struct CompletionsCommand {
|
||||
#[arg(value_enum)]
|
||||
shell: CompletionShell,
|
||||
shell: Shells,
|
||||
}
|
||||
|
||||
impl BlueBuildCommand for CompletionsCommand {
|
||||
|
|
|
|||
52
src/commands/completions/shells.rs
Normal file
52
src/commands/completions/shells.rs
Normal file
|
|
@ -0,0 +1,52 @@
|
|||
use clap::ValueEnum;
|
||||
use clap_complete::{Generator, Shell as CompletionShell};
|
||||
use clap_complete_nushell::Nushell;
|
||||
|
||||
#[derive(Debug, Clone, Copy, ValueEnum, PartialEq, Eq, Hash)]
|
||||
pub enum Shells {
|
||||
/// Bourne Again `SHell` (bash)
|
||||
Bash,
|
||||
/// Elvish shell
|
||||
Elvish,
|
||||
/// Friendly Interactive `SHell` (fish)
|
||||
Fish,
|
||||
/// `PowerShell`
|
||||
PowerShell,
|
||||
/// Z `SHell` (zsh)
|
||||
Zsh,
|
||||
/// Nushell (nu)
|
||||
Nushell,
|
||||
}
|
||||
|
||||
impl Generator for Shells {
|
||||
fn file_name(&self, name: &str) -> String {
|
||||
match *self {
|
||||
Self::Bash => CompletionShell::Bash.file_name(name),
|
||||
Self::Elvish => CompletionShell::Elvish.file_name(name),
|
||||
Self::Fish => CompletionShell::Fish.file_name(name),
|
||||
Self::PowerShell => CompletionShell::PowerShell.file_name(name),
|
||||
Self::Zsh => CompletionShell::Zsh.file_name(name),
|
||||
Self::Nushell => Nushell.file_name(name),
|
||||
}
|
||||
}
|
||||
|
||||
fn generate(&self, cmd: &clap::Command, buf: &mut dyn std::io::Write) {
|
||||
match *self {
|
||||
Self::Bash => CompletionShell::Bash.generate(cmd, buf),
|
||||
Self::Elvish => CompletionShell::Elvish.generate(cmd, buf),
|
||||
Self::Fish => CompletionShell::Fish.generate(cmd, buf),
|
||||
Self::PowerShell => CompletionShell::PowerShell.generate(cmd, buf),
|
||||
Self::Zsh => CompletionShell::Zsh.generate(cmd, buf),
|
||||
Self::Nushell => Nushell.generate(cmd, buf),
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
impl std::fmt::Display for Shells {
|
||||
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
|
||||
self.to_possible_value()
|
||||
.expect("no values are skipped")
|
||||
.get_name()
|
||||
.fmt(f)
|
||||
}
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue