5 releases (3 breaking)
Uses old Rust 2015
0.4.0 | Nov 8, 2017 |
---|---|
0.3.0 | Sep 25, 2017 |
0.2.1 | Sep 19, 2017 |
0.2.0 | Sep 19, 2017 |
0.1.0 | Sep 18, 2017 |
#2122 in Rust patterns
Used in 2 crates
17KB
380 lines
PrefixOpt
Add command line options with a prefix to override fields of structs and enums with a derive macro. This is made to extend clap.
General use
Deriving PrefixOpt for a struct or enum implements the PrefixOpt trait for the struct which allows to create a struct with a prefix. This struct can be transformed into arguments and bound to a clap::App
. The struct allows parsing the ArgMatches
of the App
.
Derivator of PrefixOpt requires that both structs and enums implement Default
.
Example
Add prefixopt
and prefixopt-derive
to your dependencies of your Cargo.toml
:
[dependencies]
prefixopt = "0.1.0"
prefixopt-derive = "0.1.0"
And then, in your rust file:
extern crate prefixopt;
#[macro_use]
extern crate prefixopt_derive;
use prefixopt::core::*;
#[derive(Debug, PrefixOpt)]
pub enum A<T> {
A(Box<T>, Option<Option<u8>>),
B{x:T},
C,
D(),
E(::std::marker::PhantomData<u32>)
}
impl Default for A {
fn default() -> A {
A::A(Box::new(1), None)
}
}
fn main() {
let a_opt = A::<u32>::with_prefix("o");
let app = a_opt.as_arguments().bind_app(clap::App::new("testing"));
let a = a_opt.match_arguments(&app.get_matches());
println!("{:?}", a);
}
Why
I have a program with too much options to encode manually. I liked OpenSSH's approach with -o
which is hopefully automatically generated. I extended the approach to enums and liked the index-like syntax.
To do and possible extensions
In a general order of personal importance.
- Optional integration with structopt which currently only supports flat flags and options.
- Add annotation to remove dependency on default and require the arguments.
- Add annotation to change the printed name instead of the field name.
- Add annotation to alias short names or shorter long names for leaf values.
- Add annotation for descriptions to arguments.
- Remove with_prefix struct, depends on clap API change concerning owned strings, issue 1041.
Changelog
- 0.4.0 Adding generics for structs and enums.
- 0.3.0 Less formatting, removing redundant indexing for unary tuples in structs and enums.
- 0.2.0 Fixing default bug, an option minimally changes it's sisters: only for sister fields in a non-default enum discriminant.
- 0.1.0 Initial version, has known bugs.
License
Dual-licensed.
Licensed under the Apache License, Version 2.0 http://www.apache.org/licenses/LICENSE-2.0 or the MIT license http://opensource.org/licenses/MIT, at your option. This project may not be copied, modified, or distributed except according to those terms.
Dependencies
~1.5MB
~25K SLoC