ctflag

Crates.ioctflag
lib.rsctflag
version0.1.2
sourcesrc
created_at2019-06-05 23:52:57.612337
updated_at2019-06-27 22:34:35.960172
descriptionCommand-line flag parsing library
homepage
repositoryhttps://github.com/adamlesinski/ctflag
max_upload_size
id139259
size26,606
Adam Lesinski (adamlesinski)

documentation

README

Capture the Flag   Latest Version

Disclaimer: This is not an official Google product.

Capture the Flag is a command-line flag parser Rust library.


Usage

use ctflag::{Flags, FromArg, FromArgError, FromArgResult};

#[derive(Flags)]
struct MyFlags {
    #[flag(desc = "The floopy floops the whoop")]
    enable_floopy: bool,

    #[flag(
        desc = "How many slomps to include",
        placeholder = "INTEGER",
        default = 34
    )]
    slomp_count: i64,

    #[flag(desc = "An optional path to a Gmup", placeholder = "PATH")]
    gmup: Option<String>,

    #[flag(short = 'h', desc = "Prints this help message")]
    help: bool,
}

// Custom type.
enum Fruit {
    Apple,
    Orange,
}

impl FromArg for Fruit {
    fn from_arg(s: &str) -> FromArgResult<Self> {
        match s {
            "apple" => Ok(Fruit::Apple),
            "orange" => Ok(Fruit::Orange),
            _ => Err(FromArgError::with_message("must be an apple or orange")),
        }
    }
}

fn main() {
    let result = MyFlags::from_args(std::env::args());
    match result {
        Ok((flags, args)) => {
            if flags.help {
                println!("{}", MyFlags::description());
                return;
            }
            // ...
        }
        Err(err) => {
            println!("Error parsing flags: {}", err);
            println!("{}", MyFlags::description());
        }
    }
}

Setup

[dependencies]
ctflag = "0.1"
Commit count: 17

cargo fmt