This repository has been archived on 2023-03-24. You can view files and clone it, but cannot push or open issues or pull requests.
rustlings-exercises-completed/exercises/error_handling/option1.rs

60 lines
1.0 KiB
Rust
Raw Normal View History

2018-02-22 00:09:53 -06:00
// option1.rs
2016-02-10 18:37:26 -06:00
// This example panics because the second time it calls `pop`, the `vec`
// is empty, so `pop` returns `None`, and `unwrap` panics if it's called
// on `None`. Handle this in a more graceful way than calling `unwrap`!
// Scroll down for hints :)
// I AM NOT DONE
pub fn pop_too_much() -> bool {
2016-02-10 18:37:26 -06:00
let mut list = vec![3];
let last = list.pop().unwrap();
println!("The last item in the list is {:?}", last);
let second_to_last = list.pop().unwrap();
println!(
"The second-to-last item in the list is {:?}",
second_to_last
);
true
2016-02-10 18:37:26 -06:00
}
#[cfg(test)]
mod tests {
use super::*;
2016-02-10 18:37:26 -06:00
#[test]
fn should_not_panic() {
assert!(pop_too_much());
}
}
2016-02-10 18:37:26 -06:00
// Try using a `match` statement where the arms are `Some(thing)` and `None`.
// Or set a default value to print out if you get `None` by using the
// function `unwrap_or`.
// Or use an `if let` statement on the result of `pop()` to both destructure
// a `Some` value and only print out something if we have a value!