pub struct Expression { /* private fields */ }Expand description
A node in a Vortex expression tree.
Expressions represent scalar computations that can be performed on data. Each expression consists of an encoding (vtable), heap-allocated metadata, and child expressions.
Implementations§
Source§impl Expression
impl Expression
Sourcepub fn try_new(
scalar_fn: ScalarFn,
children: impl Into<Arc<[Expression]>>,
) -> VortexResult<Self>
pub fn try_new( scalar_fn: ScalarFn, children: impl Into<Arc<[Expression]>>, ) -> VortexResult<Self>
Create a new expression node from a scalar_fn expression and its children.
Sourcepub fn is<V: VTable>(&self) -> bool
pub fn is<V: VTable>(&self) -> bool
Returns true if this expression is of the given vtable type.
Sourcepub fn as_opt<V: VTable>(&self) -> Option<&V::Options>
pub fn as_opt<V: VTable>(&self) -> Option<&V::Options>
Returns the typed options for this expression if it matches the given vtable type.
Sourcepub fn as_<V: VTable>(&self) -> &V::Options
pub fn as_<V: VTable>(&self) -> &V::Options
Returns the typed options for this expression if it matches the given vtable type.
Sourcepub fn children(&self) -> &Arc<[Expression]>
pub fn children(&self) -> &Arc<[Expression]>
Returns the children of this expression.
Sourcepub fn child(&self, n: usize) -> &Expression
pub fn child(&self, n: usize) -> &Expression
Returns the n’th child of this expression.
Sourcepub fn with_children(
self,
children: impl Into<Arc<[Expression]>>,
) -> VortexResult<Self>
pub fn with_children( self, children: impl Into<Arc<[Expression]>>, ) -> VortexResult<Self>
Replace the children of this expression with the provided new children.
Sourcepub fn return_dtype(&self, scope: &DType) -> VortexResult<DType>
pub fn return_dtype(&self, scope: &DType) -> VortexResult<DType>
Computes the return dtype of this expression given the input dtype.
Sourcepub fn evaluate(&self, scope: &ArrayRef) -> VortexResult<ArrayRef>
pub fn evaluate(&self, scope: &ArrayRef) -> VortexResult<ArrayRef>
Evaluates the expression in the given scope, returning an array.
Sourcepub fn stat_falsification(
&self,
catalog: &dyn StatsCatalog,
) -> Option<Expression>
pub fn stat_falsification( &self, catalog: &dyn StatsCatalog, ) -> Option<Expression>
An expression over zone-statistics which implies all records in the zone evaluate to false.
Given an expression, e, if e.stat_falsification(..) evaluates to true, it is guaranteed
that e evaluates to false on all records in the zone. However, the inverse is not
necessarily true: even if the falsification evaluates to false, e need not evaluate to
true on all records.
The StatsCatalog can be used to constrain or rename stats used in the final expr.
§Examples
- An expression over one variable:
x > 0is false for all records in a zone if the maximum value of the columnxin that zone is less than or equal to zero:max(x) <= 0. - An expression over two variables:
x > ybecomesmax(x) <= min(y). - A conjunctive expression:
x > y AND z < xbecomes `max(x) <= min(y) OR min(z) >= max(x).
Some expressions, in theory, have falsifications but this function does not support them
such as x < (y < z) or x LIKE "needle%".
Sourcepub fn stat_expression(
&self,
stat: Stat,
catalog: &dyn StatsCatalog,
) -> Option<Expression>
pub fn stat_expression( &self, stat: Stat, catalog: &dyn StatsCatalog, ) -> Option<Expression>
Returns an expression representing the zoned statistic for the given stat, if available.
The StatsCatalog returns expressions that can be evaluated using the zone map as a
scope. Expressions can implement this function to propagate such statistics through the
expression tree. For example, the a + 10 expression could propagate min: min(a) + 10.
NOTE(gatesn): we currently cannot represent statistics over nested fields. Please file an issue to discuss a solution to this.
Sourcepub fn stat_min(&self, catalog: &dyn StatsCatalog) -> Option<Expression>
pub fn stat_min(&self, catalog: &dyn StatsCatalog) -> Option<Expression>
Returns an expression representing the zoned maximum statistic, if available.
Sourcepub fn stat_max(&self, catalog: &dyn StatsCatalog) -> Option<Expression>
pub fn stat_max(&self, catalog: &dyn StatsCatalog) -> Option<Expression>
Returns an expression representing the zoned maximum statistic, if available.
Sourcepub fn fmt_sql(&self, f: &mut Formatter<'_>) -> Result
pub fn fmt_sql(&self, f: &mut Formatter<'_>) -> Result
Format the expression as a compact string.
Since this is a recursive formatter, it is exposed on the public Expression type. See fmt_data that is only implemented on the vtable trait.
Sourcepub fn display_tree(&self) -> impl Display
pub fn display_tree(&self) -> impl Display
Display the expression as a formatted tree structure.
This provides a hierarchical view of the expression that shows the relationships between parent and child expressions, making complex nested expressions easier to understand and debug.
§Example
// Build a complex nested expression
let complex_expr = select(
["result"],
and(
not(eq(get_item("status", root()), lit("inactive"))),
and(
Like.new_expr(LikeOptions::default(), [get_item("name", root()), lit("%admin%")]),
gt(
cast(get_item("score", root()), DType::Primitive(PType::F64, Nullability::NonNullable)),
lit(75.0)
)
)
)
);
println!("{}", complex_expr.display_tree());This produces output like:
Select(include): {result}
└── Binary(and)
├── lhs: Not
│ └── Binary(=)
│ ├── lhs: GetItem(status)
│ │ └── Root
│ └── rhs: Literal(value: "inactive", dtype: utf8)
└── rhs: Binary(and)
├── lhs: Like
│ ├── child: GetItem(name)
│ │ └── Root
│ └── pattern: Literal(value: "%admin%", dtype: utf8)
└── rhs: Binary(>)
├── lhs: Cast(target: f64)
│ └── GetItem(score)
│ └── Root
└── rhs: Literal(value: 75f64, dtype: f64)Source§impl Expression
impl Expression
Sourcepub fn optimize(&self, scope: &DType) -> VortexResult<Expression>
pub fn optimize(&self, scope: &DType) -> VortexResult<Expression>
Optimize the root expression node only, iterating to convergence.
This applies optimization rules repeatedly until no more changes occur:
simplify_untyped- type-independent simplificationssimplify- type-aware simplificationsreduce- abstract reduction rules viaReduceNode/ReduceCtx
Sourcepub fn try_optimize(&self, scope: &DType) -> VortexResult<Option<Expression>>
pub fn try_optimize(&self, scope: &DType) -> VortexResult<Option<Expression>>
Try to optimize the root expression node only, returning None if no optimizations applied.
Sourcepub fn optimize_recursive(&self, scope: &DType) -> VortexResult<Expression>
pub fn optimize_recursive(&self, scope: &DType) -> VortexResult<Expression>
Optimize the entire expression tree recursively.
Optimizes children first (bottom-up), then optimizes the root.
Sourcepub fn try_optimize_recursive(
&self,
scope: &DType,
) -> VortexResult<Option<Expression>>
pub fn try_optimize_recursive( &self, scope: &DType, ) -> VortexResult<Option<Expression>>
Try to optimize the entire expression tree recursively.
Sourcepub fn simplify(&self, scope: &DType) -> VortexResult<Expression>
👎Deprecated: Use Expression::optimize_recursive instead
pub fn simplify(&self, scope: &DType) -> VortexResult<Expression>
Simplify the expression, returning a potentially new expression.
Deprecated: Use Expression::optimize_recursive instead, which iterates to convergence.
Sourcepub fn simplify_untyped(&self) -> VortexResult<Expression>
👎Deprecated: Use Expression::optimize_recursive instead
pub fn simplify_untyped(&self) -> VortexResult<Expression>
Simplify the expression without type information.
Deprecated: Use Expression::optimize_recursive instead.
Methods from Deref<Target = ScalarFn>§
Sourcepub fn vtable(&self) -> &ExprVTable
pub fn vtable(&self) -> &ExprVTable
The vtable for this expression.
Sourcepub fn is<V: VTable>(&self) -> bool
pub fn is<V: VTable>(&self) -> bool
Returns whether the scalar function is of the given vtable type.
Sourcepub fn as_opt<V: VTable>(&self) -> Option<&V::Options>
pub fn as_opt<V: VTable>(&self) -> Option<&V::Options>
Returns the typed options for this expression if it matches the given vtable type.
Sourcepub fn return_dtype(&self, arg_types: &[DType]) -> VortexResult<DType>
pub fn return_dtype(&self, arg_types: &[DType]) -> VortexResult<DType>
Compute the return DType of this expression given the input argument types.
Sourcepub fn evaluate(
&self,
expr: &Expression,
scope: &ArrayRef,
) -> VortexResult<ArrayRef>
pub fn evaluate( &self, expr: &Expression, scope: &ArrayRef, ) -> VortexResult<ArrayRef>
Evaluate the expression, returning an ArrayRef.
NOTE: this function will soon be deprecated as all expressions will evaluate trivially into an ExprArray.
Sourcepub fn execute(&self, ctx: ExecutionArgs) -> VortexResult<Datum>
pub fn execute(&self, ctx: ExecutionArgs) -> VortexResult<Datum>
Execute the expression given the input arguments.
Sourcepub fn reduce(
&self,
node: &dyn ReduceNode,
ctx: &dyn ReduceCtx,
) -> VortexResult<Option<ReduceNodeRef>>
pub fn reduce( &self, node: &dyn ReduceNode, ctx: &dyn ReduceCtx, ) -> VortexResult<Option<ReduceNodeRef>>
Perform abstract reduction on this scalar function node.
Trait Implementations§
Source§impl Clone for Expression
impl Clone for Expression
Source§fn clone(&self) -> Expression
fn clone(&self) -> Expression
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl Debug for Expression
impl Debug for Expression
Source§impl Deref for Expression
impl Deref for Expression
Source§impl Display for Expression
The default display implementation for expressions uses the ‘SQL’-style format.
impl Display for Expression
The default display implementation for expressions uses the ‘SQL’-style format.
Source§impl ExprBuiltins for Expression
impl ExprBuiltins for Expression
Source§fn cast(&self, dtype: DType) -> VortexResult<Expression>
fn cast(&self, dtype: DType) -> VortexResult<Expression>
Source§fn get_item(&self, field_name: impl Into<FieldName>) -> VortexResult<Expression>
fn get_item(&self, field_name: impl Into<FieldName>) -> VortexResult<Expression>
Source§fn is_null(&self) -> VortexResult<Expression>
fn is_null(&self) -> VortexResult<Expression>
Source§fn mask(&self, mask: Expression) -> VortexResult<Expression>
fn mask(&self, mask: Expression) -> VortexResult<Expression>
Source§fn not(&self) -> VortexResult<Expression>
fn not(&self) -> VortexResult<Expression>
Source§impl ExprSerializeProtoExt for Expression
impl ExprSerializeProtoExt for Expression
Source§fn serialize_proto(&self) -> VortexResult<Expr>
fn serialize_proto(&self) -> VortexResult<Expr>
Source§impl Hash for Expression
impl Hash for Expression
Source§impl Node for Expression
impl Node for Expression
Source§fn apply_children<'a, F: FnMut(&'a Self) -> VortexResult<TraversalOrder>>(
&'a self,
f: F,
) -> VortexResult<TraversalOrder>
fn apply_children<'a, F: FnMut(&'a Self) -> VortexResult<TraversalOrder>>( &'a self, f: F, ) -> VortexResult<TraversalOrder>
f to them. Read moreSource§fn map_children<F: FnMut(Self) -> VortexResult<Transformed<Self>>>(
self,
f: F,
) -> VortexResult<Transformed<Self>>
fn map_children<F: FnMut(Self) -> VortexResult<Transformed<Self>>>( self, f: F, ) -> VortexResult<Transformed<Self>>
f to them. Read moreSource§fn iter_children<T>(
&self,
f: impl FnOnce(&mut dyn Iterator<Item = &Self>) -> T,
) -> T
fn iter_children<T>( &self, f: impl FnOnce(&mut dyn Iterator<Item = &Self>) -> T, ) -> T
Source§fn children_count(&self) -> usize
fn children_count(&self) -> usize
Source§impl<'a> NodeContainer<'a, Expression> for Expression
impl<'a> NodeContainer<'a, Expression> for Expression
Source§fn apply_elements<F: FnMut(&'a Self) -> VortexResult<TraversalOrder>>(
&'a self,
f: F,
) -> VortexResult<TraversalOrder>
fn apply_elements<F: FnMut(&'a Self) -> VortexResult<TraversalOrder>>( &'a self, f: F, ) -> VortexResult<TraversalOrder>
f to all elements of the container, accepting them by referenceSource§fn map_elements<F: FnMut(Self) -> VortexResult<Transformed<Self>>>(
self,
f: F,
) -> VortexResult<Transformed<Self>>
fn map_elements<F: FnMut(Self) -> VortexResult<Transformed<Self>>>( self, f: F, ) -> VortexResult<Transformed<Self>>
f.Source§impl PartialEq for Expression
impl PartialEq for Expression
Source§impl VortexExprExt for Expression
impl VortexExprExt for Expression
Source§fn field_references(&self) -> HashSet<FieldName>
fn field_references(&self) -> HashSet<FieldName>
impl Eq for Expression
impl StructuralPartialEq for Expression
Auto Trait Implementations§
impl Freeze for Expression
impl !RefUnwindSafe for Expression
impl Send for Expression
impl Sync for Expression
impl Unpin for Expression
impl !UnwindSafe for Expression
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
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key and return true if they are equal.Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<T> FmtForward for T
impl<T> FmtForward for T
Source§fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
self to use its Binary implementation when Debug-formatted.Source§fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
self to use its Display implementation when
Debug-formatted.Source§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
self to use its LowerExp implementation when
Debug-formatted.Source§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
self to use its LowerHex implementation when
Debug-formatted.Source§fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
self to use its Octal implementation when Debug-formatted.Source§fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
self to use its Pointer implementation when
Debug-formatted.Source§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
self to use its UpperExp implementation when
Debug-formatted.Source§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
self to use its UpperHex implementation when
Debug-formatted.Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§impl<T> NodeExt for Twhere
T: Node,
impl<T> NodeExt for Twhere
T: Node,
Source§fn rewrite<R: NodeRewriter<NodeTy = Self>>(
self,
rewriter: &mut R,
) -> VortexResult<Transformed<Self>>
fn rewrite<R: NodeRewriter<NodeTy = Self>>( self, rewriter: &mut R, ) -> VortexResult<Transformed<Self>>
Source§fn accept<'a, V: NodeVisitor<'a, NodeTy = Self>>(
&'a self,
visitor: &mut V,
) -> VortexResult<TraversalOrder>
fn accept<'a, V: NodeVisitor<'a, NodeTy = Self>>( &'a self, visitor: &mut V, ) -> VortexResult<TraversalOrder>
Source§fn transform_down<F: FnMut(Self) -> VortexResult<Transformed<Self>>>(
self,
f: F,
) -> VortexResult<Transformed<Self>>
fn transform_down<F: FnMut(Self) -> VortexResult<Transformed<Self>>>( self, f: F, ) -> VortexResult<Transformed<Self>>
fn transform<F, G>(self, down: F, up: G) -> VortexResult<Transformed<Self>>where
F: FnMut(Self) -> VortexResult<Transformed<Self>>,
G: FnMut(Self) -> VortexResult<Transformed<Self>>,
Source§fn transform_up<F: FnMut(Self) -> VortexResult<Transformed<Self>>>(
self,
f: F,
) -> VortexResult<Transformed<Self>>
fn transform_up<F: FnMut(Self) -> VortexResult<Transformed<Self>>>( self, f: F, ) -> VortexResult<Transformed<Self>>
Source§fn fold_context<R, F: NodeFolderContext<NodeTy = Self, Result = R>>(
self,
ctx: &F::Context,
folder: &mut F,
) -> VortexResult<FoldUp<R>>
fn fold_context<R, F: NodeFolderContext<NodeTy = Self, Result = R>>( self, ctx: &F::Context, folder: &mut F, ) -> VortexResult<FoldUp<R>>
NodeFolderContext to the Node tree, with an initial Context.Source§fn fold<R, F: NodeFolder<NodeTy = Self, Result = R>>(
self,
folder: &mut F,
) -> VortexResult<FoldUp<R>>
fn fold<R, F: NodeFolder<NodeTy = Self, Result = R>>( self, folder: &mut F, ) -> VortexResult<FoldUp<R>>
NodeFolder to the Node treeSource§impl<T> Paint for Twhere
T: ?Sized,
impl<T> Paint for Twhere
T: ?Sized,
Source§fn fg(&self, value: Color) -> Painted<&T>
fn fg(&self, value: Color) -> Painted<&T>
Returns a styled value derived from self with the foreground set to
value.
This method should be used rarely. Instead, prefer to use color-specific
builder methods like red() and
green(), which have the same functionality but are
pithier.
§Example
Set foreground color to white using fg():
use yansi::{Paint, Color};
painted.fg(Color::White);Set foreground color to white using white().
use yansi::Paint;
painted.white();Source§fn bright_black(&self) -> Painted<&T>
fn bright_black(&self) -> Painted<&T>
Source§fn bright_red(&self) -> Painted<&T>
fn bright_red(&self) -> Painted<&T>
Source§fn bright_green(&self) -> Painted<&T>
fn bright_green(&self) -> Painted<&T>
Source§fn bright_yellow(&self) -> Painted<&T>
fn bright_yellow(&self) -> Painted<&T>
Source§fn bright_blue(&self) -> Painted<&T>
fn bright_blue(&self) -> Painted<&T>
Source§fn bright_magenta(&self) -> Painted<&T>
fn bright_magenta(&self) -> Painted<&T>
Source§fn bright_cyan(&self) -> Painted<&T>
fn bright_cyan(&self) -> Painted<&T>
Source§fn bright_white(&self) -> Painted<&T>
fn bright_white(&self) -> Painted<&T>
Source§fn bg(&self, value: Color) -> Painted<&T>
fn bg(&self, value: Color) -> Painted<&T>
Returns a styled value derived from self with the background set to
value.
This method should be used rarely. Instead, prefer to use color-specific
builder methods like on_red() and
on_green(), which have the same functionality but
are pithier.
§Example
Set background color to red using fg():
use yansi::{Paint, Color};
painted.bg(Color::Red);Set background color to red using on_red().
use yansi::Paint;
painted.on_red();Source§fn on_primary(&self) -> Painted<&T>
fn on_primary(&self) -> Painted<&T>
Source§fn on_magenta(&self) -> Painted<&T>
fn on_magenta(&self) -> Painted<&T>
Source§fn on_bright_black(&self) -> Painted<&T>
fn on_bright_black(&self) -> Painted<&T>
Source§fn on_bright_red(&self) -> Painted<&T>
fn on_bright_red(&self) -> Painted<&T>
Source§fn on_bright_green(&self) -> Painted<&T>
fn on_bright_green(&self) -> Painted<&T>
Source§fn on_bright_yellow(&self) -> Painted<&T>
fn on_bright_yellow(&self) -> Painted<&T>
Source§fn on_bright_blue(&self) -> Painted<&T>
fn on_bright_blue(&self) -> Painted<&T>
Source§fn on_bright_magenta(&self) -> Painted<&T>
fn on_bright_magenta(&self) -> Painted<&T>
Source§fn on_bright_cyan(&self) -> Painted<&T>
fn on_bright_cyan(&self) -> Painted<&T>
Source§fn on_bright_white(&self) -> Painted<&T>
fn on_bright_white(&self) -> Painted<&T>
Source§fn attr(&self, value: Attribute) -> Painted<&T>
fn attr(&self, value: Attribute) -> Painted<&T>
Enables the styling Attribute value.
This method should be used rarely. Instead, prefer to use
attribute-specific builder methods like bold() and
underline(), which have the same functionality
but are pithier.
§Example
Make text bold using attr():
use yansi::{Paint, Attribute};
painted.attr(Attribute::Bold);Make text bold using using bold().
use yansi::Paint;
painted.bold();Source§fn rapid_blink(&self) -> Painted<&T>
fn rapid_blink(&self) -> Painted<&T>
Source§fn quirk(&self, value: Quirk) -> Painted<&T>
fn quirk(&self, value: Quirk) -> Painted<&T>
Enables the yansi Quirk value.
This method should be used rarely. Instead, prefer to use quirk-specific
builder methods like mask() and
wrap(), which have the same functionality but are
pithier.
§Example
Enable wrapping using .quirk():
use yansi::{Paint, Quirk};
painted.quirk(Quirk::Wrap);Enable wrapping using wrap().
use yansi::Paint;
painted.wrap();Source§fn clear(&self) -> Painted<&T>
👎Deprecated since 1.0.1: renamed to resetting() due to conflicts with Vec::clear().
The clear() method will be removed in a future release.
fn clear(&self) -> Painted<&T>
resetting() due to conflicts with Vec::clear().
The clear() method will be removed in a future release.Source§fn whenever(&self, value: Condition) -> Painted<&T>
fn whenever(&self, value: Condition) -> Painted<&T>
Conditionally enable styling based on whether the Condition value
applies. Replaces any previous condition.
See the crate level docs for more details.
§Example
Enable styling painted only when both stdout and stderr are TTYs:
use yansi::{Paint, Condition};
painted.red().on_yellow().whenever(Condition::STDOUTERR_ARE_TTY);Source§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
Source§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
Source§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
self and passes that borrow into the pipe function. Read moreSource§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
self and passes that borrow into the pipe function. Read moreSource§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
Source§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R,
) -> R
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
Source§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
self, then passes self.as_ref() into the pipe function.Source§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
self, then passes self.as_mut() into the pipe
function.Source§fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
self, then passes self.deref() into the pipe function.Source§impl<T> SessionVar for T
impl<T> SessionVar for T
Source§impl<T> Tap for T
impl<T> Tap for T
Source§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Borrow<B> of a value. Read moreSource§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
BorrowMut<B> of a value. Read moreSource§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
AsRef<R> view of a value. Read moreSource§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
AsMut<R> view of a value. Read moreSource§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Deref::Target of a value. Read moreSource§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Deref::Target of a value. Read moreSource§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
.tap() only in debug builds, and is erased in release builds.Source§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
.tap_mut() only in debug builds, and is erased in release
builds.Source§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
.tap_borrow() only in debug builds, and is erased in release
builds.Source§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
.tap_borrow_mut() only in debug builds, and is erased in release
builds.Source§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
.tap_ref() only in debug builds, and is erased in release
builds.Source§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
.tap_ref_mut() only in debug builds, and is erased in release
builds.Source§fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
.tap_deref() only in debug builds, and is erased in release
builds.