summaryrefslogtreecommitdiffstats
path: root/src/main.rs
diff options
context:
space:
mode:
Diffstat (limited to 'src/main.rs')
-rw-r--r--src/main.rs18
1 files changed, 12 insertions, 6 deletions
diff --git a/src/main.rs b/src/main.rs
index 4a8f1f1..6146621 100644
--- a/src/main.rs
+++ b/src/main.rs
@@ -1,5 +1,5 @@
use std::fs::File;
-use std::io::{self, Read, Write};
+use std::io::{self, Read};
use std::process;
use structopt::StructOpt;
@@ -22,6 +22,16 @@ use writer::WriteReceiver;
fn main() {
let opt = Opt::from_args();
+
+ let stdout = io::stdout();
+ let lock = stdout.lock();
+ match opt.input {
+ Some(_) => main_generic(opt, &mut io::BufWriter::new(lock)),
+ None => main_generic(opt, &mut io::LineWriter::new(lock)),
+ }
+}
+
+fn main_generic<W: WriteReceiver>(opt: Opt, handle: &mut W) {
let config = Config::new(opt);
let read = match &config.opt.input {
@@ -39,16 +49,12 @@ fn main() {
let mut reader = reader::BufReader::new(read);
let mut buffer = String::new();
- let stdout = io::stdout();
- let lock = stdout.lock();
- let mut handle = io::BufWriter::new(lock);
-
while let Some(line) = reader.read_line(&mut buffer) {
match line {
Ok(l) => {
let choice_iter = &mut config.opt.choices.iter().peekable();
while let Some(choice) = choice_iter.next() {
- choice.print_choice(&l, &config, &mut handle);
+ choice.print_choice(&l, &config, handle);
if choice_iter.peek().is_some() {
handle.write_separator(&config);
}