From 3433f378b1cd783aafcc24e8bcc5bac5e8497246 Mon Sep 17 00:00:00 2001 From: Robin Krahl Date: Wed, 8 Jan 2020 11:35:19 +0000 Subject: Handle doc comments and empty variants in the Command! macro This patch introduces two changes to the Command! macro: - We allow variants without fields so that we no longer have to define empty *Args structs just for the Command! macro. - We allow doc comments so that we can document commands without a separate *Args struct. --- src/arg_util.rs | 15 ++++++++++++--- 1 file changed, 12 insertions(+), 3 deletions(-) (limited to 'src') diff --git a/src/arg_util.rs b/src/arg_util.rs index 8cd8fe5..c72d89b 100644 --- a/src/arg_util.rs +++ b/src/arg_util.rs @@ -24,12 +24,21 @@ macro_rules! count { } } +/// Translate an optional source into an optional destination. +macro_rules! tr { + ($dst:tt, $src:tt) => { + $dst + }; + ($dst:tt) => {}; +} + macro_rules! Command { - ( $name:ident, [ $( $var:ident($inner:ident) => $exec:expr, ) *] ) => { + ( $name:ident, [ $( $(#[$doc:meta])* $var:ident$(($inner:ty))? => $exec:expr, ) *] ) => { #[derive(Debug, PartialEq, structopt::StructOpt)] pub enum $name { $( - $var($inner), + $(#[$doc])* + $var$(($inner))?, )* } @@ -41,7 +50,7 @@ macro_rules! Command { ) -> crate::Result<()> { match self { $( - $name::$var(args) => $exec(ctx, args), + $name::$var$((tr!(args, $inner)))? => $exec(ctx $(,tr!(args, $inner))?), )* } } -- cgit v1.2.3