fix bug in shell_integration (#5450)

* fix bug in shell_integration

* add some comments
This commit is contained in:
Darren Schroeder 2022-05-05 10:10:03 -05:00 committed by GitHub
parent 0b9c0fea9d
commit 78a1879e36
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -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) => {