Auto merge of #63 - matthiasbeyer:notes-show, r=matthiasbeyer
Notes show Add subcommand for `notes`: `show`, to print notes on the commandline, unrendered.
This commit is contained in:
commit
7c49cc5d14
2 changed files with 86 additions and 0 deletions
39
etc/cli.yml
39
etc/cli.yml
|
@ -314,6 +314,45 @@ subcommands:
|
||||||
required: false
|
required: false
|
||||||
takes_value: true
|
takes_value: true
|
||||||
|
|
||||||
|
- show:
|
||||||
|
about: Show note(s)
|
||||||
|
version: 0.1
|
||||||
|
author: Matthias Beyer <mail@beyermatthias.de>
|
||||||
|
args:
|
||||||
|
- plain:
|
||||||
|
long: plain
|
||||||
|
short: p
|
||||||
|
help: Show notes plain (like with 'cat')
|
||||||
|
required: false
|
||||||
|
takes_value: false
|
||||||
|
|
||||||
|
- id:
|
||||||
|
long: id
|
||||||
|
help: Open note with this ID
|
||||||
|
required: false
|
||||||
|
takes_value: true
|
||||||
|
|
||||||
|
- namegrep:
|
||||||
|
short: n
|
||||||
|
long: name
|
||||||
|
help: Open where name matches this regex
|
||||||
|
required: false
|
||||||
|
takes_value: true
|
||||||
|
|
||||||
|
- grep:
|
||||||
|
short: g
|
||||||
|
long: grep
|
||||||
|
help: Open where grep with regex finds something
|
||||||
|
required: false
|
||||||
|
takes_value: true
|
||||||
|
|
||||||
|
- tags:
|
||||||
|
short: t
|
||||||
|
long: tags
|
||||||
|
help: Open all notes with these tags
|
||||||
|
required: false
|
||||||
|
takes_value: true
|
||||||
|
|
||||||
- open:
|
- open:
|
||||||
about: Open notes as HTML page in browser (via XDG-open)
|
about: Open notes as HTML page in browser (via XDG-open)
|
||||||
version: 0.1
|
version: 0.1
|
||||||
|
|
|
@ -122,6 +122,49 @@ impl<'a> Notes<'a> {
|
||||||
return failed == 0;
|
return failed == 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn command_show(&self, matches: &ArgMatches) -> bool {
|
||||||
|
use self::header::get_name_from_header;
|
||||||
|
use self::header::get_tags_from_header;
|
||||||
|
|
||||||
|
let parser = Parser::new(JsonHeaderParser::new(None));
|
||||||
|
|
||||||
|
let filter = {
|
||||||
|
let hash_filter = create_hash_filter(matches, "id", true);
|
||||||
|
let head_filter = create_text_header_field_grep_filter(matches, "match", "NAME", true);
|
||||||
|
let text_filter = create_content_grep_filter(matches, "match", true);
|
||||||
|
let tags_filter = create_tag_filter(matches, "tags", true);
|
||||||
|
hash_filter.and(Box::new(head_filter)).and(Box::new(text_filter)).and(Box::new(tags_filter))
|
||||||
|
};
|
||||||
|
|
||||||
|
self.rt
|
||||||
|
.store()
|
||||||
|
.load_for_module(self, &parser)
|
||||||
|
.into_iter()
|
||||||
|
.filter(|file| {
|
||||||
|
let res = filter.filter_file(file);
|
||||||
|
debug!("Filter: {} -> {}", file.deref().borrow().id(), res);
|
||||||
|
res
|
||||||
|
})
|
||||||
|
.map(|file| {
|
||||||
|
let content = file.deref().borrow().data().clone();
|
||||||
|
|
||||||
|
let text = if matches.is_present("plain") {
|
||||||
|
parser.write((file.deref().borrow().header(), &content))
|
||||||
|
.unwrap_or(format!("Parser error for file: {}", file.deref().borrow().id()))
|
||||||
|
} else {
|
||||||
|
let tags = get_tags_from_header(file.deref().borrow().header());
|
||||||
|
let name = get_name_from_header(file.deref().borrow().header());
|
||||||
|
format!("Name = '{}'\nTags = '{}'\n\n{}\n\n",
|
||||||
|
name, tags.join(", "), content)
|
||||||
|
};
|
||||||
|
|
||||||
|
println!("{:-<79}", "-");
|
||||||
|
println!("{}", text);
|
||||||
|
true
|
||||||
|
})
|
||||||
|
.all(|x| x)
|
||||||
|
}
|
||||||
|
|
||||||
fn command_open(&self, matches: &ArgMatches) -> bool {
|
fn command_open(&self, matches: &ArgMatches) -> bool {
|
||||||
let parser = Parser::new(JsonHeaderParser::new(None));
|
let parser = Parser::new(JsonHeaderParser::new(None));
|
||||||
|
|
||||||
|
@ -455,6 +498,10 @@ impl<'a> Module<'a> for Notes<'a> {
|
||||||
self.command_edit(matches.subcommand_matches("edit").unwrap())
|
self.command_edit(matches.subcommand_matches("edit").unwrap())
|
||||||
},
|
},
|
||||||
|
|
||||||
|
Some("show") => {
|
||||||
|
self.command_show(matches.subcommand_matches("show").unwrap())
|
||||||
|
},
|
||||||
|
|
||||||
Some("open") => {
|
Some("open") => {
|
||||||
self.command_open(matches.subcommand_matches("open").unwrap())
|
self.command_open(matches.subcommand_matches("open").unwrap())
|
||||||
},
|
},
|
||||||
|
|
Loading…
Reference in a new issue