2018-02-22 09:09:53 +03:00
|
|
|
// errors3.rs
|
2023-05-29 20:39:08 +03:00
|
|
|
//
|
2016-06-21 17:40:32 +03:00
|
|
|
// This is a program that is trying to use a completed version of the
|
2019-11-11 15:37:43 +03:00
|
|
|
// `total_cost` function from the previous exercise. It's not working though!
|
2019-11-11 18:51:38 +03:00
|
|
|
// Why not? What should we do to fix it?
|
2023-05-29 20:39:08 +03:00
|
|
|
//
|
|
|
|
// Execute `rustlings hint errors3` or use the `hint` watch subcommand for a
|
|
|
|
// hint.
|
2016-06-21 17:40:32 +03:00
|
|
|
|
|
|
|
use std::num::ParseIntError;
|
2024-02-02 05:58:03 +03:00
|
|
|
use std::error;
|
|
|
|
|
|
|
|
// I could have just returned the ParseIntError from the total_cost function
|
|
|
|
// because we know the exact error that's being returned.
|
2016-06-21 17:40:32 +03:00
|
|
|
|
2024-02-02 05:58:03 +03:00
|
|
|
fn main() -> Result<(), Box<dyn error::Error>>{
|
|
|
|
// Box <dyn error::Error> is a trait object.
|
|
|
|
// Meaning, you would use this when you know an error can be returned but
|
|
|
|
// not necessarily what kind
|
|
|
|
|
2016-06-21 17:40:32 +03:00
|
|
|
let mut tokens = 100;
|
|
|
|
let pretend_user_input = "8";
|
|
|
|
|
2018-11-09 22:31:14 +03:00
|
|
|
let cost = total_cost(pretend_user_input)?;
|
2016-06-21 17:40:32 +03:00
|
|
|
|
|
|
|
if cost > tokens {
|
|
|
|
println!("You can't afford that many!");
|
|
|
|
} else {
|
|
|
|
tokens -= cost;
|
|
|
|
println!("You now have {} tokens.", tokens);
|
|
|
|
}
|
2024-02-02 05:58:03 +03:00
|
|
|
|
|
|
|
Ok(())
|
2016-06-21 17:40:32 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
pub fn total_cost(item_quantity: &str) -> Result<i32, ParseIntError> {
|
|
|
|
let processing_fee = 1;
|
|
|
|
let cost_per_item = 5;
|
2018-11-09 22:31:14 +03:00
|
|
|
let qty = item_quantity.parse::<i32>()?;
|
2016-06-21 17:40:32 +03:00
|
|
|
|
|
|
|
Ok(qty * cost_per_item + processing_fee)
|
|
|
|
}
|