2015-03-18 23:43:33 +00:00
# clap
![Travis-CI ](https://travis-ci.org/kbknapp/clap-rs.svg?branch=master )
2015-02-25 13:36:33 +00:00
Command Line Argument Parser written in Rust
2015-03-01 00:22:23 +00:00
2015-03-29 19:37:08 +00:00
It is a simple to use and efficient library for parsing command line arguments and subcommands when writing command line, console, or terminal applications.
2015-03-01 00:22:23 +00:00
2015-03-29 19:37:08 +00:00
You can use clap to lay out a list of possible valid command line arguments and subcommands, then let `clap` parse *and validate* the string given by the user at runtime. This means you focus on your applications functionality, not parsing and validating arguments.
2015-03-01 00:22:23 +00:00
2015-03-29 19:37:08 +00:00
What seperates `clap` from other options available is the very simple almost 'Pythonic' style in which you define the valid available arguments for your program. This means you don't have to spend tons time learning an entirely new library's structures and use.
2015-03-16 14:38:43 +00:00
2015-03-29 19:37:08 +00:00
`clap` also provides all the traditional version and help switches (or flags) 'for free' by parsing the list of developer supplied arguments. If the developer hasn't defined them already, `clap` will auto-generate only the applicable "help" and "version" switches (as well as a "help" subcommand so long as other subcommands have been manually defined as well).
2015-03-16 14:38:43 +00:00
2015-03-29 19:37:08 +00:00
After defining a list of possible valid arguments and subcommands, `clap` parses the string given by the end-user at runtime then gives you a list of the valid matches and their values. If the user made an error or typo, `clap` informs them and exits gracefully. This means that you can simply use these matches and values to determine the functioning of your program.
2015-03-01 00:22:23 +00:00
2015-03-16 14:55:45 +00:00
## Quick Example
2015-03-01 00:22:23 +00:00
2015-03-16 14:38:43 +00:00
```rust
2015-03-21 15:28:39 +00:00
// (Full example with comments in examples/01_QuickExample.rs)
2015-03-16 14:38:43 +00:00
extern crate clap;
use clap::{Arg, App, SubCommand};
2015-03-01 00:22:23 +00:00
2015-03-16 14:55:45 +00:00
fn main() {
2015-03-16 19:56:42 +00:00
let matches = App::new("MyApp")
.version("1.0")
.author("Kevin K. < kbknapp @ gmail . com > ")
.about("Does awesome things")
2015-03-26 18:24:30 +00:00
.arg(Arg::new("CONFIG")
2015-03-16 19:56:42 +00:00
.short("c")
.long("config")
.help("Sets a custom config file")
.takes_value(true))
.arg(Arg::new("output")
.help("Sets an optional output file")
.index(1))
.arg(Arg::new("debug")
.short("d")
.multiple(true)
.help("Turn debugging information on"))
.subcommand(SubCommand::new("test")
.about("controls testing features")
.arg(Arg::new("verbose")
2015-03-18 16:54:31 +00:00
.short("v")
.help("print test information verbosely")))
2015-03-16 19:56:42 +00:00
.get_matches();
if let Some(o) = matches.value_of("output") {
println!("Value for output: {}", o);
}
2015-03-26 18:23:59 +00:00
if let Some(c) = matches.value_of("CONFIG") {
2015-03-16 19:56:42 +00:00
println!("Value for config: {}", c);
}
match matches.occurrences_of("debug") {
0 => println!("Debug mode is off"),
1 => println!("Debug mode is kind of on"),
2 => println!("Debug mode is on"),
3 | _ => println!("Don't be crazy"),
}
if let Some(ref matches) = matches.subcommand_matches("test") {
2015-03-18 16:54:31 +00:00
if matches.is_present("verbose") {
println!("Printing verbosely...");
2015-03-16 19:56:42 +00:00
} else {
2015-03-18 16:54:31 +00:00
println!("Printing normally...");
2015-03-16 19:56:42 +00:00
}
}
// more porgram logic goes here...
2015-03-16 14:38:43 +00:00
}
```
2015-03-01 00:22:23 +00:00
2015-03-16 14:38:43 +00:00
If you were to compile the above program and run it with the flag `--help` or `-h` (or `help` subcommand, since we defined `test` as a subcommand) the following output woud be presented
2015-03-01 00:22:23 +00:00
2015-03-16 14:38:43 +00:00
```sh
$ myprog --help
MyApp 1.0
Kevin K. < kbknapp @ gmail . com >
Does awesome things
USAGE:
2015-03-16 19:56:42 +00:00
MyApp [FLAGS] [OPTIONS] [POSITIONAL] [SUBCOMMANDS]
2015-03-16 14:38:43 +00:00
FLAGS:
2015-03-16 19:56:42 +00:00
-d Turn debugging information on
-h,--help Prints this message
-v,--version Prints version information
2015-03-01 00:22:23 +00:00
2015-03-16 14:38:43 +00:00
OPTIONS:
2015-03-26 18:23:59 +00:00
-c,--config=CONFIG Sets a custom config file
2015-03-01 00:22:23 +00:00
2015-03-16 14:38:43 +00:00
POSITIONAL ARGUMENTS:
2015-03-16 19:56:42 +00:00
output Sets an optional output file
2015-03-15 21:25:36 +00:00
2015-03-16 14:38:43 +00:00
SUBCOMMANDS:
2015-03-16 19:56:42 +00:00
help Prints this message
test Controls testing features
2015-03-16 14:38:43 +00:00
```
2015-03-01 00:33:18 +00:00
## Installation
2015-03-16 14:38:43 +00:00
Add `clap` as a dependecy in your `Cargo.toml` file to use from crates.io:
2015-03-01 00:33:18 +00:00
2015-03-01 00:31:24 +00:00
```
[dependencies]
2015-03-01 16:27:29 +00:00
clap = "*"
2015-03-01 00:31:24 +00:00
```
2015-03-16 14:38:43 +00:00
Or track the latest on the master branch at github:
2015-03-01 00:33:18 +00:00
```
2015-03-01 00:31:24 +00:00
[dependencies.clap]
git = "https://github.com/kbknapp/clap-rs.git"
```
2015-03-16 14:38:43 +00:00
2015-03-01 16:28:42 +00:00
Then run `cargo build` or `cargo update` for your project.
2015-03-01 16:55:53 +00:00
2015-03-16 14:38:43 +00:00
## Usage
Add `extern crate clap;` to your crate root.
2015-03-01 16:55:53 +00:00
## More Information
2015-03-16 14:38:43 +00:00
2015-03-01 16:56:53 +00:00
You can find complete documentation on the [github-pages site ](http://kbknapp.github.io/clap-rs/docs/clap/index.html ) for this project.
2015-03-18 23:45:30 +00:00
2015-03-20 18:42:40 +00:00
You can also find full usage examples in the examples/ directory of this repo.
2015-03-18 23:45:30 +00:00
## How to build
2015-03-26 18:20:01 +00:00
Clone the repo (`master` branch if using `clap` , `dev` branch if contributing) and build with Cargo
```
git clone https://github.com/kbknapp/clap-rs
cd clap-rs
cargo build --release
```
2015-03-18 23:45:30 +00:00
### Running the tests
2015-03-26 18:20:01 +00:00
If contributing, you can run the tests as follows (assuming you've already cloned the repo to `clap-rs/`
2015-03-18 23:45:30 +00:00
```
2015-03-26 18:20:01 +00:00
cd clap-rs/claptests
make test
2015-03-18 23:45:30 +00:00
```
### Building the documentation
Run this instead of `cargo doc` to generate the proper module docstring:
```
make doc
```
2015-03-26 18:20:01 +00:00
Then browse to `clap-rs/docs/index.html` in your web-browser of choice