mirror of
https://github.com/nushell/nushell
synced 2025-01-26 11:55:20 +00:00
Moves additional env vars out of default_env and updates some transient prompt vars (#14579)
# Description With `NU_LIB_DIRS`, `NU_PLUGIN_DIRS`, and `ENV_CONVERSIONS` now moved out of `default_env.nu`, we're down to just a few left. This moves all non-closure `PROMPT` variables out as well (and into Rust `main()`. It also: * Implements #14565 and sets the default `TRANSIENT_PROMPT_COMMAND_RIGHT` and `TRANSIENT_MULTILINE_INDICATOR` to an empty string so that they are removed for easier copying from the terminal. * Reverses portions of #14249 where I was overzealous in some of the variables that were imported * Fixes #12096 * Will be the final fix in place, I believe, to close #13670 # User-Facing Changes Transient prompt will now remove the right-prompt and multiline-indicator once a commandline has been entered. # Tests + Formatting - 🟢 `toolkit fmt` - 🟢 `toolkit clippy` - 🟢 `toolkit test` - 🟢 `toolkit test stdlib` - # After Submitting Release notes addition
This commit is contained in:
parent
cfdb4bbf25
commit
39770d4197
2 changed files with 21 additions and 6 deletions
|
@ -17,11 +17,6 @@ $env.PROMPT_COMMAND = $env.PROMPT_COMMAND? | default {||
|
||||||
$path_segment | str replace --all (char path_sep) $"($separator_color)(char path_sep)($path_color)"
|
$path_segment | str replace --all (char path_sep) $"($separator_color)(char path_sep)($path_color)"
|
||||||
}
|
}
|
||||||
|
|
||||||
$env.PROMPT_INDICATOR = $env.PROMPT_INDICATOR? | default "> "
|
|
||||||
$env.PROMPT_INDICATOR_VI_NORMAL = $env.PROMPT_INDICATOR_VI_NORMAL? | default "> "
|
|
||||||
$env.PROMPT_INDICATOR_VI_INSERT = $env.PROMPT_INDICATOR_VI_INSERT? | default ": "
|
|
||||||
$env.PROMPT_MULTILINE_INDICATOR = $env.PROMPT_MULTILINE_INDICATOR? | default "::: "
|
|
||||||
|
|
||||||
$env.PROMPT_COMMAND_RIGHT = $env.PROMPT_COMMAND_RIGHT? | default {||
|
$env.PROMPT_COMMAND_RIGHT = $env.PROMPT_COMMAND_RIGHT? | default {||
|
||||||
# create a right prompt in magenta with green separators and am/pm underlined
|
# create a right prompt in magenta with green separators and am/pm underlined
|
||||||
let time_segment = ([
|
let time_segment = ([
|
||||||
|
|
22
src/main.rs
22
src/main.rs
|
@ -320,9 +320,29 @@ fn main() -> Result<()> {
|
||||||
"NU_VERSION".to_string(),
|
"NU_VERSION".to_string(),
|
||||||
Value::string(env!("CARGO_PKG_VERSION"), Span::unknown()),
|
Value::string(env!("CARGO_PKG_VERSION"), Span::unknown()),
|
||||||
);
|
);
|
||||||
|
|
||||||
// Add SHLVL if interactive
|
// Add SHLVL if interactive
|
||||||
if engine_state.is_interactive {
|
if engine_state.is_interactive {
|
||||||
|
engine_state.add_env_var("PROMPT_INDICATOR".to_string(), Value::test_string("> "));
|
||||||
|
engine_state.add_env_var(
|
||||||
|
"PROMPT_INDICATOR_VI_NORMAL".to_string(),
|
||||||
|
Value::test_string("> "),
|
||||||
|
);
|
||||||
|
engine_state.add_env_var(
|
||||||
|
"PROMPT_INDICATOR_VI_INSERT".to_string(),
|
||||||
|
Value::test_string(": "),
|
||||||
|
);
|
||||||
|
engine_state.add_env_var(
|
||||||
|
"PROMPT_MULTILINE_INDICATOR".to_string(),
|
||||||
|
Value::test_string("::: "),
|
||||||
|
);
|
||||||
|
engine_state.add_env_var(
|
||||||
|
"TRANSIENT_PROMPT_MULTILINE_INDICATOR".to_string(),
|
||||||
|
Value::test_string(""),
|
||||||
|
);
|
||||||
|
engine_state.add_env_var(
|
||||||
|
"TRANSIENT_PROMPT_COMMAND_RIGHT".to_string(),
|
||||||
|
Value::test_string(""),
|
||||||
|
);
|
||||||
let mut shlvl = engine_state
|
let mut shlvl = engine_state
|
||||||
.get_env_var("SHLVL")
|
.get_env_var("SHLVL")
|
||||||
.map(|x| x.as_str().unwrap_or("0").parse::<i64>().unwrap_or(0))
|
.map(|x| x.as_str().unwrap_or("0").parse::<i64>().unwrap_or(0))
|
||||||
|
|
Loading…
Reference in a new issue