forked from extern/nushell
fix bug in shell_integration (#5450)
* fix bug in shell_integration * add some comments
This commit is contained in:
parent
0b9c0fea9d
commit
78a1879e36
@ -1,21 +1,18 @@
|
|||||||
use crate::reedline_config::add_menus;
|
|
||||||
use crate::{completions::NuCompleter, NuHighlighter, NuValidator, NushellPrompt};
|
|
||||||
use crate::{prompt_update, reedline_config};
|
|
||||||
use crate::{
|
use crate::{
|
||||||
reedline_config::KeybindingsMode,
|
completions::NuCompleter,
|
||||||
|
prompt_update,
|
||||||
|
reedline_config::{add_menus, create_keybindings, KeybindingsMode},
|
||||||
util::{eval_source, report_error},
|
util::{eval_source, report_error},
|
||||||
|
NuHighlighter, NuValidator, NushellPrompt,
|
||||||
};
|
};
|
||||||
use log::info;
|
use log::{info, trace};
|
||||||
use log::trace;
|
|
||||||
use miette::{IntoDiagnostic, Result};
|
use miette::{IntoDiagnostic, Result};
|
||||||
use nu_color_config::get_color_config;
|
use nu_color_config::get_color_config;
|
||||||
use nu_engine::convert_env_values;
|
use nu_engine::convert_env_values;
|
||||||
use nu_parser::lex;
|
use nu_parser::lex;
|
||||||
use nu_protocol::engine::Stack;
|
|
||||||
use nu_protocol::PipelineData;
|
|
||||||
use nu_protocol::{
|
use nu_protocol::{
|
||||||
engine::{EngineState, StateWorkingSet},
|
engine::{EngineState, Stack, StateWorkingSet},
|
||||||
ShellError, Span, Value,
|
PipelineData, ShellError, Span, Value,
|
||||||
};
|
};
|
||||||
use reedline::{DefaultHinter, Emacs, Vi};
|
use reedline::{DefaultHinter, Emacs, Vi};
|
||||||
use std::io::{self, Write};
|
use std::io::{self, Write};
|
||||||
@ -175,7 +172,7 @@ pub fn evaluate_repl(
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Changing the line editor based on the found keybindings
|
// Changing the line editor based on the found keybindings
|
||||||
line_editor = match reedline_config::create_keybindings(config) {
|
line_editor = match create_keybindings(config) {
|
||||||
Ok(keybindings) => match keybindings {
|
Ok(keybindings) => match keybindings {
|
||||||
KeybindingsMode::Emacs(keybindings) => {
|
KeybindingsMode::Emacs(keybindings) => {
|
||||||
let edit_mode = Box::new(Emacs::new(keybindings));
|
let edit_mode = Box::new(Emacs::new(keybindings));
|
||||||
@ -244,7 +241,6 @@ pub fn evaluate_repl(
|
|||||||
&ShellError::DirectoryNotFound(tokens.0[0].span, None),
|
&ShellError::DirectoryNotFound(tokens.0[0].span, None),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
let path = nu_path::canonicalize_with(path, &cwd)
|
let path = nu_path::canonicalize_with(path, &cwd)
|
||||||
.expect("internal error: cannot canonicalize known path");
|
.expect("internal error: cannot canonicalize known path");
|
||||||
(path.to_string_lossy().to_string(), tokens.0[0].span)
|
(path.to_string_lossy().to_string(), tokens.0[0].span)
|
||||||
@ -290,6 +286,7 @@ pub fn evaluate_repl(
|
|||||||
&format!("entry #{}", entry_num),
|
&format!("entry #{}", entry_num),
|
||||||
PipelineData::new(Span::new(0, 0)),
|
PipelineData::new(Span::new(0, 0)),
|
||||||
);
|
);
|
||||||
|
}
|
||||||
|
|
||||||
stack.add_env_var(
|
stack.add_env_var(
|
||||||
"CMD_DURATION_MS".into(),
|
"CMD_DURATION_MS".into(),
|
||||||
@ -298,7 +295,7 @@ pub fn evaluate_repl(
|
|||||||
span: Span { start: 0, end: 0 },
|
span: Span { start: 0, end: 0 },
|
||||||
},
|
},
|
||||||
);
|
);
|
||||||
}
|
|
||||||
// FIXME: permanent state changes like this hopefully in time can be removed
|
// FIXME: permanent state changes like this hopefully in time can be removed
|
||||||
// and be replaced by just passing the cwd in where needed
|
// and be replaced by just passing the cwd in where needed
|
||||||
if let Some(cwd) = stack.get_env_var(engine_state, "PWD") {
|
if let Some(cwd) = stack.get_env_var(engine_state, "PWD") {
|
||||||
@ -310,17 +307,37 @@ pub fn evaluate_repl(
|
|||||||
if use_shell_integration {
|
if use_shell_integration {
|
||||||
// Just before running a command/program, send the escape code (see
|
// Just before running a command/program, send the escape code (see
|
||||||
// https://sw.kovidgoyal.net/kitty/shell-integration/#notes-for-shell-developers)
|
// https://sw.kovidgoyal.net/kitty/shell-integration/#notes-for-shell-developers)
|
||||||
let mut ansi_escapes = String::from(PROMPT_MARKER_BEFORE_CMD);
|
let mut ansi_escapes = String::from(RESET_APPLICATION_MODE);
|
||||||
ansi_escapes.push_str(RESET_APPLICATION_MODE);
|
ansi_escapes.push_str(PROMPT_MARKER_BEFORE_CMD);
|
||||||
if let Some(cwd) = stack.get_env_var(engine_state, "PWD") {
|
if let Some(cwd) = stack.get_env_var(engine_state, "PWD") {
|
||||||
let path = cwd.as_string()?;
|
let path = cwd.as_string()?;
|
||||||
ansi_escapes.push_str(&format!("\x1b]2;{}\x07", path));
|
// Try to abbreviate string for windows title
|
||||||
|
let maybe_abbrev_path = if let Some(p) = nu_path::home_dir() {
|
||||||
|
path.replace(&p.as_path().display().to_string(), "~")
|
||||||
|
} else {
|
||||||
|
path
|
||||||
|
};
|
||||||
|
|
||||||
|
// Set window title too
|
||||||
|
// https://tldp.org/HOWTO/Xterm-Title-3.html
|
||||||
|
// ESC]0;stringBEL -- Set icon name and window title to string
|
||||||
|
// ESC]1;stringBEL -- Set icon name to string
|
||||||
|
// ESC]2;stringBEL -- Set window title to string
|
||||||
|
ansi_escapes.push_str(&format!("\x1b]2;{}\x07", maybe_abbrev_path));
|
||||||
}
|
}
|
||||||
// print!("{}", ansi_escapes);
|
|
||||||
match io::stdout().write_all(ansi_escapes.as_bytes()) {
|
match io::stdout().write_all(ansi_escapes.as_bytes()) {
|
||||||
Ok(it) => it,
|
Ok(it) => it,
|
||||||
Err(err) => print!("error: {}", err),
|
Err(err) => println!("error: {}", err),
|
||||||
};
|
};
|
||||||
|
let _ = io::stdout().flush().map_err(|e| {
|
||||||
|
ShellError::GenericError(
|
||||||
|
"Error flushing stdio".into(),
|
||||||
|
e.to_string(),
|
||||||
|
Some(Span { start: 0, end: 0 }),
|
||||||
|
None,
|
||||||
|
Vec::new(),
|
||||||
|
)
|
||||||
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Ok(Signal::CtrlC) => {
|
Ok(Signal::CtrlC) => {
|
||||||
|
Loading…
Reference in New Issue
Block a user