vortex_expr/transform/
simplify.rs1use vortex_error::VortexResult;
2
3use crate::transform::match_between::find_between;
4use crate::traversal::{MutNodeVisitor, Node, TransformResult};
6use crate::{ExprRef, GetItem, Pack};
7
8pub fn simplify(e: ExprRef) -> VortexResult<ExprRef> {
12 let mut folder = Simplify;
13 let e = e.transform(&mut folder).map(|e| e.into_inner())?;
14 Ok(find_between(e.clone()))
15}
16
17struct Simplify;
18
19impl MutNodeVisitor for Simplify {
20 type NodeTy = ExprRef;
21
22 fn visit_up(&mut self, node: Self::NodeTy) -> VortexResult<TransformResult<ExprRef>> {
23 if let Some(get_item) = node.as_any().downcast_ref::<GetItem>() {
25 if let Some(pack) = get_item.child().as_any().downcast_ref::<Pack>() {
26 let expr = pack.field(get_item.field())?;
27 return Ok(TransformResult::yes(expr));
28 }
29 }
30 Ok(TransformResult::no(node))
31 }
32}
33
34#[cfg(test)]
35mod tests {
36 use vortex_dtype::Nullability::NonNullable;
37
38 use crate::transform::simplify::simplify;
39 use crate::{get_item, lit, pack};
40
41 #[test]
42 fn test_simplify() {
43 let e = get_item("b", pack([("a", lit(1)), ("b", lit(2))], NonNullable));
44 let e = simplify(e).unwrap();
45 assert_eq!(&e, &lit(2));
46 }
47}