mirror of
https://github.com/nushell/nushell.git
synced 2025-01-11 08:48:23 +01:00
Remove unused Index(Mut)
impls on AST types (#11903)
# Description Both `Block` and `Pipeline` had `Index`/`IndexMut` implementations to access their elements, that are currently unused. Explicit helpers or iteration would generally be preferred anyways but in the current state the inner containers are `pub` and are liberally used. (Sometimes with potentially panicking indexing or also iteration) As it is potentially unclear what the meaning of the element from a block or pipeline queried by a usize is, let's remove it entirely until we come up with a better API. # User-Facing Changes None Plugin authors shouldn't dig into AST internals
This commit is contained in:
parent
b23fe30530
commit
6e590fe0a2
@ -73,7 +73,7 @@ fn test_int(
|
|||||||
} else {
|
} else {
|
||||||
assert!(err.is_none(), "{test_tag}: unexpected error {err:#?}");
|
assert!(err.is_none(), "{test_tag}: unexpected error {err:#?}");
|
||||||
assert_eq!(block.len(), 1, "{test_tag}: result block length > 1");
|
assert_eq!(block.len(), 1, "{test_tag}: result block length > 1");
|
||||||
let expressions = &block[0];
|
let expressions = &block.pipelines[0];
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
expressions.len(),
|
expressions.len(),
|
||||||
1,
|
1,
|
||||||
@ -84,7 +84,7 @@ fn test_int(
|
|||||||
Expression {
|
Expression {
|
||||||
expr: observed_val, ..
|
expr: observed_val, ..
|
||||||
},
|
},
|
||||||
) = &expressions[0]
|
) = &expressions.elements[0]
|
||||||
{
|
{
|
||||||
compare_rhs_binaryOp(test_tag, &expected_val, observed_val);
|
compare_rhs_binaryOp(test_tag, &expected_val, observed_val);
|
||||||
}
|
}
|
||||||
@ -287,10 +287,10 @@ pub fn parse_int() {
|
|||||||
|
|
||||||
assert!(working_set.parse_errors.is_empty());
|
assert!(working_set.parse_errors.is_empty());
|
||||||
assert_eq!(block.len(), 1);
|
assert_eq!(block.len(), 1);
|
||||||
let expressions = &block[0];
|
let expressions = &block.pipelines[0];
|
||||||
assert_eq!(expressions.len(), 1);
|
assert_eq!(expressions.len(), 1);
|
||||||
assert!(matches!(
|
assert!(matches!(
|
||||||
expressions[0],
|
expressions.elements[0],
|
||||||
PipelineElement::Expression(
|
PipelineElement::Expression(
|
||||||
_,
|
_,
|
||||||
Expression {
|
Expression {
|
||||||
@ -310,10 +310,10 @@ pub fn parse_int_with_underscores() {
|
|||||||
|
|
||||||
assert!(working_set.parse_errors.is_empty());
|
assert!(working_set.parse_errors.is_empty());
|
||||||
assert_eq!(block.len(), 1);
|
assert_eq!(block.len(), 1);
|
||||||
let expressions = &block[0];
|
let expressions = &block.pipelines[0];
|
||||||
assert_eq!(expressions.len(), 1);
|
assert_eq!(expressions.len(), 1);
|
||||||
assert!(matches!(
|
assert!(matches!(
|
||||||
expressions[0],
|
expressions.elements[0],
|
||||||
PipelineElement::Expression(
|
PipelineElement::Expression(
|
||||||
_,
|
_,
|
||||||
Expression {
|
Expression {
|
||||||
@ -340,11 +340,11 @@ pub fn parse_cell_path() {
|
|||||||
|
|
||||||
assert!(working_set.parse_errors.is_empty());
|
assert!(working_set.parse_errors.is_empty());
|
||||||
assert_eq!(block.len(), 1);
|
assert_eq!(block.len(), 1);
|
||||||
let expressions = &block[0];
|
let expressions = &block.pipelines[0];
|
||||||
assert_eq!(expressions.len(), 1);
|
assert_eq!(expressions.len(), 1);
|
||||||
|
|
||||||
// hoo boy this pattern matching is a pain
|
// hoo boy this pattern matching is a pain
|
||||||
if let PipelineElement::Expression(_, expr) = &expressions[0] {
|
if let PipelineElement::Expression(_, expr) = &expressions.elements[0] {
|
||||||
if let Expr::FullCellPath(b) = &expr.expr {
|
if let Expr::FullCellPath(b) = &expr.expr {
|
||||||
assert!(matches!(
|
assert!(matches!(
|
||||||
b.head,
|
b.head,
|
||||||
@ -395,11 +395,11 @@ pub fn parse_cell_path_optional() {
|
|||||||
assert!(working_set.parse_errors.is_empty());
|
assert!(working_set.parse_errors.is_empty());
|
||||||
|
|
||||||
assert_eq!(block.len(), 1);
|
assert_eq!(block.len(), 1);
|
||||||
let expressions = &block[0];
|
let expressions = &block.pipelines[0];
|
||||||
assert_eq!(expressions.len(), 1);
|
assert_eq!(expressions.len(), 1);
|
||||||
|
|
||||||
// hoo boy this pattern matching is a pain
|
// hoo boy this pattern matching is a pain
|
||||||
if let PipelineElement::Expression(_, expr) = &expressions[0] {
|
if let PipelineElement::Expression(_, expr) = &expressions.elements[0] {
|
||||||
if let Expr::FullCellPath(b) = &expr.expr {
|
if let Expr::FullCellPath(b) = &expr.expr {
|
||||||
assert!(matches!(
|
assert!(matches!(
|
||||||
b.head,
|
b.head,
|
||||||
@ -442,9 +442,9 @@ pub fn parse_binary_with_hex_format() {
|
|||||||
|
|
||||||
assert!(working_set.parse_errors.is_empty());
|
assert!(working_set.parse_errors.is_empty());
|
||||||
assert_eq!(block.len(), 1);
|
assert_eq!(block.len(), 1);
|
||||||
let expressions = &block[0];
|
let expressions = &block.pipelines[0];
|
||||||
assert_eq!(expressions.len(), 1);
|
assert_eq!(expressions.len(), 1);
|
||||||
if let PipelineElement::Expression(_, expr) = &expressions[0] {
|
if let PipelineElement::Expression(_, expr) = &expressions.elements[0] {
|
||||||
assert_eq!(expr.expr, Expr::Binary(vec![0x13]))
|
assert_eq!(expr.expr, Expr::Binary(vec![0x13]))
|
||||||
} else {
|
} else {
|
||||||
panic!("Not an expression")
|
panic!("Not an expression")
|
||||||
@ -460,9 +460,9 @@ pub fn parse_binary_with_incomplete_hex_format() {
|
|||||||
|
|
||||||
assert!(working_set.parse_errors.is_empty());
|
assert!(working_set.parse_errors.is_empty());
|
||||||
assert_eq!(block.len(), 1);
|
assert_eq!(block.len(), 1);
|
||||||
let expressions = &block[0];
|
let expressions = &block.pipelines[0];
|
||||||
assert_eq!(expressions.len(), 1);
|
assert_eq!(expressions.len(), 1);
|
||||||
if let PipelineElement::Expression(_, expr) = &expressions[0] {
|
if let PipelineElement::Expression(_, expr) = &expressions.elements[0] {
|
||||||
assert_eq!(expr.expr, Expr::Binary(vec![0x03]))
|
assert_eq!(expr.expr, Expr::Binary(vec![0x03]))
|
||||||
} else {
|
} else {
|
||||||
panic!("Not an expression")
|
panic!("Not an expression")
|
||||||
@ -478,9 +478,9 @@ pub fn parse_binary_with_binary_format() {
|
|||||||
|
|
||||||
assert!(working_set.parse_errors.is_empty());
|
assert!(working_set.parse_errors.is_empty());
|
||||||
assert_eq!(block.len(), 1);
|
assert_eq!(block.len(), 1);
|
||||||
let expressions = &block[0];
|
let expressions = &block.pipelines[0];
|
||||||
assert_eq!(expressions.len(), 1);
|
assert_eq!(expressions.len(), 1);
|
||||||
if let PipelineElement::Expression(_, expr) = &expressions[0] {
|
if let PipelineElement::Expression(_, expr) = &expressions.elements[0] {
|
||||||
assert_eq!(expr.expr, Expr::Binary(vec![0b10101000]))
|
assert_eq!(expr.expr, Expr::Binary(vec![0b10101000]))
|
||||||
} else {
|
} else {
|
||||||
panic!("Not an expression")
|
panic!("Not an expression")
|
||||||
@ -496,9 +496,9 @@ pub fn parse_binary_with_incomplete_binary_format() {
|
|||||||
|
|
||||||
assert!(working_set.parse_errors.is_empty());
|
assert!(working_set.parse_errors.is_empty());
|
||||||
assert_eq!(block.len(), 1);
|
assert_eq!(block.len(), 1);
|
||||||
let expressions = &block[0];
|
let expressions = &block.pipelines[0];
|
||||||
assert_eq!(expressions.len(), 1);
|
assert_eq!(expressions.len(), 1);
|
||||||
if let PipelineElement::Expression(_, expr) = &expressions[0] {
|
if let PipelineElement::Expression(_, expr) = &expressions.elements[0] {
|
||||||
assert_eq!(expr.expr, Expr::Binary(vec![0b00000010]))
|
assert_eq!(expr.expr, Expr::Binary(vec![0b00000010]))
|
||||||
} else {
|
} else {
|
||||||
panic!("Not an expression")
|
panic!("Not an expression")
|
||||||
@ -514,9 +514,9 @@ pub fn parse_binary_with_octal_format() {
|
|||||||
|
|
||||||
assert!(working_set.parse_errors.is_empty());
|
assert!(working_set.parse_errors.is_empty());
|
||||||
assert_eq!(block.len(), 1);
|
assert_eq!(block.len(), 1);
|
||||||
let expressions = &block[0];
|
let expressions = &block.pipelines[0];
|
||||||
assert_eq!(expressions.len(), 1);
|
assert_eq!(expressions.len(), 1);
|
||||||
if let PipelineElement::Expression(_, expr) = &expressions[0] {
|
if let PipelineElement::Expression(_, expr) = &expressions.elements[0] {
|
||||||
assert_eq!(expr.expr, Expr::Binary(vec![0o250]))
|
assert_eq!(expr.expr, Expr::Binary(vec![0o250]))
|
||||||
} else {
|
} else {
|
||||||
panic!("Not an expression")
|
panic!("Not an expression")
|
||||||
@ -532,9 +532,9 @@ pub fn parse_binary_with_incomplete_octal_format() {
|
|||||||
|
|
||||||
assert!(working_set.parse_errors.is_empty());
|
assert!(working_set.parse_errors.is_empty());
|
||||||
assert_eq!(block.len(), 1);
|
assert_eq!(block.len(), 1);
|
||||||
let expressions = &block[0];
|
let expressions = &block.pipelines[0];
|
||||||
assert_eq!(expressions.len(), 1);
|
assert_eq!(expressions.len(), 1);
|
||||||
if let PipelineElement::Expression(_, expr) = &expressions[0] {
|
if let PipelineElement::Expression(_, expr) = &expressions.elements[0] {
|
||||||
assert_eq!(expr.expr, Expr::Binary(vec![0o2]))
|
assert_eq!(expr.expr, Expr::Binary(vec![0o2]))
|
||||||
} else {
|
} else {
|
||||||
panic!("Not an expression")
|
panic!("Not an expression")
|
||||||
@ -550,9 +550,9 @@ pub fn parse_binary_with_invalid_octal_format() {
|
|||||||
|
|
||||||
assert!(working_set.parse_errors.is_empty());
|
assert!(working_set.parse_errors.is_empty());
|
||||||
assert_eq!(block.len(), 1);
|
assert_eq!(block.len(), 1);
|
||||||
let expressions = &block[0];
|
let expressions = &block.pipelines[0];
|
||||||
assert_eq!(expressions.len(), 1);
|
assert_eq!(expressions.len(), 1);
|
||||||
if let PipelineElement::Expression(_, expr) = &expressions[0] {
|
if let PipelineElement::Expression(_, expr) = &expressions.elements[0] {
|
||||||
assert!(!matches!(&expr.expr, Expr::Binary(_)))
|
assert!(!matches!(&expr.expr, Expr::Binary(_)))
|
||||||
} else {
|
} else {
|
||||||
panic!("Not an expression")
|
panic!("Not an expression")
|
||||||
@ -570,9 +570,9 @@ pub fn parse_binary_with_multi_byte_char() {
|
|||||||
|
|
||||||
assert!(working_set.parse_errors.is_empty());
|
assert!(working_set.parse_errors.is_empty());
|
||||||
assert_eq!(block.len(), 1);
|
assert_eq!(block.len(), 1);
|
||||||
let expressions = &block[0];
|
let expressions = &block.pipelines[0];
|
||||||
assert_eq!(expressions.len(), 1);
|
assert_eq!(expressions.len(), 1);
|
||||||
if let PipelineElement::Expression(_, expr) = &expressions[0] {
|
if let PipelineElement::Expression(_, expr) = &expressions.elements[0] {
|
||||||
assert!(!matches!(&expr.expr, Expr::Binary(_)))
|
assert!(!matches!(&expr.expr, Expr::Binary(_)))
|
||||||
} else {
|
} else {
|
||||||
panic!("Not an expression")
|
panic!("Not an expression")
|
||||||
@ -592,7 +592,7 @@ pub fn parse_call() {
|
|||||||
assert!(working_set.parse_errors.is_empty());
|
assert!(working_set.parse_errors.is_empty());
|
||||||
assert_eq!(block.len(), 1);
|
assert_eq!(block.len(), 1);
|
||||||
|
|
||||||
let expressions = &block[0];
|
let expressions = &block.pipelines[0];
|
||||||
assert_eq!(expressions.len(), 1);
|
assert_eq!(expressions.len(), 1);
|
||||||
|
|
||||||
if let PipelineElement::Expression(
|
if let PipelineElement::Expression(
|
||||||
@ -601,7 +601,7 @@ pub fn parse_call() {
|
|||||||
expr: Expr::Call(call),
|
expr: Expr::Call(call),
|
||||||
..
|
..
|
||||||
},
|
},
|
||||||
) = &expressions[0]
|
) = &expressions.elements[0]
|
||||||
{
|
{
|
||||||
assert_eq!(call.decl_id, 0);
|
assert_eq!(call.decl_id, 0);
|
||||||
}
|
}
|
||||||
@ -651,7 +651,7 @@ pub fn parse_call_short_flag_batch_arg_allowed() {
|
|||||||
|
|
||||||
assert!(working_set.parse_errors.is_empty());
|
assert!(working_set.parse_errors.is_empty());
|
||||||
assert_eq!(block.len(), 1);
|
assert_eq!(block.len(), 1);
|
||||||
let expressions = &block[0];
|
let expressions = &block.pipelines[0];
|
||||||
assert_eq!(expressions.len(), 1);
|
assert_eq!(expressions.len(), 1);
|
||||||
|
|
||||||
if let PipelineElement::Expression(
|
if let PipelineElement::Expression(
|
||||||
@ -660,7 +660,7 @@ pub fn parse_call_short_flag_batch_arg_allowed() {
|
|||||||
expr: Expr::Call(call),
|
expr: Expr::Call(call),
|
||||||
..
|
..
|
||||||
},
|
},
|
||||||
) = &expressions[0]
|
) = &expressions.elements[0]
|
||||||
{
|
{
|
||||||
assert_eq!(call.decl_id, 0);
|
assert_eq!(call.decl_id, 0);
|
||||||
assert_eq!(call.arguments.len(), 2);
|
assert_eq!(call.arguments.len(), 2);
|
||||||
@ -768,10 +768,10 @@ fn test_nothing_comparison_eq() {
|
|||||||
assert!(working_set.parse_errors.is_empty());
|
assert!(working_set.parse_errors.is_empty());
|
||||||
assert_eq!(block.len(), 1);
|
assert_eq!(block.len(), 1);
|
||||||
|
|
||||||
let expressions = &block[0];
|
let expressions = &block.pipelines[0];
|
||||||
assert_eq!(expressions.len(), 1);
|
assert_eq!(expressions.len(), 1);
|
||||||
assert!(matches!(
|
assert!(matches!(
|
||||||
&expressions[0],
|
&expressions.elements[0],
|
||||||
PipelineElement::Expression(
|
PipelineElement::Expression(
|
||||||
_,
|
_,
|
||||||
Expression {
|
Expression {
|
||||||
@ -815,10 +815,10 @@ fn test_nothing_comparison_neq() {
|
|||||||
assert!(working_set.parse_errors.is_empty());
|
assert!(working_set.parse_errors.is_empty());
|
||||||
assert_eq!(block.len(), 1);
|
assert_eq!(block.len(), 1);
|
||||||
|
|
||||||
let expressions = &block[0];
|
let expressions = &block.pipelines[0];
|
||||||
assert_eq!(expressions.len(), 1);
|
assert_eq!(expressions.len(), 1);
|
||||||
assert!(matches!(
|
assert!(matches!(
|
||||||
&expressions[0],
|
&expressions.elements[0],
|
||||||
PipelineElement::Expression(
|
PipelineElement::Expression(
|
||||||
_,
|
_,
|
||||||
Expression {
|
Expression {
|
||||||
@ -841,9 +841,9 @@ mod string {
|
|||||||
|
|
||||||
assert!(working_set.parse_errors.is_empty());
|
assert!(working_set.parse_errors.is_empty());
|
||||||
assert_eq!(block.len(), 1);
|
assert_eq!(block.len(), 1);
|
||||||
let expressions = &block[0];
|
let expressions = &block.pipelines[0];
|
||||||
assert_eq!(expressions.len(), 1);
|
assert_eq!(expressions.len(), 1);
|
||||||
if let PipelineElement::Expression(_, expr) = &expressions[0] {
|
if let PipelineElement::Expression(_, expr) = &expressions.elements[0] {
|
||||||
assert_eq!(expr.expr, Expr::String("hello nushell".to_string()))
|
assert_eq!(expr.expr, Expr::String("hello nushell".to_string()))
|
||||||
} else {
|
} else {
|
||||||
panic!("Not an expression")
|
panic!("Not an expression")
|
||||||
@ -865,10 +865,10 @@ mod string {
|
|||||||
assert!(working_set.parse_errors.is_empty());
|
assert!(working_set.parse_errors.is_empty());
|
||||||
assert_eq!(block.len(), 1);
|
assert_eq!(block.len(), 1);
|
||||||
|
|
||||||
let expressions = &block[0];
|
let expressions = &block.pipelines[0];
|
||||||
assert_eq!(expressions.len(), 1);
|
assert_eq!(expressions.len(), 1);
|
||||||
|
|
||||||
if let PipelineElement::Expression(_, expr) = &expressions[0] {
|
if let PipelineElement::Expression(_, expr) = &expressions.elements[0] {
|
||||||
let subexprs: Vec<&Expr> = match expr {
|
let subexprs: Vec<&Expr> = match expr {
|
||||||
Expression {
|
Expression {
|
||||||
expr: Expr::StringInterpolation(expressions),
|
expr: Expr::StringInterpolation(expressions),
|
||||||
@ -897,11 +897,11 @@ mod string {
|
|||||||
assert!(working_set.parse_errors.is_empty());
|
assert!(working_set.parse_errors.is_empty());
|
||||||
|
|
||||||
assert_eq!(block.len(), 1);
|
assert_eq!(block.len(), 1);
|
||||||
let expressions = &block[0];
|
let expressions = &block.pipelines[0];
|
||||||
|
|
||||||
assert_eq!(expressions.len(), 1);
|
assert_eq!(expressions.len(), 1);
|
||||||
|
|
||||||
if let PipelineElement::Expression(_, expr) = &expressions[0] {
|
if let PipelineElement::Expression(_, expr) = &expressions.elements[0] {
|
||||||
let subexprs: Vec<&Expr> = match expr {
|
let subexprs: Vec<&Expr> = match expr {
|
||||||
Expression {
|
Expression {
|
||||||
expr: Expr::StringInterpolation(expressions),
|
expr: Expr::StringInterpolation(expressions),
|
||||||
@ -928,11 +928,11 @@ mod string {
|
|||||||
assert!(working_set.parse_errors.is_empty());
|
assert!(working_set.parse_errors.is_empty());
|
||||||
|
|
||||||
assert_eq!(block.len(), 1);
|
assert_eq!(block.len(), 1);
|
||||||
let expressions = &block[0];
|
let expressions = &block.pipelines[0];
|
||||||
|
|
||||||
assert_eq!(expressions.len(), 1);
|
assert_eq!(expressions.len(), 1);
|
||||||
|
|
||||||
if let PipelineElement::Expression(_, expr) = &expressions[0] {
|
if let PipelineElement::Expression(_, expr) = &expressions.elements[0] {
|
||||||
let subexprs: Vec<&Expr> = match expr {
|
let subexprs: Vec<&Expr> = match expr {
|
||||||
Expression {
|
Expression {
|
||||||
expr: Expr::StringInterpolation(expressions),
|
expr: Expr::StringInterpolation(expressions),
|
||||||
@ -961,11 +961,11 @@ mod string {
|
|||||||
assert!(working_set.parse_errors.is_empty());
|
assert!(working_set.parse_errors.is_empty());
|
||||||
|
|
||||||
assert_eq!(block.len(), 1);
|
assert_eq!(block.len(), 1);
|
||||||
let expressions = &block[0];
|
let expressions = &block.pipelines[0];
|
||||||
|
|
||||||
assert_eq!(expressions.len(), 1);
|
assert_eq!(expressions.len(), 1);
|
||||||
|
|
||||||
if let PipelineElement::Expression(_, expr) = &expressions[0] {
|
if let PipelineElement::Expression(_, expr) = &expressions.elements[0] {
|
||||||
let subexprs: Vec<&Expr> = match expr {
|
let subexprs: Vec<&Expr> = match expr {
|
||||||
Expression {
|
Expression {
|
||||||
expr: Expr::StringInterpolation(expressions),
|
expr: Expr::StringInterpolation(expressions),
|
||||||
@ -1085,7 +1085,7 @@ mod range {
|
|||||||
assert!(working_set.parse_errors.is_empty());
|
assert!(working_set.parse_errors.is_empty());
|
||||||
assert_eq!(block.len(), 1, "{tag}: block length");
|
assert_eq!(block.len(), 1, "{tag}: block length");
|
||||||
|
|
||||||
let expressions = &block[0];
|
let expressions = &block.pipelines[0];
|
||||||
assert_eq!(expressions.len(), 1, "{tag}: expression length");
|
assert_eq!(expressions.len(), 1, "{tag}: expression length");
|
||||||
if let PipelineElement::Expression(
|
if let PipelineElement::Expression(
|
||||||
_,
|
_,
|
||||||
@ -1102,7 +1102,7 @@ mod range {
|
|||||||
),
|
),
|
||||||
..
|
..
|
||||||
},
|
},
|
||||||
) = expressions[0]
|
) = expressions.elements[0]
|
||||||
{
|
{
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
the_inclusion, inclusion,
|
the_inclusion, inclusion,
|
||||||
@ -1144,7 +1144,7 @@ mod range {
|
|||||||
assert!(working_set.parse_errors.is_empty());
|
assert!(working_set.parse_errors.is_empty());
|
||||||
assert_eq!(block.len(), 2, "{tag} block len 2");
|
assert_eq!(block.len(), 2, "{tag} block len 2");
|
||||||
|
|
||||||
let expressions = &block[1];
|
let expressions = &block.pipelines[1];
|
||||||
assert_eq!(expressions.len(), 1, "{tag}: expression length 1");
|
assert_eq!(expressions.len(), 1, "{tag}: expression length 1");
|
||||||
if let PipelineElement::Expression(
|
if let PipelineElement::Expression(
|
||||||
_,
|
_,
|
||||||
@ -1161,7 +1161,7 @@ mod range {
|
|||||||
),
|
),
|
||||||
..
|
..
|
||||||
},
|
},
|
||||||
) = expressions[0]
|
) = expressions.elements[0]
|
||||||
{
|
{
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
the_inclusion, inclusion,
|
the_inclusion, inclusion,
|
||||||
@ -1190,7 +1190,7 @@ mod range {
|
|||||||
assert!(working_set.parse_errors.is_empty());
|
assert!(working_set.parse_errors.is_empty());
|
||||||
assert_eq!(block.len(), 1, "{tag}: block len 1");
|
assert_eq!(block.len(), 1, "{tag}: block len 1");
|
||||||
|
|
||||||
let expressions = &block[0];
|
let expressions = &block.pipelines[0];
|
||||||
assert_eq!(expressions.len(), 1, "{tag}: expression length 1");
|
assert_eq!(expressions.len(), 1, "{tag}: expression length 1");
|
||||||
if let PipelineElement::Expression(
|
if let PipelineElement::Expression(
|
||||||
_,
|
_,
|
||||||
@ -1207,7 +1207,7 @@ mod range {
|
|||||||
),
|
),
|
||||||
..
|
..
|
||||||
},
|
},
|
||||||
) = expressions[0]
|
) = expressions.elements[0]
|
||||||
{
|
{
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
the_inclusion, inclusion,
|
the_inclusion, inclusion,
|
||||||
@ -1236,7 +1236,7 @@ mod range {
|
|||||||
assert!(working_set.parse_errors.is_empty());
|
assert!(working_set.parse_errors.is_empty());
|
||||||
assert_eq!(block.len(), 1, "{tag}: block len 1");
|
assert_eq!(block.len(), 1, "{tag}: block len 1");
|
||||||
|
|
||||||
let expressions = &block[0];
|
let expressions = &block.pipelines[0];
|
||||||
assert_eq!(expressions.len(), 1, "{tag}: expression length 1");
|
assert_eq!(expressions.len(), 1, "{tag}: expression length 1");
|
||||||
if let PipelineElement::Expression(
|
if let PipelineElement::Expression(
|
||||||
_,
|
_,
|
||||||
@ -1253,7 +1253,7 @@ mod range {
|
|||||||
),
|
),
|
||||||
..
|
..
|
||||||
},
|
},
|
||||||
) = expressions[0]
|
) = expressions.elements[0]
|
||||||
{
|
{
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
the_inclusion, inclusion,
|
the_inclusion, inclusion,
|
||||||
@ -1282,7 +1282,7 @@ mod range {
|
|||||||
assert!(working_set.parse_errors.is_empty());
|
assert!(working_set.parse_errors.is_empty());
|
||||||
assert_eq!(block.len(), 1, "{tag}: block length 1");
|
assert_eq!(block.len(), 1, "{tag}: block length 1");
|
||||||
|
|
||||||
let expressions = &block[0];
|
let expressions = &block.pipelines[0];
|
||||||
assert_eq!(expressions.len(), 1, "{tag}: expression length 1");
|
assert_eq!(expressions.len(), 1, "{tag}: expression length 1");
|
||||||
if let PipelineElement::Expression(
|
if let PipelineElement::Expression(
|
||||||
_,
|
_,
|
||||||
@ -1299,7 +1299,7 @@ mod range {
|
|||||||
),
|
),
|
||||||
..
|
..
|
||||||
},
|
},
|
||||||
) = expressions[0]
|
) = expressions.elements[0]
|
||||||
{
|
{
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
the_inclusion, inclusion,
|
the_inclusion, inclusion,
|
||||||
@ -1672,10 +1672,10 @@ mod input_types {
|
|||||||
assert!(working_set.parse_errors.is_empty());
|
assert!(working_set.parse_errors.is_empty());
|
||||||
assert_eq!(block.len(), 1);
|
assert_eq!(block.len(), 1);
|
||||||
|
|
||||||
let expressions = &block[0];
|
let expressions = &block.pipelines[0];
|
||||||
assert_eq!(expressions.len(), 2);
|
assert_eq!(expressions.len(), 2);
|
||||||
|
|
||||||
match &expressions[0] {
|
match &expressions.elements[0] {
|
||||||
PipelineElement::Expression(
|
PipelineElement::Expression(
|
||||||
_,
|
_,
|
||||||
Expression {
|
Expression {
|
||||||
@ -1689,7 +1689,7 @@ mod input_types {
|
|||||||
_ => panic!("Expected expression Call not found"),
|
_ => panic!("Expected expression Call not found"),
|
||||||
}
|
}
|
||||||
|
|
||||||
match &expressions[1] {
|
match &expressions.elements[1] {
|
||||||
PipelineElement::Expression(
|
PipelineElement::Expression(
|
||||||
_,
|
_,
|
||||||
Expression {
|
Expression {
|
||||||
@ -1719,8 +1719,8 @@ mod input_types {
|
|||||||
|
|
||||||
engine_state.merge_delta(delta).unwrap();
|
engine_state.merge_delta(delta).unwrap();
|
||||||
|
|
||||||
let expressions = &block[0];
|
let expressions = &block.pipelines[0];
|
||||||
match &expressions[3] {
|
match &expressions.elements[3] {
|
||||||
PipelineElement::Expression(
|
PipelineElement::Expression(
|
||||||
_,
|
_,
|
||||||
Expression {
|
Expression {
|
||||||
@ -1735,10 +1735,10 @@ mod input_types {
|
|||||||
Expr::Subexpression(id) => {
|
Expr::Subexpression(id) => {
|
||||||
let block = engine_state.get_block(*id);
|
let block = engine_state.get_block(*id);
|
||||||
|
|
||||||
let expressions = &block[0];
|
let expressions = &block.pipelines[0];
|
||||||
assert_eq!(expressions.len(), 2);
|
assert_eq!(expressions.len(), 2);
|
||||||
|
|
||||||
match &expressions[1] {
|
match &expressions.elements[1] {
|
||||||
PipelineElement::Expression(
|
PipelineElement::Expression(
|
||||||
_,
|
_,
|
||||||
Expression {
|
Expression {
|
||||||
@ -1777,8 +1777,8 @@ mod input_types {
|
|||||||
assert!(working_set.parse_errors.is_empty());
|
assert!(working_set.parse_errors.is_empty());
|
||||||
assert_eq!(block.len(), 1);
|
assert_eq!(block.len(), 1);
|
||||||
|
|
||||||
let expressions = &block[0];
|
let expressions = &block.pipelines[0];
|
||||||
match &expressions[2] {
|
match &expressions.elements[2] {
|
||||||
PipelineElement::Expression(
|
PipelineElement::Expression(
|
||||||
_,
|
_,
|
||||||
Expression {
|
Expression {
|
||||||
@ -1792,7 +1792,7 @@ mod input_types {
|
|||||||
_ => panic!("Expected expression Call not found"),
|
_ => panic!("Expected expression Call not found"),
|
||||||
}
|
}
|
||||||
|
|
||||||
match &expressions[3] {
|
match &expressions.elements[3] {
|
||||||
PipelineElement::Expression(
|
PipelineElement::Expression(
|
||||||
_,
|
_,
|
||||||
Expression {
|
Expression {
|
||||||
|
@ -19,9 +19,9 @@ pub fn do_test(test: &[u8], expected: &str, error_contains: Option<&str>) {
|
|||||||
match working_set.parse_errors.first() {
|
match working_set.parse_errors.first() {
|
||||||
None => {
|
None => {
|
||||||
assert_eq!(block.len(), 1);
|
assert_eq!(block.len(), 1);
|
||||||
let expressions = &block[0];
|
let expressions = &block.pipelines[0];
|
||||||
assert_eq!(expressions.len(), 1);
|
assert_eq!(expressions.len(), 1);
|
||||||
if let PipelineElement::Expression(_, expr) = &expressions[0] {
|
if let PipelineElement::Expression(_, expr) = &expressions.elements[0] {
|
||||||
assert_eq!(expr.expr, Expr::String(expected.to_string()))
|
assert_eq!(expr.expr, Expr::String(expected.to_string()))
|
||||||
} else {
|
} else {
|
||||||
panic!("Not an expression")
|
panic!("Not an expression")
|
||||||
|
@ -1,7 +1,6 @@
|
|||||||
use super::Pipeline;
|
use super::Pipeline;
|
||||||
use crate::{ast::PipelineElement, Signature, Span, Type, VarId};
|
use crate::{ast::PipelineElement, Signature, Span, Type, VarId};
|
||||||
use serde::{Deserialize, Serialize};
|
use serde::{Deserialize, Serialize};
|
||||||
use std::ops::{Index, IndexMut};
|
|
||||||
|
|
||||||
#[derive(Debug, Clone, Serialize, Deserialize)]
|
#[derive(Debug, Clone, Serialize, Deserialize)]
|
||||||
pub struct Block {
|
pub struct Block {
|
||||||
@ -22,20 +21,6 @@ impl Block {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Index<usize> for Block {
|
|
||||||
type Output = Pipeline;
|
|
||||||
|
|
||||||
fn index(&self, index: usize) -> &Self::Output {
|
|
||||||
&self.pipelines[index]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl IndexMut<usize> for Block {
|
|
||||||
fn index_mut(&mut self, index: usize) -> &mut Self::Output {
|
|
||||||
&mut self.pipelines[index]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl Default for Block {
|
impl Default for Block {
|
||||||
fn default() -> Self {
|
fn default() -> Self {
|
||||||
Self::new()
|
Self::new()
|
||||||
|
@ -1,6 +1,5 @@
|
|||||||
use crate::{ast::Expression, engine::StateWorkingSet, Span};
|
use crate::{ast::Expression, engine::StateWorkingSet, Span};
|
||||||
use serde::{Deserialize, Serialize};
|
use serde::{Deserialize, Serialize};
|
||||||
use std::ops::{Index, IndexMut};
|
|
||||||
|
|
||||||
#[derive(Debug, Clone, Serialize, Deserialize, Eq, PartialEq)]
|
#[derive(Debug, Clone, Serialize, Deserialize, Eq, PartialEq)]
|
||||||
pub enum Redirection {
|
pub enum Redirection {
|
||||||
@ -159,17 +158,3 @@ impl Pipeline {
|
|||||||
self.elements.is_empty()
|
self.elements.is_empty()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Index<usize> for Pipeline {
|
|
||||||
type Output = PipelineElement;
|
|
||||||
|
|
||||||
fn index(&self, index: usize) -> &Self::Output {
|
|
||||||
&self.elements[index]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl IndexMut<usize> for Pipeline {
|
|
||||||
fn index_mut(&mut self, index: usize) -> &mut Self::Output {
|
|
||||||
&mut self.elements[index]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
Loading…
Reference in New Issue
Block a user