From e02644b9c25ec2196d846ae216fff39168549aac Mon Sep 17 00:00:00 2001 From: Ed Page Date: Thu, 27 Apr 2023 04:12:22 -0500 Subject: [PATCH 1/2] fix(usage): Provide more context in panic --- clap_builder/src/output/usage.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/clap_builder/src/output/usage.rs b/clap_builder/src/output/usage.rs index dd99c63c..87bb9452 100644 --- a/clap_builder/src/output/usage.rs +++ b/clap_builder/src/output/usage.rs @@ -439,7 +439,7 @@ impl<'cmd> Usage<'cmd> { required_groups.insert(elem); required_groups_members.extend(group_members); } else { - debug_assert!(self.cmd.find(req).is_some()); + debug_assert!(self.cmd.find(req).is_some(), "`{req}` must exist"); } } From 185729a7dc5043f75e3759e8e976183076dd50bd Mon Sep 17 00:00:00 2001 From: Ed Page Date: Thu, 27 Apr 2023 04:16:14 -0500 Subject: [PATCH 2/2] fix(builder): Assert earlier on bad requires/conflicts Fixes #4865 --- clap_builder/src/builder/debug_asserts.rs | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) diff --git a/clap_builder/src/builder/debug_asserts.rs b/clap_builder/src/builder/debug_asserts.rs index 7a7fd6ae..b7bb1ff8 100644 --- a/clap_builder/src/builder/debug_asserts.rs +++ b/clap_builder/src/builder/debug_asserts.rs @@ -300,6 +300,28 @@ pub(crate) fn assert_app(cmd: &Command) { arg ); } + + for arg in &group.requires { + // Args listed inside groups should exist + assert!( + cmd.id_exists(arg), + "Command {}: Argument group '{}' requires non-existent '{}' id", + cmd.get_name(), + group.get_id(), + arg + ); + } + + for arg in &group.conflicts { + // Args listed inside groups should exist + assert!( + cmd.id_exists(arg), + "Command {}: Argument group '{}' conflicts with non-existent '{}' id", + cmd.get_name(), + group.get_id(), + arg + ); + } } // Conflicts between flags and subcommands