Doc file fixes (#14608)

# Description

With great thanks to @fdncred and especially @PerchunPak (see #14601)
for finding and fixing a number of issues that I pulled in here due to
the filename changes and upcoming freeze.

This PR primarily fixes a poor wording choice in the new filenames and
`config` command options. The fact that these were called
`sample_config.nu` (etc.) and accessed via `config --sample` created a
great deal of confusion. These were never intended to be used as-is as
config files, but rather as in-shell documentation.

As such, I've renamed them:

* `sample_config.nu` becomes `doc_config.nu`
* `sample_env.nu` becomes `doc_env.nu`
* `config nu --sample` becomes `config nu --doc`
* `config env --sample` because `config env --doc`

Also the following:

* Updates `doc_config.nu` with a few additional comment-fixes on top of
@PerchunPak's changes.
* Adds version numbers to all files - Will need to update the version
script to add some files after this PR.
* Additional doc on plugin and plugin_gc configuration which I had
failed to previously completely update from the older wording
* Updated the comments in the `scaffold_*.nu` files to point people to
`help config`/`help nu` so that, if things change in the future, it will
become more difficult for the comments to be outdated.
* 

# User-Facing Changes

Mostly doc.

`config nu` and `config env` changes update new behavior previously
added in 0.100.1

# Tests + Formatting

- 🟢 `toolkit fmt`
- 🟢 `toolkit clippy`
- 🟢 `toolkit test`
- 🟢 `toolkit test stdlib`

# After Submitting

* Update configuration chapter of doc
* Update the blog entry on migrating config
* Update `bump-version.nu`
This commit is contained in:
Douglas 2024-12-17 15:18:23 -05:00 committed by GitHub
parent f41c53fef1
commit c0ad659985
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
9 changed files with 65 additions and 68 deletions

View file

@ -18,8 +18,8 @@ impl Command for ConfigEnv {
Some('d'), Some('d'),
) )
.switch( .switch(
"sample", "doc",
"Print a commented, sample `env.nu` file instead.", "Print a commented `env.nu` with documentation instead.",
Some('s'), Some('s'),
) )
// TODO: Signature narrower than what run actually supports theoretically // TODO: Signature narrower than what run actually supports theoretically
@ -37,8 +37,8 @@ impl Command for ConfigEnv {
result: None, result: None,
}, },
Example { Example {
description: "pretty-print a commented, sample `env.nu` that explains common settings", description: "pretty-print a commented `env.nu` that explains common settings",
example: "config env --sample | nu-highlight,", example: "config env --doc | nu-highlight,",
result: None, result: None,
}, },
Example { Example {
@ -57,13 +57,13 @@ impl Command for ConfigEnv {
_input: PipelineData, _input: PipelineData,
) -> Result<PipelineData, ShellError> { ) -> Result<PipelineData, ShellError> {
let default_flag = call.has_flag(engine_state, stack, "default")?; let default_flag = call.has_flag(engine_state, stack, "default")?;
let sample_flag = call.has_flag(engine_state, stack, "sample")?; let doc_flag = call.has_flag(engine_state, stack, "doc")?;
if default_flag && sample_flag { if default_flag && doc_flag {
return Err(ShellError::IncompatibleParameters { return Err(ShellError::IncompatibleParameters {
left_message: "can't use `--default` at the same time".into(), left_message: "can't use `--default` at the same time".into(),
left_span: call.get_flag_span(stack, "default").expect("has flag"), left_span: call.get_flag_span(stack, "default").expect("has flag"),
right_message: "because of `--sample`".into(), right_message: "because of `--doc`".into(),
right_span: call.get_flag_span(stack, "sample").expect("has flag"), right_span: call.get_flag_span(stack, "doc").expect("has flag"),
}); });
} }
// `--default` flag handling // `--default` flag handling
@ -72,10 +72,10 @@ impl Command for ConfigEnv {
return Ok(Value::string(nu_utils::get_default_env(), head).into_pipeline_data()); return Ok(Value::string(nu_utils::get_default_env(), head).into_pipeline_data());
} }
// `--sample` flag handling // `--doc` flag handling
if sample_flag { if doc_flag {
let head = call.head; let head = call.head;
return Ok(Value::string(nu_utils::get_sample_env(), head).into_pipeline_data()); return Ok(Value::string(nu_utils::get_doc_env(), head).into_pipeline_data());
} }
super::config_::start_editor("env-path", engine_state, stack, call) super::config_::start_editor("env-path", engine_state, stack, call)

View file

@ -18,8 +18,8 @@ impl Command for ConfigNu {
Some('d'), Some('d'),
) )
.switch( .switch(
"sample", "doc",
"Print a commented, sample `config.nu` file instead.", "Print a commented `config.nu` with documentation instead.",
Some('s'), Some('s'),
) )
// TODO: Signature narrower than what run actually supports theoretically // TODO: Signature narrower than what run actually supports theoretically
@ -37,8 +37,8 @@ impl Command for ConfigNu {
result: None, result: None,
}, },
Example { Example {
description: "pretty-print a commented, sample `config.nu` that explains common settings", description: "pretty-print a commented `config.nu` that explains common settings",
example: "config nu --sample | nu-highlight", example: "config nu --doc | nu-highlight",
result: None, result: None,
}, },
Example { Example {
@ -58,13 +58,13 @@ impl Command for ConfigNu {
_input: PipelineData, _input: PipelineData,
) -> Result<PipelineData, ShellError> { ) -> Result<PipelineData, ShellError> {
let default_flag = call.has_flag(engine_state, stack, "default")?; let default_flag = call.has_flag(engine_state, stack, "default")?;
let sample_flag = call.has_flag(engine_state, stack, "sample")?; let doc_flag = call.has_flag(engine_state, stack, "doc")?;
if default_flag && sample_flag { if default_flag && doc_flag {
return Err(ShellError::IncompatibleParameters { return Err(ShellError::IncompatibleParameters {
left_message: "can't use `--default` at the same time".into(), left_message: "can't use `--default` at the same time".into(),
left_span: call.get_flag_span(stack, "default").expect("has flag"), left_span: call.get_flag_span(stack, "default").expect("has flag"),
right_message: "because of `--sample`".into(), right_message: "because of `--doc`".into(),
right_span: call.get_flag_span(stack, "sample").expect("has flag"), right_span: call.get_flag_span(stack, "doc").expect("has flag"),
}); });
} }
@ -74,10 +74,10 @@ impl Command for ConfigNu {
return Ok(Value::string(nu_utils::get_default_config(), head).into_pipeline_data()); return Ok(Value::string(nu_utils::get_default_config(), head).into_pipeline_data());
} }
// `--sample` flag handling // `--doc` flag handling
if sample_flag { if doc_flag {
let head = call.head; let head = call.head;
return Ok(Value::string(nu_utils::get_sample_config(), head).into_pipeline_data()); return Ok(Value::string(nu_utils::get_doc_config(), head).into_pipeline_data());
} }
super::config_::start_editor("config-path", engine_state, stack, call) super::config_::start_editor("config-path", engine_state, stack, call)

View file

@ -9,7 +9,7 @@
* During a startup where the user specifies an alternative `env.nu` via `nu --env-config <path>` * During a startup where the user specifies an alternative `env.nu` via `nu --env-config <path>`
* During a `nu -c <commandstring>` or `nu <script>` startup so that `ENV_CONVERSIONS` is properly handled for Windows. * During a `nu -c <commandstring>` or `nu <script>` startup so that `ENV_CONVERSIONS` is properly handled for Windows.
* Is *not* loaded when running with an explicit `no --no-config-file (-n)`. * Is *not* loaded when running with an explicit `no --no-config-file (-n)`.
* Is not commented - Comments are in `sample_env.nu`. * Is not commented - Comments are in `doc_env.nu`.
* Should be optimized for fastest load times. * Should be optimized for fastest load times.
* Can be introspected via `config env --default | nu-highlight` * Can be introspected via `config env --default | nu-highlight`
@ -27,7 +27,7 @@ Counterpart to `default_env.nu`.
* `nu -n/--no-config` * `nu -n/--no-config`
* `nu -c "ls"` * `nu -c "ls"`
* `nu <script.nu>` * `nu <script.nu>`
* Is not commented - Comments are in `sample_config.nu`. * Is not commented - Comments are in `doc_config.nu`.
* Should be optimized for fastest load times. Whenever possible, values should be set via nu-protocol::config * Should be optimized for fastest load times. Whenever possible, values should be set via nu-protocol::config
* Exception: `color_config` values are currently set in this file so that user's can introspect the values * Exception: `color_config` values are currently set in this file so that user's can introspect the values
* TODO: Implement defaults for `color_config` in nu-protocol::config and remove from `default_config.nu` * TODO: Implement defaults for `color_config` in nu-protocol::config and remove from `default_config.nu`
@ -37,24 +37,24 @@ Counterpart to `default_env.nu`.
$env.config = {} $env.config = {}
``` ```
## `sample_env.nu` ## `doc_env.nu`
* A commented file documenting the most common environment variables that a user might configure in `env.nu` * A commented file documenting the most common environment variables that a user might configure in `env.nu`
* For convenient in-shell access - Can be pretty-printed via `config env --sample | nu-highlight` * For convenient in-shell access - Can be pretty-printed via `config env --doc | nu-highlight`
* Since this file is for documentation only, include actual Nushell code without comments so that it can be pretty-printed * Since this file is for documentation only, include actual Nushell code without comments so that it can be pretty-printed
* No optimization necessary - Not intended for use other than documentation. * No optimization necessary - Not intended for use other than documentation.
* Consider replacing `config env --sample` with `help env.nu` at some point. * Consider replacing `config env --doc` with `help env.nu` at some point.
* Uses a mix of default values (explained) as well as other examples that users might want in their own `env.nu` * Uses a mix of default values (explained) as well as other examples that users might want in their own `env.nu`
## `sample_config.nu` ## `doc_config.nu`
Counterpart to `sample_env.nu`. Counterpart to `doc_env.nu`.
* A commented file documenting the most common environment variables that a user might configure in `config.nu` * A commented file documenting the most common environment variables that a user might configure in `config.nu`
* For convenient in-shell access - Can be pretty-printed via `config nu --sample | nu-highlight` * For convenient in-shell access - Can be pretty-printed via `config nu --doc | nu-highlight`
* Since this file is for documentation only, include actual Nushell code without comments so that it can be pretty-printed * Since this file is for documentation only, include actual Nushell code without comments so that it can be pretty-printed
* No optimization necessary - Not intended for use other than documentation. * No optimization necessary - Not intended for use other than documentation.
* Consider replacing `config nu --sample` with `help config.nu` at some point. * Consider replacing `config nu --doc` with `help config.nu` at some point.
* Uses a mix of default values (explained) as well as other examples that users might want in their own `config.nu` * Uses a mix of default values (explained) as well as other examples that users might want in their own `config.nu`
## `scaffold_env.nu` ## `scaffold_env.nu`

View file

@ -1,4 +1,4 @@
# Nushell Sample Config File # Nushell Config File Documentation
# #
# Warning: This file is intended for documentation purposes only and # Warning: This file is intended for documentation purposes only and
# is not intended to be used as an actual configuration file as-is. # is not intended to be used as an actual configuration file as-is.
@ -18,7 +18,7 @@
# https://nushell.sh/book/configuration # https://nushell.sh/book/configuration
# #
# You can pretty-print and page this file using: # You can pretty-print and page this file using:
# config nu --sample | nu-highlight | less -R # config nu --doc | nu-highlight | less -R
# $env.config # $env.config
# ----------- # -----------
@ -335,7 +335,7 @@ $env.config.table.header_on_separator = false
# If set to an int, all tables will be abbreviated to only show the first <n> and last <n> rows # If set to an int, all tables will be abbreviated to only show the first <n> and last <n> rows
# If set to `null`, all table rows will be displayed # If set to `null`, all table rows will be displayed
# Can be overridden by passing a table to `| table --abbreviated/-a` # Can be overridden by passing a table to `| table --abbreviated/-a`
$env.config.table.abbreviated_row_count $env.config.table.abbreviated_row_count = null
# footer_inheritance (bool): Footer behavior in nested tables # footer_inheritance (bool): Footer behavior in nested tables
# true: If a nested table is long enough on its own to display a footer (per `footer_mode` above), # true: If a nested table is long enough on its own to display a footer (per `footer_mode` above),
@ -411,7 +411,7 @@ $env.config.hooks.pre_prompt = []
$env.config.hooks.pre_execution = [] $env.config.hooks.pre_execution = []
# When a specified environment variable changes # When a specified environment variable changes
$env.config.hooks.env_change = { $env.config.hooks.env_change = {
# run if the PWD environment is different since the last repl input # Example: Run if the PWD environment is different since the last REPL input
PWD: [{|before, after| null }] PWD: [{|before, after| null }]
} }
# Before Nushell output is displayed in the terminal # Before Nushell output is displayed in the terminal
@ -419,6 +419,10 @@ $env.config.hooks.display_output = "if (term size).columns >= 100 { table -e } e
# When a command is not found # When a command is not found
$env.config.hooks.command_not_found = [] $env.config.hooks.command_not_found = []
# The env_change hook accepts a record with environment variable names as keys, and a list
# of hooks to run when that variable changes
$env.config.hooks.env_change = {}
# ----------- # -----------
# Keybindings # Keybindings
# ----------- # -----------
@ -472,7 +476,9 @@ $env.config.menus ++= [
type: { type: {
layout: description layout: description
columns: 4 columns: 4
col_width: 20 # Optional value. If missing all the screen width is used to calculate column width # col_width is an optional value. If missing, the entire screen width is used to
# calculate the column width
col_width: 20
col_padding: 2 col_padding: 2
selection_rows: 4 selection_rows: 4
description_rows: 10 description_rows: 10
@ -485,29 +491,26 @@ $env.config.menus ++= [
} }
] ]
# --------------- # ---------------
# Plugin behavior # Plugin behavior
# --------------- # ---------------
# Per-plugin configuration. See https://www.nushell.sh/contributor-book/plugins.html#configuration. # Per-plugin configuration. See https://www.nushell.sh/contributor-book/plugins.html#plugin-configuration
$env.config.plugins $env.config.plugins = {}
# Configuration for plugin garbage collection # Plugin garbage collection configuration
$env.config.plugin_gc # $env.config.plugin_gc.*
$env.config.plugin_gc.default
# true to enable stopping of inactive plugins # enabled (bool): true/false to enable/disable stopping inactive plugins
$env.config.plugin_gc.default.enabled $env.config.plugin_gc.default.enabled = true
# How long to wait after a plugin is inactive before stopping it # stop_after (duration): How long to wait after a plugin is inactive before stopping it
$env.config.plugin_gc.default.stop_after $env.config.plugin_gc.default.stop_after = 10sec
# plugins (record): Alternate garbage collection configuration per-plugin.
$env.config.plugin_gc.plugins = { $env.config.plugin_gc.plugins = {
# Alternate configuration for specific plugins, by name, for example:
#
# gstat: { # gstat: {
# enabled: false # enabled: false
# } # }
} }
# ------------------------------------- # -------------------------------------
# Themes/Colors and Syntax Highlighting # Themes/Colors and Syntax Highlighting
# ------------------------------------- # -------------------------------------

View file

@ -1,4 +1,6 @@
# Sample Nushell Environment Config File # Nushell Environment Config File Documentation
#
# version = "0.100.1"
# #
# version = "0.100.1" # version = "0.100.1"
# #
@ -8,4 +10,4 @@
# To pretty-print the in-shell documentation for Nushell's various configuration # To pretty-print the in-shell documentation for Nushell's various configuration
# settings, you can run: # settings, you can run:
config nu --sample | nu-highlight | less -R config nu --doc | nu-highlight | less -R

View file

@ -12,11 +12,7 @@
# You can open this file in your default editor using: # You can open this file in your default editor using:
# config nu # config nu
# #
# To pretty-print a sample config.nu with documentation, run: # See `help config nu` for more options
# config nu --sample | nu-highlight | less -R
#
# To pretty-print the default configuration values, run:
# config nu --default | nu-highlight | less -R
# #
# You can remove these comments if you want or leave # You can remove these comments if you want or leave
# them for future reference. # them for future reference.

View file

@ -12,11 +12,7 @@
# #
# See https://www.nushell.sh/book/configuration.html # See https://www.nushell.sh/book/configuration.html
# #
# To pretty-print a sample of the configuration settings, run: # Also see `help config env` for more options.
# config nu --sample | nu-highlight | less -R
#
# To pretty-print the default env.nu, run:
# config env --default | nu-highlight | less -R
# #
# You can remove these comments if you want or leave # You can remove these comments if you want or leave
# them for future reference. # them for future reference.

View file

@ -10,8 +10,8 @@ pub mod utils;
pub use locale::get_system_locale; pub use locale::get_system_locale;
pub use utils::{ pub use utils::{
enable_vt_processing, get_default_config, get_default_env, get_ls_colors, get_sample_config, enable_vt_processing, get_default_config, get_default_env, get_doc_config, get_doc_env,
get_sample_env, get_scaffold_config, get_scaffold_env, stderr_write_all_and_flush, get_ls_colors, get_scaffold_config, get_scaffold_env, stderr_write_all_and_flush,
stdout_write_all_and_flush, terminal_size, stdout_write_all_and_flush, terminal_size,
}; };

View file

@ -94,8 +94,8 @@ pub fn get_scaffold_env() -> &'static str {
include_str!("default_files/scaffold_env.nu") include_str!("default_files/scaffold_env.nu")
} }
pub fn get_sample_env() -> &'static str { pub fn get_doc_env() -> &'static str {
include_str!("default_files/sample_env.nu") include_str!("default_files/doc_env.nu")
} }
pub fn get_default_config() -> &'static str { pub fn get_default_config() -> &'static str {
@ -106,8 +106,8 @@ pub fn get_scaffold_config() -> &'static str {
include_str!("default_files/scaffold_config.nu") include_str!("default_files/scaffold_config.nu")
} }
pub fn get_sample_config() -> &'static str { pub fn get_doc_config() -> &'static str {
include_str!("default_files/sample_config.nu") include_str!("default_files/doc_config.nu")
} }
pub fn get_ls_colors(lscolors_env_string: Option<String>) -> LsColors { pub fn get_ls_colors(lscolors_env_string: Option<String>) -> LsColors {