Reduced LOC by replacing several instances of Value::Int {}, Value::Float{}, Value::Bool {}, and Value::String {} with Value::int(), Value::float(), Value::boolean() and Value::string() (#7412)

# Description

While perusing Value.rs, I noticed the `Value::int()`, `Value::float()`,
`Value::boolean()` and `Value::string()` constructors, which seem
designed to make it easier to construct various Values, but which aren't
used often at all in the codebase. So, using a few find-replaces
regexes, I increased their usage. This reduces overall LOC because
structures like this:
```
Value::Int {
  val: a,
  span: head
}
```
are changed into
```
Value::int(a, head)
```
and are respected as such by the project's formatter.
There are little readability concerns because the second argument to all
of these is `span`, and it's almost always extremely obvious which is
the span at every callsite.

# User-Facing Changes

None.

# Tests + Formatting

Don't forget to add tests that cover your changes.

Make sure you've run and fixed any issues with these commands:

- `cargo fmt --all -- --check` to check standard code formatting (`cargo
fmt --all` applies these changes)
- `cargo clippy --workspace -- -D warnings -D clippy::unwrap_used -A
clippy::needless_collect` to check that you're using the standard code
style
- `cargo test --workspace` to check that all tests pass

# After Submitting

If your PR had any user-facing changes, update [the
documentation](https://github.com/nushell/nushell.github.io) after the
PR is merged, if necessary. This will help us keep the docs up to date.
This commit is contained in:
Leon 2022-12-10 02:37:51 +10:00 committed by GitHub
parent b56ad92e25
commit 220b105efb
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
139 changed files with 540 additions and 2141 deletions

View File

@ -77,10 +77,7 @@ impl NuCompleter {
Value::List { Value::List {
vals: spans vals: spans
.iter() .iter()
.map(|it| Value::String { .map(|it| Value::string(it, Span::unknown()))
val: it.to_string(),
span: Span::unknown(),
})
.collect(), .collect(),
span: Span::unknown(), span: Span::unknown(),
}, },

View File

@ -42,20 +42,14 @@ impl Completer for NuMenuCompleter {
if let Some(buffer) = block.signature.get_positional(0) { if let Some(buffer) = block.signature.get_positional(0) {
if let Some(buffer_id) = &buffer.var_id { if let Some(buffer_id) = &buffer.var_id {
let line_buffer = Value::String { let line_buffer = Value::string(parsed.remainder, self.span);
val: parsed.remainder.to_string(),
span: self.span,
};
self.stack.add_var(*buffer_id, line_buffer); self.stack.add_var(*buffer_id, line_buffer);
} }
} }
if let Some(position) = block.signature.get_positional(1) { if let Some(position) = block.signature.get_positional(1) {
if let Some(position_id) = &position.var_id { if let Some(position_id) = &position.var_id {
let line_buffer = Value::Int { let line_buffer = Value::int(pos as i64, self.span);
val: pos as i64,
span: self.span,
};
self.stack.add_var(*position_id, line_buffer); self.stack.add_var(*position_id, line_buffer);
} }
} }

View File

@ -993,10 +993,7 @@ mod test {
#[test] #[test]
fn test_send_event() { fn test_send_event() {
let cols = vec!["send".to_string()]; let cols = vec!["send".to_string()];
let vals = vec![Value::String { let vals = vec![Value::string("Enter", Span::test_data())];
val: "Enter".to_string(),
span: Span::test_data(),
}];
let span = Span::test_data(); let span = Span::test_data();
let b = EventType::try_from_columns(&cols, &vals, &span).unwrap(); let b = EventType::try_from_columns(&cols, &vals, &span).unwrap();
@ -1016,10 +1013,7 @@ mod test {
#[test] #[test]
fn test_edit_event() { fn test_edit_event() {
let cols = vec!["edit".to_string()]; let cols = vec!["edit".to_string()];
let vals = vec![Value::String { let vals = vec![Value::string("Clear", Span::test_data())];
val: "Clear".to_string(),
span: Span::test_data(),
}];
let span = Span::test_data(); let span = Span::test_data();
let b = EventType::try_from_columns(&cols, &vals, &span).unwrap(); let b = EventType::try_from_columns(&cols, &vals, &span).unwrap();
@ -1043,14 +1037,8 @@ mod test {
fn test_send_menu() { fn test_send_menu() {
let cols = vec!["send".to_string(), "name".to_string()]; let cols = vec!["send".to_string(), "name".to_string()];
let vals = vec![ let vals = vec![
Value::String { Value::string("Menu", Span::test_data()),
val: "Menu".to_string(), Value::string("history_menu", Span::test_data()),
span: Span::test_data(),
},
Value::String {
val: "history_menu".to_string(),
span: Span::test_data(),
},
]; ];
let span = Span::test_data(); let span = Span::test_data();
@ -1076,14 +1064,8 @@ mod test {
// Menu event // Menu event
let cols = vec!["send".to_string(), "name".to_string()]; let cols = vec!["send".to_string(), "name".to_string()];
let vals = vec![ let vals = vec![
Value::String { Value::string("Menu", Span::test_data()),
val: "Menu".to_string(), Value::string("history_menu", Span::test_data()),
span: Span::test_data(),
},
Value::String {
val: "history_menu".to_string(),
span: Span::test_data(),
},
]; ];
let menu_event = Value::Record { let menu_event = Value::Record {
@ -1094,10 +1076,7 @@ mod test {
// Enter event // Enter event
let cols = vec!["send".to_string()]; let cols = vec!["send".to_string()];
let vals = vec![Value::String { let vals = vec![Value::string("Enter", Span::test_data())];
val: "Enter".to_string(),
span: Span::test_data(),
}];
let enter_event = Value::Record { let enter_event = Value::Record {
cols, cols,
@ -1138,14 +1117,8 @@ mod test {
// Menu event // Menu event
let cols = vec!["send".to_string(), "name".to_string()]; let cols = vec!["send".to_string(), "name".to_string()];
let vals = vec![ let vals = vec![
Value::String { Value::string("Menu", Span::test_data()),
val: "Menu".to_string(), Value::string("history_menu", Span::test_data()),
span: Span::test_data(),
},
Value::String {
val: "history_menu".to_string(),
span: Span::test_data(),
},
]; ];
let menu_event = Value::Record { let menu_event = Value::Record {
@ -1156,10 +1129,7 @@ mod test {
// Enter event // Enter event
let cols = vec!["send".to_string()]; let cols = vec!["send".to_string()];
let vals = vec![Value::String { let vals = vec![Value::string("Enter", Span::test_data())];
val: "Enter".to_string(),
span: Span::test_data(),
}];
let enter_event = Value::Record { let enter_event = Value::Record {
cols, cols,
@ -1187,10 +1157,7 @@ mod test {
#[test] #[test]
fn test_error() { fn test_error() {
let cols = vec!["not_exist".to_string()]; let cols = vec!["not_exist".to_string()];
let vals = vec![Value::String { let vals = vec![Value::string("Enter", Span::test_data())];
val: "Enter".to_string(),
span: Span::test_data(),
}];
let span = Span::test_data(); let span = Span::test_data();
let b = EventType::try_from_columns(&cols, &vals, &span); let b = EventType::try_from_columns(&cols, &vals, &span);

View File

@ -74,19 +74,10 @@ pub fn evaluate_repl(
// seed env vars // seed env vars
stack.add_env_var( stack.add_env_var(
"CMD_DURATION_MS".into(), "CMD_DURATION_MS".into(),
Value::String { Value::string("0823", Span::unknown()),
val: "0823".to_string(),
span: Span::unknown(),
},
); );
stack.add_env_var( stack.add_env_var("LAST_EXIT_CODE".into(), Value::int(0, Span::unknown()));
"LAST_EXIT_CODE".into(),
Value::Int {
val: 0,
span: Span::unknown(),
},
);
info!( info!(
"load config initially {}:{}:{}", "load config initially {}:{}:{}",

View File

@ -289,10 +289,7 @@ pub fn eval_source(
fn set_last_exit_code(stack: &mut Stack, exit_code: i64) { fn set_last_exit_code(stack: &mut Stack, exit_code: i64) {
stack.add_env_var( stack.add_env_var(
"LAST_EXIT_CODE".to_string(), "LAST_EXIT_CODE".to_string(),
Value::Int { Value::int(exit_code, Span::unknown()),
val: exit_code,
span: Span::unknown(),
},
); );
} }

View File

@ -54,10 +54,7 @@ impl Command for SubCommand {
Example { Example {
description: "Apply bits and to two numbers", description: "Apply bits and to two numbers",
example: "2 | bits and 2", example: "2 | bits and 2",
result: Some(Value::Int { result: Some(Value::int(2, Span::test_data())),
val: 2,
span: Span::test_data(),
}),
}, },
Example { Example {
description: "Apply logical and to a list of numbers", description: "Apply logical and to a list of numbers",

View File

@ -54,10 +54,7 @@ impl Command for SubCommand {
Example { Example {
description: "Apply bits or to two numbers", description: "Apply bits or to two numbers",
example: "2 | bits or 6", example: "2 | bits or 6",
result: Some(Value::Int { result: Some(Value::int(6, Span::test_data())),
val: 6,
span: Span::test_data(),
}),
}, },
Example { Example {
description: "Apply logical or to a list of numbers", description: "Apply logical or to a list of numbers",

View File

@ -76,10 +76,7 @@ impl Command for SubCommand {
Example { Example {
description: "Rotate left a number with 2 bits", description: "Rotate left a number with 2 bits",
example: "17 | bits rol 2", example: "17 | bits rol 2",
result: Some(Value::Int { result: Some(Value::int(68, Span::test_data())),
val: 68,
span: Span::test_data(),
}),
}, },
Example { Example {
description: "Rotate left a list of numbers with 2 bits", description: "Rotate left a list of numbers with 2 bits",

View File

@ -76,10 +76,7 @@ impl Command for SubCommand {
Example { Example {
description: "Rotate right a number with 60 bits", description: "Rotate right a number with 60 bits",
example: "17 | bits ror 60", example: "17 | bits ror 60",
result: Some(Value::Int { result: Some(Value::int(272, Span::test_data())),
val: 272,
span: Span::test_data(),
}),
}, },
Example { Example {
description: "Rotate right a list of numbers of one byte", description: "Rotate right a list of numbers of one byte",

View File

@ -76,26 +76,17 @@ impl Command for SubCommand {
Example { Example {
description: "Shift left a number by 7 bits", description: "Shift left a number by 7 bits",
example: "2 | bits shl 7", example: "2 | bits shl 7",
result: Some(Value::Int { result: Some(Value::int(256, Span::test_data())),
val: 256,
span: Span::test_data(),
}),
}, },
Example { Example {
description: "Shift left a number with 1 byte by 7 bits", description: "Shift left a number with 1 byte by 7 bits",
example: "2 | bits shl 7 -n 1", example: "2 | bits shl 7 -n 1",
result: Some(Value::Int { result: Some(Value::int(0, Span::test_data())),
val: 0,
span: Span::test_data(),
}),
}, },
Example { Example {
description: "Shift left a signed number by 1 bit", description: "Shift left a signed number by 1 bit",
example: "0x7F | bits shl 1 -s", example: "0x7F | bits shl 1 -s",
result: Some(Value::Int { result: Some(Value::int(254, Span::test_data())),
val: 254,
span: Span::test_data(),
}),
}, },
Example { Example {
description: "Shift left a list of numbers", description: "Shift left a list of numbers",

View File

@ -76,10 +76,7 @@ impl Command for SubCommand {
Example { Example {
description: "Shift right a number with 2 bits", description: "Shift right a number with 2 bits",
example: "8 | bits shr 2", example: "8 | bits shr 2",
result: Some(Value::Int { result: Some(Value::int(2, Span::test_data())),
val: 2,
span: Span::test_data(),
}),
}, },
Example { Example {
description: "Shift right a list of numbers", description: "Shift right a list of numbers",

View File

@ -54,10 +54,7 @@ impl Command for SubCommand {
Example { Example {
description: "Apply bits xor to two numbers", description: "Apply bits xor to two numbers",
example: "2 | bits xor 2", example: "2 | bits xor 2",
result: Some(Value::Int { result: Some(Value::int(0, Span::test_data())),
val: 0,
span: Span::test_data(),
}),
}, },
Example { Example {
description: "Apply logical xor to a list of numbers", description: "Apply logical xor to a list of numbers",

View File

@ -68,26 +68,17 @@ impl Command for BytesEndsWith {
Example { Example {
description: "Checks if binary ends with `0x[AA]`", description: "Checks if binary ends with `0x[AA]`",
example: "0x[1F FF AA AA] | bytes ends-with 0x[AA]", example: "0x[1F FF AA AA] | bytes ends-with 0x[AA]",
result: Some(Value::Bool { result: Some(Value::boolean(true, Span::test_data())),
val: true,
span: Span::test_data(),
}),
}, },
Example { Example {
description: "Checks if binary ends with `0x[FF AA AA]`", description: "Checks if binary ends with `0x[FF AA AA]`",
example: "0x[1F FF AA AA] | bytes ends-with 0x[FF AA AA]", example: "0x[1F FF AA AA] | bytes ends-with 0x[FF AA AA]",
result: Some(Value::Bool { result: Some(Value::boolean(true, Span::test_data())),
val: true,
span: Span::test_data(),
}),
}, },
Example { Example {
description: "Checks if binary ends with `0x[11]`", description: "Checks if binary ends with `0x[11]`",
example: "0x[1F FF AA AA] | bytes ends-with 0x[11]", example: "0x[1F FF AA AA] | bytes ends-with 0x[11]",
result: Some(Value::Bool { result: Some(Value::boolean(false, Span::test_data())),
val: false,
span: Span::test_data(),
}),
}, },
] ]
} }
@ -98,10 +89,7 @@ fn ends_with(val: &Value, args: &Arguments, span: Span) -> Value {
Value::Binary { Value::Binary {
val, val,
span: val_span, span: val_span,
} => Value::Bool { } => Value::boolean(val.ends_with(&args.pattern), *val_span),
val: val.ends_with(&args.pattern),
span: *val_span,
},
other => Value::Error { other => Value::Error {
error: ShellError::UnsupportedInput( error: ShellError::UnsupportedInput(
format!( format!(

View File

@ -70,10 +70,7 @@ fn length(val: &Value, _args: &CellPathOnlyArgs, span: Span) -> Value {
Value::Binary { Value::Binary {
val, val,
span: val_span, span: val_span,
} => Value::Int { } => Value::int(val.len() as i64, *val_span),
val: val.len() as i64,
span: *val_span,
},
other => Value::Error { other => Value::Error {
error: ShellError::UnsupportedInput( error: ShellError::UnsupportedInput(
format!( format!(

View File

@ -74,26 +74,17 @@ impl Command for BytesStartsWith {
Example { Example {
description: "Checks if binary starts with `0x[1F FF AA]`", description: "Checks if binary starts with `0x[1F FF AA]`",
example: "0x[1F FF AA AA] | bytes starts-with 0x[1F FF AA]", example: "0x[1F FF AA AA] | bytes starts-with 0x[1F FF AA]",
result: Some(Value::Bool { result: Some(Value::boolean(true, Span::test_data())),
val: true,
span: Span::test_data(),
}),
}, },
Example { Example {
description: "Checks if binary starts with `0x[1F]`", description: "Checks if binary starts with `0x[1F]`",
example: "0x[1F FF AA AA] | bytes starts-with 0x[1F]", example: "0x[1F FF AA AA] | bytes starts-with 0x[1F]",
result: Some(Value::Bool { result: Some(Value::boolean(true, Span::test_data())),
val: true,
span: Span::test_data(),
}),
}, },
Example { Example {
description: "Checks if binary starts with `0x[1F]`", description: "Checks if binary starts with `0x[1F]`",
example: "0x[1F FF AA AA] | bytes starts-with 0x[11]", example: "0x[1F FF AA AA] | bytes starts-with 0x[11]",
result: Some(Value::Bool { result: Some(Value::boolean(false, Span::test_data())),
val: false,
span: Span::test_data(),
}),
}, },
] ]
} }
@ -104,10 +95,7 @@ fn starts_with(val: &Value, args: &Arguments, span: Span) -> Value {
Value::Binary { Value::Binary {
val, val,
span: val_span, span: val_span,
} => Value::Bool { } => Value::boolean(val.starts_with(&args.pattern), *val_span),
val: val.starts_with(&args.pattern),
span: *val_span,
},
other => Value::Error { other => Value::Error {
error: ShellError::UnsupportedInput( error: ShellError::UnsupportedInput(
format!( format!(

View File

@ -44,38 +44,14 @@ impl Command for Fmt {
"upperhex".into(), "upperhex".into(),
], ],
vals: vec![ vals: vec![
Value::String { Value::string("0b101010", Span::test_data()),
val: "0b101010".to_string(), Value::string("42", Span::test_data()),
span: Span::test_data(), Value::string("42", Span::test_data()),
}, Value::string("4.2e1", Span::test_data()),
Value::String { Value::string("0x2a", Span::test_data()),
val: "42".to_string(), Value::string("0o52", Span::test_data()),
span: Span::test_data(), Value::string("4.2E1", Span::test_data()),
}, Value::string("0x2A", Span::test_data()),
Value::String {
val: "42".to_string(),
span: Span::test_data(),
},
Value::String {
val: "4.2e1".to_string(),
span: Span::test_data(),
},
Value::String {
val: "0x2a".to_string(),
span: Span::test_data(),
},
Value::String {
val: "0o52".to_string(),
span: Span::test_data(),
},
Value::String {
val: "4.2E1".to_string(),
span: Span::test_data(),
},
Value::String {
val: "0x2A".to_string(),
span: Span::test_data(),
},
], ],
span: Span::test_data(), span: Span::test_data(),
}), }),

View File

@ -86,7 +86,7 @@ fn action(input: &Value, _args: &CellPathOnlyArgs, head: Span) -> Value {
let other = s.trim(); let other = s.trim();
match other.parse::<f64>() { match other.parse::<f64>() {
Ok(x) => Value::Float { val: x, span: head }, Ok(x) => Value::float(x, head),
Err(reason) => Value::Error { Err(reason) => Value::Error {
error: ShellError::CantConvert( error: ShellError::CantConvert(
"float".to_string(), "float".to_string(),
@ -97,10 +97,7 @@ fn action(input: &Value, _args: &CellPathOnlyArgs, head: Span) -> Value {
}, },
} }
} }
Value::Int { val: v, span } => Value::Float { Value::Int { val: v, span } => Value::float(*v as f64, *span),
val: *v as f64,
span: *span,
},
Value::Bool { val: b, span } => Value::Float { Value::Bool { val: b, span } => Value::Float {
val: match b { val: match b {
true => 1.0, true => 1.0,

View File

@ -113,10 +113,7 @@ impl Command for SubCommand {
Example { Example {
description: "Convert file size to integer", description: "Convert file size to integer",
example: "4KB | into int", example: "4KB | into int",
result: Some(Value::Int { result: Some(Value::int(4000, Span::test_data())),
val: 4000,
span: Span::test_data(),
}),
}, },
Example { Example {
description: "Convert bool to integer", description: "Convert bool to integer",
@ -233,20 +230,14 @@ fn action(input: &Value, args: &Arguments, span: Span) -> Value {
} }
val.resize(8, 0); val.resize(8, 0);
Value::Int { Value::int(LittleEndian::read_i64(&val), *span)
val: LittleEndian::read_i64(&val),
span: *span,
}
} else { } else {
while val.len() < 8 { while val.len() < 8 {
val.insert(0, 0); val.insert(0, 0);
} }
val.resize(8, 0); val.resize(8, 0);
Value::Int { Value::int(BigEndian::read_i64(&val), *span)
val: BigEndian::read_i64(&val),
span: *span,
}
} }
} }
_ => Value::Error { _ => Value::Error {
@ -269,13 +260,13 @@ fn convert_int(input: &Value, head: Span, radix: u32) -> Value {
// octal // octal
{ {
match int_from_string(val, head) { match int_from_string(val, head) {
Ok(x) => return Value::Int { val: x, span: head }, Ok(x) => return Value::int(x, head),
Err(e) => return Value::Error { error: e }, Err(e) => return Value::Error { error: e },
} }
} else if val.starts_with("00") { } else if val.starts_with("00") {
// It's a padded string // It's a padded string
match i64::from_str_radix(val, radix) { match i64::from_str_radix(val, radix) {
Ok(n) => return Value::Int { val: n, span: head }, Ok(n) => return Value::int(n, head),
Err(e) => { Err(e) => {
return Value::Error { return Value::Error {
error: ShellError::CantConvert( error: ShellError::CantConvert(
@ -300,7 +291,7 @@ fn convert_int(input: &Value, head: Span, radix: u32) -> Value {
} }
}; };
match i64::from_str_radix(i.trim(), radix) { match i64::from_str_radix(i.trim(), radix) {
Ok(n) => Value::Int { val: n, span: head }, Ok(n) => Value::int(n, head),
Err(_reason) => Value::Error { Err(_reason) => Value::Error {
error: ShellError::CantConvert("string".to_string(), "int".to_string(), head, None), error: ShellError::CantConvert("string".to_string(), "int".to_string(), head, None),
}, },

View File

@ -79,34 +79,22 @@ impl Command for SubCommand {
Example { Example {
description: "convert integer to string and append three decimal places", description: "convert integer to string and append three decimal places",
example: "5 | into string -d 3", example: "5 | into string -d 3",
result: Some(Value::String { result: Some(Value::string("5.000", Span::test_data())),
val: "5.000".to_string(),
span: Span::test_data(),
}),
}, },
Example { Example {
description: "convert decimal to string and round to nearest integer", description: "convert decimal to string and round to nearest integer",
example: "1.7 | into string -d 0", example: "1.7 | into string -d 0",
result: Some(Value::String { result: Some(Value::string("2", Span::test_data())),
val: "2".to_string(),
span: Span::test_data(),
}),
}, },
Example { Example {
description: "convert decimal to string", description: "convert decimal to string",
example: "1.7 | into string -d 1", example: "1.7 | into string -d 1",
result: Some(Value::String { result: Some(Value::string("1.7", Span::test_data())),
val: "1.7".to_string(),
span: Span::test_data(),
}),
}, },
Example { Example {
description: "convert decimal to string and limit to 2 decimals", description: "convert decimal to string and limit to 2 decimals",
example: "1.734 | into string -d 2", example: "1.734 | into string -d 2",
result: Some(Value::String { result: Some(Value::string("1.73", Span::test_data())),
val: "1.73".to_string(),
span: Span::test_data(),
}),
}, },
Example { Example {
description: "try to convert decimal to string and provide negative decimal points", description: "try to convert decimal to string and provide negative decimal points",
@ -123,26 +111,17 @@ impl Command for SubCommand {
Example { Example {
description: "convert decimal to string", description: "convert decimal to string",
example: "4.3 | into string", example: "4.3 | into string",
result: Some(Value::String { result: Some(Value::string("4.3", Span::test_data())),
val: "4.3".to_string(),
span: Span::test_data(),
}),
}, },
Example { Example {
description: "convert string to string", description: "convert string to string",
example: "'1234' | into string", example: "'1234' | into string",
result: Some(Value::String { result: Some(Value::string("1234", Span::test_data())),
val: "1234".to_string(),
span: Span::test_data(),
}),
}, },
Example { Example {
description: "convert boolean to string", description: "convert boolean to string",
example: "true | into string", example: "true | into string",
result: Some(Value::String { result: Some(Value::string("true", Span::test_data())),
val: "true".to_string(),
span: Span::test_data(),
}),
}, },
// TODO: This should work but does not; see https://github.com/nushell/nushell/issues/7032 // TODO: This should work but does not; see https://github.com/nushell/nushell/issues/7032
// Example { // Example {

View File

@ -72,10 +72,7 @@ def-env cd_with_fallback [arg = ""] {
vec![Example { vec![Example {
description: "Set environment variable by call a custom command", description: "Set environment variable by call a custom command",
example: r#"def-env foo [] { let-env BAR = "BAZ" }; foo; $env.BAR"#, example: r#"def-env foo [] { let-env BAR = "BAZ" }; foo; $env.BAR"#,
result: Some(Value::String { result: Some(Value::string("BAZ", Span::test_data())),
val: "BAZ".to_string(),
span: Span::test_data(),
}),
}] }]
} }
} }

View File

@ -51,13 +51,7 @@ little reason to use this over just writing the values as-is."#
std::cmp::Ordering::Equal => PipelineData::Value(to_be_echoed[0].clone(), None), std::cmp::Ordering::Equal => PipelineData::Value(to_be_echoed[0].clone(), None),
// When there are no elements, we echo the empty string // When there are no elements, we echo the empty string
std::cmp::Ordering::Less => PipelineData::Value( std::cmp::Ordering::Less => PipelineData::Value(Value::string("", call.head), None),
Value::String {
val: "".to_string(),
span: call.head,
},
None,
),
} }
}) })
} }

View File

@ -56,10 +56,7 @@ impl Command for ExportCommand {
vec![Example { vec![Example {
description: "Export a definition from a module", description: "Export a definition from a module",
example: r#"module utils { export def my-command [] { "hello" } }; use utils my-command; my-command"#, example: r#"module utils { export def my-command [] { "hello" } }; use utils my-command; my-command"#,
result: Some(Value::String { result: Some(Value::string("hello", Span::test_data())),
val: "hello".to_string(),
span: Span::test_data(),
}),
}] }]
} }

View File

@ -46,10 +46,7 @@ impl Command for ExportDef {
vec![Example { vec![Example {
description: "Define a custom command in a module and call it", description: "Define a custom command in a module and call it",
example: r#"module spam { export def foo [] { "foo" } }; use spam foo; foo"#, example: r#"module spam { export def foo [] { "foo" } }; use spam foo; foo"#,
result: Some(Value::String { result: Some(Value::string("foo", Span::test_data())),
val: "foo".to_string(),
span: Span::test_data(),
}),
}] }]
} }

View File

@ -72,10 +72,7 @@ export def-env cd_with_fallback [arg = ""] {
vec![Example { vec![Example {
description: "Define a custom command that participates in the environment in a module and call it", description: "Define a custom command that participates in the environment in a module and call it",
example: r#"module foo { export def-env bar [] { let-env FOO_BAR = "BAZ" } }; use foo bar; bar; $env.FOO_BAR"#, example: r#"module foo { export def-env bar [] { let-env FOO_BAR = "BAZ" } }; use foo bar; bar; $env.FOO_BAR"#,
result: Some(Value::String { result: Some(Value::string("BAZ", Span::test_data())),
val: "BAZ".to_string(),
span: Span::test_data(),
}),
}] }]
} }

View File

@ -48,10 +48,7 @@ impl Command for ExportUse {
use eggs foo use eggs foo
foo foo
"#, "#,
result: Some(Value::String { result: Some(Value::string("foo", Span::test_data())),
val: "foo".to_string(),
span: Span::test_data(),
}),
}] }]
} }

View File

@ -91,13 +91,7 @@ impl Command for For {
if numbered { if numbered {
Value::Record { Value::Record {
cols: vec!["index".into(), "item".into()], cols: vec!["index".into(), "item".into()],
vals: vec![ vals: vec![Value::int(idx as i64, head), x],
Value::Int {
val: idx as i64,
span: head,
},
x,
],
span: head, span: head,
} }
} else { } else {
@ -136,13 +130,7 @@ impl Command for For {
if numbered { if numbered {
Value::Record { Value::Record {
cols: vec!["index".into(), "item".into()], cols: vec!["index".into(), "item".into()],
vals: vec![ vals: vec![Value::int(idx as i64, head), x],
Value::Int {
val: idx as i64,
span: head,
},
x,
],
span: head, span: head,
} }
} else { } else {

View File

@ -131,10 +131,7 @@ fn help(
}); });
cols.push("category".into()); cols.push("category".into());
vals.push(Value::String { vals.push(Value::string(sig.category.to_string(), head));
val: sig.category.to_string(),
span: head,
});
cols.push("command_type".into()); cols.push("command_type".into());
vals.push(Value::String { vals.push(Value::String {
@ -231,10 +228,7 @@ fn help(
}); });
cols.push("category".into()); cols.push("category".into());
vals.push(Value::String { vals.push(Value::string(sig.category.to_string(), head));
val: sig.category.to_string(),
span: head,
});
cols.push("command_type".into()); cols.push("command_type".into());
vals.push(Value::String { vals.push(Value::String {
@ -334,11 +328,7 @@ Get the processes on your system actively using CPU:
You can also learn more at https://www.nushell.sh/book/"#; You can also learn more at https://www.nushell.sh/book/"#;
Ok(Value::String { Ok(Value::string(msg, head).into_pipeline_data())
val: msg.into(),
span: head,
}
.into_pipeline_data())
} }
} }

View File

@ -80,10 +80,7 @@ impl Command for Loop {
vec![Example { vec![Example {
description: "Loop while a condition is true", description: "Loop while a condition is true",
example: "mut x = 0; loop { if $x > 10 { break }; $x = $x + 1 }; $x", example: "mut x = 0; loop { if $x > 10 { break }; $x = $x + 1 }; $x",
result: Some(Value::Int { result: Some(Value::int(11, Span::test_data())),
val: 11,
span: Span::test_data(),
}),
}] }]
} }
} }

View File

@ -81,19 +81,13 @@ impl Command for Metadata {
data_source: DataSource::Ls, data_source: DataSource::Ls,
} => { } => {
cols.push("source".into()); cols.push("source".into());
vals.push(Value::String { vals.push(Value::string("ls", head))
val: "ls".into(),
span: head,
})
} }
PipelineMetadata { PipelineMetadata {
data_source: DataSource::HtmlThemes, data_source: DataSource::HtmlThemes,
} => { } => {
cols.push("source".into()); cols.push("source".into());
vals.push(Value::String { vals.push(Value::string("into html --list", head))
val: "into html --list".into(),
span: head,
})
} }
} }
} }
@ -152,19 +146,13 @@ fn build_metadata_record(arg: &Value, metadata: &Option<PipelineMetadata>, head:
data_source: DataSource::Ls, data_source: DataSource::Ls,
} => { } => {
cols.push("source".into()); cols.push("source".into());
vals.push(Value::String { vals.push(Value::string("ls", head))
val: "ls".into(),
span: head,
})
} }
PipelineMetadata { PipelineMetadata {
data_source: DataSource::HtmlThemes, data_source: DataSource::HtmlThemes,
} => { } => {
cols.push("source".into()); cols.push("source".into());
vals.push(Value::String { vals.push(Value::string("into html --list", head))
val: "into html --list".into(),
span: head,
})
} }
} }
} }

View File

@ -46,26 +46,17 @@ impl Command for Module {
Example { Example {
description: "Define a custom command in a module and call it", description: "Define a custom command in a module and call it",
example: r#"module spam { export def foo [] { "foo" } }; use spam foo; foo"#, example: r#"module spam { export def foo [] { "foo" } }; use spam foo; foo"#,
result: Some(Value::String { result: Some(Value::string("foo", Span::test_data())),
val: "foo".to_string(),
span: Span::test_data(),
}),
}, },
Example { Example {
description: "Define an environment variable in a module", description: "Define an environment variable in a module",
example: r#"module foo { export-env { let-env FOO = "BAZ" } }; use foo; $env.FOO"#, example: r#"module foo { export-env { let-env FOO = "BAZ" } }; use foo; $env.FOO"#,
result: Some(Value::String { result: Some(Value::string("BAZ", Span::test_data())),
val: "BAZ".to_string(),
span: Span::test_data(),
}),
}, },
Example { Example {
description: "Define a custom command that participates in the environment in a module and call it", description: "Define a custom command that participates in the environment in a module and call it",
example: r#"module foo { export def-env bar [] { let-env FOO_BAR = "BAZ" } }; use foo bar; bar; $env.FOO_BAR"#, example: r#"module foo { export def-env bar [] { let-env FOO_BAR = "BAZ" } }; use foo bar; bar; $env.FOO_BAR"#,
result: Some(Value::String { result: Some(Value::string("BAZ", Span::test_data())),
val: "BAZ".to_string(),
span: Span::test_data(),
}),
}, },
] ]
} }

View File

@ -50,10 +50,7 @@ impl Command for OverlayList {
example: r#"module spam { export def foo [] { "foo" } } example: r#"module spam { export def foo [] { "foo" } }
overlay use spam overlay use spam
overlay list | last"#, overlay list | last"#,
result: Some(Value::String { result: Some(Value::string("spam", Span::test_data())),
val: "spam".to_string(),
span: Span::test_data(),
}),
}] }]
} }
} }

View File

@ -135,10 +135,7 @@ impl Command for OverlayUse {
let mut parent = path.clone(); let mut parent = path.clone();
parent.pop(); parent.pop();
let file_pwd = Value::String { let file_pwd = Value::string(parent.to_string_lossy(), call.head);
val: parent.to_string_lossy().to_string(),
span: call.head,
};
caller_stack.add_env_var("FILE_PWD".to_string(), file_pwd); caller_stack.add_env_var("FILE_PWD".to_string(), file_pwd);
} }

View File

@ -79,10 +79,7 @@ impl Command for Use {
// If so, set the currently evaluated directory (file-relative PWD) // If so, set the currently evaluated directory (file-relative PWD)
if let Some(parent) = maybe_parent { if let Some(parent) = maybe_parent {
let file_pwd = Value::String { let file_pwd = Value::string(parent.to_string_lossy(), call.head);
val: parent.to_string_lossy().to_string(),
span: call.head,
};
callee_stack.add_env_var("FILE_PWD".to_string(), file_pwd); callee_stack.add_env_var("FILE_PWD".to_string(), file_pwd);
} }
@ -120,18 +117,12 @@ impl Command for Use {
Example { Example {
description: "Define a custom command in a module and call it", description: "Define a custom command in a module and call it",
example: r#"module spam { export def foo [] { "foo" } }; use spam foo; foo"#, example: r#"module spam { export def foo [] { "foo" } }; use spam foo; foo"#,
result: Some(Value::String { result: Some(Value::string("foo", Span::test_data())),
val: "foo".to_string(),
span: Span::test_data(),
}),
}, },
Example { Example {
description: "Define a custom command that participates in the environment in a module and call it", description: "Define a custom command that participates in the environment in a module and call it",
example: r#"module foo { export def-env bar [] { let-env FOO_BAR = "BAZ" } }; use foo bar; bar; $env.FOO_BAR"#, example: r#"module foo { export def-env bar [] { let-env FOO_BAR = "BAZ" } }; use foo bar; bar; $env.FOO_BAR"#,
result: Some(Value::String { result: Some(Value::string("BAZ", Span::test_data())),
val: "BAZ".to_string(),
span: Span::test_data(),
}),
}, },
] ]
} }

View File

@ -54,97 +54,64 @@ pub fn version(
let mut vals = vec![]; let mut vals = vec![];
cols.push("version".to_string()); cols.push("version".to_string());
vals.push(Value::String { vals.push(Value::string(env!("CARGO_PKG_VERSION"), tag));
val: env!("CARGO_PKG_VERSION").to_string(),
span: tag,
});
cols.push("branch".to_string()); cols.push("branch".to_string());
vals.push(Value::String { vals.push(Value::string(shadow::BRANCH, call.head));
val: shadow::BRANCH.to_string(),
span: call.head,
});
let commit_hash: Option<&str> = option_env!("NU_COMMIT_HASH"); let commit_hash: Option<&str> = option_env!("NU_COMMIT_HASH");
if let Some(commit_hash) = commit_hash { if let Some(commit_hash) = commit_hash {
cols.push("commit_hash".to_string()); cols.push("commit_hash".to_string());
vals.push(Value::String { vals.push(Value::string(commit_hash, call.head));
val: commit_hash.to_string(),
span: call.head,
});
} }
let build_os: Option<&str> = Some(shadow::BUILD_OS).filter(|x| !x.is_empty()); let build_os: Option<&str> = Some(shadow::BUILD_OS).filter(|x| !x.is_empty());
if let Some(build_os) = build_os { if let Some(build_os) = build_os {
cols.push("build_os".to_string()); cols.push("build_os".to_string());
vals.push(Value::String { vals.push(Value::string(build_os, call.head));
val: build_os.to_string(),
span: call.head,
});
} }
let build_target: Option<&str> = Some(shadow::BUILD_TARGET).filter(|x| !x.is_empty()); let build_target: Option<&str> = Some(shadow::BUILD_TARGET).filter(|x| !x.is_empty());
if let Some(build_target) = build_target { if let Some(build_target) = build_target {
cols.push("build_target".to_string()); cols.push("build_target".to_string());
vals.push(Value::String { vals.push(Value::string(build_target, call.head));
val: build_target.to_string(),
span: call.head,
});
} }
let rust_version: Option<&str> = Some(shadow::RUST_VERSION).filter(|x| !x.is_empty()); let rust_version: Option<&str> = Some(shadow::RUST_VERSION).filter(|x| !x.is_empty());
if let Some(rust_version) = rust_version { if let Some(rust_version) = rust_version {
cols.push("rust_version".to_string()); cols.push("rust_version".to_string());
vals.push(Value::String { vals.push(Value::string(rust_version, call.head));
val: rust_version.to_string(),
span: call.head,
});
} }
let rust_channel: Option<&str> = Some(shadow::RUST_CHANNEL).filter(|x| !x.is_empty()); let rust_channel: Option<&str> = Some(shadow::RUST_CHANNEL).filter(|x| !x.is_empty());
if let Some(rust_channel) = rust_channel { if let Some(rust_channel) = rust_channel {
cols.push("rust_channel".to_string()); cols.push("rust_channel".to_string());
vals.push(Value::String { vals.push(Value::string(rust_channel, call.head));
val: rust_channel.to_string(),
span: call.head,
});
} }
let cargo_version: Option<&str> = Some(shadow::CARGO_VERSION).filter(|x| !x.is_empty()); let cargo_version: Option<&str> = Some(shadow::CARGO_VERSION).filter(|x| !x.is_empty());
if let Some(cargo_version) = cargo_version { if let Some(cargo_version) = cargo_version {
cols.push("cargo_version".to_string()); cols.push("cargo_version".to_string());
vals.push(Value::String { vals.push(Value::string(cargo_version, call.head));
val: cargo_version.to_string(),
span: call.head,
});
} }
let pkg_version: Option<&str> = Some(shadow::PKG_VERSION).filter(|x| !x.is_empty()); let pkg_version: Option<&str> = Some(shadow::PKG_VERSION).filter(|x| !x.is_empty());
if let Some(pkg_version) = pkg_version { if let Some(pkg_version) = pkg_version {
cols.push("pkg_version".to_string()); cols.push("pkg_version".to_string());
vals.push(Value::String { vals.push(Value::string(pkg_version, call.head));
val: pkg_version.to_string(),
span: call.head,
});
} }
let build_time: Option<&str> = Some(shadow::BUILD_TIME).filter(|x| !x.is_empty()); let build_time: Option<&str> = Some(shadow::BUILD_TIME).filter(|x| !x.is_empty());
if let Some(build_time) = build_time { if let Some(build_time) = build_time {
cols.push("build_time".to_string()); cols.push("build_time".to_string());
vals.push(Value::String { vals.push(Value::string(build_time, call.head));
val: build_time.to_string(),
span: call.head,
});
} }
let build_rust_channel: Option<&str> = let build_rust_channel: Option<&str> =
Some(shadow::BUILD_RUST_CHANNEL).filter(|x| !x.is_empty()); Some(shadow::BUILD_RUST_CHANNEL).filter(|x| !x.is_empty());
if let Some(build_rust_channel) = build_rust_channel { if let Some(build_rust_channel) = build_rust_channel {
cols.push("build_rust_channel".to_string()); cols.push("build_rust_channel".to_string());
vals.push(Value::String { vals.push(Value::string(build_rust_channel, call.head));
val: build_rust_channel.to_string(),
span: call.head,
});
} }
cols.push("features".to_string()); cols.push("features".to_string());

View File

@ -30,14 +30,8 @@ impl Command for ColumnsDF {
example: "[[a b]; [1 2] [3 4]] | into df | columns", example: "[[a b]; [1 2] [3 4]] | into df | columns",
result: Some(Value::List { result: Some(Value::List {
vals: vec![ vals: vec![
Value::String { Value::string("a", Span::test_data()),
val: "a".into(), Value::string("b", Span::test_data()),
span: Span::test_data(),
},
Value::String {
val: "b".into(),
span: Span::test_data(),
},
], ],
span: Span::test_data(), span: Span::test_data(),
}), }),
@ -67,10 +61,7 @@ fn command(
.as_ref() .as_ref()
.get_column_names() .get_column_names()
.iter() .iter()
.map(|v| Value::String { .map(|v| Value::string(*v, call.head))
val: v.to_string(),
span: call.head,
})
.collect(); .collect();
let names = Value::List { let names = Value::List {

View File

@ -82,10 +82,7 @@ fn command(
span: call.head, span: call.head,
}); });
Value::String { Value::string(*v, call.head)
val: v.to_string(),
span: call.head,
}
}) })
.collect(); .collect();

View File

@ -61,15 +61,9 @@ impl Command for ListDF {
span: call.head, span: call.head,
}; };
let columns = Value::Int { let columns = Value::int(df.as_ref().width() as i64, call.head);
val: df.as_ref().width() as i64,
span: call.head,
};
let rows = Value::Int { let rows = Value::int(df.as_ref().height() as i64, call.head);
val: df.as_ref().height() as i64,
span: call.head,
};
let cols = vec![ let cols = vec![
"name".to_string(), "name".to_string(),

View File

@ -61,15 +61,9 @@ fn command(
) -> Result<PipelineData, ShellError> { ) -> Result<PipelineData, ShellError> {
let df = NuDataFrame::try_from_pipeline(input, call.head)?; let df = NuDataFrame::try_from_pipeline(input, call.head)?;
let rows = Value::Int { let rows = Value::int(df.as_ref().height() as i64, call.head);
val: df.as_ref().height() as i64,
span: call.head,
};
let cols = Value::Int { let cols = Value::int(df.as_ref().width() as i64, call.head);
val: df.as_ref().width() as i64,
span: call.head,
};
let rows_col = Column::new("rows".to_string(), vec![rows]); let rows_col = Column::new("rows".to_string(), vec![rows]);
let cols_col = Column::new("columns".to_string(), vec![cols]); let cols_col = Column::new("columns".to_string(), vec![cols]);

View File

@ -32,14 +32,8 @@ impl Command for ExprAsNu {
result: Some(Value::Record { result: Some(Value::Record {
cols: vec!["expr".into(), "value".into()], cols: vec!["expr".into(), "value".into()],
vals: vec![ vals: vec![
Value::String { Value::string("column", Span::test_data()),
val: "column".into(), Value::string("a", Span::test_data()),
span: Span::test_data(),
},
Value::String {
val: "a".into(),
span: Span::test_data(),
},
], ],
span: Span::test_data(), span: Span::test_data(),
}), }),

View File

@ -38,14 +38,8 @@ impl Command for ExprCol {
result: Some(Value::Record { result: Some(Value::Record {
cols: vec!["expr".into(), "value".into()], cols: vec!["expr".into(), "value".into()],
vals: vec![ vals: vec![
Value::String { Value::string("column", Span::test_data()),
val: "column".into(), Value::string("a", Span::test_data()),
span: Span::test_data(),
},
Value::String {
val: "a".into(),
span: Span::test_data(),
},
], ],
span: Span::test_data(), span: Span::test_data(),
}), }),

View File

@ -37,14 +37,8 @@ impl Command for ExprLit {
result: Some(Value::Record { result: Some(Value::Record {
cols: vec!["expr".into(), "value".into()], cols: vec!["expr".into(), "value".into()],
vals: vec![ vals: vec![
Value::String { Value::string("literal", Span::test_data()),
val: "literal".into(), Value::string("2i64", Span::test_data()),
span: Span::test_data(),
},
Value::String {
val: "2i64".into(),
span: Span::test_data(),
},
], ],
span: Span::test_data(), span: Span::test_data(),
}), }),

View File

@ -86,10 +86,7 @@ fn command(
) )
})?; })?;
let value = Value::Bool { let value = Value::boolean(!bool.any(), call.head);
val: !bool.any(),
span: call.head,
};
NuDataFrame::try_from_columns(vec![Column::new("all_false".to_string(), vec![value])]) NuDataFrame::try_from_columns(vec![Column::new("all_false".to_string(), vec![value])])
.map(|df| PipelineData::Value(NuDataFrame::into_value(df, call.head), None)) .map(|df| PipelineData::Value(NuDataFrame::into_value(df, call.head), None))

View File

@ -86,10 +86,7 @@ fn command(
) )
})?; })?;
let value = Value::Bool { let value = Value::boolean(bool.all(), call.head);
val: bool.all(),
span: call.head,
};
NuDataFrame::try_from_columns(vec![Column::new("all_true".to_string(), vec![value])]) NuDataFrame::try_from_columns(vec![Column::new("all_true".to_string(), vec![value])])
.map(|df| PipelineData::Value(NuDataFrame::into_value(df, call.head), None)) .map(|df| PipelineData::Value(NuDataFrame::into_value(df, call.head), None))

View File

@ -61,10 +61,7 @@ fn command(
let df = NuDataFrame::try_from_pipeline(input, call.head)?; let df = NuDataFrame::try_from_pipeline(input, call.head)?;
let res = df.as_series(call.head)?.null_count(); let res = df.as_series(call.head)?.null_count();
let value = Value::Int { let value = Value::int(res as i64, call.head);
val: res as i64,
span: call.head,
};
NuDataFrame::try_from_columns(vec![Column::new("count_null".to_string(), vec![value])]) NuDataFrame::try_from_columns(vec![Column::new("count_null".to_string(), vec![value])])
.map(|df| PipelineData::Value(NuDataFrame::into_value(df, call.head), None)) .map(|df| PipelineData::Value(NuDataFrame::into_value(df, call.head), None))

View File

@ -67,10 +67,7 @@ fn command(
) )
})?; })?;
let value = Value::Int { let value = Value::int(res as i64, call.head);
val: res as i64,
span: call.head,
};
NuDataFrame::try_from_columns(vec![Column::new("count_unique".to_string(), vec![value])]) NuDataFrame::try_from_columns(vec![Column::new("count_unique".to_string(), vec![value])])
.map(|df| PipelineData::Value(NuDataFrame::into_value(df, call.head), None)) .map(|df| PipelineData::Value(NuDataFrame::into_value(df, call.head), None))

View File

@ -110,10 +110,7 @@ impl Command for SubCommand {
Example { Example {
description: "Format a given date using a given format string.", description: "Format a given date using a given format string.",
example: r#""2021-10-22 20:00:12 +01:00" | date format "%Y-%m-%d""#, example: r#""2021-10-22 20:00:12 +01:00" | date format "%Y-%m-%d""#,
result: Some(Value::String { result: Some(Value::string("2021-10-22", Span::test_data())),
val: "2021-10-22".to_string(),
span: Span::test_data(),
}),
}, },
] ]
} }
@ -429,18 +426,9 @@ pub(crate) fn generate_strftime_list(head: Span, show_parse_only_formats: bool)
.map(|s| Value::Record { .map(|s| Value::Record {
cols: column_names.clone(), cols: column_names.clone(),
vals: vec![ vals: vec![
Value::String { Value::string(s.spec, head),
val: s.spec.to_string(), Value::string(now.format(s.spec).to_string(), head),
span: head, Value::string(s.description, head),
},
Value::String {
val: now.format(s.spec).to_string(),
span: head,
},
Value::String {
val: s.description.to_string(),
span: head,
},
], ],
span: head, span: head,
}) })
@ -459,19 +447,15 @@ pub(crate) fn generate_strftime_list(head: Span, show_parse_only_formats: bool)
records.push(Value::Record { records.push(Value::Record {
cols: column_names, cols: column_names,
vals: vec![ vals: vec![
Value::String { Value::string("%#z", head),
val: "%#z".to_string(),
span: head,
},
Value::String { Value::String {
val: example, val: example,
span: head, span: head,
}, },
Value::String { Value::string(
val: "Parsing only: Same as %z but allows minutes to be missing or present." "Parsing only: Same as %z but allows minutes to be missing or present.",
.to_string(), head,
span: head, ),
},
], ],
span: head, span: head,
}); });

View File

@ -110,34 +110,13 @@ fn parse_date_into_table(date: Result<DateTime<FixedOffset>, Value>, head: Span)
match date { match date {
Ok(x) => { Ok(x) => {
let vals = vec![ let vals = vec![
Value::Int { Value::int(x.year() as i64, head),
val: x.year() as i64, Value::int(x.month() as i64, head),
span: head, Value::int(x.day() as i64, head),
}, Value::int(x.hour() as i64, head),
Value::Int { Value::int(x.minute() as i64, head),
val: x.month() as i64, Value::int(x.second() as i64, head),
span: head, Value::string(x.offset().to_string(), head),
},
Value::Int {
val: x.day() as i64,
span: head,
},
Value::Int {
val: x.hour() as i64,
span: head,
},
Value::Int {
val: x.minute() as i64,
span: head,
},
Value::Int {
val: x.second() as i64,
span: head,
},
Value::String {
val: x.offset().to_string(),
span: head,
},
]; ];
Value::Record { Value::Record {
cols, cols,

View File

@ -113,34 +113,13 @@ fn parse_date_into_table(date: Result<DateTime<FixedOffset>, Value>, head: Span)
match date { match date {
Ok(x) => { Ok(x) => {
let vals = vec![ let vals = vec![
Value::Int { Value::int(x.year() as i64, head),
val: x.year() as i64, Value::int(x.month() as i64, head),
span: head, Value::int(x.day() as i64, head),
}, Value::int(x.hour() as i64, head),
Value::Int { Value::int(x.minute() as i64, head),
val: x.month() as i64, Value::int(x.second() as i64, head),
span: head, Value::string(x.offset().to_string(), head),
},
Value::Int {
val: x.day() as i64,
span: head,
},
Value::Int {
val: x.hour() as i64,
span: head,
},
Value::Int {
val: x.minute() as i64,
span: head,
},
Value::Int {
val: x.second() as i64,
span: head,
},
Value::String {
val: x.offset().to_string(),
span: head,
},
]; ];
Value::List { Value::List {
vals: vec![Value::Record { vals: vec![Value::Record {

View File

@ -46,13 +46,7 @@ impl Command for LoadEnv {
let cwd = current_dir(engine_state, stack)?; let cwd = current_dir(engine_state, stack)?;
let rhs = rhs.as_string()?; let rhs = rhs.as_string()?;
let rhs = nu_path::expand_path_with(rhs, cwd); let rhs = nu_path::expand_path_with(rhs, cwd);
stack.add_env_var( stack.add_env_var(env_var, Value::string(rhs.to_string_lossy(), call.head));
env_var,
Value::String {
val: rhs.to_string_lossy().to_string(),
span: call.head,
},
);
} else { } else {
stack.add_env_var(env_var, rhs); stack.add_env_var(env_var, rhs);
} }
@ -72,10 +66,7 @@ impl Command for LoadEnv {
let rhs = nu_path::expand_path_with(rhs, cwd); let rhs = nu_path::expand_path_with(rhs, cwd);
stack.add_env_var( stack.add_env_var(
env_var, env_var,
Value::String { Value::string(rhs.to_string_lossy(), call.head),
val: rhs.to_string_lossy().to_string(),
span: call.head,
},
); );
} else { } else {
stack.add_env_var(env_var, rhs); stack.add_env_var(env_var, rhs);

View File

@ -53,10 +53,7 @@ impl Command for SourceEnv {
}; };
parent.pop(); parent.pop();
let file_pwd = Value::String { let file_pwd = Value::string(parent.to_string_lossy(), call.head);
val: parent.to_string_lossy().to_string(),
span: call.head,
};
caller_stack.add_env_var("FILE_PWD".to_string(), file_pwd); caller_stack.add_env_var("FILE_PWD".to_string(), file_pwd);

View File

@ -208,10 +208,7 @@ mod test_examples {
// Set up PWD // Set up PWD
stack.add_env_var( stack.add_env_var(
"PWD".to_string(), "PWD".to_string(),
Value::String { Value::string(cwd.to_string_lossy(), Span::test_data()),
val: cwd.to_string_lossy().to_string(),
span: Span::test_data(),
},
); );
engine_state engine_state
@ -296,10 +293,7 @@ mod test_examples {
stack.add_env_var( stack.add_env_var(
"PWD".to_string(), "PWD".to_string(),
Value::String { Value::string(cwd.to_string_lossy(), Span::test_data()),
val: cwd.to_string_lossy().to_string(),
span: Span::test_data(),
},
); );
match nu_engine::eval_block(engine_state, &mut stack, &block, input, true, true) { match nu_engine::eval_block(engine_state, &mut stack, &block, input, true, true) {

View File

@ -30,11 +30,7 @@ impl Command for IsAdmin {
call: &Call, call: &Call,
_input: PipelineData, _input: PipelineData,
) -> Result<nu_protocol::PipelineData, nu_protocol::ShellError> { ) -> Result<nu_protocol::PipelineData, nu_protocol::ShellError> {
Ok(Value::Bool { Ok(Value::boolean(is_root(), call.head).into_pipeline_data())
val: is_root(),
span: call.head,
}
.into_pipeline_data())
} }
fn examples(&self) -> Vec<Example> { fn examples(&self) -> Vec<Example> {
@ -42,10 +38,7 @@ impl Command for IsAdmin {
Example { Example {
description: "Echo 'iamroot' if nushell is running with admin/root privileges, and 'iamnotroot' if not.", description: "Echo 'iamroot' if nushell is running with admin/root privileges, and 'iamnotroot' if not.",
example: r#"if is-admin { echo "iamroot" } else { echo "iamnotroot" }"#, example: r#"if is-admin { echo "iamroot" } else { echo "iamnotroot" }"#,
result: Some(Value::String { result: Some(Value::string("iamnotroot", Span::test_data())),
val: "iamnotroot".to_string(),
span: Span::test_data(),
}),
}, },
] ]
} }

View File

@ -166,42 +166,27 @@ impl Command for ViewSource {
Example { Example {
description: "View the source of a code block", description: "View the source of a code block",
example: r#"let abc = { echo 'hi' }; view-source $abc"#, example: r#"let abc = { echo 'hi' }; view-source $abc"#,
result: Some(Value::String { result: Some(Value::string("{ echo 'hi' }", Span::test_data())),
val: "{ echo 'hi' }".to_string(),
span: Span::test_data(),
}),
}, },
Example { Example {
description: "View the source of a custom command", description: "View the source of a custom command",
example: r#"def hi [] { echo 'Hi!' }; view-source hi"#, example: r#"def hi [] { echo 'Hi!' }; view-source hi"#,
result: Some(Value::String { result: Some(Value::string("{ echo 'Hi!' }", Span::test_data())),
val: "{ echo 'Hi!' }".to_string(),
span: Span::test_data(),
}),
}, },
Example { Example {
description: "View the source of a custom command, which participates in the caller environment", description: "View the source of a custom command, which participates in the caller environment",
example: r#"def-env foo [] { let-env BAR = 'BAZ' }; view-source foo"#, example: r#"def-env foo [] { let-env BAR = 'BAZ' }; view-source foo"#,
result: Some(Value::String { result: Some(Value::string("{ let-env BAR = 'BAZ' }", Span::test_data())),
val: "{ let-env BAR = 'BAZ' }".to_string(),
span: Span::test_data(),
}),
}, },
Example { Example {
description: "View the source of a module", description: "View the source of a module",
example: r#"module mod-foo { export-env { let-env FOO_ENV = 'BAZ' } }; view-source mod-foo"#, example: r#"module mod-foo { export-env { let-env FOO_ENV = 'BAZ' } }; view-source mod-foo"#,
result: Some(Value::String { result: Some(Value::string(" export-env { let-env FOO_ENV = 'BAZ' }", Span::test_data())),
val: " export-env { let-env FOO_ENV = 'BAZ' }".to_string(),
span: Span::test_data(),
}),
}, },
Example { Example {
description: "View the source of an alias", description: "View the source of an alias",
example: r#"alias hello = echo hi; view-source hello"#, example: r#"alias hello = echo hi; view-source hello"#,
result: Some(Value::String { result: Some(Value::string("echo hi", Span::test_data())),
val: "echo hi".to_string(),
span: Span::test_data(),
}),
}, },
] ]
} }

View File

@ -163,10 +163,7 @@ impl Command for Cd {
let path_tointo = path.clone(); let path_tointo = path.clone();
let path_value = Value::String { val: path, span }; let path_value = Value::String { val: path, span };
let cwd = Value::String { let cwd = Value::string(cwd.to_string_lossy(), call.head);
val: cwd.to_string_lossy().to_string(),
span: call.head,
};
let mut shells = get_shells(engine_state, stack, cwd); let mut shells = get_shells(engine_state, stack, cwd);
let current_shell = get_current_shell(engine_state, stack); let current_shell = get_current_shell(engine_state, stack);
@ -181,10 +178,7 @@ impl Command for Cd {
); );
stack.add_env_var( stack.add_env_var(
"NUSHELL_CURRENT_SHELL".into(), "NUSHELL_CURRENT_SHELL".into(),
Value::Int { Value::int(current_shell as i64, call.head),
val: current_shell as i64,
span: call.head,
},
); );
if let Some(oldpwd) = stack.get_env_var(engine_state, "PWD") { if let Some(oldpwd) = stack.get_env_var(engine_state, "PWD") {

View File

@ -170,13 +170,7 @@ impl Command for Watch {
if let Some(position) = block.signature.get_positional(0) { if let Some(position) = block.signature.get_positional(0) {
if let Some(position_id) = &position.var_id { if let Some(position_id) = &position.var_id {
stack.add_var( stack.add_var(*position_id, Value::string(operation, call.span()));
*position_id,
Value::String {
val: operation.to_string(),
span: call.span(),
},
);
} }
} }
@ -184,10 +178,7 @@ impl Command for Watch {
if let Some(position_id) = &position.var_id { if let Some(position_id) = &position.var_id {
stack.add_var( stack.add_var(
*position_id, *position_id,
Value::String { Value::string(path.to_string_lossy(), call.span()),
val: path.to_string_lossy().to_string(),
span: call.span(),
},
); );
} }
} }
@ -196,13 +187,10 @@ impl Command for Watch {
if let Some(position_id) = &position.var_id { if let Some(position_id) = &position.var_id {
stack.add_var( stack.add_var(
*position_id, *position_id,
Value::String { Value::string(
val: new_path new_path.unwrap_or_else(|| "".into()).to_string_lossy(),
.unwrap_or_else(|| "".into()) call.span(),
.to_string_lossy() ),
.to_string(),
span: call.span(),
},
); );
} }
} }

View File

@ -55,28 +55,16 @@ with 'transpose' first."#
fn examples(&self) -> Vec<Example> { fn examples(&self) -> Vec<Example> {
let stream_test_1 = vec![ let stream_test_1 = vec![
Value::Int { Value::int(2, Span::test_data()),
val: 2, Value::int(4, Span::test_data()),
span: Span::test_data(), Value::int(6, Span::test_data()),
},
Value::Int {
val: 4,
span: Span::test_data(),
},
Value::Int {
val: 6,
span: Span::test_data(),
},
]; ];
let stream_test_2 = vec![ let stream_test_2 = vec![
Value::Nothing { Value::Nothing {
span: Span::test_data(), span: Span::test_data(),
}, },
Value::String { Value::string("found 2!", Span::test_data()),
val: "found 2!".to_string(),
span: Span::test_data(),
},
Value::Nothing { Value::Nothing {
span: Span::test_data(), span: Span::test_data(),
}, },
@ -96,14 +84,8 @@ with 'transpose' first."#
description: "Produce a list that has \"two\" for each 2 in the input", description: "Produce a list that has \"two\" for each 2 in the input",
result: Some(Value::List { result: Some(Value::List {
vals: vec![ vals: vec![
Value::String { Value::string("two", Span::test_data()),
val: "two".to_string(), Value::string("two", Span::test_data()),
span: Span::test_data(),
},
Value::String {
val: "two".to_string(),
span: Span::test_data(),
},
], ],
span: Span::test_data(), span: Span::test_data(),
}), }),
@ -113,10 +95,7 @@ with 'transpose' first."#
description: description:
"Iterate over each element, producing a list showing indexes of any 2s", "Iterate over each element, producing a list showing indexes of any 2s",
result: Some(Value::List { result: Some(Value::List {
vals: vec![Value::String { vals: vec![Value::string("found 2 at 1!", Span::test_data())],
val: "found 2 at 1!".to_string(),
span: Span::test_data(),
}],
span: Span::test_data(), span: Span::test_data(),
}), }),
}, },

View File

@ -43,24 +43,12 @@ impl Command for EachWhile {
fn examples(&self) -> Vec<Example> { fn examples(&self) -> Vec<Example> {
let stream_test_1 = vec![ let stream_test_1 = vec![
Value::Int { Value::int(2, Span::test_data()),
val: 2, Value::int(4, Span::test_data()),
span: Span::test_data(),
},
Value::Int {
val: 4,
span: Span::test_data(),
},
]; ];
let stream_test_2 = vec![ let stream_test_2 = vec![
Value::String { Value::string("Output: 1", Span::test_data()),
val: "Output: 1".into(), Value::string("Output: 2", Span::test_data()),
span: Span::test_data(),
},
Value::String {
val: "Output: 2".into(),
span: Span::test_data(),
},
]; ];
vec![ vec![
@ -84,10 +72,7 @@ impl Command for EachWhile {
example: r#"[1 2 3] | each while {|el ind| if $el < 2 { $"value ($el) at ($ind)!"} }"#, example: r#"[1 2 3] | each while {|el ind| if $el < 2 { $"value ($el) at ($ind)!"} }"#,
description: "Iterate over each element, printing the matching value and its index", description: "Iterate over each element, printing the matching value and its index",
result: Some(Value::List { result: Some(Value::List {
vals: vec![Value::String { vals: vec![Value::string("value 1 at 0!", Span::test_data())],
val: "value 1 at 0!".to_string(),
span: Span::test_data(),
}],
span: Span::test_data(), span: Span::test_data(),
}), }),
}, },

View File

@ -43,27 +43,18 @@ impl Command for Empty {
Example { Example {
description: "Check if a string is empty", description: "Check if a string is empty",
example: "'' | is-empty", example: "'' | is-empty",
result: Some(Value::Bool { result: Some(Value::boolean(true, Span::test_data())),
val: true,
span: Span::test_data(),
}),
}, },
Example { Example {
description: "Check if a list is empty", description: "Check if a list is empty",
example: "[] | is-empty", example: "[] | is-empty",
result: Some(Value::Bool { result: Some(Value::boolean(true, Span::test_data())),
val: true,
span: Span::test_data(),
}),
}, },
Example { Example {
// TODO: revisit empty cell path semantics for a record. // TODO: revisit empty cell path semantics for a record.
description: "Check if more than one column are empty", description: "Check if more than one column are empty",
example: "[[meal size]; [arepa small] [taco '']] | is-empty meal size", example: "[[meal size]; [arepa small] [taco '']] | is-empty meal size",
result: Some(Value::Bool { result: Some(Value::boolean(false, Span::test_data())),
val: false,
span: Span::test_data(),
}),
}, },
] ]
} }
@ -84,23 +75,13 @@ fn empty(
let val = val.clone(); let val = val.clone();
match val.follow_cell_path(&column.members, false) { match val.follow_cell_path(&column.members, false) {
Ok(Value::Nothing { .. }) => {} Ok(Value::Nothing { .. }) => {}
Ok(_) => { Ok(_) => return Ok(Value::boolean(false, head).into_pipeline_data()),
return Ok(Value::Bool {
val: false,
span: head,
}
.into_pipeline_data())
}
Err(err) => return Err(err), Err(err) => return Err(err),
} }
} }
} }
Ok(Value::Bool { Ok(Value::boolean(true, head).into_pipeline_data())
val: true,
span: head,
}
.into_pipeline_data())
} else { } else {
match input { match input {
PipelineData::Empty => Ok(PipelineData::Empty), PipelineData::Empty => Ok(PipelineData::Empty),
@ -109,30 +90,18 @@ fn empty(
let bytes = s.into_bytes(); let bytes = s.into_bytes();
match bytes { match bytes {
Ok(s) => Ok(Value::Bool { Ok(s) => Ok(Value::boolean(s.item.is_empty(), head).into_pipeline_data()),
val: s.item.is_empty(),
span: head,
}
.into_pipeline_data()),
Err(err) => Err(err), Err(err) => Err(err),
} }
} }
None => Ok(Value::Bool { None => Ok(Value::boolean(true, head).into_pipeline_data()),
val: true,
span: head,
}
.into_pipeline_data()),
}, },
PipelineData::ListStream(s, ..) => Ok(Value::Bool { PipelineData::ListStream(s, ..) => {
val: s.count() == 0, Ok(Value::boolean(s.count() == 0, head).into_pipeline_data())
span: head,
} }
.into_pipeline_data()), PipelineData::Value(value, ..) => {
PipelineData::Value(value, ..) => Ok(Value::Bool { Ok(Value::boolean(value.is_empty(), head).into_pipeline_data())
val: value.is_empty(),
span: head,
} }
.into_pipeline_data()),
} }
} }
} }

View File

@ -36,27 +36,15 @@ impl Command for Group {
let stream_test_1 = vec![ let stream_test_1 = vec![
Value::List { Value::List {
vals: vec![ vals: vec![
Value::Int { Value::int(1, Span::test_data()),
val: 1, Value::int(2, Span::test_data()),
span: Span::test_data(),
},
Value::Int {
val: 2,
span: Span::test_data(),
},
], ],
span: Span::test_data(), span: Span::test_data(),
}, },
Value::List { Value::List {
vals: vec![ vals: vec![
Value::Int { Value::int(3, Span::test_data()),
val: 3, Value::int(4, Span::test_data()),
span: Span::test_data(),
},
Value::Int {
val: 4,
span: Span::test_data(),
},
], ],
span: Span::test_data(), span: Span::test_data(),
}, },

View File

@ -149,10 +149,7 @@ pub fn group_by(
} }
let value = match collection.get(0) { let value = match collection.get(0) {
Some(Value::Error { .. }) | None => Value::String { Some(Value::Error { .. }) | None => Value::string(error_key, name),
val: error_key.to_string(),
span: name,
},
Some(return_value) => return_value.clone(), Some(return_value) => return_value.clone(),
}; };

View File

@ -78,16 +78,10 @@ fn length_col(
fn length_row(call: &Call, input: PipelineData) -> Result<PipelineData, ShellError> { fn length_row(call: &Call, input: PipelineData) -> Result<PipelineData, ShellError> {
match input { match input {
PipelineData::Value(Value::Nothing { .. }, ..) => Ok(Value::Int { PipelineData::Value(Value::Nothing { .. }, ..) => {
val: 0, Ok(Value::int(0, call.head).into_pipeline_data())
span: call.head,
} }
.into_pipeline_data()), _ => Ok(Value::int(input.into_iter().count() as i64, call.head).into_pipeline_data()),
_ => Ok(Value::Int {
val: input.into_iter().count() as i64,
span: call.head,
}
.into_pipeline_data()),
} }
} }

View File

@ -173,10 +173,10 @@ impl Iterator for RawStreamLinesAdapter {
// inner is complete, feed out remaining state // inner is complete, feed out remaining state
if self.inner_complete { if self.inner_complete {
if !self.incomplete_line.is_empty() { if !self.incomplete_line.is_empty() {
let r = Some(Ok(Value::String { let r = Some(Ok(Value::string(
val: self.incomplete_line.to_string(), self.incomplete_line.to_string(),
span: self.span, self.span,
})); )));
self.incomplete_line = String::new(); self.incomplete_line = String::new();
return r; return r;
} }

View File

@ -52,10 +52,7 @@ impl Command for ParEach {
example: r#"[1 2 3] | par-each -n { |it| if $it.item == 2 { echo $"found 2 at ($it.index)!"} }"#, example: r#"[1 2 3] | par-each -n { |it| if $it.item == 2 { echo $"found 2 at ($it.index)!"} }"#,
description: "Iterate over each element, print the matching value and its index", description: "Iterate over each element, print the matching value and its index",
result: Some(Value::List { result: Some(Value::List {
vals: vec![Value::String { vals: vec![Value::string("found 2 at 1!", Span::test_data())],
val: "found 2 at 1!".to_string(),
span: Span::test_data(),
}],
span: Span::test_data(), span: Span::test_data(),
}), }),
}, },

View File

@ -54,26 +54,17 @@ impl Command for Reduce {
Example { Example {
example: "[ 1 2 3 4 ] | reduce {|it, acc| $it + $acc }", example: "[ 1 2 3 4 ] | reduce {|it, acc| $it + $acc }",
description: "Sum values of a list (same as 'math sum')", description: "Sum values of a list (same as 'math sum')",
result: Some(Value::Int { result: Some(Value::int(10, Span::test_data())),
val: 10,
span: Span::test_data(),
}),
}, },
Example { Example {
example: "[ 8 7 6 ] | reduce {|it, acc, ind| $acc + $it + $ind }", example: "[ 8 7 6 ] | reduce {|it, acc, ind| $acc + $it + $ind }",
description: "Sum values of a list, plus their indexes", description: "Sum values of a list, plus their indexes",
result: Some(Value::Int { result: Some(Value::int(22, Span::test_data())),
val: 22,
span: Span::test_data(),
}),
}, },
Example { Example {
example: "[ 1 2 3 4 ] | reduce -f 10 {|it, acc| $acc + $it }", example: "[ 1 2 3 4 ] | reduce -f 10 {|it, acc| $acc + $it }",
description: "Sum values with a starting value (fold)", description: "Sum values with a starting value (fold)",
result: Some(Value::Int { result: Some(Value::int(20, Span::test_data())),
val: 20,
span: Span::test_data(),
}),
}, },
Example { Example {
example: r#"[ i o t ] | reduce -f "Arthur, King of the Britons" {|it, acc| $acc | str replace -a $it "X" }"#, example: r#"[ i o t ] | reduce -f "Arthur, King of the Britons" {|it, acc| $acc | str replace -a $it "X" }"#,

View File

@ -68,10 +68,7 @@ impl Command for Reject {
example: "{a: 1, b: 2} | reject a", example: "{a: 1, b: 2} | reject a",
result: Some(Value::Record { result: Some(Value::Record {
cols: vec!["b".into()], cols: vec!["b".into()],
vals: vec![Value::Int { vals: vec![Value::int(2, Span::test_data())],
val: 2,
span: Span::test_data(),
}],
span: Span::test_data(), span: Span::test_data(),
}), }),
}, },
@ -82,10 +79,7 @@ impl Command for Reject {
cols: vec!["a".into()], cols: vec!["a".into()],
vals: vec![Value::Record { vals: vec![Value::Record {
cols: vec!["c".into()], cols: vec!["c".into()],
vals: vec![Value::Int { vals: vec![Value::int(5, Span::test_data())],
val: 5,
span: Span::test_data(),
}],
span: Span::test_data(), span: Span::test_data(),
}], }],
span: Span::test_data(), span: Span::test_data(),

View File

@ -313,10 +313,7 @@ pub fn rotate(
for (idx, val) in columns_iter { for (idx, val) in columns_iter {
// when rotating counter clockwise, the old columns names become the first column's values // when rotating counter clockwise, the old columns names become the first column's values
let mut res = if ccw { let mut res = if ccw {
vec![Value::String { vec![Value::string(val, call.head)]
val: val.to_string(),
span: call.head,
}]
} else { } else {
vec![] vec![]
}; };
@ -329,10 +326,7 @@ pub fn rotate(
} }
// when rotating clockwise, the old column names become the last column's values // when rotating clockwise, the old column names become the last column's values
if !ccw { if !ccw {
res.push(Value::String { res.push(Value::string(val, call.head));
val: val.to_string(),
span: call.head,
});
} }
res.to_vec() res.to_vec()
}; };

View File

@ -206,13 +206,7 @@ fn generate_results_with_count(head: Span, uniq_values: Vec<ValueCounter>) -> Ve
.into_iter() .into_iter()
.map(|item| Value::Record { .map(|item| Value::Record {
cols: vec!["value".to_string(), "count".to_string()], cols: vec!["value".to_string(), "count".to_string()],
vals: vec![ vals: vec![item.val, Value::int(item.count, head)],
item.val,
Value::Int {
val: item.count,
span: head,
},
],
span: head, span: head,
}) })
.collect() .collect()

View File

@ -43,40 +43,22 @@ impl Command for Window {
let stream_test_1 = vec![ let stream_test_1 = vec![
Value::List { Value::List {
vals: vec![ vals: vec![
Value::Int { Value::int(1, Span::test_data()),
val: 1, Value::int(2, Span::test_data()),
span: Span::test_data(),
},
Value::Int {
val: 2,
span: Span::test_data(),
},
], ],
span: Span::test_data(), span: Span::test_data(),
}, },
Value::List { Value::List {
vals: vec![ vals: vec![
Value::Int { Value::int(2, Span::test_data()),
val: 2, Value::int(3, Span::test_data()),
span: Span::test_data(),
},
Value::Int {
val: 3,
span: Span::test_data(),
},
], ],
span: Span::test_data(), span: Span::test_data(),
}, },
Value::List { Value::List {
vals: vec![ vals: vec![
Value::Int { Value::int(3, Span::test_data()),
val: 3, Value::int(4, Span::test_data()),
span: Span::test_data(),
},
Value::Int {
val: 4,
span: Span::test_data(),
},
], ],
span: Span::test_data(), span: Span::test_data(),
}, },
@ -85,40 +67,22 @@ impl Command for Window {
let stream_test_2 = vec![ let stream_test_2 = vec![
Value::List { Value::List {
vals: vec![ vals: vec![
Value::Int { Value::int(1, Span::test_data()),
val: 1, Value::int(2, Span::test_data()),
span: Span::test_data(),
},
Value::Int {
val: 2,
span: Span::test_data(),
},
], ],
span: Span::test_data(), span: Span::test_data(),
}, },
Value::List { Value::List {
vals: vec![ vals: vec![
Value::Int { Value::int(4, Span::test_data()),
val: 4, Value::int(5, Span::test_data()),
span: Span::test_data(),
},
Value::Int {
val: 5,
span: Span::test_data(),
},
], ],
span: Span::test_data(), span: Span::test_data(),
}, },
Value::List { Value::List {
vals: vec![ vals: vec![
Value::Int { Value::int(7, Span::test_data()),
val: 7, Value::int(8, Span::test_data()),
span: Span::test_data(),
},
Value::Int {
val: 8,
span: Span::test_data(),
},
], ],
span: Span::test_data(), span: Span::test_data(),
}, },
@ -127,31 +91,16 @@ impl Command for Window {
let stream_test_3 = vec![ let stream_test_3 = vec![
Value::List { Value::List {
vals: vec![ vals: vec![
Value::Int { Value::int(1, Span::test_data()),
val: 1, Value::int(2, Span::test_data()),
span: Span::test_data(), Value::int(3, Span::test_data()),
},
Value::Int {
val: 2,
span: Span::test_data(),
},
Value::Int {
val: 3,
span: Span::test_data(),
},
], ],
span: Span::test_data(), span: Span::test_data(),
}, },
Value::List { Value::List {
vals: vec![ vals: vec![
Value::Int { Value::int(4, Span::test_data()),
val: 4, Value::int(5, Span::test_data()),
span: Span::test_data(),
},
Value::Int {
val: 5,
span: Span::test_data(),
},
], ],
span: Span::test_data(), span: Span::test_data(),
}, },

View File

@ -37,42 +37,24 @@ impl Command for Zip {
fn examples(&self) -> Vec<Example> { fn examples(&self) -> Vec<Example> {
let test_row_1 = Value::List { let test_row_1 = Value::List {
vals: vec![ vals: vec![
Value::Int { Value::int(1, Span::test_data()),
val: 1, Value::int(4, Span::test_data()),
span: Span::test_data(),
},
Value::Int {
val: 4,
span: Span::test_data(),
},
], ],
span: Span::test_data(), span: Span::test_data(),
}; };
let test_row_2 = Value::List { let test_row_2 = Value::List {
vals: vec![ vals: vec![
Value::Int { Value::int(2, Span::test_data()),
val: 2, Value::int(5, Span::test_data()),
span: Span::test_data(),
},
Value::Int {
val: 5,
span: Span::test_data(),
},
], ],
span: Span::test_data(), span: Span::test_data(),
}; };
let test_row_3 = Value::List { let test_row_3 = Value::List {
vals: vec![ vals: vec![
Value::Int { Value::int(3, Span::test_data()),
val: 3, Value::int(6, Span::test_data()),
span: Span::test_data(),
},
Value::Int {
val: 6,
span: Span::test_data(),
},
], ],
span: Span::test_data(), span: Span::test_data(),
}; };

View File

@ -168,10 +168,7 @@ fn headerfieldvalue_to_value(head: Span, value: &HeaderFieldValue) -> Value {
.collect(), .collect(),
span: head, span: head,
}, },
Unstructured(s) => Value::String { Unstructured(s) => Value::string(s, head),
val: s.to_string(),
span: head,
},
Empty => Value::nothing(head), Empty => Value::nothing(head),
} }
} }

View File

@ -34,14 +34,8 @@ b=2' | from ini",
vals: vec![Value::Record { vals: vec![Value::Record {
cols: vec!["a".to_string(), "b".to_string()], cols: vec!["a".to_string(), "b".to_string()],
vals: vec![ vals: vec![
Value::String { Value::string("1", Span::test_data()),
val: "1".to_string(), Value::string("2", Span::test_data()),
span: Span::test_data(),
},
Value::String {
val: "2".to_string(),
span: Span::test_data(),
},
], ],
span: Span::test_data(), span: Span::test_data(),
}], }],

View File

@ -31,10 +31,7 @@ impl Command for FromJson {
description: "Converts json formatted string to table", description: "Converts json formatted string to table",
result: Some(Value::Record { result: Some(Value::Record {
cols: vec!["a".to_string()], cols: vec!["a".to_string()],
vals: vec![Value::Int { vals: vec![Value::int(1, Span::test_data())],
val: 1,
span: Span::test_data(),
}],
span: Span::test_data(), span: Span::test_data(),
}), }),
}, },
@ -44,20 +41,11 @@ impl Command for FromJson {
result: Some(Value::Record { result: Some(Value::Record {
cols: vec!["a".to_string(), "b".to_string()], cols: vec!["a".to_string(), "b".to_string()],
vals: vec![ vals: vec![
Value::Int { Value::int(1, Span::test_data()),
val: 1,
span: Span::test_data(),
},
Value::List { Value::List {
vals: vec![ vals: vec![
Value::Int { Value::int(1, Span::test_data()),
val: 1, Value::int(2, Span::test_data()),
span: Span::test_data(),
},
Value::Int {
val: 2,
span: Span::test_data(),
},
], ],
span: Span::test_data(), span: Span::test_data(),
}, },

View File

@ -29,10 +29,7 @@ impl Command for FromNuon {
description: "Converts nuon formatted string to table", description: "Converts nuon formatted string to table",
result: Some(Value::Record { result: Some(Value::Record {
cols: vec!["a".to_string()], cols: vec!["a".to_string()],
vals: vec![Value::Int { vals: vec![Value::int(1, Span::test_data())],
val: 1,
span: Span::test_data(),
}],
span: Span::test_data(), span: Span::test_data(),
}), }),
}, },
@ -42,20 +39,11 @@ impl Command for FromNuon {
result: Some(Value::Record { result: Some(Value::Record {
cols: vec!["a".to_string(), "b".to_string()], cols: vec!["a".to_string(), "b".to_string()],
vals: vec![ vals: vec![
Value::Int { Value::int(1, Span::test_data()),
val: 1,
span: Span::test_data(),
},
Value::List { Value::List {
vals: vec![ vals: vec![
Value::Int { Value::int(1, Span::test_data()),
val: 1, Value::int(2, Span::test_data()),
span: Span::test_data(),
},
Value::Int {
val: 2,
span: Span::test_data(),
},
], ],
span: Span::test_data(), span: Span::test_data(),
}, },

View File

@ -133,18 +133,9 @@ fn from_ods(
let value = match cell { let value = match cell {
DataType::Empty => Value::nothing(head), DataType::Empty => Value::nothing(head),
DataType::String(s) => Value::string(s, head), DataType::String(s) => Value::string(s, head),
DataType::Float(f) => Value::Float { DataType::Float(f) => Value::float(*f, head),
val: *f, DataType::Int(i) => Value::int(*i, head),
span: head, DataType::Bool(b) => Value::boolean(*b, head),
},
DataType::Int(i) => Value::Int {
val: *i,
span: head,
},
DataType::Bool(b) => Value::Bool {
val: *b,
span: head,
},
_ => Value::nothing(head), _ => Value::nothing(head),
}; };

View File

@ -44,13 +44,13 @@ impl Command for FromSsv {
example: r#"'FOO BAR example: r#"'FOO BAR
1 2' | from ssv"#, 1 2' | from ssv"#,
description: "Converts ssv formatted string to table", description: "Converts ssv formatted string to table",
result: Some(Value::List { vals: vec![Value::Record { cols: vec!["FOO".to_string(), "BAR".to_string()], vals: vec![Value::String { val: "1".to_string(), span: Span::test_data() }, Value::String { val: "2".to_string(), span: Span::test_data() }], span: Span::test_data() }], span: Span::test_data() }), result: Some(Value::List { vals: vec![Value::Record { cols: vec!["FOO".to_string(), "BAR".to_string()], vals: vec![Value::string("1", Span::test_data()), Value::string("2", Span::test_data())], span: Span::test_data() }], span: Span::test_data() }),
}, Example { }, Example {
example: r#"'FOO BAR example: r#"'FOO BAR
1 2' | from ssv -n"#, 1 2' | from ssv -n"#,
description: "Converts ssv formatted string to table but not treating the first row as column names", description: "Converts ssv formatted string to table but not treating the first row as column names",
result: Some( result: Some(
Value::List { vals: vec![Value::Record { cols: vec!["column1".to_string(), "column2".to_string()], vals: vec![Value::String { val: "FOO".to_string(), span: Span::test_data() }, Value::String { val: "BAR".to_string(), span: Span::test_data() }], span: Span::test_data() }, Value::Record { cols: vec!["column1".to_string(), "column2".to_string()], vals: vec![Value::String { val: "1".to_string(), span: Span::test_data() }, Value::String { val: "2".to_string(), span: Span::test_data() }], span: Span::test_data() }], span: Span::test_data() }), Value::List { vals: vec![Value::Record { cols: vec!["column1".to_string(), "column2".to_string()], vals: vec![Value::string("FOO", Span::test_data()), Value::string("BAR", Span::test_data())], span: Span::test_data() }, Value::Record { cols: vec!["column1".to_string(), "column2".to_string()], vals: vec![Value::string("1", Span::test_data()), Value::string("2", Span::test_data())], span: Span::test_data() }], span: Span::test_data() }),
}] }]
} }

View File

@ -29,10 +29,7 @@ impl Command for FromToml {
description: "Converts toml formatted string to record", description: "Converts toml formatted string to record",
result: Some(Value::Record { result: Some(Value::Record {
cols: vec!["a".to_string()], cols: vec!["a".to_string()],
vals: vec![Value::Int { vals: vec![Value::int(1, Span::test_data())],
val: 1,
span: Span::test_data(),
}],
span: Span::test_data(), span: Span::test_data(),
}), }),
}, },
@ -43,20 +40,11 @@ b = [1, 2]' | from toml",
result: Some(Value::Record { result: Some(Value::Record {
cols: vec!["a".to_string(), "b".to_string()], cols: vec!["a".to_string(), "b".to_string()],
vals: vec![ vals: vec![
Value::Int { Value::int(1, Span::test_data()),
val: 1,
span: Span::test_data(),
},
Value::List { Value::List {
vals: vec![ vals: vec![
Value::Int { Value::int(1, Span::test_data()),
val: 1, Value::int(2, Span::test_data()),
span: Span::test_data(),
},
Value::Int {
val: 2,
span: Span::test_data(),
},
], ],
span: Span::test_data(), span: Span::test_data(),
}, },

View File

@ -57,14 +57,8 @@ END:VCARD' | from vcf",
"params".to_string(), "params".to_string(),
], ],
vals: vec![ vals: vec![
Value::String { Value::string("N", Span::test_data()),
val: "N".to_string(), Value::string("Foo", Span::test_data()),
span: Span::test_data(),
},
Value::String {
val: "Foo".to_string(),
span: Span::test_data(),
},
Value::Nothing { Value::Nothing {
span: Span::test_data(), span: Span::test_data(),
}, },
@ -78,14 +72,8 @@ END:VCARD' | from vcf",
"params".to_string(), "params".to_string(),
], ],
vals: vec![ vals: vec![
Value::String { Value::string("FN", Span::test_data()),
val: "FN".to_string(), Value::string("Bar", Span::test_data()),
span: Span::test_data(),
},
Value::String {
val: "Bar".to_string(),
span: Span::test_data(),
},
Value::Nothing { Value::Nothing {
span: Span::test_data(), span: Span::test_data(),
}, },
@ -99,14 +87,8 @@ END:VCARD' | from vcf",
"params".to_string(), "params".to_string(),
], ],
vals: vec![ vals: vec![
Value::String { Value::string("EMAIL", Span::test_data()),
val: "EMAIL".to_string(), Value::string("foo@bar.com", Span::test_data()),
span: Span::test_data(),
},
Value::String {
val: "foo@bar.com".to_string(),
span: Span::test_data(),
},
Value::Nothing { Value::Nothing {
span: Span::test_data(), span: Span::test_data(),
}, },

View File

@ -133,18 +133,9 @@ fn from_xlsx(
let value = match cell { let value = match cell {
DataType::Empty => Value::nothing(head), DataType::Empty => Value::nothing(head),
DataType::String(s) => Value::string(s, head), DataType::String(s) => Value::string(s, head),
DataType::Float(f) => Value::Float { DataType::Float(f) => Value::float(*f, head),
val: *f, DataType::Int(i) => Value::int(*i, head),
span: head, DataType::Bool(b) => Value::boolean(*b, head),
},
DataType::Int(i) => Value::Int {
val: *i,
span: head,
},
DataType::Bool(b) => Value::Bool {
val: *b,
span: head,
},
_ => Value::nothing(head), _ => Value::nothing(head),
}; };

View File

@ -54,10 +54,7 @@ impl Command for FromXml {
cols: vec!["children".to_string(), "attributes".to_string()], cols: vec!["children".to_string(), "attributes".to_string()],
vals: vec![ vals: vec![
Value::List { Value::List {
vals: vec![Value::String { vals: vec![Value::string("Event", Span::test_data())],
val: "Event".to_string(),
span: Span::test_data(),
}],
span: Span::test_data(), span: Span::test_data(),
}, },
Value::Record { Value::Record {
@ -201,10 +198,7 @@ mod tests {
use nu_protocol::{Spanned, Value}; use nu_protocol::{Spanned, Value};
fn string(input: impl Into<String>) -> Value { fn string(input: impl Into<String>) -> Value {
Value::String { Value::string(input, Span::test_data())
val: input.into(),
span: Span::test_data(),
}
} }
fn row(entries: IndexMap<String, Value>) -> Value { fn row(entries: IndexMap<String, Value>) -> Value {

View File

@ -181,10 +181,7 @@ pub fn get_examples() -> Vec<Example> {
description: "Converts yaml formatted string to table", description: "Converts yaml formatted string to table",
result: Some(Value::Record { result: Some(Value::Record {
cols: vec!["a".to_string()], cols: vec!["a".to_string()],
vals: vec![Value::Int { vals: vec![Value::int(1, Span::test_data())],
val: 1,
span: Span::test_data(),
}],
span: Span::test_data(), span: Span::test_data(),
}), }),
}, },
@ -240,10 +237,7 @@ mod test {
input: r#"value: "{{ something }}""#, input: r#"value: "{{ something }}""#,
expected: Ok(Value::Record { expected: Ok(Value::Record {
cols: vec!["value".to_string()], cols: vec!["value".to_string()],
vals: vec![Value::String { vals: vec![Value::string("{{ something }}", Span::test_data())],
val: "{{ something }}".to_string(),
span: Span::test_data(),
}],
span: Span::test_data(), span: Span::test_data(),
}), }),
}, },
@ -252,10 +246,7 @@ mod test {
input: r#"value: {{ something }}"#, input: r#"value: {{ something }}"#,
expected: Ok(Value::Record { expected: Ok(Value::Record {
cols: vec!["value".to_string()], cols: vec!["value".to_string()],
vals: vec![Value::String { vals: vec![Value::string("{{ something }}", Span::test_data())],
val: "{{ something }}".to_string(),
span: Span::test_data(),
}],
span: Span::test_data(), span: Span::test_data(),
}), }),
}, },

View File

@ -307,20 +307,14 @@ fn add_month_to_table(
if should_show_year_column { if should_show_year_column {
indexmap.insert( indexmap.insert(
"year".to_string(), "year".to_string(),
Value::Int { Value::int(month_helper.selected_year as i64, tag),
val: month_helper.selected_year as i64,
span: tag,
},
); );
} }
if should_show_quarter_column { if should_show_quarter_column {
indexmap.insert( indexmap.insert(
"quarter".to_string(), "quarter".to_string(),
Value::Int { Value::int(month_helper.quarter_number as i64, tag),
val: month_helper.quarter_number as i64,
span: tag,
},
); );
} }
@ -331,10 +325,7 @@ fn add_month_to_table(
span: tag, span: tag,
} }
} else { } else {
Value::Int { Value::int(month_helper.selected_month as i64, tag)
val: month_helper.selected_month as i64,
span: tag,
}
}; };
indexmap.insert("month".to_string(), month_value); indexmap.insert("month".to_string(), month_value);
@ -349,10 +340,7 @@ fn add_month_to_table(
if should_add_day_number_to_table { if should_add_day_number_to_table {
let adjusted_day_number = day_number - total_start_offset; let adjusted_day_number = day_number - total_start_offset;
value = Value::Int { value = Value::int(adjusted_day_number as i64, tag);
val: adjusted_day_number as i64,
span: tag,
};
if let Some(current_day) = current_day_option { if let Some(current_day) = current_day_option {
if current_day == adjusted_day_number { if current_day == adjusted_day_number {

View File

@ -187,10 +187,7 @@ impl Iterator for FloatSeq {
return None; return None;
} }
self.index += 1; self.index += 1;
Some(Value::Float { Some(Value::float(count, self.span))
val: count,
span: self.span,
})
} }
} }
@ -208,10 +205,7 @@ impl Iterator for IntSeq {
{ {
return None; return None;
} }
let ret = Some(Value::Int { let ret = Some(Value::int(self.count, self.span));
val: self.count,
span: self.span,
});
self.count += self.step; self.count += self.step;
ret ret
} }

View File

@ -46,10 +46,7 @@ impl Command for SubCommand {
result: Some(Value::List { result: Some(Value::List {
vals: vec![ vals: vec![
Value::test_int(50), Value::test_int(50),
Value::Float { Value::float(100.0, Span::test_data()),
val: 100.0,
span: Span::test_data(),
},
Value::test_int(25), Value::test_int(25),
], ],
span: Span::test_data(), span: Span::test_data(),

View File

@ -40,24 +40,14 @@ impl Command for SubCommand {
vec![Example { vec![Example {
description: "Compute the average of a list of numbers", description: "Compute the average of a list of numbers",
example: "[-50 100.0 25] | math avg", example: "[-50 100.0 25] | math avg",
result: Some(Value::Float { result: Some(Value::float(25.0, Span::test_data())),
val: 25.0,
span: Span::test_data(),
}),
}] }]
} }
} }
pub fn average(values: &[Value], head: &Span) -> Result<Value, ShellError> { pub fn average(values: &[Value], head: &Span) -> Result<Value, ShellError> {
let sum = reducer_for(Reduce::Summation); let sum = reducer_for(Reduce::Summation);
let total = &sum( let total = &sum(Value::int(0, *head), values.to_vec(), *head)?;
Value::Int {
val: 0,
span: *head,
},
values.to_vec(),
*head,
)?;
match total { match total {
Value::Filesize { val, span } => Ok(Value::Filesize { Value::Filesize { val, span } => Ok(Value::Filesize {
val: val / values.len() as i64, val: val / values.len() as i64,
@ -67,14 +57,7 @@ pub fn average(values: &[Value], head: &Span) -> Result<Value, ShellError> {
val: val / values.len() as i64, val: val / values.len() as i64,
span: *span, span: *span,
}), }),
_ => total.div( _ => total.div(*head, &Value::int(values.len() as i64, *head), *head),
*head,
&Value::Int {
val: values.len() as i64,
span: *head,
},
*head,
),
} }
} }

View File

@ -40,11 +40,7 @@ impl Command for SubCommand {
call: &Call, call: &Call,
_input: PipelineData, _input: PipelineData,
) -> Result<nu_protocol::PipelineData, nu_protocol::ShellError> { ) -> Result<nu_protocol::PipelineData, nu_protocol::ShellError> {
Ok(Value::Float { Ok(Value::float(std::f64::consts::E, call.head).into_pipeline_data())
val: std::f64::consts::E,
span: call.head,
}
.into_pipeline_data())
} }
} }

View File

@ -47,10 +47,7 @@ impl Command for SubCommand {
vec![Example { vec![Example {
description: "Evaluate math in the pipeline", description: "Evaluate math in the pipeline",
example: "'10 / 4' | math eval", example: "'10 / 4' | math eval",
result: Some(Value::Float { result: Some(Value::float(2.5, Span::test_data())),
val: 2.5,
span: Span::test_data(),
}),
}] }]
} }
} }
@ -104,10 +101,7 @@ pub fn parse(math_expression: &str, span: &Span) -> Result<Value, String> {
ctx.var("tau", std::f64::consts::TAU); ctx.var("tau", std::f64::consts::TAU);
match meval::eval_str_with_context(math_expression, &ctx) { match meval::eval_str_with_context(math_expression, &ctx) {
Ok(num) if num.is_infinite() || num.is_nan() => Err("cannot represent result".to_string()), Ok(num) if num.is_infinite() || num.is_nan() => Err("cannot represent result".to_string()),
Ok(num) => Ok(Value::Float { Ok(num) => Ok(Value::float(num, *span)),
val: num,
span: *span,
}),
Err(error) => Err(error.to_string().to_lowercase()), Err(error) => Err(error.to_string().to_lowercase()),
} }
} }

View File

@ -46,10 +46,7 @@ impl Command for SubCommand {
Example { Example {
description: "Compute the median of a list of numbers", description: "Compute the median of a list of numbers",
example: "[3 8 9 12 12 15] | math median", example: "[3 8 9 12 12 15] | math median",
result: Some(Value::Float { result: Some(Value::float(10.5, Span::test_data())),
val: 10.5,
span: Span::test_data(),
}),
}, },
Example { Example {
description: "Compute the medians of the columns of a table", description: "Compute the medians of the columns of a table",

View File

@ -171,14 +171,8 @@ pub fn mode(values: &[Value], head: &Span) -> Result<Value, ShellError> {
fn recreate_value(hashable_value: &HashableType, head: Span) -> Value { fn recreate_value(hashable_value: &HashableType, head: Span) -> Value {
let bytes = hashable_value.bytes; let bytes = hashable_value.bytes;
match &hashable_value.original_type { match &hashable_value.original_type {
NumberTypes::Int => Value::Int { NumberTypes::Int => Value::int(i64::from_ne_bytes(bytes), head),
val: i64::from_ne_bytes(bytes), NumberTypes::Float => Value::float(f64::from_ne_bytes(bytes), head),
span: head,
},
NumberTypes::Float => Value::Float {
val: f64::from_ne_bytes(bytes),
span: head,
},
NumberTypes::Duration => Value::Duration { NumberTypes::Duration => Value::Duration {
val: i64::from_ne_bytes(bytes), val: i64::from_ne_bytes(bytes),
span: head, span: head,

View File

@ -40,11 +40,7 @@ impl Command for SubCommand {
call: &Call, call: &Call,
_input: PipelineData, _input: PipelineData,
) -> Result<nu_protocol::PipelineData, nu_protocol::ShellError> { ) -> Result<nu_protocol::PipelineData, nu_protocol::ShellError> {
Ok(Value::Float { Ok(Value::float(std::f64::consts::PI, call.head).into_pipeline_data())
val: std::f64::consts::PI,
span: call.head,
}
.into_pipeline_data())
} }
} }

View File

@ -80,10 +80,7 @@ pub fn sum(data: Vec<Value>, head: Span) -> Result<Value, ShellError> {
val: 0, val: 0,
span: *span, span: *span,
}), }),
Some(Value::Int { span, .. }) | Some(Value::Float { span, .. }) => Ok(Value::Int { Some(Value::Int { span, .. }) | Some(Value::Float { span, .. }) => Ok(Value::int(0, *span)),
val: 0,
span: *span,
}),
None => Err(ShellError::UnsupportedInput( None => Err(ShellError::UnsupportedInput(
"Empty input".to_string(), "Empty input".to_string(),
head, head,
@ -114,10 +111,7 @@ pub fn product(data: Vec<Value>, head: Span) -> Result<Value, ShellError> {
let initial_value = data.get(0); let initial_value = data.get(0);
let mut acc = match initial_value { let mut acc = match initial_value {
Some(Value::Int { span, .. }) | Some(Value::Float { span, .. }) => Ok(Value::Int { Some(Value::Int { span, .. }) | Some(Value::Float { span, .. }) => Ok(Value::int(1, *span)),
val: 1,
span: *span,
}),
None => Err(ShellError::UnsupportedInput( None => Err(ShellError::UnsupportedInput(
"Empty input".to_string(), "Empty input".to_string(),
head, head,

View File

@ -64,18 +64,9 @@ impl Command for SubCommand {
example: "[1.555 2.333 -3.111] | math round -p 2", example: "[1.555 2.333 -3.111] | math round -p 2",
result: Some(Value::List { result: Some(Value::List {
vals: vec![ vals: vec![
Value::Float { Value::float(1.56, Span::test_data()),
val: 1.56, Value::float(2.33, Span::test_data()),
span: Span::test_data(), Value::float(-3.11, Span::test_data()),
},
Value::Float {
val: 2.33,
span: Span::test_data(),
},
Value::Float {
val: -3.11,
span: Span::test_data(),
},
], ],
span: Span::test_data(), span: Span::test_data(),
}), }),

View File

@ -54,18 +54,12 @@ impl Command for SubCommand {
Example { Example {
description: "Compute the standard deviation of a list of numbers", description: "Compute the standard deviation of a list of numbers",
example: "[1 2 3 4 5] | math stddev", example: "[1 2 3 4 5] | math stddev",
result: Some(Value::Float { result: Some(Value::float(std::f64::consts::SQRT_2, Span::test_data())),
val: std::f64::consts::SQRT_2,
span: Span::test_data(),
}),
}, },
Example { Example {
description: "Compute the sample standard deviation of a list of numbers", description: "Compute the sample standard deviation of a list of numbers",
example: "[1 2 3 4 5] | math stddev -s", example: "[1 2 3 4 5] | math stddev -s",
result: Some(Value::Float { result: Some(Value::float(1.5811388300841898, Span::test_data())),
val: 1.5811388300841898,
span: Span::test_data(),
}),
}, },
] ]
} }

View File

@ -40,11 +40,7 @@ impl Command for SubCommand {
call: &Call, call: &Call,
_input: PipelineData, _input: PipelineData,
) -> Result<nu_protocol::PipelineData, nu_protocol::ShellError> { ) -> Result<nu_protocol::PipelineData, nu_protocol::ShellError> {
Ok(Value::Float { Ok(Value::float(std::f64::consts::TAU, call.head).into_pipeline_data())
val: std::f64::consts::TAU,
span: call.head,
}
.into_pipeline_data())
} }
} }

View File

@ -46,36 +46,21 @@ impl Command for SubCommand {
Example { Example {
description: "Get the variance of a list of numbers", description: "Get the variance of a list of numbers",
example: "echo [1 2 3 4 5] | math variance", example: "echo [1 2 3 4 5] | math variance",
result: Some(Value::Float { result: Some(Value::float(2.0, Span::test_data())),
val: 2.0,
span: Span::test_data(),
}),
}, },
Example { Example {
description: "Get the sample variance of a list of numbers", description: "Get the sample variance of a list of numbers",
example: "[1 2 3 4 5] | math variance -s", example: "[1 2 3 4 5] | math variance -s",
result: Some(Value::Float { result: Some(Value::float(2.5, Span::test_data())),
val: 2.5,
span: Span::test_data(),
}),
}, },
] ]
} }
} }
fn sum_of_squares(values: &[Value], span: &Span) -> Result<Value, ShellError> { fn sum_of_squares(values: &[Value], span: &Span) -> Result<Value, ShellError> {
let n = Value::Int { let n = Value::int(values.len() as i64, *span);
val: values.len() as i64, let mut sum_x = Value::int(0, *span);
span: *span, let mut sum_x2 = Value::int(0, *span);
};
let mut sum_x = Value::Int {
val: 0,
span: *span,
};
let mut sum_x2 = Value::Int {
val: 0,
span: *span,
};
for value in values { for value in values {
let v = match &value { let v = match &value {
Value::Int { .. } Value::Int { .. }
@ -116,10 +101,7 @@ pub fn compute_variance(sample: bool) -> impl Fn(&[Value], &Span) -> Result<Valu
)), )),
other => other, other => other,
}?; }?;
let n = Value::Int { let n = Value::int(n as i64, *span);
val: n as i64,
span: *span,
};
ss.div(*span, &n, *span) ss.div(*span, &n, *span)
} }
} }

View File

@ -93,10 +93,7 @@ impl Command for History {
val: entry.command_line, val: entry.command_line,
span: head, span: head,
}, },
Value::Int { Value::int(idx as i64, head),
val: idx as i64,
span: head,
},
], ],
span: head, span: head,
}) })
@ -183,14 +180,8 @@ impl Command for History {
}, },
span: head, span: head,
}, },
Value::Int { Value::int(entry.exit_status.unwrap_or(0), head),
val: entry.exit_status.unwrap_or(0), Value::int(idx as i64, head),
span: head,
},
Value::Int {
val: idx as i64,
span: head,
},
], ],
span: head, span: head,
}) })

View File

@ -418,11 +418,7 @@ fn display(help: &str, engine_state: &EngineState, stack: &mut Stack, span: Span
engine_state, engine_state,
stack, stack,
&Call::new(span), &Call::new(span),
Value::String { Value::string(item, Span::unknown()).into_pipeline_data(),
val: item.to_string(),
span: Span::unknown(),
}
.into_pipeline_data(),
) { ) {
let result = output.into_value(Span::unknown()); let result = output.into_value(Span::unknown());
match result.as_string() { match result.as_string() {

View File

@ -50,10 +50,7 @@ impl Command for SubCommand {
Example { Example {
description: "get a free port between 3121 and 4000", description: "get a free port between 3121 and 4000",
example: "port 3121 4000", example: "port 3121 4000",
result: Some(Value::Int { result: Some(Value::int(3121, Span::test_data())),
val: 3121,
span: Span::test_data(),
}),
}, },
Example { Example {
description: "get a free port from system", description: "get a free port from system",
@ -101,9 +98,5 @@ fn get_free_port(
}; };
let free_port = listener.local_addr()?.port(); let free_port = listener.local_addr()?.port();
Ok(Value::Int { Ok(Value::int(free_port as i64, call.head).into_pipeline_data())
val: free_port as i64,
span: call.head,
}
.into_pipeline_data())
} }

View File

@ -69,10 +69,7 @@ If you need to distinguish dirs and files, please use `path type`."#
Example { Example {
description: "Check if a file exists", description: "Check if a file exists",
example: "'C:\\Users\\joe\\todo.txt' | path exists", example: "'C:\\Users\\joe\\todo.txt' | path exists",
result: Some(Value::Bool { result: Some(Value::boolean(false, Span::test_data())),
val: false,
span: Span::test_data(),
}),
}, },
Example { Example {
description: "Check if a file exists in a column", description: "Check if a file exists in a column",
@ -88,10 +85,7 @@ If you need to distinguish dirs and files, please use `path type`."#
Example { Example {
description: "Check if a file exists", description: "Check if a file exists",
example: "'/home/joe/todo.txt' | path exists", example: "'/home/joe/todo.txt' | path exists",
result: Some(Value::Bool { result: Some(Value::boolean(false, Span::test_data())),
val: false,
span: Span::test_data(),
}),
}, },
Example { Example {
description: "Check if a file exists in a column", description: "Check if a file exists in a column",

View File

@ -95,15 +95,9 @@ fn get_records(entry_type: &str, span: &Span) -> Vec<Value> {
} }
fn convert_to_record(edit: &str, entry_type: &str, span: &Span) -> Value { fn convert_to_record(edit: &str, entry_type: &str, span: &Span) -> Value {
let entry_type = Value::String { let entry_type = Value::string(entry_type, *span);
val: entry_type.to_string(),
span: *span,
};
let name = Value::String { let name = Value::string(edit, *span);
val: edit.to_string(),
span: *span,
};
Value::Record { Value::Record {
cols: vec!["type".to_string(), "name".to_string()], cols: vec!["type".to_string(), "name".to_string()],

View File

@ -56,14 +56,8 @@ impl Command for TermSize {
Ok(Value::Record { Ok(Value::Record {
cols: vec!["columns".into(), "rows".into()], cols: vec!["columns".into(), "rows".into()],
vals: vec![ vals: vec![
Value::Int { Value::int(cols.0 as i64, Span::test_data()),
val: cols.0 as i64, Value::int(rows.0 as i64, Span::test_data()),
span: Span::test_data(),
},
Value::Int {
val: rows.0 as i64,
span: Span::test_data(),
},
], ],
span: head, span: head,
} }

Some files were not shown because too many files have changed in this diff Show More