mirror of
https://github.com/nushell/nushell
synced 2025-01-13 21:55:07 +00:00
list keybinding options (#906)
* list keybinding optins * list keybinding options * clippy error
This commit is contained in:
parent
a008f1aa80
commit
1e86af2fb9
8 changed files with 392 additions and 224 deletions
436
Cargo.lock
generated
436
Cargo.lock
generated
File diff suppressed because it is too large
Load diff
|
@ -74,7 +74,8 @@ unicode-segmentation = "1.8.0"
|
||||||
url = "2.2.1"
|
url = "2.2.1"
|
||||||
uuid = { version = "0.8.2", features = ["v4"] }
|
uuid = { version = "0.8.2", features = ["v4"] }
|
||||||
which = { version = "4.2.2", optional = true }
|
which = { version = "4.2.2", optional = true }
|
||||||
zip = { version="0.5.9", optional=true }
|
reedline = { git = "https://github.com/nushell/reedline", branch = "main" }
|
||||||
|
zip = { version="0.5.9", optional = true }
|
||||||
|
|
||||||
[target.'cfg(unix)'.dependencies]
|
[target.'cfg(unix)'.dependencies]
|
||||||
umask = "1.0.0"
|
umask = "1.0.0"
|
||||||
|
@ -101,4 +102,4 @@ shadow-rs = "0.8.1"
|
||||||
hamcrest2 = "0.3.0"
|
hamcrest2 = "0.3.0"
|
||||||
dirs-next = "2.0.0"
|
dirs-next = "2.0.0"
|
||||||
quickcheck = "1.0.3"
|
quickcheck = "1.0.3"
|
||||||
quickcheck_macros = "1.0.0"
|
quickcheck_macros = "1.0.0"
|
||||||
|
|
|
@ -188,7 +188,9 @@ pub fn create_default_context(cwd: impl AsRef<Path>) -> EngineState {
|
||||||
Clear,
|
Clear,
|
||||||
Input,
|
Input,
|
||||||
InputKeys,
|
InputKeys,
|
||||||
|
Keybindings,
|
||||||
Kill,
|
Kill,
|
||||||
|
ListKeybindings,
|
||||||
Sleep,
|
Sleep,
|
||||||
TermSize,
|
TermSize,
|
||||||
};
|
};
|
||||||
|
|
|
@ -3,8 +3,8 @@ mod clear;
|
||||||
mod dir_info;
|
mod dir_info;
|
||||||
mod du;
|
mod du;
|
||||||
mod input;
|
mod input;
|
||||||
mod input_keys;
|
|
||||||
mod kill;
|
mod kill;
|
||||||
|
mod reedline_commands;
|
||||||
mod sleep;
|
mod sleep;
|
||||||
mod term_size;
|
mod term_size;
|
||||||
|
|
||||||
|
@ -13,7 +13,7 @@ pub use clear::Clear;
|
||||||
pub use dir_info::{DirBuilder, DirInfo, FileInfo};
|
pub use dir_info::{DirBuilder, DirInfo, FileInfo};
|
||||||
pub use du::Du;
|
pub use du::Du;
|
||||||
pub use input::Input;
|
pub use input::Input;
|
||||||
pub use input_keys::InputKeys;
|
|
||||||
pub use kill::Kill;
|
pub use kill::Kill;
|
||||||
|
pub use reedline_commands::{InputKeys, Keybindings, ListKeybindings};
|
||||||
pub use sleep::Sleep;
|
pub use sleep::Sleep;
|
||||||
pub use term_size::TermSize;
|
pub use term_size::TermSize;
|
||||||
|
|
42
crates/nu-command/src/platform/reedline_commands/command.rs
Normal file
42
crates/nu-command/src/platform/reedline_commands/command.rs
Normal file
|
@ -0,0 +1,42 @@
|
||||||
|
use nu_engine::get_full_help;
|
||||||
|
use nu_protocol::{
|
||||||
|
ast::Call,
|
||||||
|
engine::{Command, EngineState, Stack},
|
||||||
|
Category, IntoPipelineData, PipelineData, Signature, Value,
|
||||||
|
};
|
||||||
|
|
||||||
|
#[derive(Clone)]
|
||||||
|
pub struct Keybindings;
|
||||||
|
|
||||||
|
impl Command for Keybindings {
|
||||||
|
fn name(&self) -> &str {
|
||||||
|
"keybindings"
|
||||||
|
}
|
||||||
|
|
||||||
|
fn signature(&self) -> Signature {
|
||||||
|
Signature::build(self.name()).category(Category::Platform)
|
||||||
|
}
|
||||||
|
|
||||||
|
fn usage(&self) -> &str {
|
||||||
|
"Keybindings related commands"
|
||||||
|
}
|
||||||
|
|
||||||
|
fn run(
|
||||||
|
&self,
|
||||||
|
engine_state: &EngineState,
|
||||||
|
stack: &mut Stack,
|
||||||
|
call: &Call,
|
||||||
|
_input: PipelineData,
|
||||||
|
) -> Result<nu_protocol::PipelineData, nu_protocol::ShellError> {
|
||||||
|
Ok(Value::String {
|
||||||
|
val: get_full_help(
|
||||||
|
&Keybindings.signature(),
|
||||||
|
&Keybindings.examples(),
|
||||||
|
engine_state,
|
||||||
|
stack,
|
||||||
|
),
|
||||||
|
span: call.head,
|
||||||
|
}
|
||||||
|
.into_pipeline_data())
|
||||||
|
}
|
||||||
|
}
|
|
@ -12,7 +12,7 @@ pub struct InputKeys;
|
||||||
|
|
||||||
impl Command for InputKeys {
|
impl Command for InputKeys {
|
||||||
fn name(&self) -> &str {
|
fn name(&self) -> &str {
|
||||||
"input-keys"
|
"keybindings listen"
|
||||||
}
|
}
|
||||||
|
|
||||||
fn usage(&self) -> &str {
|
fn usage(&self) -> &str {
|
||||||
|
@ -20,7 +20,7 @@ impl Command for InputKeys {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn signature(&self) -> Signature {
|
fn signature(&self) -> Signature {
|
||||||
Signature::build("input-keys").category(Category::Platform)
|
Signature::build(self.name()).category(Category::Platform)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn run(
|
fn run(
|
||||||
|
@ -47,7 +47,7 @@ impl Command for InputKeys {
|
||||||
fn examples(&self) -> Vec<Example> {
|
fn examples(&self) -> Vec<Example> {
|
||||||
vec![Example {
|
vec![Example {
|
||||||
description: "Type and see key event codes",
|
description: "Type and see key event codes",
|
||||||
example: "input-keys",
|
example: "keybindings listen",
|
||||||
result: None,
|
result: None,
|
||||||
}]
|
}]
|
||||||
}
|
}
|
|
@ -0,0 +1,114 @@
|
||||||
|
use nu_protocol::{
|
||||||
|
ast::Call,
|
||||||
|
engine::{Command, EngineState, Stack},
|
||||||
|
Category, Example, IntoPipelineData, PipelineData, Signature, Span, Value,
|
||||||
|
};
|
||||||
|
use reedline::{
|
||||||
|
get_reedline_edit_commands, get_reedline_keybinding_modifiers, get_reedline_keycodes,
|
||||||
|
get_reedline_prompt_edit_modes, get_reedline_reedline_events,
|
||||||
|
};
|
||||||
|
|
||||||
|
#[derive(Clone)]
|
||||||
|
pub struct ListKeybindings;
|
||||||
|
|
||||||
|
impl Command for ListKeybindings {
|
||||||
|
fn name(&self) -> &str {
|
||||||
|
"keybindings list"
|
||||||
|
}
|
||||||
|
|
||||||
|
fn signature(&self) -> Signature {
|
||||||
|
Signature::build(self.name())
|
||||||
|
.switch("modifiers", "list of modifiers", Some('m'))
|
||||||
|
.switch("keycodes", "list of keycodes", Some('k'))
|
||||||
|
.switch("modes", "list of edit modes", Some('o'))
|
||||||
|
.switch("events", "list of reedline event", Some('e'))
|
||||||
|
.switch("edits", "list of edit commands", Some('d'))
|
||||||
|
.category(Category::Platform)
|
||||||
|
}
|
||||||
|
|
||||||
|
fn usage(&self) -> &str {
|
||||||
|
"List available options that can be used to create keybindings"
|
||||||
|
}
|
||||||
|
|
||||||
|
fn examples(&self) -> Vec<Example> {
|
||||||
|
vec![
|
||||||
|
Example {
|
||||||
|
description: "Get list of key modifiers",
|
||||||
|
example: "keybindings list -m",
|
||||||
|
result: None,
|
||||||
|
},
|
||||||
|
Example {
|
||||||
|
description: "Get list of reedline events and edit commands",
|
||||||
|
example: "keybindings list -e -d",
|
||||||
|
result: None,
|
||||||
|
},
|
||||||
|
Example {
|
||||||
|
description: "Get list with all the available options",
|
||||||
|
example: "keybindings list",
|
||||||
|
result: None,
|
||||||
|
},
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
||||||
|
fn run(
|
||||||
|
&self,
|
||||||
|
_engine_state: &EngineState,
|
||||||
|
_stack: &mut Stack,
|
||||||
|
call: &Call,
|
||||||
|
_input: PipelineData,
|
||||||
|
) -> Result<nu_protocol::PipelineData, nu_protocol::ShellError> {
|
||||||
|
let records = if call.named.is_empty() {
|
||||||
|
let all_options = vec!["modifiers", "keycodes", "edits", "modes", "events"];
|
||||||
|
all_options
|
||||||
|
.iter()
|
||||||
|
.flat_map(|argument| get_records(argument, &call.head))
|
||||||
|
.collect()
|
||||||
|
} else {
|
||||||
|
call.named
|
||||||
|
.iter()
|
||||||
|
.flat_map(|(argument, _)| get_records(argument.item.as_str(), &call.head))
|
||||||
|
.collect()
|
||||||
|
};
|
||||||
|
|
||||||
|
Ok(Value::List {
|
||||||
|
vals: records,
|
||||||
|
span: call.head,
|
||||||
|
}
|
||||||
|
.into_pipeline_data())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn get_records(entry_type: &str, span: &Span) -> Vec<Value> {
|
||||||
|
let values = match entry_type {
|
||||||
|
"modifiers" => get_reedline_keybinding_modifiers(),
|
||||||
|
"keycodes" => get_reedline_keycodes(),
|
||||||
|
"edits" => get_reedline_edit_commands(),
|
||||||
|
"modes" => get_reedline_prompt_edit_modes(),
|
||||||
|
"events" => get_reedline_reedline_events(),
|
||||||
|
_ => Vec::new(),
|
||||||
|
};
|
||||||
|
|
||||||
|
values
|
||||||
|
.iter()
|
||||||
|
.map(|edit| edit.split('\n'))
|
||||||
|
.flat_map(|edit| edit.map(|edit| convert_to_record(edit, entry_type, span)))
|
||||||
|
.collect()
|
||||||
|
}
|
||||||
|
|
||||||
|
fn convert_to_record(edit: &str, entry_type: &str, span: &Span) -> Value {
|
||||||
|
let entry_type = Value::String {
|
||||||
|
val: entry_type.to_string(),
|
||||||
|
span: *span,
|
||||||
|
};
|
||||||
|
|
||||||
|
let name = Value::String {
|
||||||
|
val: edit.to_string(),
|
||||||
|
span: *span,
|
||||||
|
};
|
||||||
|
|
||||||
|
Value::Record {
|
||||||
|
cols: vec!["type".to_string(), "name".to_string()],
|
||||||
|
vals: vec![entry_type, name],
|
||||||
|
span: *span,
|
||||||
|
}
|
||||||
|
}
|
7
crates/nu-command/src/platform/reedline_commands/mod.rs
Normal file
7
crates/nu-command/src/platform/reedline_commands/mod.rs
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
mod command;
|
||||||
|
mod input_keys;
|
||||||
|
mod list_keybindings;
|
||||||
|
|
||||||
|
pub use command::Keybindings;
|
||||||
|
pub use input_keys::InputKeys;
|
||||||
|
pub use list_keybindings::ListKeybindings;
|
Loading…
Reference in a new issue