Matthias Beyer
90eaeb642a
This patch removes the magic constant we used when calling `trace_unwrap_exit()` or `map_err_trace_exit_unwrap()`. We used to call it with `1` as parameter, where the number was the exit code to use. Now the implementation of the function does it automatically (using 1 (one) as exit code). All calls of these functions were fixed. Thanks to vim this was easy. Signed-off-by: Matthias Beyer <mail@beyermatthias.de>
150 lines
5.8 KiB
Rust
150 lines
5.8 KiB
Rust
//
|
|
// imag - the personal information management suite for the commandline
|
|
// Copyright (C) 2015-2019 Matthias Beyer <mail@beyermatthias.de> and contributors
|
|
//
|
|
// This library is free software; you can redistribute it and/or
|
|
// modify it under the terms of the GNU Lesser General Public
|
|
// License as published by the Free Software Foundation; version
|
|
// 2.1 of the License.
|
|
//
|
|
// This library is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
// Lesser General Public License for more details.
|
|
//
|
|
// You should have received a copy of the GNU Lesser General Public
|
|
// License along with this library; if not, write to the Free Software
|
|
// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
|
//
|
|
|
|
use std::path::PathBuf;
|
|
|
|
use clap::{Arg, ArgMatches, App, SubCommand};
|
|
|
|
use libimagstore::storeid::StoreId;
|
|
use libimagstore::storeid::IntoStoreId;
|
|
use libimagrt::runtime::IdPathProvider;
|
|
use libimagerror::trace::MapErrTrace;
|
|
|
|
pub fn build_ui<'a>(app: App<'a, 'a>) -> App<'a, 'a> {
|
|
app
|
|
.subcommand(SubCommand::with_name("add")
|
|
.about("Add annotation to an entry")
|
|
.version("0.1")
|
|
|
|
.arg(Arg::with_name("dont-print-name")
|
|
.short("N")
|
|
.long("no-name")
|
|
.takes_value(false)
|
|
.required(false)
|
|
.multiple(false)
|
|
.help("Do not print the name of the annotation after annotating.")
|
|
)
|
|
.arg(Arg::with_name("entry")
|
|
.index(1)
|
|
.takes_value(true)
|
|
.required(true)
|
|
.multiple(false)
|
|
.help("The entry to add the latitude/longitude to")
|
|
.value_name("ENTRY"))
|
|
)
|
|
|
|
.subcommand(SubCommand::with_name("remove")
|
|
.about("Remove annotation from an entry")
|
|
.version("0.1")
|
|
.arg(Arg::with_name("entry")
|
|
.index(1)
|
|
.takes_value(true)
|
|
.required(true)
|
|
.multiple(false)
|
|
.help("The entry to remove the latitude/longitude from")
|
|
.value_name("ENTRY"))
|
|
.arg(Arg::with_name("annotation_name")
|
|
.index(2)
|
|
.takes_value(true)
|
|
.required(true)
|
|
.multiple(false)
|
|
.help("Name of the annotation to remove")
|
|
.value_name("NAME"))
|
|
.arg(Arg::with_name("delete-annotation")
|
|
.short("D")
|
|
.long("delete")
|
|
.takes_value(false)
|
|
.required(false)
|
|
.multiple(false)
|
|
.help("Do not only 'unlink' the annotation, but also delete it from the store"))
|
|
)
|
|
|
|
.subcommand(SubCommand::with_name("list")
|
|
.about("List annotations")
|
|
.version("0.1")
|
|
.arg(Arg::with_name("entry")
|
|
.index(1)
|
|
.takes_value(true)
|
|
.required(false)
|
|
.multiple(false)
|
|
.help("The entry to list annotations for (all annotations if not passed)")
|
|
.value_name("ENTRY"))
|
|
.arg(Arg::with_name("list-with-text")
|
|
.long("text")
|
|
.short("t")
|
|
.takes_value(false)
|
|
.required(false)
|
|
.multiple(false)
|
|
.help("List annotations with text"))
|
|
)
|
|
}
|
|
|
|
pub struct PathProvider;
|
|
impl IdPathProvider for PathProvider {
|
|
fn get_ids(matches: &ArgMatches) -> Vec<StoreId> {
|
|
match matches.subcommand() {
|
|
("add", Some(subm)) => {
|
|
subm.values_of("entry")
|
|
.ok_or_else(|| {
|
|
error!("No StoreId found");
|
|
::std::process::exit(1)
|
|
})
|
|
.unwrap()
|
|
.into_iter()
|
|
.map(PathBuf::from)
|
|
.map(|pb| pb.into_storeid())
|
|
.collect::<Result<Vec<_>, _>>()
|
|
.map_err_trace_exit_unwrap()
|
|
},
|
|
|
|
("remove", Some(subm)) => {
|
|
subm.values_of("entry")
|
|
.ok_or_else(|| {
|
|
error!("No StoreId found");
|
|
::std::process::exit(1)
|
|
})
|
|
.unwrap()
|
|
.into_iter()
|
|
.map(PathBuf::from)
|
|
.map(|pb| pb.into_storeid())
|
|
.collect::<Result<Vec<_>, _>>()
|
|
.map_err_trace_exit_unwrap()
|
|
},
|
|
|
|
("list", Some(subm)) => {
|
|
subm.values_of("entry")
|
|
.ok_or_else(|| {
|
|
error!("No StoreId found");
|
|
::std::process::exit(1)
|
|
})
|
|
.unwrap()
|
|
.into_iter()
|
|
.map(PathBuf::from)
|
|
.map(|pb| pb.into_storeid())
|
|
.collect::<Result<Vec<_>, _>>()
|
|
.map_err_trace_exit_unwrap()
|
|
},
|
|
|
|
(other, _) => {
|
|
error!("Not a known command: {}", other);
|
|
::std::process::exit(1)
|
|
}
|
|
}
|
|
}
|
|
}
|