2016-02-23 10:02:59 +00:00
|
|
|
use clap::{Arg, ArgMatches, App, SubCommand};
|
|
|
|
|
|
|
|
use tag::Tag;
|
|
|
|
|
|
|
|
/// Generates a clap::SubCommand to be integrated in the commandline-ui builder for building a
|
|
|
|
/// "tags --add foo --remove bar" subcommand to do tagging action.
|
|
|
|
pub fn tag_subcommand<'a, 'b>() -> App<'a, 'b> {
|
2016-03-19 16:48:03 +00:00
|
|
|
SubCommand::with_name(tag_subcommand_name())
|
2016-02-23 10:02:59 +00:00
|
|
|
.author("Matthias Beyer <mail@beyermatthias.de>")
|
|
|
|
.version("0.1")
|
|
|
|
.about("Add or remove tags")
|
|
|
|
|
2016-03-19 16:48:03 +00:00
|
|
|
.arg(Arg::with_name(tag_subcommand_add_arg_name())
|
2016-02-23 10:02:59 +00:00
|
|
|
.short("a")
|
|
|
|
.long("add")
|
|
|
|
.takes_value(true)
|
|
|
|
.multiple(true)
|
|
|
|
.help("Add tags, seperated by comma or by specifying multiple times"))
|
|
|
|
|
2016-03-19 16:48:03 +00:00
|
|
|
.arg(Arg::with_name(tag_subcommand_remove_arg_name())
|
2016-02-23 10:02:59 +00:00
|
|
|
.short("r")
|
|
|
|
.long("remove")
|
|
|
|
.takes_value(true)
|
|
|
|
.multiple(true)
|
|
|
|
.help("Remove tags, seperated by comma or by specifying multiple times"))
|
|
|
|
}
|
|
|
|
|
2016-03-19 16:48:03 +00:00
|
|
|
pub fn tag_subcommand_name() -> &'static str {
|
|
|
|
"tags"
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn tag_subcommand_add_arg_name() -> &'static str {
|
|
|
|
"add-tags"
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn tag_subcommand_remove_arg_name() -> &'static str {
|
|
|
|
"remove-tags"
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn tag_subcommand_names() -> Vec<&'static str> {
|
|
|
|
vec![tag_subcommand_add_arg_name(), tag_subcommand_remove_arg_name()]
|
|
|
|
}
|
|
|
|
|
2016-02-23 10:02:59 +00:00
|
|
|
/// Generates a clap::Arg which can be integrated into the commandline-ui builder for building a
|
|
|
|
/// "-t" or "--tags" argument which takes values for tagging actions (add, remove)
|
|
|
|
pub fn tag_argument<'a, 'b>() -> Arg<'a, 'b> {
|
2016-03-19 16:48:03 +00:00
|
|
|
Arg::with_name(tag_argument_name())
|
2016-02-23 10:02:59 +00:00
|
|
|
.short("t")
|
|
|
|
.long("tags")
|
|
|
|
.takes_value(true)
|
|
|
|
.multiple(true)
|
|
|
|
.help("Add or remove tags, prefixed by '+' (for adding) or '-' (for removing)")
|
|
|
|
}
|
|
|
|
|
2016-03-19 16:48:03 +00:00
|
|
|
pub fn tag_argument_name() -> &'static str {
|
|
|
|
"specify-tags"
|
|
|
|
}
|
|
|
|
|
2016-02-23 10:02:59 +00:00
|
|
|
/// Get the tags which should be added from the commandline
|
|
|
|
///
|
|
|
|
/// Returns none if the argument was not specified
|
|
|
|
pub fn get_add_tags(matches: &ArgMatches) -> Option<Vec<Tag>> {
|
|
|
|
extract_tags(matches, "add-tags", '+')
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Get the tags which should be removed from the commandline
|
|
|
|
///
|
|
|
|
/// Returns none if the argument was not specified
|
|
|
|
pub fn get_remove_tags(matches: &ArgMatches) -> Option<Vec<Tag>> {
|
|
|
|
extract_tags(matches, "remove-tags", '-')
|
|
|
|
}
|
|
|
|
|
|
|
|
fn extract_tags(matches: &ArgMatches, specifier: &str, specchar: char) -> Option<Vec<Tag>> {
|
|
|
|
if let Some(submatch) = matches.subcommand_matches("tags") {
|
|
|
|
submatch.values_of(specifier)
|
|
|
|
.map(|values| values.map(String::from).collect())
|
|
|
|
} else {
|
|
|
|
matches.values_of("specify-tags")
|
|
|
|
.map(|argmatches| {
|
|
|
|
argmatches
|
|
|
|
.map(String::from)
|
|
|
|
.filter(|s| s.chars().next() == Some(specchar))
|
|
|
|
.map(|s| {
|
|
|
|
String::from(s.split_at(1).1)
|
|
|
|
})
|
|
|
|
.collect()
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|