Line buffer editor (#5381)

* allow line editing

* cargo fmt
This commit is contained in:
Fernando Herrera 2022-04-30 15:40:41 +01:00 committed by GitHub
parent 5999506f87
commit 9da2e142b2
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 14 additions and 1 deletions

2
Cargo.lock generated
View File

@ -3716,7 +3716,7 @@ dependencies = [
[[package]] [[package]]
name = "reedline" name = "reedline"
version = "0.4.0" version = "0.4.0"
source = "git+https://github.com/nushell/reedline?branch=main#2e2bdc54621643e7bee5ba2e2d9bf28e757074e0" source = "git+https://github.com/nushell/reedline?branch=main#39c70136bb95b50104a57767fbfdde50d7654421"
dependencies = [ dependencies = [
"chrono", "chrono",
"crossterm", "crossterm",

View File

@ -161,6 +161,8 @@ pub fn evaluate_repl(
} }
}; };
line_editor = line_editor.with_buffer_editor(config.buffer_editor.clone(), "nu".into());
if config.sync_history_on_enter { if config.sync_history_on_enter {
if is_perf_true { if is_perf_true {
info!("sync history {}:{}:{}", file!(), line!(), column!()); info!("sync history {}:{}:{}", file!(), line!(), column!());

View File

@ -47,6 +47,7 @@ pub struct Config {
pub menus: Vec<ParsedMenu>, pub menus: Vec<ParsedMenu>,
pub rm_always_trash: bool, pub rm_always_trash: bool,
pub shell_integration: bool, pub shell_integration: bool,
pub buffer_editor: String,
pub disable_table_indexes: bool, pub disable_table_indexes: bool,
} }
@ -74,6 +75,7 @@ impl Default for Config {
menus: Vec::new(), menus: Vec::new(),
rm_always_trash: false, rm_always_trash: false,
shell_integration: false, shell_integration: false,
buffer_editor: String::new(),
disable_table_indexes: false, disable_table_indexes: false,
} }
} }
@ -256,6 +258,14 @@ impl Value {
eprintln!("$config.shell_integration is not a bool") eprintln!("$config.shell_integration is not a bool")
} }
} }
"buffer_editor" => {
if let Ok(v) = value.as_string() {
config.buffer_editor = v.to_lowercase();
} else {
eprintln!("$config.buffer_editor is not a string")
}
}
"disable_table_indexes" => { "disable_table_indexes" => {
if let Ok(b) = value.as_bool() { if let Ok(b) = value.as_bool() {
config.disable_table_indexes = b; config.disable_table_indexes = b;

View File

@ -190,6 +190,7 @@ let-env config = {
completion_algorithm: "prefix" # prefix, fuzzy completion_algorithm: "prefix" # prefix, fuzzy
animate_prompt: false # redraw the prompt every second animate_prompt: false # redraw the prompt every second
float_precision: 2 float_precision: 2
buffer_editor: "emacs" # command that will be used to edit the current line buffer with ctr+e
use_ansi_coloring: true use_ansi_coloring: true
filesize_format: "auto" # b, kb, kib, mb, mib, gb, gib, tb, tib, pb, pib, eb, eib, zb, zib, auto filesize_format: "auto" # b, kb, kib, mb, mib, gb, gib, tb, tib, pb, pib, eb, eib, zb, zib, auto
edit_mode: emacs # emacs, vi edit_mode: emacs # emacs, vi