mirror of
https://github.com/nushell/nushell
synced 2025-01-26 11:55:20 +00:00
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:
parent
f41c53fef1
commit
c0ad659985
9 changed files with 65 additions and 68 deletions
22
crates/nu-command/src/env/config/config_env.rs
vendored
22
crates/nu-command/src/env/config/config_env.rs
vendored
|
@ -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)
|
||||||
|
|
22
crates/nu-command/src/env/config/config_nu.rs
vendored
22
crates/nu-command/src/env/config/config_nu.rs
vendored
|
@ -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)
|
||||||
|
|
|
@ -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`
|
||||||
|
|
|
@ -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
|
||||||
# -------------------------------------
|
# -------------------------------------
|
|
@ -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
|
|
@ -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.
|
||||||
|
|
|
@ -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.
|
||||||
|
|
|
@ -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,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -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 {
|
||||||
|
|
Loading…
Reference in a new issue