forked from extern/nushell
e4226def16
This commit extracts five new crates: - nu-source, which contains the core source-code handling logic in Nu, including Text, Span, and also the pretty.rs-based debug logic - nu-parser, which is the parser and expander logic - nu-protocol, which is the bulk of the types and basic conveniences used by plugins - nu-errors, which contains ShellError, ParseError and error handling conveniences - nu-textview, which is the textview plugin extracted into a crate One of the major consequences of this refactor is that it's no longer possible to `impl X for Spanned<Y>` outside of the `nu-source` crate, so a lot of types became more concrete (Value became a concrete type instead of Spanned<Value>, for example). This also turned a number of inherent methods in the main nu crate into plain functions (impl Value {} became a bunch of functions in the `value` namespace in `crate::data::value`).
93 lines
2.8 KiB
Rust
93 lines
2.8 KiB
Rust
use crate::prelude::*;
|
|
use log::trace;
|
|
use nu_protocol::{Primitive, SpannedTypeName, UntaggedValue, Value};
|
|
use nu_errors::{ShellError, CoerceInto};
|
|
use nu_source::Tagged;
|
|
|
|
pub trait ExtractType: Sized {
|
|
fn extract(value: &Value) -> Result<Self, ShellError>;
|
|
}
|
|
|
|
impl<T: ExtractType> ExtractType for Tagged<T> {
|
|
fn extract(value: &Value) -> Result<Tagged<T>, ShellError> {
|
|
let name = std::any::type_name::<T>();
|
|
trace!("<Tagged> Extracting {:?} for Tagged<{}>", value, name);
|
|
|
|
Ok(T::extract(value)?.tagged(value.tag()))
|
|
}
|
|
}
|
|
|
|
impl ExtractType for bool {
|
|
fn extract(value: &Value) -> Result<bool, ShellError> {
|
|
trace!("Extracting {:?} for bool", value);
|
|
|
|
match &value {
|
|
Value {
|
|
value: UntaggedValue::Primitive(Primitive::Boolean(b)),
|
|
..
|
|
} => Ok(*b),
|
|
Value {
|
|
value: UntaggedValue::Primitive(Primitive::Nothing),
|
|
..
|
|
} => Ok(false),
|
|
other => Err(ShellError::type_error("Boolean", other.spanned_type_name())),
|
|
}
|
|
}
|
|
}
|
|
|
|
impl ExtractType for std::path::PathBuf {
|
|
fn extract(value: &Value) -> Result<std::path::PathBuf, ShellError> {
|
|
trace!("Extracting {:?} for PathBuf", value);
|
|
|
|
match &value {
|
|
Value {
|
|
value: UntaggedValue::Primitive(Primitive::Path(p)),
|
|
..
|
|
} => Ok(p.clone()),
|
|
other => Err(ShellError::type_error("Path", other.spanned_type_name())),
|
|
}
|
|
}
|
|
}
|
|
|
|
impl ExtractType for i64 {
|
|
fn extract(value: &Value) -> Result<i64, ShellError> {
|
|
trace!("Extracting {:?} for i64", value);
|
|
|
|
match &value {
|
|
&Value {
|
|
value: UntaggedValue::Primitive(Primitive::Int(int)),
|
|
..
|
|
} => Ok(int.tagged(&value.tag).coerce_into("converting to i64")?),
|
|
other => Err(ShellError::type_error("Integer", other.spanned_type_name())),
|
|
}
|
|
}
|
|
}
|
|
|
|
impl ExtractType for u64 {
|
|
fn extract(value: &Value) -> Result<u64, ShellError> {
|
|
trace!("Extracting {:?} for u64", value);
|
|
|
|
match &value {
|
|
&Value {
|
|
value: UntaggedValue::Primitive(Primitive::Int(int)),
|
|
..
|
|
} => Ok(int.tagged(&value.tag).coerce_into("converting to u64")?),
|
|
other => Err(ShellError::type_error("Integer", other.spanned_type_name())),
|
|
}
|
|
}
|
|
}
|
|
|
|
impl ExtractType for String {
|
|
fn extract(value: &Value) -> Result<String, ShellError> {
|
|
trace!("Extracting {:?} for String", value);
|
|
|
|
match value {
|
|
Value {
|
|
value: UntaggedValue::Primitive(Primitive::String(string)),
|
|
..
|
|
} => Ok(string.clone()),
|
|
other => Err(ShellError::type_error("String", other.spanned_type_name())),
|
|
}
|
|
}
|
|
}
|