-
Notifications
You must be signed in to change notification settings - Fork 23
/
Copy pathgit.rs
59 lines (50 loc) · 1.44 KB
/
git.rs
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
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
//! `git.rs` serves as a demonstration of how to use subcommands,
//! as well as a demonstration of adding documentation to subcommands.
//!
//! Note, this "fetch" command uses fallback to inner description to get the help message, "add"
//! uses explicit override with the same value.
use std::path::PathBuf;
use bpaf::*;
#[allow(dead_code)]
#[derive(Debug, Clone)]
enum Opt {
Fetch {
dry_run: bool,
all: bool,
repository: String,
},
Add {
interactive: bool,
all: bool,
files: Vec<PathBuf>,
},
}
fn main() {
let dry_run = long("dry_run").switch();
let all = long("all").switch();
let repository = positional::<String>("SRC").fallback("origin".to_string());
let fetch = construct!(Opt::Fetch {
dry_run,
all,
repository
})
.to_options()
.descr("fetches branches from remote repository");
let fetch_cmd = fetch.command("fetch");
let interactive = short('i').switch();
let all = long("all").switch();
let files = positional::<PathBuf>("FILE").many();
let add = construct!(Opt::Add {
interactive,
all,
files
})
.to_options()
.descr("add files to the staging area");
let add_cmd = add.command("add").help("add files to the staging area");
let opt = construct!([fetch_cmd, add_cmd])
.to_options()
.descr("The stupid content tracker")
.run();
println!("{:?}", opt);
}