2021-11-29 06:50:57 +00:00
|
|
|
use std::{cmp::Ordering, fmt};
|
2021-11-23 08:14:40 +00:00
|
|
|
|
2021-12-21 18:32:09 +00:00
|
|
|
use crate::{ast::Operator, ShellError, Span, Value};
|
2021-11-23 08:14:40 +00:00
|
|
|
|
|
|
|
// Trait definition for a custom value
|
|
|
|
#[typetag::serde(tag = "type")]
|
|
|
|
pub trait CustomValue: fmt::Debug + Send + Sync {
|
|
|
|
fn clone_value(&self, span: Span) -> Value;
|
|
|
|
|
2021-12-21 18:32:09 +00:00
|
|
|
//fn category(&self) -> Category;
|
2021-11-28 19:35:02 +00:00
|
|
|
|
2021-11-23 08:14:40 +00:00
|
|
|
// 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<Value, ShellError>;
|
|
|
|
|
|
|
|
// 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
|
2021-12-21 18:32:09 +00:00
|
|
|
fn follow_path_int(&self, _count: usize, span: Span) -> Result<Value, ShellError> {
|
|
|
|
Err(ShellError::IncompatiblePathAccess(
|
2022-04-20 04:58:21 +00:00
|
|
|
format!("{} doesn't support path access", self.value_string()),
|
2021-12-21 18:32:09 +00:00
|
|
|
span,
|
|
|
|
))
|
|
|
|
}
|
|
|
|
|
|
|
|
fn follow_path_string(&self, _column_name: String, span: Span) -> Result<Value, ShellError> {
|
|
|
|
Err(ShellError::IncompatiblePathAccess(
|
2022-04-20 04:58:21 +00:00
|
|
|
format!("{} doesn't support path access", self.value_string()),
|
2021-12-21 18:32:09 +00:00
|
|
|
span,
|
|
|
|
))
|
|
|
|
}
|
2021-11-23 08:14:40 +00:00
|
|
|
|
2021-11-29 06:50:57 +00:00
|
|
|
// ordering with other value
|
2021-12-06 04:09:49 +00:00
|
|
|
fn partial_cmp(&self, _other: &Value) -> Option<Ordering> {
|
|
|
|
None
|
|
|
|
}
|
2021-11-29 06:50:57 +00:00
|
|
|
|
2021-11-23 08:14:40 +00:00
|
|
|
// 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<Value, ShellError> {
|
|
|
|
Err(ShellError::UnsupportedOperator(operator, op))
|
|
|
|
}
|
|
|
|
}
|