Auto merge of #44 - matthiasbeyer:bm-open-xdg, r=matthiasbeyer

Bm open xdg

Add subcommand to `BM` to open links via xdg.

Closes #28
This commit is contained in:
Homu 2016-01-03 00:25:31 +09:00
commit 9a82ccd2d1
5 changed files with 79 additions and 0 deletions

6
Cargo.lock generated
View file

@ -7,6 +7,7 @@ dependencies = [
"config 0.1.2 (registry+https://github.com/rust-lang/crates.io-index)",
"glob 0.2.10 (registry+https://github.com/rust-lang/crates.io-index)",
"log 0.3.2 (registry+https://github.com/rust-lang/crates.io-index)",
"open 1.1.0 (registry+https://github.com/rust-lang/crates.io-index)",
"prettytable-rs 0.4.0 (registry+https://github.com/rust-lang/crates.io-index)",
"regex 0.1.41 (registry+https://github.com/rust-lang/crates.io-index)",
"rustty 0.1.9 (registry+https://github.com/rust-lang/crates.io-index)",
@ -141,6 +142,11 @@ dependencies = [
"rustc-serialize 0.3.16 (registry+https://github.com/rust-lang/crates.io-index)",
]
[[package]]
name = "open"
version = "1.1.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
[[package]]
name = "prettytable-rs"
version = "0.4.0"

View file

@ -26,4 +26,5 @@ rustty = "0.1.9"
term = "0.2.12"
term_grid = "0.1.2"
prettytable-rs = "0.4.0"
open = "1.1.0"

View file

@ -105,6 +105,31 @@ subcommands:
required: false
takes_value: true
- open:
about: Open bookmarks
version: 0.1
author: Matthias Beyer <mail@beyermatthias.de>
args:
- id:
long: id
help: Open Bookmark with ID
required: false
takes_value: true
- match:
short: m
long: match
help: Open links matching regex
required: false
takes_value: true
- tags:
short: t
long: tags
help: Open links with these tags
required: false
takes_value: true
- remove:
about: Remove bookmark(s)
version: 0.1

View file

@ -8,6 +8,7 @@
#[macro_use] extern crate prettytable;
extern crate url;
extern crate config;
extern crate open;
pub use cli::CliConfig;
pub use configuration::Configuration;

View file

@ -127,6 +127,48 @@ impl<'a> BM<'a> {
true
}
/**
* Subcommand: open
*/
fn command_open(&self, matches: &ArgMatches) -> bool {
use open;
let parser = Parser::new(JsonHeaderParser::new(None));
let filter : Box<CliFileFilter> = get_file_filter_by_cli(&parser, matches, "id", "match", "tags", None);
let result = self.rt
.store()
.load_for_module(self, &parser)
.iter()
.filter(|file| filter.filter_file(file))
.map(|file| {
debug!("File loaded, can open now: {:?}", file);
let f = file.deref().borrow();
get_url_from_header(f.header()).map(|url| {
if open::that(&url[..]).is_ok() {
info!("open({})", url);
true
} else {
info!("could not open({})", url);
false
}
})
.unwrap_or(false)
})
.fold((0, 0), |acc, succeeded| {
let (worked, failed) = acc;
if succeeded {
(worked + 1, failed)
} else {
(worked, failed + 1)
}
});
let (succ, fail) = result;
info!("open() succeeded for {} files", succ);
info!("open() failed for {} files", fail);
return fail == 0;
}
/**
* Subcommand: remove
*/
@ -263,6 +305,10 @@ impl<'a> Module<'a> for BM<'a> {
self.command_list(matches.subcommand_matches("list").unwrap())
},
Some("open") => {
self.command_open(matches.subcommand_matches("open").unwrap())
},
Some("remove") => {
self.command_remove(matches.subcommand_matches("remove").unwrap())
},