1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
#[must_use = "iterator adaptors are lazy and do nothing unless consumed"]
pub struct OnErr<I, O, E, F>(I, F)
where I: Iterator<Item = Result<O, E>>,
F: Fn(&E) -> ();
pub trait OnErrDo<I, O, E, F>
where I: Iterator<Item = Result<O, E>>,
F: Fn(&E) -> ()
{
fn on_err(self, F) -> OnErr<I, O, E, F>;
}
impl<I, O, E, F> OnErrDo<I, O, E, F> for I
where I: Iterator<Item = Result<O, E>>,
F: Fn(&E) -> ()
{
fn on_err(self, f: F) -> OnErr<I, O, E, F> {
OnErr(self, f)
}
}
impl<I, O, E, F> Iterator for OnErr<I, O, E, F>
where I: Iterator<Item = Result<O, E>>,
F: Fn(&E) -> ()
{
type Item = Result<O, E>;
fn next(&mut self) -> Option<Self::Item> {
self.0.next().map(|r| r.map_err(|e| {(self.1)(&e); e }))
}
}
#[test]
fn test_compile_1() {
use std::str::FromStr;
let _ : Vec<Result<usize, ::std::num::ParseIntError>> = ["1", "2", "3", "4", "5"]
.into_iter()
.map(|e| usize::from_str(e))
.on_err(|e| println!("Error: {:?}", e))
.collect();
}