Split into several files
This commit is contained in:
parent
f6971c6896
commit
5bde1cc207
7 changed files with 333 additions and 271 deletions
112
imag-diary/src/create.rs
Normal file
112
imag-diary/src/create.rs
Normal file
|
@ -0,0 +1,112 @@
|
||||||
|
use std::process::exit;
|
||||||
|
|
||||||
|
use libimagdiary::diary::Diary;
|
||||||
|
use libimagdiary::diaryid::DiaryId;
|
||||||
|
use libimagdiary::error::DiaryError as DE;
|
||||||
|
use libimagdiary::error::DiaryErrorKind as DEK;
|
||||||
|
use libimagrt::edit::Edit;
|
||||||
|
use libimagrt::runtime::Runtime;
|
||||||
|
use libimagerror::trace::trace_error;
|
||||||
|
use libimagdiary::entry::Entry;
|
||||||
|
use libimagdiary::result::Result;
|
||||||
|
|
||||||
|
use util::get_diary_name;
|
||||||
|
|
||||||
|
pub fn create(rt: &Runtime) {
|
||||||
|
|
||||||
|
let diaryname = get_diary_name(rt);
|
||||||
|
if diaryname.is_none() {
|
||||||
|
warn!("No diary selected. Use either the configuration file or the commandline option");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
let diaryname = diaryname.unwrap();
|
||||||
|
|
||||||
|
let prevent_edit = rt.cli().subcommand_matches("create").unwrap().is_present("no-edit");
|
||||||
|
|
||||||
|
fn create_entry<'a>(diary: &'a Diary, rt: &Runtime) -> Result<Entry<'a>> {
|
||||||
|
use std::str::FromStr;
|
||||||
|
|
||||||
|
let create = rt.cli().subcommand_matches("create").unwrap();
|
||||||
|
if !create.is_present("timed") {
|
||||||
|
debug!("Creating non-timed entry");
|
||||||
|
diary.new_entry_today()
|
||||||
|
} else {
|
||||||
|
let id = match create.value_of("timed") {
|
||||||
|
Some("h") | Some("hourly") => {
|
||||||
|
debug!("Creating hourly-timed entry");
|
||||||
|
let mut time = DiaryId::now(String::from(diary.name()));
|
||||||
|
let hr = create
|
||||||
|
.value_of("hour")
|
||||||
|
.map(|v| { debug!("Creating hourly entry with hour = {:?}", v); v })
|
||||||
|
.and_then(|s| {
|
||||||
|
FromStr::from_str(s)
|
||||||
|
.map_err(|_| warn!("Could not parse hour: '{}'", s))
|
||||||
|
.ok()
|
||||||
|
})
|
||||||
|
.unwrap_or(time.hour());
|
||||||
|
|
||||||
|
time.with_hour(hr).with_minute(0)
|
||||||
|
},
|
||||||
|
|
||||||
|
Some("m") | Some("minutely") => {
|
||||||
|
debug!("Creating minutely-timed entry");
|
||||||
|
let mut time = DiaryId::now(String::from(diary.name()));
|
||||||
|
let hr = create
|
||||||
|
.value_of("hour")
|
||||||
|
.map(|h| { debug!("hour = {:?}", h); h })
|
||||||
|
.and_then(|s| {
|
||||||
|
FromStr::from_str(s)
|
||||||
|
.map_err(|_| warn!("Could not parse hour: '{}'", s))
|
||||||
|
.ok()
|
||||||
|
})
|
||||||
|
.unwrap_or(time.hour());
|
||||||
|
|
||||||
|
let min = create
|
||||||
|
.value_of("minute")
|
||||||
|
.map(|m| { debug!("minute = {:?}", m); m })
|
||||||
|
.and_then(|s| {
|
||||||
|
FromStr::from_str(s)
|
||||||
|
.map_err(|_| warn!("Could not parse minute: '{}'", s))
|
||||||
|
.ok()
|
||||||
|
})
|
||||||
|
.unwrap_or(time.minute());
|
||||||
|
|
||||||
|
time.with_hour(hr).with_minute(min)
|
||||||
|
},
|
||||||
|
|
||||||
|
Some(_) => {
|
||||||
|
warn!("Timed creation failed: Unknown spec '{}'",
|
||||||
|
create.value_of("timed").unwrap());
|
||||||
|
exit(1);
|
||||||
|
},
|
||||||
|
|
||||||
|
None => {
|
||||||
|
warn!("Unexpected error, cannot continue");
|
||||||
|
exit(1);
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
diary.new_entry_by_id(id)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
let diary = Diary::open(rt.store(), &diaryname[..]);
|
||||||
|
let res = create_entry(&diary, rt)
|
||||||
|
.and_then(|mut entry| {
|
||||||
|
if prevent_edit {
|
||||||
|
debug!("Not editing new diary entry");
|
||||||
|
Ok(())
|
||||||
|
} else {
|
||||||
|
debug!("Editing new diary entry");
|
||||||
|
entry.edit_content(rt)
|
||||||
|
.map_err(|e| DE::new(DEK::DiaryEditError, Some(Box::new(e))))
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
if let Err(e) = res {
|
||||||
|
trace_error(&e);
|
||||||
|
} else {
|
||||||
|
info!("Ok!");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
66
imag-diary/src/delete.rs
Normal file
66
imag-diary/src/delete.rs
Normal file
|
@ -0,0 +1,66 @@
|
||||||
|
use std::process::exit;
|
||||||
|
use chrono::naive::datetime::NaiveDateTime;
|
||||||
|
|
||||||
|
use libimagdiary::diary::Diary;
|
||||||
|
use libimagdiary::diaryid::DiaryId;
|
||||||
|
use libimagrt::runtime::Runtime;
|
||||||
|
use libimagerror::trace::trace_error;
|
||||||
|
use libimagtimeui::datetime::DateTime;
|
||||||
|
use libimagtimeui::parse::Parse;
|
||||||
|
|
||||||
|
use util::get_diary_name;
|
||||||
|
|
||||||
|
pub fn delete(rt: &Runtime) {
|
||||||
|
use libimaginteraction::ask::ask_bool;
|
||||||
|
|
||||||
|
let diaryname = get_diary_name(rt);
|
||||||
|
if diaryname.is_none() {
|
||||||
|
warn!("No diary selected. Use either the configuration file or the commandline option");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
let diaryname = diaryname.unwrap();
|
||||||
|
|
||||||
|
let diary = Diary::open(rt.store(), &diaryname[..]);
|
||||||
|
debug!("Diary opened: {:?}", diary);
|
||||||
|
|
||||||
|
let datetime : Option<NaiveDateTime> = rt
|
||||||
|
.cli()
|
||||||
|
.subcommand_matches("delete")
|
||||||
|
.unwrap()
|
||||||
|
.value_of("datetime")
|
||||||
|
.map(|dt| { debug!("DateTime = {:?}", dt); dt })
|
||||||
|
.and_then(DateTime::parse)
|
||||||
|
.map(|dt| dt.into());
|
||||||
|
|
||||||
|
let to_del = match datetime {
|
||||||
|
Some(dt) => Some(diary.retrieve(DiaryId::from_datetime(diaryname.clone(), dt))),
|
||||||
|
None => diary.get_youngest_entry(),
|
||||||
|
};
|
||||||
|
|
||||||
|
let to_del = match to_del {
|
||||||
|
Some(Ok(e)) => e,
|
||||||
|
|
||||||
|
Some(Err(e)) => {
|
||||||
|
trace_error(&e);
|
||||||
|
exit(1);
|
||||||
|
},
|
||||||
|
None => {
|
||||||
|
warn!("No entry");
|
||||||
|
exit(1);
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
if !ask_bool(&format!("Deleting {:?}", to_del.get_location())[..], Some(true)) {
|
||||||
|
info!("Aborting delete action");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
match diary.delete_entry(to_del) {
|
||||||
|
Ok(_) => info!("Ok"),
|
||||||
|
Err(e) => {
|
||||||
|
trace_error(&e);
|
||||||
|
exit(1);
|
||||||
|
},
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
47
imag-diary/src/edit.rs
Normal file
47
imag-diary/src/edit.rs
Normal file
|
@ -0,0 +1,47 @@
|
||||||
|
use std::process::exit;
|
||||||
|
use chrono::naive::datetime::NaiveDateTime;
|
||||||
|
|
||||||
|
use libimagdiary::diary::Diary;
|
||||||
|
use libimagdiary::diaryid::DiaryId;
|
||||||
|
use libimagdiary::error::DiaryError as DE;
|
||||||
|
use libimagdiary::error::DiaryErrorKind as DEK;
|
||||||
|
use libimagrt::edit::Edit;
|
||||||
|
use libimagrt::runtime::Runtime;
|
||||||
|
use libimagerror::trace::trace_error;
|
||||||
|
use libimagtimeui::datetime::DateTime;
|
||||||
|
use libimagtimeui::parse::Parse;
|
||||||
|
|
||||||
|
use util::get_diary_name;
|
||||||
|
|
||||||
|
pub fn edit(rt: &Runtime) {
|
||||||
|
let diaryname = get_diary_name(rt);
|
||||||
|
if diaryname.is_none() {
|
||||||
|
warn!("No diary name");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
let diaryname = diaryname.unwrap();
|
||||||
|
let diary = Diary::open(rt.store(), &diaryname[..]);
|
||||||
|
|
||||||
|
let datetime : Option<NaiveDateTime> = rt
|
||||||
|
.cli()
|
||||||
|
.subcommand_matches("edit")
|
||||||
|
.unwrap()
|
||||||
|
.value_of("datetime")
|
||||||
|
.and_then(DateTime::parse)
|
||||||
|
.map(|dt| dt.into());
|
||||||
|
|
||||||
|
let to_edit = match datetime {
|
||||||
|
Some(dt) => Some(diary.retrieve(DiaryId::from_datetime(diaryname.clone(), dt))),
|
||||||
|
None => diary.get_youngest_entry(),
|
||||||
|
};
|
||||||
|
|
||||||
|
match to_edit {
|
||||||
|
Some(Ok(mut e)) => e.edit_content(rt).map_err(|e| DE::new(DEK::IOError, Some(Box::new(e)))),
|
||||||
|
|
||||||
|
Some(Err(e)) => Err(e),
|
||||||
|
None => Err(DE::new(DEK::EntryNotInDiary, None)),
|
||||||
|
}
|
||||||
|
.map_err(|e| trace_error(&e)).ok();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
52
imag-diary/src/list.rs
Normal file
52
imag-diary/src/list.rs
Normal file
|
@ -0,0 +1,52 @@
|
||||||
|
use std::path::PathBuf;
|
||||||
|
use std::process::exit;
|
||||||
|
|
||||||
|
use libimagdiary::diary::Diary;
|
||||||
|
use libimagdiary::error::DiaryError as DE;
|
||||||
|
use libimagdiary::error::DiaryErrorKind as DEK;
|
||||||
|
use libimagentrylist::listers::core::CoreLister;
|
||||||
|
use libimagentrylist::lister::Lister;
|
||||||
|
use libimagrt::runtime::Runtime;
|
||||||
|
use libimagstore::storeid::StoreId;
|
||||||
|
use libimagerror::trace::trace_error;
|
||||||
|
|
||||||
|
use util::get_diary_name;
|
||||||
|
|
||||||
|
pub fn list(rt: &Runtime) {
|
||||||
|
let diaryname = get_diary_name(rt);
|
||||||
|
if diaryname.is_none() {
|
||||||
|
warn!("No diary selected. Use either the configuration file or the commandline option");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
let diaryname = diaryname.unwrap();
|
||||||
|
|
||||||
|
fn location_to_listing_string(id: &StoreId, base: &PathBuf) -> String {
|
||||||
|
id.strip_prefix(base)
|
||||||
|
.map_err(|e| trace_error(&e))
|
||||||
|
.ok()
|
||||||
|
.and_then(|p| p.to_str().map(String::from))
|
||||||
|
.unwrap_or(String::from("<<Path Parsing Error>>"))
|
||||||
|
}
|
||||||
|
|
||||||
|
let diary = Diary::open(rt.store(), &diaryname[..]);
|
||||||
|
debug!("Diary opened: {:?}", diary);
|
||||||
|
diary.entries()
|
||||||
|
.and_then(|es| {
|
||||||
|
debug!("Iterator for listing: {:?}", es);
|
||||||
|
|
||||||
|
let es = es.filter_map(|a| {
|
||||||
|
debug!("Filtering: {:?}", a);
|
||||||
|
a.ok()
|
||||||
|
}).map(|e| e.into());
|
||||||
|
|
||||||
|
let base = rt.store().path();
|
||||||
|
|
||||||
|
CoreLister::new(&move |e| location_to_listing_string(e.get_location(), base))
|
||||||
|
.list(es) // TODO: Do not ignore non-ok()s
|
||||||
|
.map_err(|e| DE::new(DEK::IOError, Some(Box::new(e))))
|
||||||
|
})
|
||||||
|
.map(|_| debug!("Ok"))
|
||||||
|
.map_err(|e| trace_error(&e))
|
||||||
|
.ok();
|
||||||
|
}
|
||||||
|
|
|
@ -13,29 +13,24 @@ extern crate libimagutil;
|
||||||
extern crate libimagtimeui;
|
extern crate libimagtimeui;
|
||||||
#[macro_use] extern crate libimagerror;
|
#[macro_use] extern crate libimagerror;
|
||||||
|
|
||||||
use std::path::PathBuf;
|
|
||||||
use std::process::exit;
|
use std::process::exit;
|
||||||
use chrono::naive::datetime::NaiveDateTime;
|
|
||||||
|
|
||||||
use libimagdiary::diary::Diary;
|
|
||||||
use libimagdiary::diaryid::DiaryId;
|
|
||||||
use libimagdiary::error::DiaryError as DE;
|
|
||||||
use libimagdiary::error::DiaryErrorKind as DEK;
|
|
||||||
use libimagentrylist::listers::core::CoreLister;
|
|
||||||
use libimagentrylist::lister::Lister;
|
|
||||||
use libimagentryview::viewer::Viewer;
|
|
||||||
use libimagentryview::builtin::plain::PlainViewer;
|
|
||||||
use libimagrt::edit::Edit;
|
|
||||||
use libimagrt::runtime::Runtime;
|
use libimagrt::runtime::Runtime;
|
||||||
use libimagstore::storeid::StoreId;
|
|
||||||
use libimagerror::trace::trace_error;
|
|
||||||
use libimagtimeui::datetime::DateTime;
|
|
||||||
use libimagtimeui::parse::Parse;
|
|
||||||
use libimagstore::store::FileLockEntry;
|
|
||||||
|
|
||||||
|
mod create;
|
||||||
|
mod delete;
|
||||||
|
mod edit;
|
||||||
|
mod list;
|
||||||
mod ui;
|
mod ui;
|
||||||
|
mod util;
|
||||||
|
mod view;
|
||||||
|
|
||||||
|
use create::create;
|
||||||
|
use delete::delete;
|
||||||
|
use edit::edit;
|
||||||
|
use list::list;
|
||||||
use ui::build_ui;
|
use ui::build_ui;
|
||||||
|
use view::view;
|
||||||
|
|
||||||
fn main() {
|
fn main() {
|
||||||
let name = "imag-diary";
|
let name = "imag-diary";
|
||||||
|
@ -71,262 +66,7 @@ fn main() {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
fn create(rt: &Runtime) {
|
|
||||||
use libimagdiary::entry::Entry;
|
|
||||||
use libimagdiary::result::Result;
|
|
||||||
|
|
||||||
let diaryname = get_diary_name(rt);
|
|
||||||
if diaryname.is_none() {
|
|
||||||
warn!("No diary selected. Use either the configuration file or the commandline option");
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
let diaryname = diaryname.unwrap();
|
|
||||||
|
|
||||||
let prevent_edit = rt.cli().subcommand_matches("create").unwrap().is_present("no-edit");
|
|
||||||
|
|
||||||
fn create_entry<'a>(diary: &'a Diary, rt: &Runtime) -> Result<Entry<'a>> {
|
|
||||||
use std::str::FromStr;
|
|
||||||
|
|
||||||
let create = rt.cli().subcommand_matches("create").unwrap();
|
|
||||||
if !create.is_present("timed") {
|
|
||||||
debug!("Creating non-timed entry");
|
|
||||||
diary.new_entry_today()
|
|
||||||
} else {
|
|
||||||
let id = match create.value_of("timed") {
|
|
||||||
Some("h") | Some("hourly") => {
|
|
||||||
debug!("Creating hourly-timed entry");
|
|
||||||
let mut time = DiaryId::now(String::from(diary.name()));
|
|
||||||
let hr = create
|
|
||||||
.value_of("hour")
|
|
||||||
.map(|v| { debug!("Creating hourly entry with hour = {:?}", v); v })
|
|
||||||
.and_then(|s| {
|
|
||||||
FromStr::from_str(s)
|
|
||||||
.map_err(|_| warn!("Could not parse hour: '{}'", s))
|
|
||||||
.ok()
|
|
||||||
})
|
|
||||||
.unwrap_or(time.hour());
|
|
||||||
|
|
||||||
time.with_hour(hr).with_minute(0)
|
|
||||||
},
|
|
||||||
|
|
||||||
Some("m") | Some("minutely") => {
|
|
||||||
debug!("Creating minutely-timed entry");
|
|
||||||
let mut time = DiaryId::now(String::from(diary.name()));
|
|
||||||
let hr = create
|
|
||||||
.value_of("hour")
|
|
||||||
.map(|h| { debug!("hour = {:?}", h); h })
|
|
||||||
.and_then(|s| {
|
|
||||||
FromStr::from_str(s)
|
|
||||||
.map_err(|_| warn!("Could not parse hour: '{}'", s))
|
|
||||||
.ok()
|
|
||||||
})
|
|
||||||
.unwrap_or(time.hour());
|
|
||||||
|
|
||||||
let min = create
|
|
||||||
.value_of("minute")
|
|
||||||
.map(|m| { debug!("minute = {:?}", m); m })
|
|
||||||
.and_then(|s| {
|
|
||||||
FromStr::from_str(s)
|
|
||||||
.map_err(|_| warn!("Could not parse minute: '{}'", s))
|
|
||||||
.ok()
|
|
||||||
})
|
|
||||||
.unwrap_or(time.minute());
|
|
||||||
|
|
||||||
time.with_hour(hr).with_minute(min)
|
|
||||||
},
|
|
||||||
|
|
||||||
Some(_) => {
|
|
||||||
warn!("Timed creation failed: Unknown spec '{}'",
|
|
||||||
create.value_of("timed").unwrap());
|
|
||||||
exit(1);
|
|
||||||
},
|
|
||||||
|
|
||||||
None => {
|
|
||||||
warn!("Unexpected error, cannot continue");
|
|
||||||
exit(1);
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
diary.new_entry_by_id(id)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
let diary = Diary::open(rt.store(), &diaryname[..]);
|
|
||||||
let res = create_entry(&diary, rt)
|
|
||||||
.and_then(|mut entry| {
|
|
||||||
if prevent_edit {
|
|
||||||
debug!("Not editing new diary entry");
|
|
||||||
Ok(())
|
|
||||||
} else {
|
|
||||||
debug!("Editing new diary entry");
|
|
||||||
entry.edit_content(rt)
|
|
||||||
.map_err(|e| DE::new(DEK::DiaryEditError, Some(Box::new(e))))
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
if let Err(e) = res {
|
|
||||||
trace_error(&e);
|
|
||||||
} else {
|
|
||||||
info!("Ok!");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn list(rt: &Runtime) {
|
|
||||||
let diaryname = get_diary_name(rt);
|
|
||||||
if diaryname.is_none() {
|
|
||||||
warn!("No diary selected. Use either the configuration file or the commandline option");
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
let diaryname = diaryname.unwrap();
|
|
||||||
|
|
||||||
fn location_to_listing_string(id: &StoreId, base: &PathBuf) -> String {
|
|
||||||
id.strip_prefix(base)
|
|
||||||
.map_err(|e| trace_error(&e))
|
|
||||||
.ok()
|
|
||||||
.and_then(|p| p.to_str().map(String::from))
|
|
||||||
.unwrap_or(String::from("<<Path Parsing Error>>"))
|
|
||||||
}
|
|
||||||
|
|
||||||
let diary = Diary::open(rt.store(), &diaryname[..]);
|
|
||||||
debug!("Diary opened: {:?}", diary);
|
|
||||||
diary.entries()
|
|
||||||
.and_then(|es| {
|
|
||||||
debug!("Iterator for listing: {:?}", es);
|
|
||||||
|
|
||||||
let es = es.filter_map(|a| {
|
|
||||||
debug!("Filtering: {:?}", a);
|
|
||||||
a.ok()
|
|
||||||
}).map(|e| e.into());
|
|
||||||
|
|
||||||
let base = rt.store().path();
|
|
||||||
|
|
||||||
CoreLister::new(&move |e| location_to_listing_string(e.get_location(), base))
|
|
||||||
.list(es) // TODO: Do not ignore non-ok()s
|
|
||||||
.map_err(|e| DE::new(DEK::IOError, Some(Box::new(e))))
|
|
||||||
})
|
|
||||||
.map(|_| debug!("Ok"))
|
|
||||||
.map_err(|e| trace_error(&e))
|
|
||||||
.ok();
|
|
||||||
}
|
|
||||||
|
|
||||||
fn delete(rt: &Runtime) {
|
|
||||||
use libimaginteraction::ask::ask_bool;
|
|
||||||
|
|
||||||
let diaryname = get_diary_name(rt);
|
|
||||||
if diaryname.is_none() {
|
|
||||||
warn!("No diary selected. Use either the configuration file or the commandline option");
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
let diaryname = diaryname.unwrap();
|
|
||||||
|
|
||||||
let diary = Diary::open(rt.store(), &diaryname[..]);
|
|
||||||
debug!("Diary opened: {:?}", diary);
|
|
||||||
|
|
||||||
let datetime : Option<NaiveDateTime> = rt
|
|
||||||
.cli()
|
|
||||||
.subcommand_matches("delete")
|
|
||||||
.unwrap()
|
|
||||||
.value_of("datetime")
|
|
||||||
.map(|dt| { debug!("DateTime = {:?}", dt); dt })
|
|
||||||
.and_then(DateTime::parse)
|
|
||||||
.map(|dt| dt.into());
|
|
||||||
|
|
||||||
let to_del = match datetime {
|
|
||||||
Some(dt) => Some(diary.retrieve(DiaryId::from_datetime(diaryname.clone(), dt))),
|
|
||||||
None => diary.get_youngest_entry(),
|
|
||||||
};
|
|
||||||
|
|
||||||
let to_del = match to_del {
|
|
||||||
Some(Ok(e)) => e,
|
|
||||||
|
|
||||||
Some(Err(e)) => {
|
|
||||||
trace_error(&e);
|
|
||||||
exit(1);
|
|
||||||
},
|
|
||||||
None => {
|
|
||||||
warn!("No entry");
|
|
||||||
exit(1);
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
if !ask_bool(&format!("Deleting {:?}", to_del.get_location())[..], Some(true)) {
|
|
||||||
info!("Aborting delete action");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
match diary.delete_entry(to_del) {
|
|
||||||
Ok(_) => info!("Ok"),
|
|
||||||
Err(e) => {
|
|
||||||
trace_error(&e);
|
|
||||||
exit(1);
|
|
||||||
},
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn edit(rt: &Runtime) {
|
|
||||||
let diaryname = get_diary_name(rt);
|
|
||||||
if diaryname.is_none() {
|
|
||||||
warn!("No diary name");
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
let diaryname = diaryname.unwrap();
|
|
||||||
let diary = Diary::open(rt.store(), &diaryname[..]);
|
|
||||||
|
|
||||||
let datetime : Option<NaiveDateTime> = rt
|
|
||||||
.cli()
|
|
||||||
.subcommand_matches("edit")
|
|
||||||
.unwrap()
|
|
||||||
.value_of("datetime")
|
|
||||||
.and_then(DateTime::parse)
|
|
||||||
.map(|dt| dt.into());
|
|
||||||
|
|
||||||
let to_edit = match datetime {
|
|
||||||
Some(dt) => Some(diary.retrieve(DiaryId::from_datetime(diaryname.clone(), dt))),
|
|
||||||
None => diary.get_youngest_entry(),
|
|
||||||
};
|
|
||||||
|
|
||||||
match to_edit {
|
|
||||||
Some(Ok(mut e)) => e.edit_content(rt).map_err(|e| DE::new(DEK::IOError, Some(Box::new(e)))),
|
|
||||||
|
|
||||||
Some(Err(e)) => Err(e),
|
|
||||||
None => Err(DE::new(DEK::EntryNotInDiary, None)),
|
|
||||||
}
|
|
||||||
.map_err(|e| trace_error(&e)).ok();
|
|
||||||
}
|
|
||||||
|
|
||||||
fn diary(rt: &Runtime) {
|
fn diary(rt: &Runtime) {
|
||||||
unimplemented!()
|
unimplemented!()
|
||||||
}
|
}
|
||||||
|
|
||||||
fn view(rt: &Runtime) {
|
|
||||||
let diaryname = get_diary_name(rt);
|
|
||||||
if diaryname.is_none() {
|
|
||||||
warn!("No diary name");
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
let diaryname = diaryname.unwrap();
|
|
||||||
let diary = Diary::open(rt.store(), &diaryname[..]);
|
|
||||||
let show_header = 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);
|
|
||||||
pv.view_entry(&entry);
|
|
||||||
println!("\n---\n");
|
|
||||||
}
|
|
||||||
},
|
|
||||||
Err(e) => {
|
|
||||||
trace_error(&e);
|
|
||||||
},
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn get_diary_name(rt: &Runtime) -> Option<String> {
|
|
||||||
use libimagdiary::config::get_default_diary_name;
|
|
||||||
|
|
||||||
get_default_diary_name(rt)
|
|
||||||
.or(rt.cli().value_of("diaryname").map(String::from))
|
|
||||||
}
|
|
||||||
|
|
9
imag-diary/src/util.rs
Normal file
9
imag-diary/src/util.rs
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
use libimagrt::runtime::Runtime;
|
||||||
|
|
||||||
|
pub fn get_diary_name(rt: &Runtime) -> Option<String> {
|
||||||
|
use libimagdiary::config::get_default_diary_name;
|
||||||
|
|
||||||
|
get_default_diary_name(rt)
|
||||||
|
.or(rt.cli().value_of("diaryname").map(String::from))
|
||||||
|
}
|
||||||
|
|
36
imag-diary/src/view.rs
Normal file
36
imag-diary/src/view.rs
Normal file
|
@ -0,0 +1,36 @@
|
||||||
|
use std::process::exit;
|
||||||
|
|
||||||
|
use libimagdiary::diary::Diary;
|
||||||
|
use libimagentryview::viewer::Viewer;
|
||||||
|
use libimagentryview::builtin::plain::PlainViewer;
|
||||||
|
use libimagrt::runtime::Runtime;
|
||||||
|
use libimagerror::trace::trace_error;
|
||||||
|
|
||||||
|
use util::get_diary_name;
|
||||||
|
|
||||||
|
pub fn view(rt: &Runtime) {
|
||||||
|
let diaryname = get_diary_name(rt);
|
||||||
|
if diaryname.is_none() {
|
||||||
|
warn!("No diary name");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
let diaryname = diaryname.unwrap();
|
||||||
|
let diary = Diary::open(rt.store(), &diaryname[..]);
|
||||||
|
let show_header = 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);
|
||||||
|
pv.view_entry(&entry);
|
||||||
|
println!("\n---\n");
|
||||||
|
}
|
||||||
|
},
|
||||||
|
Err(e) => {
|
||||||
|
trace_error(&e);
|
||||||
|
},
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue