pub struct Tree<T> { /* private fields */ }
Expand description
A compound node in a filter expression, consisting of a logical operator and a set of child expressions.
Implementations§
Source§impl<T> Tree<T>
impl<T> Tree<T>
pub fn new(operator: Logic, rules: Vec<T>) -> Self
pub fn operator(&self) -> Logic
Sourcepub fn into_tuple(self) -> (Logic, Vec<T>)
pub fn into_tuple(self) -> (Logic, Vec<T>)
Decompose the tree into its operator and rules.
Sourcepub fn from_iter(operator: Logic, rules: impl Iterator<Item = T>) -> Self
pub fn from_iter(operator: Logic, rules: impl Iterator<Item = T>) -> Self
Create an instance by collecting the rules from an iterator.
§Example
let rules = vec![
Clause::new("name", "=", "jim"),
Clause::new("age", ">", "10")
];
let tree = Tree::from_iter(
Logic::And,
rules.into_iter().filter(|f| *f.field() != "age")
);
assert_eq!(1, tree.rules().len());
Sourcepub fn map<U, F>(self, transform: F) -> Tree<U>where
F: FnMut(T) -> U,
pub fn map<U, F>(self, transform: F) -> Tree<U>where
F: FnMut(T) -> U,
Create a new tree by applying a transform to all its rules.
§Example
let tree = Tree::new(Logic::Or, vec![1, 2]);
let tree2 = tree.map(|x| x * 10);
assert_eq!(Tree::new(Logic::Or, vec![10, 20]), tree2);
Sourcepub fn try_map<U, E, F>(self, transform: F) -> Result<Tree<U>, E>
pub fn try_map<U, E, F>(self, transform: F) -> Result<Tree<U>, E>
Create a new tree by applying a fallible transform to all its rules. The function will return the first error it encounters.
§Example
let tree = Tree::new(Logic::Or, vec![1, 2]);
let tree2 = tree.try_map(|x| {
if x % 2 == 0 {
Ok(x * 10)
} else {
Err(format!("Odd number: {}", x))
}
});
assert_eq!("Odd number: 1", &tree2.unwrap_err());
Trait Implementations§
impl<T: Eq> Eq for Tree<T>
impl<T> StructuralPartialEq for Tree<T>
Auto Trait Implementations§
impl<T> Freeze for Tree<T>
impl<T> RefUnwindSafe for Tree<T>where
T: RefUnwindSafe,
impl<T> Send for Tree<T>where
T: Send,
impl<T> Sync for Tree<T>where
T: Sync,
impl<T> Unpin for Tree<T>where
T: Unpin,
impl<T> UnwindSafe for Tree<T>where
T: UnwindSafe,
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