Merge pull request #1315 from matthiasbeyer/libimagrt/provide-io
libimagrt: provide io
This commit is contained in:
commit
763f3fab86
28 changed files with 153 additions and 105 deletions
|
@ -135,7 +135,6 @@ fn remove(rt: &Runtime) {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn list(rt: &Runtime) {
|
fn list(rt: &Runtime) {
|
||||||
let mut out = ::std::io::stdout();
|
|
||||||
let scmd = rt.cli().subcommand_matches("list").unwrap(); // safed by clap
|
let scmd = rt.cli().subcommand_matches("list").unwrap(); // safed by clap
|
||||||
let with_text = scmd.is_present("list-with-text");
|
let with_text = scmd.is_present("list-with-text");
|
||||||
match scmd.value_of("entry").map(PathBuf::from) {
|
match scmd.value_of("entry").map(PathBuf::from) {
|
||||||
|
@ -150,7 +149,7 @@ fn list(rt: &Runtime) {
|
||||||
.map_err_trace_exit_unwrap(1)
|
.map_err_trace_exit_unwrap(1)
|
||||||
.enumerate()
|
.enumerate()
|
||||||
.map(|(i, a)| {
|
.map(|(i, a)| {
|
||||||
list_annotation(&mut out, i, a.map_err_trace_exit_unwrap(1), with_text)
|
list_annotation(&rt, i, a.map_err_trace_exit_unwrap(1), with_text)
|
||||||
})
|
})
|
||||||
.collect::<Vec<_>>();
|
.collect::<Vec<_>>();
|
||||||
}
|
}
|
||||||
|
@ -163,22 +162,22 @@ fn list(rt: &Runtime) {
|
||||||
.map_err_trace_exit_unwrap(1)
|
.map_err_trace_exit_unwrap(1)
|
||||||
.enumerate()
|
.enumerate()
|
||||||
.map(|(i, a)| {
|
.map(|(i, a)| {
|
||||||
list_annotation(&mut out, i, a.map_err_trace_exit_unwrap(1), with_text)
|
list_annotation(&rt, i, a.map_err_trace_exit_unwrap(1), with_text)
|
||||||
})
|
})
|
||||||
.collect::<Vec<_>>();
|
.collect::<Vec<_>>();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn list_annotation<'a>(out: &mut Write, i: usize, a: FileLockEntry<'a>, with_text: bool) {
|
fn list_annotation<'a>(rt: &Runtime, i: usize, a: FileLockEntry<'a>, with_text: bool) {
|
||||||
let _ = if with_text {
|
let _ = if with_text {
|
||||||
writeln!(out,
|
writeln!(rt.stdout(),
|
||||||
"--- {i: >5} | {id}\n{text}\n\n",
|
"--- {i: >5} | {id}\n{text}\n\n",
|
||||||
i = i,
|
i = i,
|
||||||
id = a.get_location(),
|
id = a.get_location(),
|
||||||
text = a.get_content())
|
text = a.get_content())
|
||||||
} else {
|
} else {
|
||||||
writeln!(out, "{: >5} | {}", i, a.get_location())
|
writeln!(rt.stdout(), "{: >5} | {}", i, a.get_location())
|
||||||
}
|
}
|
||||||
.to_exit_code()
|
.to_exit_code()
|
||||||
.unwrap_or_exit();
|
.unwrap_or_exit();
|
||||||
|
|
|
@ -155,7 +155,7 @@ fn main() {
|
||||||
|
|
||||||
let n = diags.len();
|
let n = diags.len();
|
||||||
|
|
||||||
let mut out = ::std::io::stdout();
|
let mut out = rt.stdout();
|
||||||
|
|
||||||
let _ = writeln!(out, "imag version {}", env!("CARGO_PKG_VERSION"))
|
let _ = writeln!(out, "imag version {}", env!("CARGO_PKG_VERSION"))
|
||||||
.to_exit_code()
|
.to_exit_code()
|
||||||
|
|
|
@ -144,10 +144,8 @@ fn remove(rt: &Runtime) {
|
||||||
})
|
})
|
||||||
.map_err_trace_exit_unwrap(1); // The parsing of the deleted values failed
|
.map_err_trace_exit_unwrap(1); // The parsing of the deleted values failed
|
||||||
|
|
||||||
let mut out = ::std::io::stdout();
|
|
||||||
|
|
||||||
if scmd.is_present("print-removed") {
|
if scmd.is_present("print-removed") {
|
||||||
let _ = writeln!(out, "{}", removed_value).to_exit_code().unwrap_or_exit();
|
let _ = writeln!(rt.stdout(), "{}", removed_value).to_exit_code().unwrap_or_exit();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -174,7 +172,6 @@ fn get(rt: &Runtime) {
|
||||||
exit(1)
|
exit(1)
|
||||||
});
|
});
|
||||||
|
|
||||||
let mut out = ::std::io::stdout();
|
let _ = writeln!(rt.stdout(), "{}", value).to_exit_code().unwrap_or_exit();
|
||||||
let _ = writeln!(out, "{}", value).to_exit_code().unwrap_or_exit();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -44,6 +44,7 @@ use std::io::Write;
|
||||||
|
|
||||||
use regex::Regex;
|
use regex::Regex;
|
||||||
|
|
||||||
|
use libimagrt::runtime::Runtime;
|
||||||
use libimagrt::setup::generate_runtime_setup;
|
use libimagrt::setup::generate_runtime_setup;
|
||||||
use libimagstore::store::Entry;
|
use libimagstore::store::Entry;
|
||||||
use libimagerror::trace::MapErrTrace;
|
use libimagerror::trace::MapErrTrace;
|
||||||
|
@ -88,15 +89,13 @@ fn main() {
|
||||||
.into_get_iter()
|
.into_get_iter()
|
||||||
.filter_map(|res| res.map_err_trace_exit_unwrap(1))
|
.filter_map(|res| res.map_err_trace_exit_unwrap(1))
|
||||||
.filter(|entry| pattern.is_match(entry.get_content()))
|
.filter(|entry| pattern.is_match(entry.get_content()))
|
||||||
.map(|entry| show(&entry, &pattern, &opts, &mut count))
|
.map(|entry| show(&rt, &entry, &pattern, &opts, &mut count))
|
||||||
.count();
|
.count();
|
||||||
|
|
||||||
let mut out = ::std::io::stdout();
|
|
||||||
|
|
||||||
if opts.count {
|
if opts.count {
|
||||||
let _ = writeln!(out, "{}", count).to_exit_code().unwrap_or_exit();
|
let _ = writeln!(rt.stdout(), "{}", count).to_exit_code().unwrap_or_exit();
|
||||||
} else if !opts.files_with_matches {
|
} else if !opts.files_with_matches {
|
||||||
let _ = writeln!(out, "Processed {} files, {} matches, {} nonmatches",
|
let _ = writeln!(rt.stdout(), "Processed {} files, {} matches, {} nonmatches",
|
||||||
overall_count,
|
overall_count,
|
||||||
count,
|
count,
|
||||||
overall_count - count)
|
overall_count - count)
|
||||||
|
@ -105,24 +104,22 @@ fn main() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn show(e: &Entry, re: &Regex, opts: &Options, count: &mut usize) {
|
fn show(rt: &Runtime, e: &Entry, re: &Regex, opts: &Options, count: &mut usize) {
|
||||||
let mut out = ::std::io::stdout();
|
|
||||||
|
|
||||||
if opts.files_with_matches {
|
if opts.files_with_matches {
|
||||||
let _ = writeln!(out, "{}", e.get_location()).to_exit_code().unwrap_or_exit();
|
let _ = writeln!(rt.stdout(), "{}", e.get_location()).to_exit_code().unwrap_or_exit();
|
||||||
} else if opts.count {
|
} else if opts.count {
|
||||||
*count += 1;
|
*count += 1;
|
||||||
} else {
|
} else {
|
||||||
let _ = writeln!(out, "{}:", e.get_location()).to_exit_code().unwrap_or_exit();
|
let _ = writeln!(rt.stdout(), "{}:", e.get_location()).to_exit_code().unwrap_or_exit();
|
||||||
for capture in re.captures_iter(e.get_content()) {
|
for capture in re.captures_iter(e.get_content()) {
|
||||||
for mtch in capture.iter() {
|
for mtch in capture.iter() {
|
||||||
if let Some(m) = mtch {
|
if let Some(m) = mtch {
|
||||||
let _ = writeln!(out, " '{}'", m.as_str()).to_exit_code().unwrap_or_exit();
|
let _ = writeln!(rt.stdout(), " '{}'", m.as_str()).to_exit_code().unwrap_or_exit();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
let _ = writeln!(out, "").to_exit_code().unwrap_or_exit();
|
let _ = writeln!(rt.stdout(), "").to_exit_code().unwrap_or_exit();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -60,13 +60,11 @@ fn main() {
|
||||||
"print all ids",
|
"print all ids",
|
||||||
build_ui);
|
build_ui);
|
||||||
|
|
||||||
let mut out = ::std::io::stdout();
|
|
||||||
|
|
||||||
rt.store()
|
rt.store()
|
||||||
.entries()
|
.entries()
|
||||||
.map_err_trace_exit_unwrap(1)
|
.map_err_trace_exit_unwrap(1)
|
||||||
.for_each(|id| {
|
.for_each(|id| {
|
||||||
let _ = writeln!(out, "{}", id.to_str().map_err_trace_exit_unwrap(1))
|
let _ = writeln!(rt.stdout(), "{}", id.to_str().map_err_trace_exit_unwrap(1))
|
||||||
.to_exit_code()
|
.to_exit_code()
|
||||||
.unwrap_or_exit();
|
.unwrap_or_exit();
|
||||||
})
|
})
|
||||||
|
|
|
@ -254,7 +254,6 @@ fn list_linkings(rt: &Runtime) {
|
||||||
.unwrap(); // safed by clap
|
.unwrap(); // safed by clap
|
||||||
|
|
||||||
let list_externals = cmd.is_present("list-externals-too");
|
let list_externals = cmd.is_present("list-externals-too");
|
||||||
let mut out = ::std::io::stdout();
|
|
||||||
|
|
||||||
for entry in cmd.values_of("entries").unwrap() { // safed by clap
|
for entry in cmd.values_of("entries").unwrap() { // safed by clap
|
||||||
match rt.store().get(PathBuf::from(entry)) {
|
match rt.store().get(PathBuf::from(entry)) {
|
||||||
|
@ -268,7 +267,7 @@ fn list_linkings(rt: &Runtime) {
|
||||||
.ok();
|
.ok();
|
||||||
|
|
||||||
if let Some(link) = link {
|
if let Some(link) = link {
|
||||||
let _ = writeln!(out, "{: <3}: {}", i, link)
|
let _ = writeln!(rt.stdout(), "{: <3}: {}", i, link)
|
||||||
.to_exit_code()
|
.to_exit_code()
|
||||||
.unwrap_or_exit();
|
.unwrap_or_exit();
|
||||||
i += 1;
|
i += 1;
|
||||||
|
@ -284,7 +283,7 @@ fn list_linkings(rt: &Runtime) {
|
||||||
.map_err_trace_exit_unwrap(1)
|
.map_err_trace_exit_unwrap(1)
|
||||||
.into_string();
|
.into_string();
|
||||||
|
|
||||||
let _ = writeln!(out, "{: <3}: {}", i, link)
|
let _ = writeln!(rt.stdout(), "{: <3}: {}", i, link)
|
||||||
.to_exit_code()
|
.to_exit_code()
|
||||||
.unwrap_or_exit();
|
.unwrap_or_exit();
|
||||||
|
|
||||||
|
|
|
@ -51,11 +51,9 @@ pub fn retrieve(rt: &Runtime) {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn print_entry(rt: &Runtime, scmd: &ArgMatches, e: FileLockEntry) {
|
pub fn print_entry(rt: &Runtime, scmd: &ArgMatches, e: FileLockEntry) {
|
||||||
let mut out = ::std::io::stdout();
|
|
||||||
|
|
||||||
if do_print_raw(scmd) {
|
if do_print_raw(scmd) {
|
||||||
debug!("Printing raw content...");
|
debug!("Printing raw content...");
|
||||||
let _ = writeln!(out, "{}", e.to_str())
|
let _ = writeln!(rt.stdout(), "{}", e.to_str())
|
||||||
.to_exit_code()
|
.to_exit_code()
|
||||||
.unwrap_or_exit();
|
.unwrap_or_exit();
|
||||||
} else if do_filter(scmd) {
|
} else if do_filter(scmd) {
|
||||||
|
@ -74,7 +72,7 @@ pub fn print_entry(rt: &Runtime, scmd: &ArgMatches, e: FileLockEntry) {
|
||||||
unimplemented!()
|
unimplemented!()
|
||||||
} else {
|
} else {
|
||||||
debug!("Printing header as TOML...");
|
debug!("Printing header as TOML...");
|
||||||
let _ = writeln!(out, "{}", e.get_header())
|
let _ = writeln!(rt.stdout(), "{}", e.get_header())
|
||||||
.to_exit_code()
|
.to_exit_code()
|
||||||
.unwrap_or_exit();
|
.unwrap_or_exit();
|
||||||
}
|
}
|
||||||
|
@ -82,7 +80,7 @@ pub fn print_entry(rt: &Runtime, scmd: &ArgMatches, e: FileLockEntry) {
|
||||||
|
|
||||||
if do_print_content(scmd) {
|
if do_print_content(scmd) {
|
||||||
debug!("Printing content...");
|
debug!("Printing content...");
|
||||||
let _ = writeln!(out, "{}", e.get_content())
|
let _ = writeln!(rt.stdout(), "{}", e.get_content())
|
||||||
.to_exit_code()
|
.to_exit_code()
|
||||||
.unwrap_or_exit();
|
.unwrap_or_exit();
|
||||||
}
|
}
|
||||||
|
|
|
@ -164,11 +164,9 @@ fn list(id: PathBuf, rt: &Runtime) {
|
||||||
unimplemented!()
|
unimplemented!()
|
||||||
}
|
}
|
||||||
|
|
||||||
let mut out = ::std::io::stdout();
|
|
||||||
|
|
||||||
if line_out {
|
if line_out {
|
||||||
for tag in &tags {
|
for tag in &tags {
|
||||||
let _ = writeln!(out, "{}", tag)
|
let _ = writeln!(rt.stdout(), "{}", tag)
|
||||||
.to_exit_code()
|
.to_exit_code()
|
||||||
.unwrap_or_exit();
|
.unwrap_or_exit();
|
||||||
}
|
}
|
||||||
|
@ -176,13 +174,13 @@ fn list(id: PathBuf, rt: &Runtime) {
|
||||||
|
|
||||||
if sepp_out {
|
if sepp_out {
|
||||||
let sepp = scmd.value_of("sep").unwrap(); // we checked before
|
let sepp = scmd.value_of("sep").unwrap(); // we checked before
|
||||||
let _ = writeln!(out, "{}", tags.join(sepp))
|
let _ = writeln!(rt.stdout(), "{}", tags.join(sepp))
|
||||||
.to_exit_code()
|
.to_exit_code()
|
||||||
.unwrap_or_exit();
|
.unwrap_or_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
if comm_out {
|
if comm_out {
|
||||||
let _ = writeln!(out, "{}", tags.join(", "))
|
let _ = writeln!(rt.stdout(), "{}", tags.join(", "))
|
||||||
.to_exit_code()
|
.to_exit_code()
|
||||||
.unwrap_or_exit();
|
.unwrap_or_exit();
|
||||||
}
|
}
|
||||||
|
|
|
@ -135,11 +135,10 @@ fn list(rt: &Runtime) {
|
||||||
.map_err_trace_exit_unwrap(1);
|
.map_err_trace_exit_unwrap(1);
|
||||||
|
|
||||||
let links = collection.links(rt.store()).map_err_trace_exit_unwrap(1);
|
let links = collection.links(rt.store()).map_err_trace_exit_unwrap(1);
|
||||||
let mut out = ::std::io::stdout();
|
|
||||||
debug!("Listing...");
|
debug!("Listing...");
|
||||||
for (i, link) in links.enumerate() {
|
for (i, link) in links.enumerate() {
|
||||||
match link {
|
match link {
|
||||||
Ok(link) => writeln!(out, "{: >3}: {}", i, link).to_exit_code().unwrap_or_exit(),
|
Ok(link) => writeln!(rt.stdout(), "{: >3}: {}", i, link).to_exit_code().unwrap_or_exit(),
|
||||||
Err(e) => trace_error(&e)
|
Err(e) => trace_error(&e)
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
|
@ -20,7 +20,6 @@
|
||||||
use std::collections::BTreeMap;
|
use std::collections::BTreeMap;
|
||||||
use std::process::exit;
|
use std::process::exit;
|
||||||
use std::io::Write;
|
use std::io::Write;
|
||||||
use std::io::stdout;
|
|
||||||
use std::path::PathBuf;
|
use std::path::PathBuf;
|
||||||
use std::fs::OpenOptions;
|
use std::fs::OpenOptions;
|
||||||
|
|
||||||
|
@ -96,7 +95,7 @@ pub fn create(rt: &Runtime) {
|
||||||
|
|
||||||
(Box::new(file), Some(fl))
|
(Box::new(file), Some(fl))
|
||||||
} else {
|
} else {
|
||||||
(Box::new(stdout()), None)
|
(Box::new(rt.stdout()), None)
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -109,7 +109,6 @@ fn main() {
|
||||||
fn list(rt: &Runtime) {
|
fn list(rt: &Runtime) {
|
||||||
let scmd = rt.cli().subcommand_matches("list").unwrap();
|
let scmd = rt.cli().subcommand_matches("list").unwrap();
|
||||||
let list_format = get_contact_print_format("contact.list_format", rt, &scmd);
|
let list_format = get_contact_print_format("contact.list_format", rt, &scmd);
|
||||||
let mut out = ::std::io::stdout();
|
|
||||||
|
|
||||||
let _ = rt
|
let _ = rt
|
||||||
.store()
|
.store()
|
||||||
|
@ -144,7 +143,7 @@ fn list(rt: &Runtime) {
|
||||||
.map_err(CE::from)
|
.map_err(CE::from)
|
||||||
.map_err_trace_exit_unwrap(1);
|
.map_err_trace_exit_unwrap(1);
|
||||||
|
|
||||||
writeln!(out, "{}", s).to_exit_code().unwrap_or_exit()
|
writeln!(rt.stdout(), "{}", s).to_exit_code().unwrap_or_exit()
|
||||||
})
|
})
|
||||||
.collect::<Vec<_>>();
|
.collect::<Vec<_>>();
|
||||||
}
|
}
|
||||||
|
|
|
@ -33,13 +33,11 @@ pub fn list(rt: &Runtime) {
|
||||||
let diaryname = get_diary_name(rt)
|
let diaryname = get_diary_name(rt)
|
||||||
.unwrap_or_else(|| warn_exit("No diary selected. Use either the configuration file or the commandline option", 1));
|
.unwrap_or_else(|| warn_exit("No diary selected. Use either the configuration file or the commandline option", 1));
|
||||||
|
|
||||||
let mut out = ::std::io::stdout();
|
|
||||||
|
|
||||||
Diary::entries(rt.store(), &diaryname)
|
Diary::entries(rt.store(), &diaryname)
|
||||||
.map_dbg_str("Ok")
|
.map_dbg_str("Ok")
|
||||||
.map_err_trace_exit_unwrap(1)
|
.map_err_trace_exit_unwrap(1)
|
||||||
.for_each(|id| {
|
.for_each(|id| {
|
||||||
writeln!(out, "{}", id
|
writeln!(rt.stdout(), "{}", id
|
||||||
.without_base()
|
.without_base()
|
||||||
.to_str()
|
.to_str()
|
||||||
.map_err_trace()
|
.map_err_trace()
|
||||||
|
|
|
@ -47,12 +47,7 @@ extern crate libimagstore;
|
||||||
extern crate libimagtimeui;
|
extern crate libimagtimeui;
|
||||||
extern crate libimagutil;
|
extern crate libimagutil;
|
||||||
|
|
||||||
use std::io::Write;
|
use libimagrt::setup::generate_runtime_setup;
|
||||||
use std::process::exit;
|
|
||||||
|
|
||||||
use libimagerror::exit::ExitUnwrap;
|
|
||||||
use libimagerror::io::ToExitCode;
|
|
||||||
use libimagrt::runtime::Runtime;
|
|
||||||
|
|
||||||
mod create;
|
mod create;
|
||||||
mod delete;
|
mod delete;
|
||||||
|
@ -66,25 +61,14 @@ use create::create;
|
||||||
use delete::delete;
|
use delete::delete;
|
||||||
use edit::edit;
|
use edit::edit;
|
||||||
use list::list;
|
use list::list;
|
||||||
use ui::build_ui;
|
|
||||||
use view::view;
|
use view::view;
|
||||||
|
|
||||||
fn main() {
|
fn main() {
|
||||||
let version = make_imag_version!();
|
let version = make_imag_version!();
|
||||||
let name = "imag-diary";
|
let rt = generate_runtime_setup("imag-diary",
|
||||||
let about = "Personal Diary/Diaries";
|
&version,
|
||||||
let ui = build_ui(Runtime::get_default_cli_builder(name, &version, about));
|
"Personal Diary/Diaries",
|
||||||
let rt = {
|
ui::build_ui);
|
||||||
let rt = Runtime::new(ui);
|
|
||||||
if rt.is_ok() {
|
|
||||||
rt.unwrap()
|
|
||||||
} else {
|
|
||||||
let mut out = ::std::io::stdout();
|
|
||||||
let _ = writeln!(out, "Could not set up Runtime").to_exit_code().unwrap_or_exit();
|
|
||||||
let _ = writeln!(out, "{:?}", rt.err().unwrap()).to_exit_code().unwrap_or_exit();
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
rt.cli()
|
rt.cli()
|
||||||
.subcommand_name()
|
.subcommand_name()
|
||||||
|
|
|
@ -332,8 +332,7 @@ fn today(rt: &Runtime, future: bool) {
|
||||||
}
|
}
|
||||||
|
|
||||||
if !empty {
|
if !empty {
|
||||||
let mut out = ::std::io::stdout();
|
let _ = table.print(&mut rt.stdout()).to_exit_code().unwrap_or_exit();
|
||||||
let _ = table.print(&mut out).to_exit_code().unwrap_or_exit();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -388,8 +387,7 @@ fn list(rt: &Runtime) {
|
||||||
});
|
});
|
||||||
|
|
||||||
if !empty {
|
if !empty {
|
||||||
let mut out = ::std::io::stdout();
|
let _ = table.print(&mut rt.stdout()).to_exit_code().unwrap_or_exit();
|
||||||
let _ = table.print(&mut out).to_exit_code().unwrap_or_exit();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -411,7 +409,6 @@ fn show(rt: &Runtime) {
|
||||||
vec![date, comm]
|
vec![date, comm]
|
||||||
}
|
}
|
||||||
|
|
||||||
let mut out = ::std::io::stdout();
|
|
||||||
let header = ["#", "Date", "Comment"]
|
let header = ["#", "Date", "Comment"]
|
||||||
.iter()
|
.iter()
|
||||||
.map(|s| Cell::new(s))
|
.map(|s| Cell::new(s))
|
||||||
|
@ -433,7 +430,7 @@ fn show(rt: &Runtime) {
|
||||||
let recur = habit.habit_recur_spec().map_err_trace_exit_unwrap(1);
|
let recur = habit.habit_recur_spec().map_err_trace_exit_unwrap(1);
|
||||||
let comm = habit.habit_comment().map_err_trace_exit_unwrap(1);
|
let comm = habit.habit_comment().map_err_trace_exit_unwrap(1);
|
||||||
|
|
||||||
let _ = writeln!(out,
|
let _ = writeln!(rt.stdout(),
|
||||||
"{i} - {name}\nBase : {b},\nRecurrence: {r}\nComment : {c}\n",
|
"{i} - {name}\nBase : {b},\nRecurrence: {r}\nComment : {c}\n",
|
||||||
i = i,
|
i = i,
|
||||||
name = name,
|
name = name,
|
||||||
|
@ -461,8 +458,7 @@ fn show(rt: &Runtime) {
|
||||||
});
|
});
|
||||||
|
|
||||||
if !empty {
|
if !empty {
|
||||||
let mut out = ::std::io::stdout();
|
let _ = table.print(&mut rt.stdout()).to_exit_code().unwrap_or_exit();
|
||||||
let _ = table.print(&mut out).to_exit_code().unwrap_or_exit();
|
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
.collect::<Vec<_>>();
|
.collect::<Vec<_>>();
|
||||||
|
|
|
@ -137,7 +137,7 @@ fn show(rt: &Runtime) {
|
||||||
}
|
}
|
||||||
|
|
||||||
let id = e.diary_id().map_err_trace_exit_unwrap(1);
|
let id = e.diary_id().map_err_trace_exit_unwrap(1);
|
||||||
writeln!(::std::io::stdout(),
|
writeln!(rt.stdout(),
|
||||||
"{dname: >10} - {y: >4}-{m:0>2}-{d:0>2}T{H:0>2}:{M:0>2} - {text}",
|
"{dname: >10} - {y: >4}-{m:0>2}-{d:0>2}T{H:0>2}:{M:0>2} - {text}",
|
||||||
dname = id.diary_name(),
|
dname = id.diary_name(),
|
||||||
y = id.year(),
|
y = id.year(),
|
||||||
|
|
|
@ -73,7 +73,7 @@ fn list(rt: &Runtime) {
|
||||||
use libimagmail::error::ResultExt;
|
use libimagmail::error::ResultExt;
|
||||||
|
|
||||||
// TODO: Implement lister type in libimagmail for this
|
// TODO: Implement lister type in libimagmail for this
|
||||||
fn list_mail(m: Mail) {
|
fn list_mail(rt: &Runtime, m: Mail) {
|
||||||
let id = match m.get_message_id() {
|
let id = match m.get_message_id() {
|
||||||
Ok(Some(f)) => f,
|
Ok(Some(f)) => f,
|
||||||
Ok(None) => "<no id>".to_owned(),
|
Ok(None) => "<no id>".to_owned(),
|
||||||
|
@ -110,7 +110,7 @@ fn list(rt: &Runtime) {
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
writeln!(::std::io::stdout(),
|
writeln!(rt.stdout(),
|
||||||
"Mail: {id}\n\tFrom: {from}\n\tTo: {to}\n\t{subj}\n",
|
"Mail: {id}\n\tFrom: {from}\n\tTo: {to}\n\t{subj}\n",
|
||||||
from = from,
|
from = from,
|
||||||
id = id,
|
id = id,
|
||||||
|
@ -130,7 +130,7 @@ fn list(rt: &Runtime) {
|
||||||
.map(|fle| Mail::from_fle(fle).map_err_trace().ok())
|
.map(|fle| Mail::from_fle(fle).map_err_trace().ok())
|
||||||
})
|
})
|
||||||
.filter_map(|e| e)
|
.filter_map(|e| e)
|
||||||
.for_each(list_mail);
|
.for_each(|m| list_mail(&rt, m));
|
||||||
}
|
}
|
||||||
|
|
||||||
fn mail_store(rt: &Runtime) {
|
fn mail_store(rt: &Runtime) {
|
||||||
|
|
|
@ -119,8 +119,6 @@ fn edit(rt: &Runtime) {
|
||||||
fn list(rt: &Runtime) {
|
fn list(rt: &Runtime) {
|
||||||
use std::cmp::Ordering;
|
use std::cmp::Ordering;
|
||||||
|
|
||||||
let mut out = ::std::io::stdout();
|
|
||||||
|
|
||||||
let _ = rt
|
let _ = rt
|
||||||
.store()
|
.store()
|
||||||
.all_notes()
|
.all_notes()
|
||||||
|
@ -139,7 +137,7 @@ fn list(rt: &Runtime) {
|
||||||
.iter()
|
.iter()
|
||||||
.for_each(|note| {
|
.for_each(|note| {
|
||||||
let name = note.get_name().map_err_trace_exit_unwrap(1);
|
let name = note.get_name().map_err_trace_exit_unwrap(1);
|
||||||
writeln!(out, "{}", name)
|
writeln!(rt.stdout(), "{}", name)
|
||||||
.to_exit_code()
|
.to_exit_code()
|
||||||
.unwrap_or_exit()
|
.unwrap_or_exit()
|
||||||
});
|
});
|
||||||
|
|
|
@ -86,7 +86,6 @@ pub fn day(rt: &Runtime) -> i32 {
|
||||||
tags_filter.and(start_time_filter).and(end_time_filter)
|
tags_filter.and(start_time_filter).and(end_time_filter)
|
||||||
};
|
};
|
||||||
|
|
||||||
let mut out = ::std::io::stdout();
|
|
||||||
rt.store()
|
rt.store()
|
||||||
.get_timetrackings()
|
.get_timetrackings()
|
||||||
.map_err_trace_exit_unwrap(1)
|
.map_err_trace_exit_unwrap(1)
|
||||||
|
@ -111,9 +110,9 @@ pub fn day(rt: &Runtime) -> i32 {
|
||||||
.trace_unwrap_exit(1)
|
.trace_unwrap_exit(1)
|
||||||
.map(|(tag, start, end)| {
|
.map(|(tag, start, end)| {
|
||||||
match (start, end) {
|
match (start, end) {
|
||||||
(None, _) => writeln!(out, "{} has no start time.", tag),
|
(None, _) => writeln!(rt.stdout(), "{} has no start time.", tag),
|
||||||
(Some(s), None) => writeln!(out, "{} | {} - ...", tag, s),
|
(Some(s), None) => writeln!(rt.stdout(), "{} | {} - ...", tag, s),
|
||||||
(Some(s), Some(e)) => writeln!(out, "{} | {} - {}", tag, s, e),
|
(Some(s), Some(e)) => writeln!(rt.stdout(), "{} | {} - {}", tag, s, e),
|
||||||
}
|
}
|
||||||
.to_exit_code()
|
.to_exit_code()
|
||||||
})
|
})
|
||||||
|
|
|
@ -117,8 +117,6 @@ pub fn list_impl(rt: &Runtime,
|
||||||
let mut table = Table::new();
|
let mut table = Table::new();
|
||||||
table.set_titles(Row::new(["Tag", "Start", "End"].into_iter().map(|s| Cell::new(s)).collect()));
|
table.set_titles(Row::new(["Tag", "Start", "End"].into_iter().map(|s| Cell::new(s)).collect()));
|
||||||
|
|
||||||
let mut stdout = ::std::io::stdout();
|
|
||||||
|
|
||||||
rt.store()
|
rt.store()
|
||||||
.get_timetrackings()
|
.get_timetrackings()
|
||||||
.map_err_trace_exit_unwrap(1)
|
.map_err_trace_exit_unwrap(1)
|
||||||
|
@ -167,7 +165,7 @@ pub fn list_impl(rt: &Runtime,
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
.map_err_trace_exit_unwrap(1)
|
.map_err_trace_exit_unwrap(1)
|
||||||
.print(&mut stdout)
|
.print(&mut rt.stdout())
|
||||||
.map_err(|_| TimeTrackError::from(String::from("Failed printing table")))
|
.map_err(|_| TimeTrackError::from(String::from("Failed printing table")))
|
||||||
.map(|_| 0)
|
.map(|_| 0)
|
||||||
.map_err_trace()
|
.map_err_trace()
|
||||||
|
|
|
@ -101,8 +101,6 @@ pub fn month(rt: &Runtime) -> i32 {
|
||||||
tags_filter.and(start_time_filter).and(end_time_filter)
|
tags_filter.and(start_time_filter).and(end_time_filter)
|
||||||
};
|
};
|
||||||
|
|
||||||
let mut out = ::std::io::stdout();
|
|
||||||
|
|
||||||
rt.store()
|
rt.store()
|
||||||
.get_timetrackings()
|
.get_timetrackings()
|
||||||
.map_err_trace_exit_unwrap(1)
|
.map_err_trace_exit_unwrap(1)
|
||||||
|
@ -127,9 +125,9 @@ pub fn month(rt: &Runtime) -> i32 {
|
||||||
.trace_unwrap_exit(1)
|
.trace_unwrap_exit(1)
|
||||||
.map(|(tag, start, end)| {
|
.map(|(tag, start, end)| {
|
||||||
match (start, end) {
|
match (start, end) {
|
||||||
(None, _) => writeln!(out, "{} has no start time.", tag),
|
(None, _) => writeln!(rt.stdout(), "{} has no start time.", tag),
|
||||||
(Some(s), None) => writeln!(out, "{} | {} - ...", tag, s),
|
(Some(s), None) => writeln!(rt.stdout(), "{} | {} - ...", tag, s),
|
||||||
(Some(s), Some(e)) => writeln!(out, "{} | {} - {}", tag, s, e),
|
(Some(s), Some(e)) => writeln!(rt.stdout(), "{} | {} - {}", tag, s, e),
|
||||||
}
|
}
|
||||||
.to_exit_code()
|
.to_exit_code()
|
||||||
})
|
})
|
||||||
|
|
|
@ -99,7 +99,6 @@ pub fn week(rt: &Runtime) -> i32 {
|
||||||
tags_filter.and(start_time_filter).and(end_time_filter)
|
tags_filter.and(start_time_filter).and(end_time_filter)
|
||||||
};
|
};
|
||||||
|
|
||||||
let mut out = ::std::io::stdout();
|
|
||||||
rt.store()
|
rt.store()
|
||||||
.get_timetrackings()
|
.get_timetrackings()
|
||||||
.map_err_trace_exit_unwrap(1)
|
.map_err_trace_exit_unwrap(1)
|
||||||
|
@ -124,9 +123,9 @@ pub fn week(rt: &Runtime) -> i32 {
|
||||||
.trace_unwrap_exit(1)
|
.trace_unwrap_exit(1)
|
||||||
.map(|(tag, start, end)| {
|
.map(|(tag, start, end)| {
|
||||||
match (start, end) {
|
match (start, end) {
|
||||||
(None, _) => writeln!(out, "{} has no start time.", tag),
|
(None, _) => writeln!(rt.stdout(), "{} has no start time.", tag),
|
||||||
(Some(s), None) => writeln!(out, "{} | {} - ...", tag, s),
|
(Some(s), None) => writeln!(rt.stdout(), "{} | {} - ...", tag, s),
|
||||||
(Some(s), Some(e)) => writeln!(out, "{} | {} - {}", tag, s, e),
|
(Some(s), Some(e)) => writeln!(rt.stdout(), "{} | {} - {}", tag, s, e),
|
||||||
}
|
}
|
||||||
.to_exit_code()
|
.to_exit_code()
|
||||||
})
|
})
|
||||||
|
|
|
@ -98,7 +98,7 @@ pub fn year(rt: &Runtime) -> i32 {
|
||||||
tags_filter.and(start_time_filter).and(end_time_filter)
|
tags_filter.and(start_time_filter).and(end_time_filter)
|
||||||
};
|
};
|
||||||
|
|
||||||
let mut out = ::std::io::stdout();
|
let mut out = rt.stdout();
|
||||||
rt.store()
|
rt.store()
|
||||||
.get_timetrackings()
|
.get_timetrackings()
|
||||||
.map_err_trace_exit_unwrap(1)
|
.map_err_trace_exit_unwrap(1)
|
||||||
|
|
|
@ -71,7 +71,7 @@ fn tw_hook(rt: &Runtime) {
|
||||||
.import_task_from_reader(stdin)
|
.import_task_from_reader(stdin)
|
||||||
.map_err_trace_exit_unwrap(1);
|
.map_err_trace_exit_unwrap(1);
|
||||||
|
|
||||||
let _ = writeln!(::std::io::stdout(), "{}\nTask {} stored in imag", line, uuid)
|
let _ = writeln!(rt.stdout(), "{}\nTask {} stored in imag", line, uuid)
|
||||||
.to_exit_code()
|
.to_exit_code()
|
||||||
.unwrap_or_exit();
|
.unwrap_or_exit();
|
||||||
|
|
||||||
|
@ -148,7 +148,7 @@ fn list(rt: &Runtime) {
|
||||||
};
|
};
|
||||||
|
|
||||||
// and then print that
|
// and then print that
|
||||||
let _ = writeln!(::std::io::stdout(), "{}", outstring).to_exit_code().unwrap_or_exit();
|
let _ = writeln!(rt.stdout(), "{}", outstring).to_exit_code().unwrap_or_exit();
|
||||||
});
|
});
|
||||||
|
|
||||||
res.map_err_trace().ok();
|
res.map_err_trace().ok();
|
||||||
|
|
|
@ -29,6 +29,7 @@ is-match = "0.1"
|
||||||
toml-query = "0.6"
|
toml-query = "0.6"
|
||||||
error-chain = "0.11"
|
error-chain = "0.11"
|
||||||
handlebars = "0.29.0"
|
handlebars = "0.29.0"
|
||||||
|
atty = "0.2"
|
||||||
|
|
||||||
libimagstore = { version = "0.7.0", path = "../../../lib/core/libimagstore" }
|
libimagstore = { version = "0.7.0", path = "../../../lib/core/libimagstore" }
|
||||||
libimagerror = { version = "0.7.0", path = "../../../lib/core/libimagerror" }
|
libimagerror = { version = "0.7.0", path = "../../../lib/core/libimagerror" }
|
||||||
|
|
66
lib/core/libimagrt/src/io.rs
Normal file
66
lib/core/libimagrt/src/io.rs
Normal file
|
@ -0,0 +1,66 @@
|
||||||
|
//
|
||||||
|
// imag - the personal information management suite for the commandline
|
||||||
|
// Copyright (C) 2015-2018 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
|
||||||
|
//
|
||||||
|
|
||||||
|
//! Proxy objects for std::io::Stdin, std::io::Stdout, std::io::Stderr
|
||||||
|
|
||||||
|
use std::fmt::Debug;
|
||||||
|
use std::io::Write;
|
||||||
|
|
||||||
|
/// Proxy object for output
|
||||||
|
///
|
||||||
|
/// This is returned by `Runtime::stdout()` does implement `Write`. So you can
|
||||||
|
/// `write!(rt.stdout(), "some things")` and it just works.
|
||||||
|
///
|
||||||
|
/// The `Runtime` has to decide whether the OutputProxy should write to stdout, stderr or simply be
|
||||||
|
/// a "sink" which does not write to either.
|
||||||
|
///
|
||||||
|
pub enum OutputProxy {
|
||||||
|
Out,
|
||||||
|
Err,
|
||||||
|
Sink,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Write for OutputProxy {
|
||||||
|
fn write(&mut self, buf: &[u8]) -> ::std::io::Result<usize> {
|
||||||
|
match *self {
|
||||||
|
OutputProxy::Out => ::std::io::stdout().write(buf),
|
||||||
|
OutputProxy::Err => ::std::io::stderr().write(buf),
|
||||||
|
OutputProxy::Sink => Ok(0),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn flush(&mut self) -> ::std::io::Result<()> {
|
||||||
|
match *self {
|
||||||
|
OutputProxy::Out => ::std::io::stdout().flush(),
|
||||||
|
OutputProxy::Err => ::std::io::stderr().flush(),
|
||||||
|
OutputProxy::Sink => Ok(()),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Debug for OutputProxy {
|
||||||
|
fn fmt(&self, f: &mut ::std::fmt::Formatter) -> Result<(), ::std::fmt::Error> {
|
||||||
|
match *self {
|
||||||
|
OutputProxy::Out => write!(f, "OutputProxy(Stdout)"),
|
||||||
|
OutputProxy::Err => write!(f, "OutputProxy(Stderr)"),
|
||||||
|
OutputProxy::Sink => write!(f, "OutputProxy(Sink)"),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -47,6 +47,7 @@ extern crate clap;
|
||||||
extern crate toml;
|
extern crate toml;
|
||||||
extern crate toml_query;
|
extern crate toml_query;
|
||||||
#[macro_use] extern crate is_match;
|
#[macro_use] extern crate is_match;
|
||||||
|
extern crate atty;
|
||||||
|
|
||||||
extern crate libimagstore;
|
extern crate libimagstore;
|
||||||
extern crate libimagutil;
|
extern crate libimagutil;
|
||||||
|
@ -56,6 +57,7 @@ extern crate libimaginteraction;
|
||||||
pub mod error;
|
pub mod error;
|
||||||
pub mod configuration;
|
pub mod configuration;
|
||||||
pub mod logger;
|
pub mod logger;
|
||||||
|
pub mod io;
|
||||||
pub mod runtime;
|
pub mod runtime;
|
||||||
pub mod setup;
|
pub mod setup;
|
||||||
pub mod spec;
|
pub mod spec;
|
||||||
|
|
|
@ -21,6 +21,7 @@ use std::path::PathBuf;
|
||||||
use std::process::Command;
|
use std::process::Command;
|
||||||
use std::env;
|
use std::env;
|
||||||
use std::process::exit;
|
use std::process::exit;
|
||||||
|
use std::io::Stdin;
|
||||||
|
|
||||||
pub use clap::App;
|
pub use clap::App;
|
||||||
use toml::Value;
|
use toml::Value;
|
||||||
|
@ -32,6 +33,7 @@ use error::RuntimeError;
|
||||||
use error::RuntimeErrorKind;
|
use error::RuntimeErrorKind;
|
||||||
use error::ResultExt;
|
use error::ResultExt;
|
||||||
use logger::ImagLogger;
|
use logger::ImagLogger;
|
||||||
|
use io::OutputProxy;
|
||||||
|
|
||||||
use libimagerror::trace::*;
|
use libimagerror::trace::*;
|
||||||
use libimagstore::store::Store;
|
use libimagstore::store::Store;
|
||||||
|
@ -47,6 +49,8 @@ pub struct Runtime<'a> {
|
||||||
configuration: Option<Value>,
|
configuration: Option<Value>,
|
||||||
cli_matches: ArgMatches<'a>,
|
cli_matches: ArgMatches<'a>,
|
||||||
store: Store,
|
store: Store,
|
||||||
|
stdin_is_tty: bool,
|
||||||
|
stdout_is_tty: bool,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'a> Runtime<'a> {
|
impl<'a> Runtime<'a> {
|
||||||
|
@ -150,6 +154,8 @@ impl<'a> Runtime<'a> {
|
||||||
configuration: config,
|
configuration: config,
|
||||||
rtp: rtp,
|
rtp: rtp,
|
||||||
store: store,
|
store: store,
|
||||||
|
stdout_is_tty: ::atty::is(::atty::Stream::Stdout),
|
||||||
|
stdin_is_tty: ::atty::is(::atty::Stream::Stdin),
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
.chain_err(|| RuntimeErrorKind::Instantiate)
|
.chain_err(|| RuntimeErrorKind::Instantiate)
|
||||||
|
@ -438,6 +444,26 @@ impl<'a> Runtime<'a> {
|
||||||
.or(env::var("EDITOR").ok())
|
.or(env::var("EDITOR").ok())
|
||||||
.map(Command::new)
|
.map(Command::new)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn stdout(&self) -> OutputProxy {
|
||||||
|
if self.stdout_is_tty {
|
||||||
|
OutputProxy::Out
|
||||||
|
} else {
|
||||||
|
OutputProxy::Err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn stderr(&self) -> OutputProxy {
|
||||||
|
OutputProxy::Err
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn stdin(&self) -> Option<Stdin> {
|
||||||
|
if self.stdin_is_tty {
|
||||||
|
Some(::std::io::stdin())
|
||||||
|
} else {
|
||||||
|
None
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Exported for the `imag` command, you probably do not want to use that.
|
/// Exported for the `imag` command, you probably do not want to use that.
|
||||||
|
|
Loading…
Reference in a new issue