Merge pull request #5685 from epage/engine

fix(complete)!: Rename dynamic to engine
This commit is contained in:
Ed Page 2024-08-19 10:45:55 -05:00 committed by GitHub
commit 8b3de18a8d
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
10 changed files with 186 additions and 84 deletions

View file

@ -216,7 +216,7 @@ impl CompleteArgs {
/// ///
/// This will generally be called by [`CompleteCommand`] or [`CompleteArgs`]. /// This will generally be called by [`CompleteCommand`] or [`CompleteArgs`].
/// ///
/// This handles adapting between the shell and [`completer`][crate::dynamic::complete()]. /// This handles adapting between the shell and [`completer`][crate::engine::complete()].
/// A `CommandCompleter` can choose how much of that lives within the registration script and or /// A `CommandCompleter` can choose how much of that lives within the registration script and or
/// lives in [`CommandCompleter::write_complete`]. /// lives in [`CommandCompleter::write_complete`].
pub trait CommandCompleter { pub trait CommandCompleter {
@ -238,9 +238,9 @@ pub trait CommandCompleter {
/// Complete the given command /// Complete the given command
/// ///
/// Adapt information from arguments and [`CommandCompleter::write_registration`]-defined env /// Adapt information from arguments and [`CommandCompleter::write_registration`]-defined env
/// variables to what is needed for [`completer`][crate::dynamic::complete()]. /// variables to what is needed for [`completer`][crate::engine::complete()].
/// ///
/// Write out the [`CompletionCandidate`][crate::dynamic::CompletionCandidate]s in a way the shell will understand. /// Write out the [`CompletionCandidate`][crate::engine::CompletionCandidate]s in a way the shell will understand.
fn write_complete( fn write_complete(
&self, &self,
cmd: &mut clap::Command, cmd: &mut clap::Command,

View file

@ -241,7 +241,7 @@ fi
.ok() .ok()
.and_then(|i| i.parse().ok()); .and_then(|i| i.parse().ok());
let ifs: Option<String> = std::env::var("IFS").ok().and_then(|i| i.parse().ok()); let ifs: Option<String> = std::env::var("IFS").ok().and_then(|i| i.parse().ok());
let completions = crate::dynamic::complete(cmd, args, index, current_dir)?; let completions = crate::engine::complete(cmd, args, index, current_dir)?;
for (i, candidate) in completions.iter().enumerate() { for (i, candidate) in completions.iter().enumerate() {
if i != 0 { if i != 0 {
@ -335,7 +335,7 @@ set edit:completion:arg-completer[BIN] = { |@words|
.and_then(|i| i.parse().ok()) .and_then(|i| i.parse().ok())
.unwrap_or_default(); .unwrap_or_default();
let ifs: Option<String> = std::env::var("_CLAP_IFS").ok().and_then(|i| i.parse().ok()); let ifs: Option<String> = std::env::var("_CLAP_IFS").ok().and_then(|i| i.parse().ok());
let completions = crate::dynamic::complete(cmd, args, index, current_dir)?; let completions = crate::engine::complete(cmd, args, index, current_dir)?;
for (i, candidate) in completions.iter().enumerate() { for (i, candidate) in completions.iter().enumerate() {
if i != 0 { if i != 0 {
@ -376,7 +376,7 @@ impl CommandCompleter for Fish {
buf: &mut dyn std::io::Write, buf: &mut dyn std::io::Write,
) -> Result<(), std::io::Error> { ) -> Result<(), std::io::Error> {
let index = args.len() - 1; let index = args.len() - 1;
let completions = crate::dynamic::complete(cmd, args, index, current_dir)?; let completions = crate::engine::complete(cmd, args, index, current_dir)?;
for candidate in completions { for candidate in completions {
write!(buf, "{}", candidate.get_content().to_string_lossy())?; write!(buf, "{}", candidate.get_content().to_string_lossy())?;
@ -442,7 +442,7 @@ Register-ArgumentCompleter -Native -CommandName {bin} -ScriptBlock {{
buf: &mut dyn std::io::Write, buf: &mut dyn std::io::Write,
) -> Result<(), std::io::Error> { ) -> Result<(), std::io::Error> {
let index = args.len() - 1; let index = args.len() - 1;
let completions = crate::dynamic::complete(cmd, args, index, current_dir)?; let completions = crate::engine::complete(cmd, args, index, current_dir)?;
for candidate in completions { for candidate in completions {
write!(buf, "{}", candidate.get_content().to_string_lossy())?; write!(buf, "{}", candidate.get_content().to_string_lossy())?;
@ -516,7 +516,7 @@ compdef _clap_dynamic_completer BIN"#
if args.len() == index { if args.len() == index {
args.push("".into()); args.push("".into());
} }
let completions = crate::dynamic::complete(cmd, args, index, current_dir)?; let completions = crate::engine::complete(cmd, args, index, current_dir)?;
for (i, candidate) in completions.iter().enumerate() { for (i, candidate) in completions.iter().enumerate() {
if i != 0 { if i != 0 {

View file

@ -37,7 +37,7 @@ impl CompletionCandidate {
/// Add a prefix to the content of completion candidate /// Add a prefix to the content of completion candidate
/// ///
/// This is generally used for post-process by [`complete`][crate::dynamic::complete()] for /// This is generally used for post-process by [`complete`][crate::engine::complete()] for
/// things like pre-pending flags, merging delimiter-separated values, etc. /// things like pre-pending flags, merging delimiter-separated values, etc.
pub fn add_prefix(mut self, prefix: impl Into<OsString>) -> Self { pub fn add_prefix(mut self, prefix: impl Into<OsString>) -> Self {
let suffix = self.content; let suffix = self.content;

View file

@ -11,7 +11,7 @@ use super::CompletionCandidate;
/// ///
/// ```rust /// ```rust
/// use clap::Parser; /// use clap::Parser;
/// use clap_complete::dynamic::{ArgValueCompleter, CompletionCandidate}; /// use clap_complete::engine::{ArgValueCompleter, CompletionCandidate};
/// ///
/// #[derive(Debug, Parser)] /// #[derive(Debug, Parser)]
/// struct Cli { /// struct Cli {

View file

@ -273,7 +273,7 @@ impl<'s> Shells<'s> {
/// ///
/// This will generally be called by [`CompleteEnv`]. /// This will generally be called by [`CompleteEnv`].
/// ///
/// This handles adapting between the shell and [`completer`][crate::dynamic::complete()]. /// This handles adapting between the shell and [`completer`][crate::engine::complete()].
/// A `EnvCompleter` can choose how much of that lives within the registration script or /// A `EnvCompleter` can choose how much of that lives within the registration script or
/// lives in [`EnvCompleter::write_complete`]. /// lives in [`EnvCompleter::write_complete`].
pub trait EnvCompleter { pub trait EnvCompleter {
@ -308,9 +308,9 @@ pub trait EnvCompleter {
/// Complete the given command /// Complete the given command
/// ///
/// Adapt information from arguments and [`EnvCompleter::write_registration`]-defined env /// Adapt information from arguments and [`EnvCompleter::write_registration`]-defined env
/// variables to what is needed for [`completer`][crate::dynamic::complete()]. /// variables to what is needed for [`completer`][crate::engine::complete()].
/// ///
/// Write out the [`CompletionCandidate`][crate::dynamic::CompletionCandidate]s in a way the shell will understand. /// Write out the [`CompletionCandidate`][crate::engine::CompletionCandidate]s in a way the shell will understand.
fn write_complete( fn write_complete(
&self, &self,
cmd: &mut clap::Command, cmd: &mut clap::Command,

View file

@ -86,7 +86,7 @@ fi
.ok() .ok()
.and_then(|i| i.parse().ok()); .and_then(|i| i.parse().ok());
let ifs: Option<String> = std::env::var("IFS").ok().and_then(|i| i.parse().ok()); let ifs: Option<String> = std::env::var("IFS").ok().and_then(|i| i.parse().ok());
let completions = crate::dynamic::complete(cmd, args, index, current_dir)?; let completions = crate::engine::complete(cmd, args, index, current_dir)?;
for (i, candidate) in completions.iter().enumerate() { for (i, candidate) in completions.iter().enumerate() {
if i != 0 { if i != 0 {
@ -189,7 +189,7 @@ set edit:completion:arg-completer[BIN] = { |@words|
.and_then(|i| i.parse().ok()) .and_then(|i| i.parse().ok())
.unwrap_or_default(); .unwrap_or_default();
let ifs: Option<String> = std::env::var("_CLAP_IFS").ok().and_then(|i| i.parse().ok()); let ifs: Option<String> = std::env::var("_CLAP_IFS").ok().and_then(|i| i.parse().ok());
let completions = crate::dynamic::complete(cmd, args, index, current_dir)?; let completions = crate::engine::complete(cmd, args, index, current_dir)?;
for (i, candidate) in completions.iter().enumerate() { for (i, candidate) in completions.iter().enumerate() {
if i != 0 { if i != 0 {
@ -237,7 +237,7 @@ impl EnvCompleter for Fish {
buf: &mut dyn std::io::Write, buf: &mut dyn std::io::Write,
) -> Result<(), std::io::Error> { ) -> Result<(), std::io::Error> {
let index = args.len() - 1; let index = args.len() - 1;
let completions = crate::dynamic::complete(cmd, args, index, current_dir)?; let completions = crate::engine::complete(cmd, args, index, current_dir)?;
for candidate in completions { for candidate in completions {
write!(buf, "{}", candidate.get_content().to_string_lossy())?; write!(buf, "{}", candidate.get_content().to_string_lossy())?;
@ -310,7 +310,7 @@ Register-ArgumentCompleter -Native -CommandName {bin} -ScriptBlock {{
buf: &mut dyn std::io::Write, buf: &mut dyn std::io::Write,
) -> Result<(), std::io::Error> { ) -> Result<(), std::io::Error> {
let index = args.len() - 1; let index = args.len() - 1;
let completions = crate::dynamic::complete(cmd, args, index, current_dir)?; let completions = crate::engine::complete(cmd, args, index, current_dir)?;
for candidate in completions { for candidate in completions {
write!(buf, "{}", candidate.get_content().to_string_lossy())?; write!(buf, "{}", candidate.get_content().to_string_lossy())?;
@ -393,7 +393,7 @@ compdef _clap_dynamic_completer BIN"#
if args.len() == index { if args.len() == index {
args.push("".into()); args.push("".into());
} }
let completions = crate::dynamic::complete(cmd, args, index, current_dir)?; let completions = crate::engine::complete(cmd, args, index, current_dir)?;
for (i, candidate) in completions.iter().enumerate() { for (i, candidate) in completions.iter().enumerate() {
if i != 0 { if i != 0 {

View file

@ -69,7 +69,7 @@ pub mod aot;
#[cfg(feature = "unstable-command")] #[cfg(feature = "unstable-command")]
pub mod command; pub mod command;
#[cfg(feature = "unstable-dynamic")] #[cfg(feature = "unstable-dynamic")]
pub mod dynamic; pub mod engine;
#[cfg(feature = "unstable-dynamic")] #[cfg(feature = "unstable-dynamic")]
pub mod env; pub mod env;
@ -80,10 +80,10 @@ pub use command::CompleteArgs;
pub use command::CompleteCommand; pub use command::CompleteCommand;
#[doc(inline)] #[doc(inline)]
#[cfg(feature = "unstable-dynamic")] #[cfg(feature = "unstable-dynamic")]
pub use dynamic::ArgValueCompleter; pub use engine::ArgValueCompleter;
#[doc(inline)] #[doc(inline)]
#[cfg(feature = "unstable-dynamic")] #[cfg(feature = "unstable-dynamic")]
pub use dynamic::CompletionCandidate; pub use engine::CompletionCandidate;
#[cfg(feature = "unstable-dynamic")] #[cfg(feature = "unstable-dynamic")]
pub use env::CompleteEnv; pub use env::CompleteEnv;

View file

@ -4,7 +4,7 @@ use std::fs;
use std::path::Path; use std::path::Path;
use clap::{builder::PossibleValue, Command}; use clap::{builder::PossibleValue, Command};
use clap_complete::dynamic::{ArgValueCompleter, CompletionCandidate, CustomCompleter}; use clap_complete::engine::{ArgValueCompleter, CompletionCandidate, CustomCompleter};
use snapbox::assert_data_eq; use snapbox::assert_data_eq;
macro_rules! complete { macro_rules! complete {
@ -25,11 +25,14 @@ fn suggest_subcommand_subset() {
.subcommand(Command::new("hello-moon")) .subcommand(Command::new("hello-moon"))
.subcommand(Command::new("goodbye-world")); .subcommand(Command::new("goodbye-world"));
assert_data_eq!(complete!(cmd, "he"), snapbox::str![[r#" assert_data_eq!(
complete!(cmd, "he"),
snapbox::str![[r#"
hello-moon hello-moon
hello-world hello-world
help Print this message or the help of the given subcommand(s) help Print this message or the help of the given subcommand(s)
"#]],); "#]],
);
} }
#[test] #[test]
@ -42,9 +45,15 @@ fn suggest_hidden_long_flags() {
.hide(true), .hide(true),
); );
assert_data_eq!(complete!(cmd, "--hello-world"), snapbox::str!["--hello-world-visible"]); assert_data_eq!(
complete!(cmd, "--hello-world"),
snapbox::str!["--hello-world-visible"]
);
assert_data_eq!(complete!(cmd, "--hello-world-h"), snapbox::str!["--hello-world-hidden"]); assert_data_eq!(
complete!(cmd, "--hello-world-h"),
snapbox::str!["--hello-world-hidden"]
);
} }
#[test] #[test]
@ -62,18 +71,27 @@ fn suggest_hidden_subcommand_and_aliases() {
.hide(true), .hide(true),
); );
assert_data_eq!(complete!(cmd, "test"), snapbox::str![[r#" assert_data_eq!(
complete!(cmd, "test"),
snapbox::str![[r#"
test_visible test_visible
test_visible-alias_visible test_visible-alias_visible
"#]]); "#]]
);
assert_data_eq!(complete!(cmd, "test_h"), snapbox::str![[r#" assert_data_eq!(
complete!(cmd, "test_h"),
snapbox::str![[r#"
test_hidden test_hidden
test_hidden-alias_hidden test_hidden-alias_hidden
test_hidden-alias_visible test_hidden-alias_visible
"#]]); "#]]
);
assert_data_eq!(complete!(cmd, "test_hidden-alias_h"), snapbox::str!["test_hidden-alias_hidden"]); assert_data_eq!(
complete!(cmd, "test_hidden-alias_h"),
snapbox::str!["test_hidden-alias_hidden"]
);
} }
#[test] #[test]
@ -95,12 +113,15 @@ fn suggest_subcommand_aliases() {
.alias("hidden-goodbye"), .alias("hidden-goodbye"),
); );
assert_data_eq!(complete!(cmd, "hello"), snapbox::str![[r#" assert_data_eq!(
complete!(cmd, "hello"),
snapbox::str![[r#"
hello-moon hello-moon
hello-moon-foo hello-moon-foo
hello-world hello-world
hello-world-foo hello-world-foo
"#]],); "#]],
);
} }
#[test] #[test]
@ -114,9 +135,15 @@ fn suggest_hidden_possible_value() {
]), ]),
); );
assert_data_eq!(complete!(cmd, "--test=test"), snapbox::str!["--test=test-visible Say hello to the world"]); assert_data_eq!(
complete!(cmd, "--test=test"),
snapbox::str!["--test=test-visible Say hello to the world"]
);
assert_data_eq!(complete!(cmd, "--test=test-h"), snapbox::str!["--test=test-hidden Say hello to the moon"]); assert_data_eq!(
complete!(cmd, "--test=test-h"),
snapbox::str!["--test=test-hidden Say hello to the moon"]
);
} }
#[test] #[test]
@ -136,20 +163,32 @@ fn suggest_hidden_long_flag_aliases() {
.hide(true), .hide(true),
); );
assert_data_eq!(complete!(cmd, "--test"), snapbox::str![[r#" assert_data_eq!(
complete!(cmd, "--test"),
snapbox::str![[r#"
--test_visible --test_visible
--test_visible-alias_visible --test_visible-alias_visible
"#]]); "#]]
);
assert_data_eq!(complete!(cmd, "--test_h"), snapbox::str![[r#" assert_data_eq!(
complete!(cmd, "--test_h"),
snapbox::str![[r#"
--test_hidden --test_hidden
--test_hidden-alias_visible --test_hidden-alias_visible
--test_hidden-alias_hidden --test_hidden-alias_hidden
"#]]); "#]]
);
assert_data_eq!(complete!(cmd, "--test_visible-alias_h"), snapbox::str!["--test_visible-alias_hidden"]); assert_data_eq!(
complete!(cmd, "--test_visible-alias_h"),
snapbox::str!["--test_visible-alias_hidden"]
);
assert_data_eq!(complete!(cmd, "--test_hidden-alias_h"), snapbox::str!["--test_hidden-alias_hidden"]); assert_data_eq!(
complete!(cmd, "--test_hidden-alias_h"),
snapbox::str!["--test_hidden-alias_hidden"]
);
} }
#[test] #[test]
@ -171,11 +210,14 @@ fn suggest_long_flag_subset() {
.action(clap::ArgAction::Count), .action(clap::ArgAction::Count),
); );
assert_data_eq!(complete!(cmd, "--he"), snapbox::str![[r#" assert_data_eq!(
complete!(cmd, "--he"),
snapbox::str![[r#"
--hello-world --hello-world
--hello-moon --hello-moon
--help Print help --help Print help
"#]],); "#]],
);
} }
#[test] #[test]
@ -187,10 +229,13 @@ fn suggest_possible_value_subset() {
"goodbye-world".into(), "goodbye-world".into(),
])); ]));
assert_data_eq!(complete!(cmd, "hello"), snapbox::str![[r#" assert_data_eq!(
complete!(cmd, "hello"),
snapbox::str![[r#"
hello-world Say hello to the world hello-world Say hello to the world
hello-moon hello-moon
"#]],); "#]],
);
} }
#[test] #[test]
@ -212,12 +257,15 @@ fn suggest_additional_short_flags() {
.action(clap::ArgAction::Count), .action(clap::ArgAction::Count),
); );
assert_data_eq!(complete!(cmd, "-a"), snapbox::str![[r#" assert_data_eq!(
complete!(cmd, "-a"),
snapbox::str![[r#"
-aa -aa
-ab -ab
-ac -ac
-ah Print help -ah Print help
"#]],); "#]],
);
} }
#[test] #[test]
@ -230,13 +278,16 @@ fn suggest_subcommand_positional() {
]), ]),
)); ));
assert_data_eq!(complete!(cmd, "hello-world [TAB]"), snapbox::str![[r#" assert_data_eq!(
complete!(cmd, "hello-world [TAB]"),
snapbox::str![[r#"
--help Print help (see more with '--help') --help Print help (see more with '--help')
-h Print help (see more with '--help') -h Print help (see more with '--help')
hello-world Say hello to the world hello-world Say hello to the world
hello-moon hello-moon
goodbye-world goodbye-world
"#]],); "#]],
);
} }
#[test] #[test]
@ -301,17 +352,23 @@ d_dir/
snapbox::str!["b_file"], snapbox::str!["b_file"],
); );
assert_data_eq!(complete!(cmd, "--format [TAB]"), snapbox::str![[r#" assert_data_eq!(
complete!(cmd, "--format [TAB]"),
snapbox::str![[r#"
json json
yaml yaml
toml toml
"#]],); "#]],
);
assert_data_eq!(complete!(cmd, "-F [TAB]"), snapbox::str![[r#" assert_data_eq!(
complete!(cmd, "-F [TAB]"),
snapbox::str![[r#"
json json
yaml yaml
toml toml
"#]],); "#]],
);
assert_data_eq!(complete!(cmd, "--format j[TAB]"), snapbox::str!["json"],); assert_data_eq!(complete!(cmd, "--format j[TAB]"), snapbox::str!["json"],);
@ -321,13 +378,18 @@ toml
assert_data_eq!(complete!(cmd, "-F t[TAB]"), snapbox::str!["toml"],); assert_data_eq!(complete!(cmd, "-F t[TAB]"), snapbox::str!["toml"],);
assert_data_eq!(complete!(cmd, "-cccF [TAB]"), snapbox::str![[r#" assert_data_eq!(
complete!(cmd, "-cccF [TAB]"),
snapbox::str![[r#"
json json
yaml yaml
toml toml
"#]]); "#]]
);
assert_data_eq!(complete!(cmd, "--input a_file [TAB]"), snapbox::str![[r#" assert_data_eq!(
complete!(cmd, "--input a_file [TAB]"),
snapbox::str![[r#"
--input --input
--format --format
--count --count
@ -339,7 +401,8 @@ toml
pos_a pos_a
pos_b pos_b
pos_c pos_c
"#]]); "#]]
);
assert_data_eq!( assert_data_eq!(
complete!(cmd, "-ci[TAB]", current_dir = Some(testdir_path)), complete!(cmd, "-ci[TAB]", current_dir = Some(testdir_path)),
@ -395,17 +458,23 @@ fn suggest_argument_multi_values() {
.num_args(1..=3), .num_args(1..=3),
); );
assert_data_eq!(complete!(cmd, "--certain-num [TAB]"), snapbox::str![[r#" assert_data_eq!(
complete!(cmd, "--certain-num [TAB]"),
snapbox::str![[r#"
val1 val1
val2 val2
val3 val3
"#]]); "#]]
);
assert_data_eq!(complete!(cmd, "--certain-num val1 [TAB]"), snapbox::str![[r#" assert_data_eq!(
complete!(cmd, "--certain-num val1 [TAB]"),
snapbox::str![[r#"
val1 val1
val2 val2
val3 val3
"#]]); "#]]
);
assert_data_eq!( assert_data_eq!(
complete!(cmd, "--certain-num val1 val2 val3 [TAB]"), complete!(cmd, "--certain-num val1 val2 val3 [TAB]"),
@ -419,11 +488,14 @@ val3
"#]] "#]]
); );
assert_data_eq!(complete!(cmd, "--uncertain-num [TAB]"), snapbox::str![[r#" assert_data_eq!(
complete!(cmd, "--uncertain-num [TAB]"),
snapbox::str![[r#"
val1 val1
val2 val2
val3 val3
"#]]); "#]]
);
assert_data_eq!( assert_data_eq!(
complete!(cmd, "--uncertain-num val1 [TAB]"), complete!(cmd, "--uncertain-num val1 [TAB]"),
@ -452,34 +524,48 @@ val3
"#]] "#]]
); );
assert_data_eq!(complete!(cmd, "-Y [TAB]"), snapbox::str![[r#" assert_data_eq!(
complete!(cmd, "-Y [TAB]"),
snapbox::str![[r#"
val1 val1
val2 val2
val3 val3
"#]]); "#]]
);
assert_data_eq!(complete!(cmd, "-Y val1 [TAB]"), snapbox::str![[r#" assert_data_eq!(
complete!(cmd, "-Y val1 [TAB]"),
snapbox::str![[r#"
val1 val1
val2 val2
val3 val3
"#]]); "#]]
);
assert_data_eq!(complete!(cmd, "-Y val1 val2 val3 [TAB]"), snapbox::str![[r#" assert_data_eq!(
complete!(cmd, "-Y val1 val2 val3 [TAB]"),
snapbox::str![[r#"
--certain-num --certain-num
--uncertain-num --uncertain-num
--help Print help --help Print help
-Y -Y
-N -N
-h Print help -h Print help
"#]]); "#]]
);
assert_data_eq!(complete!(cmd, "-N [TAB]"), snapbox::str![[r#" assert_data_eq!(
complete!(cmd, "-N [TAB]"),
snapbox::str![[r#"
val1 val1
val2 val2
val3 val3
"#]]); "#]]
);
assert_data_eq!(complete!(cmd, "-N val1 [TAB]"), snapbox::str![[r#" assert_data_eq!(
complete!(cmd, "-N val1 [TAB]"),
snapbox::str![[r#"
val1 val1
val2 val2
val3 val3
@ -489,16 +575,20 @@ val3
-Y -Y
-N -N
-h Print help -h Print help
"#]]); "#]]
);
assert_data_eq!(complete!(cmd, "-N val1 val2 val3 [TAB]"), snapbox::str![[r#" assert_data_eq!(
complete!(cmd, "-N val1 val2 val3 [TAB]"),
snapbox::str![[r#"
--certain-num --certain-num
--uncertain-num --uncertain-num
--help Print help --help Print help
-Y -Y
-N -N
-h Print help -h Print help
"#]]); "#]]
);
} }
#[test] #[test]
@ -522,11 +612,14 @@ fn suggest_custom_arg_value() {
.add::<ArgValueCompleter>(ArgValueCompleter::new(MyCustomCompleter {})), .add::<ArgValueCompleter>(ArgValueCompleter::new(MyCustomCompleter {})),
); );
assert_data_eq!(complete!(cmd, "--custom [TAB]"), snapbox::str![[r#" assert_data_eq!(
complete!(cmd, "--custom [TAB]"),
snapbox::str![[r#"
custom1 custom1
custom2 custom2
custom3 custom3
"#]],); "#]],
);
} }
#[test] #[test]
@ -550,19 +643,27 @@ fn suggest_multi_positional() {
.value_parser(["json", "yaml", "toml"]), .value_parser(["json", "yaml", "toml"]),
); );
assert_data_eq!(complete!(cmd, "pos_1 pos_a [TAB]"), snapbox::str![[r#" assert_data_eq!(
complete!(cmd, "pos_1 pos_a [TAB]"),
snapbox::str![[r#"
pos_a pos_a
pos_b pos_b
pos_c pos_c
"#]]); "#]]
);
assert_data_eq!(complete!(cmd, "pos_1 pos_a pos_b [TAB]"), snapbox::str![[r#" assert_data_eq!(
complete!(cmd, "pos_1 pos_a pos_b [TAB]"),
snapbox::str![[r#"
pos_a pos_a
pos_b pos_b
pos_c pos_c
"#]]); "#]]
);
assert_data_eq!(complete!(cmd, "--format json pos_1 [TAB]"), snapbox::str![[r#" assert_data_eq!(
complete!(cmd, "--format json pos_1 [TAB]"),
snapbox::str![[r#"
--format --format
--help Print help --help Print help
-F -F
@ -570,7 +671,8 @@ pos_c
pos_a pos_a
pos_b pos_b
pos_c pos_c
"#]]); "#]]
);
assert_data_eq!( assert_data_eq!(
complete!(cmd, "--format json pos_1 pos_a [TAB]"), complete!(cmd, "--format json pos_1 pos_a [TAB]"),
@ -794,7 +896,7 @@ fn complete(cmd: &mut Command, args: impl AsRef<str>, current_dir: Option<&Path>
arg_index = args.len() - 1; arg_index = args.len() - 1;
} }
clap_complete::dynamic::complete(cmd, args, arg_index, current_dir) clap_complete::engine::complete(cmd, args, arg_index, current_dir)
.unwrap() .unwrap()
.into_iter() .into_iter()
.map(|candidate| { .map(|candidate| {