diff --git a/imag-diary/src/view.rs b/imag-diary/src/view.rs index 742bc262..444c7131 100644 --- a/imag-diary/src/view.rs +++ b/imag-diary/src/view.rs @@ -1,30 +1,19 @@ use libimagdiary::diary::Diary; -use libimagentryview::viewer::Viewer; -use libimagentryview::builtin::plain::PlainViewer; +use libimagdiary::viewer::DiaryViewer as DV; use libimagrt::runtime::Runtime; -use libimagerror::trace::trace_error; +use libimagerror::trace::MapErrTrace; use libimagutil::warn_exit::warn_exit; use util::get_diary_name; pub fn view(rt: &Runtime) { let diaryname = get_diary_name(rt).unwrap_or_else(|| warn_exit("No diary name", 1)); - let diary = Diary::open(rt.store(), &diaryname[..]); - let show_header = rt.cli().subcommand_matches("view").unwrap().is_present("show-header"); + let diary = Diary::open(rt.store(), &diaryname[..]); + let hdr = rt.cli().subcommand_matches("view").unwrap().is_present("show-header"); - match diary.entries() { - Ok(entries) => { - let pv = PlainViewer::new(show_header); - for entry in entries.into_iter().filter_map(Result::ok) { - let id = entry.diary_id(); - println!("{} :\n", id); - if let Err(e) = pv.view_entry(&entry) { - trace_error(&e); - }; - println!("\n---\n"); - } - }, - Err(e) => trace_error(&e), - } + diary.entries() + .and_then(|entries| DV::new(hdr).view_entries(entries.into_iter().filter_map(Result::ok))) + .map_err_trace() + .ok(); } diff --git a/libimagdiary/src/error.rs b/libimagdiary/src/error.rs index 5cb37915..9ad53604 100644 --- a/libimagdiary/src/error.rs +++ b/libimagdiary/src/error.rs @@ -7,7 +7,8 @@ generate_error_module!( DiaryEditError => "Cannot edit diary entry", PathConversionError => "Error while converting paths internally", EntryNotInDiary => "Entry not in Diary", - IOError => "IO Error" + IOError => "IO Error", + ViewError => "Error viewing diary entry" ); ); diff --git a/libimagdiary/src/lib.rs b/libimagdiary/src/lib.rs index b668a48d..1a808283 100644 --- a/libimagdiary/src/lib.rs +++ b/libimagdiary/src/lib.rs @@ -39,3 +39,5 @@ pub mod is_in_diary; pub mod entry; pub mod iter; pub mod result; +pub mod viewer; + diff --git a/libimagdiary/src/viewer.rs b/libimagdiary/src/viewer.rs new file mode 100644 index 00000000..63c4f030 --- /dev/null +++ b/libimagdiary/src/viewer.rs @@ -0,0 +1,45 @@ +//! A diary viewer built on libimagentryview. + +use entry::Entry; +use error::DiaryErrorKind as DEK; +use error::MapErrInto; +use result::Result; + +use libimagentryview::viewer::Viewer; +use libimagentryview::builtin::plain::PlainViewer; + +/// This viewer does _not_ implement libimagentryview::viewer::Viewer because we need to be able to +/// call some diary-type specific functions on the entries passed to this. +/// +/// This type is mainly just written to be constructed-called-deleted in one go: +/// +/// ```ignore +/// DiaryViewer::new(show_header).view_entries(entries); +/// ``` +/// +pub struct DiaryViewer(PlainViewer); + +impl DiaryViewer { + + pub fn new(show_header: bool) -> DiaryViewer { + DiaryViewer(PlainViewer::new(show_header)) + } + + /// View all entries from the iterator, or stop immediately if an error occurs, returning that + /// error. + pub fn view_entries<'a, I: Iterator>>(&self, entries: I) -> Result<()> { + for entry in entries { + let id = entry.diary_id(); + println!("{} :\n", id); + let _ = try!(self.0 + .view_entry(&entry) + .map_err_into(DEK::ViewError) + .map_err_into(DEK::IOError)); + println!("\n---\n"); + } + + Ok(()) + } + +} +