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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
//! # How to use `pipeline_macro` ?
//!
//! * Define a pipeline with type in input and type in ouput
//! * Use `run` method to run this pipeline
//!
//! ## Basic example:
//! ```
//! use pipeline_macro::*;
//! # fn add2(i: i32) -> i32 { i + 2 }
//! # fn div_by_3(i: i32) -> f64 { (i as f64) / 3.0 }
//! # fn mul_by_83(i: f64) -> f32 { (i as f32) * 83.0 }
//!
//! let pipeline = pipeline! {
//!     i32
//!     => add2
//!     => div_by_3
//!     => mul_by_83
//!     ;-> f64
//! };
//!
//! let result = pipeline.run(3); // ~= 110.6666..
//! ```
//!
//! ## Closure example:
//! ```
//! use pipeline_macro::*;
//! # fn div_by_3(i: i32) -> f64 { (i as f64) / 3.0 }
//! # fn mul_by_83(i: f64) -> f32 { (i as f32) * 83.0 }
//!
//! let pipeline = pipeline! {
//!     i32
//!     => |i: i32| i + 2
//!     => div_by_3
//!     => mul_by_83
//!     ;-> f64
//! };
//!
//! let result = pipeline.run(3); // ~= 110.6666..
//! ```
mod pipeline;
mod macros;

pub use pipeline::Pipeline;


#[cfg(test)]
mod tests {

    use crate::*;

    fn add2(i: i32) -> i32 {
        i + 2
    }

    fn div_by_3(i: i32) -> f64 {
        (i as f64) / 3.0
    }

    fn mul_by_83(i: f64) -> f32 {
        (i as f32) * 83.0
    }

    #[test]
    fn basic_pipeline() {
        let pipeline = pipeline! {
            i32
            => add2
            => div_by_3
            => mul_by_83
            ;-> f32
        };
        let result = pipeline.run(2);

        assert_eq!(result, ((2 + 2) as f64 / 3.0) as f32 * 83.0);
    }


    #[test]
    fn pipeline_with_closures() {
        let pipeline = pipeline! {
            i32
            => |i: i32| i + 2
            => div_by_3
            => mul_by_83
            ;-> f32
        };
        let result = pipeline.run(2);

        assert_eq!(result, ((2 + 2) as f64 / 3.0) as f32 * 83.0);
    }
}