Crates.io | badargs |
lib.rs | badargs |
version | 0.2.0 |
source | src |
created_at | 2021-10-02 10:57:33.067879 |
updated_at | 2021-12-15 21:08:11.433667 |
description | Type safe zero-dependency argument parser |
homepage | https://github.com/Nilstrieb/badargs |
repository | https://github.com/Nilstrieb/badargs |
max_upload_size | |
id | 459395 |
size | 28,055 |
Node: badargs is not 1.0 yet, so it may change at any time. Use it with caution.
A zero-dependency full type-safe argument parser.
It's correct enough for what it does.
badargs
handles non Utf8 input by just printing an error and exiting the program gracefully.
use badargs::arg;
arg!(OutFile: "output", 'o' -> String);
arg!(Force: "force", 'f' -> bool);
arg!(OLevel: "optimize" -> usize);
fn main() {
let args = badargs::badargs!(OutFile, Force, OLevel);
let outfile = args.get::<OutFile>();
let force = args.get::<Force>();
let o_level = args.get::<OLevel>();
println!("output: {:?}", outfile);
println!("force: {:?}", force);
println!("o-level: {:?}", o_level);
println!("other args: {:?}", args.unnamed())
}
Use the badargs::arg!
macro to declare arguments like this:
arg!(Binding, long_name, optional_short_name -> return_type)
The following return types are currently available:
Boolean values can only be None
or Some(true)
.
The other values can be None
or Some(_)
Being able to add more metadata for better --help
or --version
If you want a fully featured, even more type safe argument parser, use Clap, or structopt.
These do have a lot of dependencies and/or proc macros, so they are a lot more heavy compilation wise. Badargs is perfect for you if you don't want or need that.