mirror of
https://github.com/nushell/nushell
synced 2025-01-07 10:49:03 +00:00
c6fe58467b
* Change alias shape inference to proposal of RFC#4 * Remove commented code * Fix typo * Change comment to be more informative * Make match statement to lookup in table * Remove resolved question https://github.com/nushell/nushell/pull/2685#discussion_r509832054 * Pick ...or_insert_dependency functions into pieces Previously there was get_shape_of_expr_or_insert dependency, now there is get_shape_of_expr and get_shape_of_expr_or_insert_dependency 2 new functions have been added: get_result_shape_of_math_expr and get_result_shape_of_math_expr_or_insert_dependency * Remove flattening of deep binary expressions Previously deep binary expressions have been flattened through the insertion of fake vars. This logic was quite complicated. Now if a variable depends on the result shape of a binary expression and the result shape can't be computed, the variable simply depends on the whole binary. * Change Expression::Variable(Variable::It(...)) to Expression::Variable(...) * Simplify get_result_shapes_in_math_expr * Simplify infer_shapes_in_binary_expr * Clarify comment * Clarify comment * Fix clippy lint * Move check for real var into checked_insert * Remove comment * Rename var
57 lines
1.9 KiB
Rust
57 lines
1.9 KiB
Rust
use nu_source::{b, DebugDocBuilder, PrettyDebug};
|
|
use serde::{Deserialize, Serialize};
|
|
|
|
/// The syntactic shapes that values must match to be passed into a command. You can think of this as the type-checking that occurs when you call a function.
|
|
#[derive(Debug, Copy, Clone, Serialize, Deserialize, PartialEq, Eq, Hash)]
|
|
pub enum SyntaxShape {
|
|
/// Any syntactic form is allowed
|
|
Any,
|
|
/// Strings and string-like bare words are allowed
|
|
String,
|
|
/// A dotted path to navigate the table
|
|
ColumnPath,
|
|
/// A dotted path to navigate the table (including variable)
|
|
FullColumnPath,
|
|
/// Only a numeric (integer or decimal) value is allowed
|
|
Number,
|
|
/// A range is allowed (eg, `1..3`)
|
|
Range,
|
|
/// Only an integer value is allowed
|
|
Int,
|
|
/// A filepath is allowed
|
|
Path,
|
|
/// A glob pattern is allowed, eg `foo*`
|
|
Pattern,
|
|
/// A block is allowed, eg `{start this thing}`
|
|
Block,
|
|
/// A table is allowed, eg `[first second]`
|
|
Table,
|
|
/// A unit value is allowed, eg `10kb`
|
|
Unit,
|
|
/// An operator
|
|
Operator,
|
|
/// A math expression, eg `foo > 1`
|
|
Math,
|
|
}
|
|
|
|
impl PrettyDebug for SyntaxShape {
|
|
/// Prepare SyntaxShape for pretty-printing
|
|
fn pretty(&self) -> DebugDocBuilder {
|
|
b::kind(match self {
|
|
SyntaxShape::Any => "any",
|
|
SyntaxShape::String => "string",
|
|
SyntaxShape::FullColumnPath => "column path (with variable)",
|
|
SyntaxShape::ColumnPath => "column path",
|
|
SyntaxShape::Number => "number",
|
|
SyntaxShape::Range => "range",
|
|
SyntaxShape::Int => "integer",
|
|
SyntaxShape::Path => "file path",
|
|
SyntaxShape::Pattern => "pattern",
|
|
SyntaxShape::Block => "block",
|
|
SyntaxShape::Table => "table",
|
|
SyntaxShape::Unit => "unit",
|
|
SyntaxShape::Operator => "operator",
|
|
SyntaxShape::Math => "condition",
|
|
})
|
|
}
|
|
}
|