use std::{cmp::Ordering, fmt}; use crate::{ast::Operator, ShellError, Span, Value}; // Trait definition for a custom value #[typetag::serde(tag = "type")] pub trait CustomValue: fmt::Debug + Send + Sync { fn clone_value(&self, span: Span) -> Value; //fn category(&self) -> Category; // Define string representation of the custom value fn value_string(&self) -> String; // Converts the custom value to a base nushell value // This is used to represent the custom value using the table representations // That already exist in nushell fn to_base_value(&self, span: Span) -> Result; // Json representation of custom value fn to_json(&self) -> nu_json::Value { nu_json::Value::Null } // Any representation used to downcast object to its original type fn as_any(&self) -> &dyn std::any::Any; // Follow cell path functions fn follow_path_int(&self, _count: usize, span: Span) -> Result { Err(ShellError::IncompatiblePathAccess( format!("{} doesn't support path access", self.value_string()), span, )) } fn follow_path_string(&self, _column_name: String, span: Span) -> Result { Err(ShellError::IncompatiblePathAccess( format!("{} doesn't support path access", self.value_string()), span, )) } // ordering with other value fn partial_cmp(&self, _other: &Value) -> Option { None } // Definition of an operation between the object that implements the trait // and another Value. // The Operator enum is used to indicate the expected operation fn operation( &self, _lhs_span: Span, operator: Operator, op: Span, _right: &Value, ) -> Result { Err(ShellError::UnsupportedOperator(operator, op)) } }