1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
//! convert verbosty level from count of -v flags into enum from a logger crate of your choice

use bpaf::*;

// generally you'd use this from the log crate itself
#[derive(Debug, Copy, Clone)]
pub enum LevelFilter {
    Off,
    Error,
    Warn,
    Info,
    Debug,
    Trace,
}

#[derive(Bpaf)]
#[bpaf(options)]
#[allow(dead_code)]
#[derive(Debug, Clone)]
struct Options {
    #[bpaf(external)]
    verbose: LevelFilter,
    /// number of potatoes
    #[bpaf(fallback(3))]
    potato: usize,
}

fn verbose() -> impl Parser<LevelFilter> {
    short('v')
        .help("Verbosity level, use multiple times for more verbosity")
        .req_flag(())
        .many()
        .map(|v| {
            use LevelFilter::*;
            *[Off, Error, Warn, Info, Debug, Trace]
                .get(v.len())
                .unwrap_or(&Trace)
        })
}

fn main() {
    println!("{:#?}", options().run());
}