nushell/crates/nu-table/src
Devyn Cairns 2ae9ad8676
Copy-on-write for record values (#12305)
# Description
This adds a `SharedCow` type as a transparent copy-on-write pointer that
clones to unique on mutate.

As an initial test, the `Record` within `Value::Record` is shared.

There are some pretty big wins for performance. I'll post benchmark
results in a comment. The biggest winner is nested access, as that would
have cloned the records for each cell path follow before and it doesn't
have to anymore.

The reusability of the `SharedCow` type is nice and I think it could be
used to clean up the previous work I did with `Arc` in `EngineState`.
It's meant to be a mostly transparent clone-on-write that just clones on
`.to_mut()` or `.into_owned()` if there are actually multiple
references, but avoids cloning if the reference is unique.

# User-Facing Changes
- `Value::Record` field is a different type (plugin authors)

# Tests + Formatting
- 🟢 `toolkit fmt`
- 🟢 `toolkit clippy`
- 🟢 `toolkit test`
- 🟢 `toolkit test stdlib`

# After Submitting
- [ ] use for `EngineState`
- [ ] use for `Value::List`
2024-04-14 01:42:03 +00:00
..
types Copy-on-write for record values (#12305) 2024-04-14 01:42:03 +00:00
common.rs Add command_prelude module (#12291) 2024-03-26 21:17:30 +00:00
lib.rs Add an option to set header on border (style) (#9920) 2023-08-04 13:50:47 -05:00
table.rs Use nightly clippy to kill dead code/fix style (#12334) 2024-03-30 09:17:28 +08:00
table_theme.rs Update crates-ci/typos and fix new typos (#10313) 2023-09-11 12:37:06 +02:00
unstructured_table.rs Copy-on-write for record values (#12305) 2024-04-14 01:42:03 +00:00
util.rs nu-table: Fix expand table unnessary color in trail head config when wrap is used (#10367) 2023-09-15 11:44:53 -05:00