use crate::dataframe::values::NuExpression; use nu_engine::CallExt; use nu_protocol::{ ast::Call, engine::{Command, EngineState, Stack}, Category, Example, PipelineData, ShellError, Signature, Span, SyntaxShape, Type, Value, }; #[derive(Clone)] pub struct ExprLit; impl Command for ExprLit { fn name(&self) -> &str { "dfr lit" } fn usage(&self) -> &str { "Creates a literal expression." } fn signature(&self) -> Signature { Signature::build(self.name()) .required( "literal", SyntaxShape::Any, "literal to construct the expression", ) .input_type(Type::Any) .output_type(Type::Custom("expression".into())) .category(Category::Custom("expression".into())) } fn examples(&self) -> Vec { vec![Example { description: "Created a literal expression and converts it to a nu object", example: "dfr lit 2 | dfr into-nu", result: Some(Value::Record { cols: vec!["expr".into(), "value".into()], vals: vec![Value::test_string("literal"), Value::test_string("2i64")], span: Span::test_data(), }), }] } fn search_terms(&self) -> Vec<&str> { vec!["string", "literal", "expression"] } fn run( &self, engine_state: &EngineState, stack: &mut Stack, call: &Call, _input: PipelineData, ) -> Result { let literal: Value = call.req(engine_state, stack, 0)?; let expr = NuExpression::try_from_value(literal)?; Ok(PipelineData::Value( NuExpression::into_value(expr, call.head), None, )) } } #[cfg(test)] mod test { use super::super::super::test_dataframe::test_dataframe; use super::*; use crate::dataframe::expressions::as_nu::ExprAsNu; #[test] fn test_examples() { test_dataframe(vec![Box::new(ExprLit {}), Box::new(ExprAsNu {})]) } }