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
//
// This Source Code Form is subject to the terms of the Mozilla Public
// License, v. 2.0. If a copy of the MPL was not distributed with this
// file, You can obtain one at http://mozilla.org/MPL/2.0/.
//

#[cfg(not(test))]
use core::iter::*;
#[cfg(test)]
use std::iter::*;

use util::*;

pub use util::Process as Oks;
// for backward compatibility with previous implementation

/// Extension trait for `Iterator<Item = Result<T, E>>` to get all `T`s
#[allow(clippy::type_complexity)]
pub trait GetOks<T, E>: Sized {
    /// Iterate over every `Ok` while ignoring every `Err`
    ///
    /// ```
    /// use std::str::FromStr;
    /// use resiter::oks::GetOks;
    ///
    /// let res:Vec<usize> = ["1", "2", "3", "a", "4", "5"]
    ///     .iter()
    ///     .map(|e| usize::from_str(e))
    ///     .oks()
    ///     .collect();
    ///
    /// assert_eq!(
    ///     res,
    ///     vec![1,2,3,4,5]
    /// );
    /// ```
    fn oks(self) -> FilterMap<Self, fn(Result<T, E>) -> Option<T>>;
}

impl<T, E, I> GetOks<T, E> for I
where
    I: Iterator<Item = Result<T, E>> + Sized,
{
    #[inline]
    #[allow(clippy::type_complexity)]
    fn oks(self) -> FilterMap<Self, fn(Result<T, E>) -> Option<T>> {
        self.filter_map(GetOk::get_ok)
    }
}