pub struct ArcConditionalBiTransformer<T, U, R> { /* private fields */ }Expand description
ArcConditionalBiTransformer struct
A thread-safe conditional bi-transformer that only executes when a
bi-predicate is satisfied. Uses ArcBiTransformer and ArcBiPredicate for
shared ownership across threads.
This type is typically created by calling ArcBiTransformer::when() and is
designed to work with the or_else() method to create if-then-else logic.
§Features
- Shared Ownership: Cloneable via
Arc, multiple owners allowed - Thread-Safe: Implements
Send + Sync, safe for concurrent use - Conditional Execution: Only transforms when bi-predicate returns
true - Chainable: Can add
or_elsebranch to create if-then-else logic
§Examples
use prism3_function::{BiTransformer, ArcBiTransformer};
let add = ArcBiTransformer::new(|x: i32, y: i32| x + y);
let multiply = ArcBiTransformer::new(|x: i32, y: i32| x * y);
let conditional = add.when(|x: &i32, y: &i32| *x > 0).or_else(multiply);
let conditional_clone = conditional.clone();
assert_eq!(conditional.apply(5, 3), 8);
assert_eq!(conditional_clone.apply(-5, 3), -15);§Author
Haixing Hu
Implementations§
Source§impl<T, U, R> ArcConditionalBiTransformer<T, U, R>
impl<T, U, R> ArcConditionalBiTransformer<T, U, R>
Sourcepub fn or_else<F>(&self, else_transformer: F) -> ArcBiTransformer<T, U, R>
pub fn or_else<F>(&self, else_transformer: F) -> ArcBiTransformer<T, U, R>
Adds an else branch (thread-safe version)
Executes the original bi-transformer when the condition is satisfied, otherwise executes else_transformer.
§Parameters
else_transformer- The bi-transformer for the else branch, can be:- Closure:
|x: T, y: U| -> R(must beSend + Sync) ArcBiTransformer<T, U, R>,BoxBiTransformer<T, U, R>- Any type implementing
BiTransformer<T, U, R> + Send + Sync
- Closure:
§Returns
Returns the composed ArcBiTransformer<T, U, R>
§Examples
§Using a closure (recommended)
use prism3_function::{BiTransformer, ArcBiTransformer};
let add = ArcBiTransformer::new(|x: i32, y: i32| x + y);
let conditional = add.when(|x: &i32, y: &i32| *x > 0).or_else(|x: i32, y: i32| x * y);
assert_eq!(conditional.apply(5, 3), 8);
assert_eq!(conditional.apply(-5, 3), -15);Trait Implementations§
Source§impl<T, U, R> Clone for ArcConditionalBiTransformer<T, U, R>
impl<T, U, R> Clone for ArcConditionalBiTransformer<T, U, R>
Auto Trait Implementations§
impl<T, U, R> Freeze for ArcConditionalBiTransformer<T, U, R>
impl<T, U, R> !RefUnwindSafe for ArcConditionalBiTransformer<T, U, R>
impl<T, U, R> Send for ArcConditionalBiTransformer<T, U, R>
impl<T, U, R> Sync for ArcConditionalBiTransformer<T, U, R>
impl<T, U, R> Unpin for ArcConditionalBiTransformer<T, U, R>
impl<T, U, R> !UnwindSafe for ArcConditionalBiTransformer<T, U, R>
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more