mirror of
https://github.com/nushell/nushell.git
synced 2025-08-09 14:15:53 +02:00
Math commands can work with bounded ranges and produce list of numbers (#15319)
No associated issue, but follows up #15135. See also discussion on [discord](https://discord.com/channels/601130461678272522/1349139634281513093/1349139639356624966) with @sholderbach # Description ### Math commands `range -> list<number>` This enables the following math commands: - abs - ceil - floor - log - round to work with ranges. When a range is given, the command will apply the command on each item of the range, thus producing a list of number as output. Example  The commands still do not work work with unbounded ranges:  And I left out the "mode" command because I think it does not make sense to use it on ranges... ### Math commands `range -> number` This was the topic of my previous PR, but for whatever reason I didn't do `math variance` and `math stddev`. I had to use `input.try_expand_range` to convert the range into a list before computing the variance/stddev.  And same, does not work in infinite ranges:  ### Also done: - find link in documentation # User-Facing Changes - Command signatures changes - ability to use some commands with unbounded ranges - ability to use variance and stddev with bounded ranges # Tests + Formatting Cargo fmt and clippy OK Tests OK # After Submitting I guess nothing, or maybe release notes?
This commit is contained in:
@ -7,8 +7,16 @@ fn const_ceil() {
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn cannot_ceil_range() {
|
||||
let actual = nu!("0..5 | math ceil");
|
||||
fn can_ceil_range_into_list() {
|
||||
let actual = nu!("(1.8)..(3.8) | math ceil");
|
||||
let expected = nu!("[2 3 4]");
|
||||
|
||||
assert!(actual.err.contains("nu::parser::input_type_mismatch"));
|
||||
assert_eq!(actual.out, expected.out);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn cannot_ceil_infinite_range() {
|
||||
let actual = nu!("0.. | math ceil");
|
||||
|
||||
assert!(actual.err.contains("nu::shell::incorrect_value"));
|
||||
}
|
||||
|
Reference in New Issue
Block a user