1
0
mirror of https://github.com/nushell/nushell.git synced 2025-01-09 07:48:14 +01:00
nushell/crates/nu-std
Bahex cfdb4bbf25
std/iter scan: change closure signature to be consistent with reduce ()
# Description

I noticed that `std/iter scan`'s closure has the order of parameters
reversed compared to `reduce`, so changed it to be consistent.

Also it didn't have `$acc` as `$in` like `reduce`, so fixed that as
well.

# User-Facing Changes

> [!WARNING]
> This is a breaking change for all operations where order of `$it` and
`$acc` matter.

-   This is still fine.
    ```nushell
    [1 2 3] | iter scan 0 {|x, y| $x + $y}
    ```

-   This is broken
    ```nushell
    [a b c d] | iter scan "" {|x, y| [$x, $y] | str join} -n
    ```
    and should be changed to either one of these
    -   ```nushell
        [a b c d] | iter scan "" {|it, acc| [$acc, $it] | str join} -n
        ```
    -   ```nushell
        [a b c d] | iter scan "" {|it| append $it | str join} -n
        ```

# Tests + Formatting
Only change is in the std and its tests
- 🟢 toolkit test stdlib

# After Submitting
Mention in release notes
2024-12-16 06:13:51 -06:00
..
src Always load default env/config values () 2024-11-20 16:15:15 -06:00
std std/iter scan: change closure signature to be consistent with reduce () 2024-12-16 06:13:51 -06:00
tests std/iter scan: change closure signature to be consistent with reduce () 2024-12-16 06:13:51 -06:00
Cargo.toml Start to Add WASM Support Again () 2024-11-30 07:57:11 -06:00
CONTRIBUTING.md Surprising symlink resolution for std path add () 2024-06-28 18:11:48 -05:00
LICENSE add LICENSE to nu-std () 2023-04-07 13:39:21 -07:00
README.md Change the usage misnomer to "description" () 2024-08-22 12:02:08 +02:00
testing.nu Fix silent failure of parsing input output types () 2024-12-07 09:55:15 -06:00

Welcome to the standard library of `nushell`!

The standard library is a pure-nushell collection of custom commands which provide interactive utilities and building blocks for users writing casual scripts or complex applications.

To see what's here:

> use std
> scope commands | select name description | where name =~ "std "
#┬───────────name────────────┬───────────────────description───────────────────
0│std assert                 │Universal assert command
1│std assert equal           │Assert $left == $right
2│std assert error           │Assert that executing the code generates an error
3│std assert greater         │Assert $left > $right
4│std assert greater or equal│Assert $left >= $right
             ...                                     ...
─┴───────────────────────────┴─────────────────────────────────────────────────

🧰 Using the standard library in the REPL or in scripts

All commands in the standard library must be "imported" into the running environment (the interactive read-execute-print-loop (REPL) or a .nu script) using the use command.

You can choose to import the whole module, but then must refer to individual commands with a std prefix, e.g:

use std

std log debug "Running now"
std assert (1 == 2)

Or you can enumerate the specific commands you want to import and invoke them without the std prefix.

use std ["log debug" assert]

log debug "Running again"
assert (2 == 1)

This is probably the form of import you'll want to add to your env.nu for interactive use.

✏️ contribute to the standard library

You're invited to contribute to the standard library! See CONTRIBUTING.md for details