From cc53dab035c5d5fe5037981bd1fedee87a3962a4 Mon Sep 17 00:00:00 2001 From: emma Date: Sat, 24 Aug 2024 18:18:27 -0600 Subject: [PATCH] rpn(1): handles errors when writing to stdout --- src/rpn.rs | 27 ++++++++++++++++----------- 1 file changed, 16 insertions(+), 11 deletions(-) diff --git a/src/rpn.rs b/src/rpn.rs index ff0b1bd..d4056b6 100644 --- a/src/rpn.rs +++ b/src/rpn.rs @@ -46,7 +46,7 @@ use std::{ collections::VecDeque, env::args, fmt::{ self, Display, Formatter }, - io::stdin, + io::{ Error, Write, stdin, stdout }, process::ExitCode, }; @@ -125,7 +125,7 @@ struct EvaluationError { /* I’m no math nerd but I want the highest possible approximation of 0.9 * repeating and it seems this can give it to me */ -const PRECISION_MOD: f64 = 0.9 + f64::EPSILON * 100.0; +const PRECISION_MOD: f64 = 0.9 + f64::EPSILON; fn err(argv0: &String, e: std::io::Error, code: Option) -> ExitCode { eprintln!("{}: {}", argv0, e.strerror()); @@ -204,16 +204,16 @@ fn round_precise(value: &f64) -> f64 { (value * multiplier).round() / multiplier } -fn unstack(stack: VecDeque, op: bool) -> bool { +fn unstack(stack: VecDeque, op: bool) -> Result { if let Some(val) = stack.iter().last() { - if !op { return true; } + if !op { return Ok(true); } - println!("{}", round_precise(val).to_string()); + let out = round_precise(val).to_string() + &'\n'.to_string(); + + return stdout().write_all(out.as_bytes()).map(|_| true); } else { - return false; + return Ok(false); } - - return true; } fn main() -> ExitCode { @@ -240,7 +240,9 @@ fn main() -> ExitCode { match eval(&input, stack) { Ok(s) => { - let _ = unstack(s.0.clone(), s.1.clone()); + if let Err(e) = unstack(s.0.clone(), s.1.clone()) { + return err(&argv[0], e, Some(EX_IOERR)); + } return ExitCode::SUCCESS; } Err(e) => { @@ -261,8 +263,11 @@ fn main() -> ExitCode { buf.clear(); stack = s.0.clone(); - if unstack(s.0, s.1) { continue; } - else { break; } + match unstack(s.0, s.1) { + Ok(b) if b => continue, + Ok(_) => break, + Err(e) => return err(&argv[0], e, Some(EX_IOERR)), + }; }, Err(e) => { eprintln!("{}: {}", argv[0], e.message);