2018-07-02 17:50:46 +00:00
# Work in Progress
2017-02-03 00:03:51 +00:00
2018-07-02 17:50:46 +00:00
This crate is currently a work in progress and not meant to be used. Please use [`structopt` ](https://github.com/TeXitoi/structopt )
while this crate is being built.
# clap_derive[![Build status](https://travis-ci.org/kbknapp/clap_derive.svg?branch=master)](https://travis-ci.org/kbknapp/clap_derive) [![](https://img.shields.io/crates/v/clap_derive.svg)](https://crates.io/crates/clap_derive) [![](https://docs.rs/clap_derive/badge.svg)](https://docs.rs/clap_derive)
Parse command line argument by defining a struct. It combines [structopt ](https://github.com/TeXitoi/structopt ) and [clap ](https://crates.io/crates/clap ) into a single experience. This crate is used by clap, and not meant to be used directly by
consumers.
2017-02-03 00:03:51 +00:00
## Documentation
2018-07-02 17:50:46 +00:00
Find it on [Docs.rs ](https://docs.rs/clap_derive ). You can also check the [examples ](https://github.com/kbknapp/clap_derive/tree/master/examples ) and the [changelog ](https://github.com/kbknapp/clap_derive/blob/master/CHANGELOG.md ).
2017-02-09 21:31:06 +00:00
## Example
2018-07-02 17:50:46 +00:00
Add `clap` to your dependencies of your `Cargo.toml` :
2017-02-10 23:32:01 +00:00
```toml
[dependencies]
2018-07-02 17:50:46 +00:00
clap = "3"
2017-02-10 23:32:01 +00:00
```
And then, in your rust file:
2017-02-09 21:31:06 +00:00
```rust
#[macro_use]
2018-07-02 17:50:46 +00:00
extern crate clap;
2017-02-09 21:31:06 +00:00
2018-02-11 00:06:38 +00:00
use std::path::PathBuf;
2018-07-02 17:50:46 +00:00
use clap::Clap;
2017-02-09 21:31:06 +00:00
2018-02-01 23:00:08 +00:00
/// A basic example
2018-07-02 17:50:46 +00:00
#[derive(Clap, Debug)]
#[clap(name = "basic")]
2017-02-09 21:31:06 +00:00
struct Opt {
2018-02-01 23:00:08 +00:00
// A flag, true if used in the command line. Note doc comment will
// be used for the help message of the flag.
/// Activate debug mode
2018-07-02 17:50:46 +00:00
#[clap(short = "d", long = "debug")]
2017-02-09 21:31:06 +00:00
debug: bool,
2018-02-01 23:00:08 +00:00
// The number of occurences of the `v/verbose` flag
/// Verbose mode (-v, -vv, -vvv, etc.)
2018-07-02 17:50:46 +00:00
#[clap(short = "v", long = "verbose", parse(from_occurrences))]
2018-02-01 23:00:08 +00:00
verbose: u8,
/// Set speed
2018-07-02 17:50:46 +00:00
#[clap(short = "s", long = "speed", default_value = "42")]
2017-02-09 21:31:06 +00:00
speed: f64,
2018-02-01 23:00:08 +00:00
/// Output file
2018-07-02 17:50:46 +00:00
#[clap(short = "o", long = "output", parse(from_os_str))]
2018-02-01 23:00:08 +00:00
output: PathBuf,
2018-02-10 19:57:33 +00:00
/// Number of cars
2018-07-02 17:50:46 +00:00
#[clap(short = "c", long = "nb-cars")]
2018-02-10 19:57:33 +00:00
nb_cars: Option< i32 > ,
2018-02-01 23:00:08 +00:00
/// admin_level to consider
2018-07-02 17:50:46 +00:00
#[clap(short = "l", long = "level")]
2018-02-01 23:00:08 +00:00
level: Vec< String > ,
2017-02-09 21:31:06 +00:00
2018-02-01 23:00:08 +00:00
/// Files to process
2018-07-02 17:50:46 +00:00
#[clap(name = "FILE", parse(from_os_str))]
2018-02-01 23:00:08 +00:00
files: Vec< PathBuf > ,
2017-02-09 21:31:06 +00:00
}
fn main() {
2018-07-02 17:50:46 +00:00
let opt = Opt::parse();
2017-02-09 21:31:06 +00:00
println!("{:?}", opt);
}
```
Using this example:
```
2018-02-01 23:00:08 +00:00
$ ./basic
2017-02-09 21:31:06 +00:00
error: The following required arguments were not provided:
2018-02-01 23:00:08 +00:00
--output < output >
2017-02-09 21:31:06 +00:00
USAGE:
2018-02-01 23:00:08 +00:00
basic --output < output > --speed < speed >
2017-02-09 21:31:06 +00:00
For more information try --help
2018-02-01 23:00:08 +00:00
$ ./basic --help
2018-02-04 17:43:53 +00:00
basic 0.2.0
2017-02-09 21:31:06 +00:00
Guillaume Pinot < texitoi @ texitoi . eu >
2018-02-01 23:00:08 +00:00
A basic example
2017-02-09 21:31:06 +00:00
USAGE:
2018-02-01 23:00:08 +00:00
basic [FLAGS] [OPTIONS] --output < output > [--] [FILE]...
2017-02-09 21:31:06 +00:00
2018-07-02 17:50:46 +00:00
ARGS:
< FILE > ... Files to process
2017-02-09 21:31:06 +00:00
FLAGS:
-d, --debug Activate debug mode
-h, --help Prints help information
-V, --version Prints version information
2018-02-01 23:00:08 +00:00
-v, --verbose Verbose mode
2017-02-09 21:31:06 +00:00
OPTIONS:
2018-03-19 22:45:47 +00:00
-c, --nb-cars < nb_cars > Number of cars
2018-02-01 23:00:08 +00:00
-l, --level < level > ... admin_level to consider
-o, --output < output > Output file
-s, --speed < speed > Set speed [default: 42]
$ ./basic -o foo.txt
Opt { debug: false, verbose: 0, speed: 42, output: "foo.txt", car: None, level: [], files: [] }
2018-03-19 22:45:47 +00:00
$ ./basic -o foo.txt -dvvvs 1337 -l alice -l bob --nb-cars 4 bar.txt baz.txt
Opt { debug: true, verbose: 3, speed: 1337, output: "foo.txt", nb_cars: Some(4), level: ["alice", "bob"], files: ["bar.txt", "baz.txt"] }
2017-02-09 21:31:06 +00:00
```
2018-07-02 17:50:46 +00:00
## clap_derive rustc version policy
2018-06-07 13:04:37 +00:00
2018-07-02 17:50:46 +00:00
- Minimum rustc version modification must be specified in the [changelog ](https://github.com/kbknapp/clap_derive/blob/master/CHANGELOG.md ) and in the [travis configuration ](https://github.com/kbknapp/clap_derive/blob/master/.travis.yml ).
- Contributors can increment minimum rustc version without any justification if the new version is required by the latest version of one of clap_derive's depedencies (`cargo update` will not fail on clap_derive).
2018-06-07 13:04:37 +00:00
- Contributors can increment minimum rustc version if the library user experience is improved.
2017-02-09 21:31:06 +00:00
## Why
2018-07-02 17:50:46 +00:00
I've (@TeXitoi) used [docopt ](https://crates.io/crates/docopt ) for a long time (pre rust 1.0). I really like the fact that you have a structure with the parsed argument: no need to convert `String` to `f64` , no useless `unwrap` . But on the other hand, I don't like to write by hand the usage string. That's like going back to the golden age of WYSIWYG editors. Field naming is also a bit artificial.
2017-02-09 21:31:06 +00:00
2017-02-10 00:28:00 +00:00
Today, the new standard to read command line arguments in Rust is [clap ](https://crates.io/crates/clap ). This library is so feature full! But I think there is one downside: even if you can validate argument and expressing that an argument is required, you still need to transform something looking like a hashmap of string vectors to something useful for your application.
2017-02-09 21:31:06 +00:00
Now, there is stable custom derive. Thus I can add to clap the automatic conversion that I miss. Here is the result.
2018-02-25 10:22:24 +00:00
## License
Licensed under either of
- Apache License, Version 2.0 ([LICENSE-APACHE](LICENSE-APACHE) or < https: // www . apache . org / licenses / LICENSE-2 . 0 > )
- MIT license ([LICENSE-MIT](LICENSE-MIT) or < https: // opensource . org / licenses / MIT > )
at your option.
### Contribution
Unless you explicitly state otherwise, any contribution intentionally submitted
for inclusion in the work by you, as defined in the Apache-2.0 license, shall be
dual licensed as above, without any additional terms or conditions.