mirror of
https://github.com/nushell/nushell
synced 2025-01-15 22:54:16 +00:00
remove cmd from edit (#4840)
This commit is contained in:
parent
72daf8c64e
commit
6e65aef9bf
2 changed files with 139 additions and 144 deletions
|
@ -247,7 +247,7 @@ let $config = {
|
||||||
event: {
|
event: {
|
||||||
until: [
|
until: [
|
||||||
{ send: menupageprevious }
|
{ send: menupageprevious }
|
||||||
{ edit: { cmd: undo } }
|
{ edit: undo }
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -368,7 +368,13 @@ fn parse_event(value: &Value, config: &Config) -> Result<ReedlineEvent, ShellErr
|
||||||
span,
|
span,
|
||||||
),
|
),
|
||||||
EventType::Edit(value) => {
|
EventType::Edit(value) => {
|
||||||
let edit = parse_edit(value, config)?;
|
let edit = edit_from_record(
|
||||||
|
value.into_string("", config).to_lowercase().as_str(),
|
||||||
|
cols,
|
||||||
|
vals,
|
||||||
|
config,
|
||||||
|
span,
|
||||||
|
)?;
|
||||||
Ok(ReedlineEvent::Edit(vec![edit]))
|
Ok(ReedlineEvent::Edit(vec![edit]))
|
||||||
}
|
}
|
||||||
EventType::Until(value) => match value {
|
EventType::Until(value) => match value {
|
||||||
|
@ -411,60 +417,60 @@ fn event_from_record(
|
||||||
config: &Config,
|
config: &Config,
|
||||||
span: &Span,
|
span: &Span,
|
||||||
) -> Result<ReedlineEvent, ShellError> {
|
) -> Result<ReedlineEvent, ShellError> {
|
||||||
match name {
|
let event = match name {
|
||||||
"none" => Ok(ReedlineEvent::None),
|
"none" => ReedlineEvent::None,
|
||||||
"actionhandler" => Ok(ReedlineEvent::ActionHandler),
|
"actionhandler" => ReedlineEvent::ActionHandler,
|
||||||
"clearscreen" => Ok(ReedlineEvent::ClearScreen),
|
"clearscreen" => ReedlineEvent::ClearScreen,
|
||||||
"historyhintcomplete" => Ok(ReedlineEvent::HistoryHintComplete),
|
"historyhintcomplete" => ReedlineEvent::HistoryHintComplete,
|
||||||
"historyhintwordcomplete" => Ok(ReedlineEvent::HistoryHintWordComplete),
|
"historyhintwordcomplete" => ReedlineEvent::HistoryHintWordComplete,
|
||||||
"ctrld" => Ok(ReedlineEvent::CtrlD),
|
"ctrld" => ReedlineEvent::CtrlD,
|
||||||
"ctrlc" => Ok(ReedlineEvent::CtrlC),
|
"ctrlc" => ReedlineEvent::CtrlC,
|
||||||
"enter" => Ok(ReedlineEvent::Enter),
|
"enter" => ReedlineEvent::Enter,
|
||||||
"esc" | "escape" => Ok(ReedlineEvent::Esc),
|
"esc" | "escape" => ReedlineEvent::Esc,
|
||||||
"up" => Ok(ReedlineEvent::Up),
|
"up" => ReedlineEvent::Up,
|
||||||
"down" => Ok(ReedlineEvent::Down),
|
"down" => ReedlineEvent::Down,
|
||||||
"right" => Ok(ReedlineEvent::Right),
|
"right" => ReedlineEvent::Right,
|
||||||
"left" => Ok(ReedlineEvent::Left),
|
"left" => ReedlineEvent::Left,
|
||||||
"searchhistory" => Ok(ReedlineEvent::SearchHistory),
|
"searchhistory" => ReedlineEvent::SearchHistory,
|
||||||
"nexthistory" => Ok(ReedlineEvent::NextHistory),
|
"nexthistory" => ReedlineEvent::NextHistory,
|
||||||
"previoushistory" => Ok(ReedlineEvent::PreviousHistory),
|
"previoushistory" => ReedlineEvent::PreviousHistory,
|
||||||
"repaint" => Ok(ReedlineEvent::Repaint),
|
"repaint" => ReedlineEvent::Repaint,
|
||||||
"menudown" => Ok(ReedlineEvent::MenuDown),
|
"menudown" => ReedlineEvent::MenuDown,
|
||||||
"menuup" => Ok(ReedlineEvent::MenuUp),
|
"menuup" => ReedlineEvent::MenuUp,
|
||||||
"menuleft" => Ok(ReedlineEvent::MenuLeft),
|
"menuleft" => ReedlineEvent::MenuLeft,
|
||||||
"menuright" => Ok(ReedlineEvent::MenuRight),
|
"menuright" => ReedlineEvent::MenuRight,
|
||||||
"menunext" => Ok(ReedlineEvent::MenuNext),
|
"menunext" => ReedlineEvent::MenuNext,
|
||||||
"menuprevious" => Ok(ReedlineEvent::MenuPrevious),
|
"menuprevious" => ReedlineEvent::MenuPrevious,
|
||||||
"menupagenext" => Ok(ReedlineEvent::MenuPageNext),
|
"menupagenext" => ReedlineEvent::MenuPageNext,
|
||||||
"menupageprevious" => Ok(ReedlineEvent::MenuPagePrevious),
|
"menupageprevious" => ReedlineEvent::MenuPagePrevious,
|
||||||
"menu" => {
|
"menu" => {
|
||||||
let menu = extract_value("name", cols, vals, span)?;
|
let menu = extract_value("name", cols, vals, span)?;
|
||||||
Ok(ReedlineEvent::Menu(menu.into_string("", config)))
|
ReedlineEvent::Menu(menu.into_string("", config))
|
||||||
}
|
}
|
||||||
"executehostcommand" => {
|
"executehostcommand" => {
|
||||||
let cmd = extract_value("cmd", cols, vals, span)?;
|
let cmd = extract_value("cmd", cols, vals, span)?;
|
||||||
Ok(ReedlineEvent::ExecuteHostCommand(
|
ReedlineEvent::ExecuteHostCommand(cmd.into_string("", config))
|
||||||
cmd.into_string("", config),
|
|
||||||
))
|
|
||||||
}
|
}
|
||||||
v => Err(ShellError::UnsupportedConfigValue(
|
v => {
|
||||||
|
return Err(ShellError::UnsupportedConfigValue(
|
||||||
"Reedline event".to_string(),
|
"Reedline event".to_string(),
|
||||||
v.to_string(),
|
v.to_string(),
|
||||||
*span,
|
*span,
|
||||||
)),
|
))
|
||||||
}
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
Ok(event)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn parse_edit(edit: &Value, config: &Config) -> Result<EditCommand, ShellError> {
|
fn edit_from_record(
|
||||||
let edit = match edit {
|
name: &str,
|
||||||
Value::Record {
|
cols: &[String],
|
||||||
cols: edit_cols,
|
vals: &[Value],
|
||||||
vals: edit_vals,
|
config: &Config,
|
||||||
span: edit_span,
|
span: &Span,
|
||||||
} => {
|
) -> Result<EditCommand, ShellError> {
|
||||||
let cmd = extract_value("cmd", edit_cols, edit_vals, edit_span)?;
|
let edit = match name {
|
||||||
|
|
||||||
match cmd.into_string("", config).to_lowercase().as_str() {
|
|
||||||
"movetostart" => EditCommand::MoveToStart,
|
"movetostart" => EditCommand::MoveToStart,
|
||||||
"movetolinestart" => EditCommand::MoveToLineStart,
|
"movetolinestart" => EditCommand::MoveToLineStart,
|
||||||
"movetoend" => EditCommand::MoveToEnd,
|
"movetoend" => EditCommand::MoveToEnd,
|
||||||
|
@ -474,11 +480,12 @@ fn parse_edit(edit: &Value, config: &Config) -> Result<EditCommand, ShellError>
|
||||||
"movewordleft" => EditCommand::MoveWordLeft,
|
"movewordleft" => EditCommand::MoveWordLeft,
|
||||||
"movewordright" => EditCommand::MoveWordRight,
|
"movewordright" => EditCommand::MoveWordRight,
|
||||||
"insertchar" => {
|
"insertchar" => {
|
||||||
let char = extract_char("value", edit_cols, edit_vals, config, edit_span)?;
|
let value = extract_value("value", cols, vals, span)?;
|
||||||
|
let char = extract_char(value, config)?;
|
||||||
EditCommand::InsertChar(char)
|
EditCommand::InsertChar(char)
|
||||||
}
|
}
|
||||||
"insertstring" => {
|
"insertstring" => {
|
||||||
let value = extract_value("value", edit_cols, edit_vals, edit_span)?;
|
let value = extract_value("value", cols, vals, span)?;
|
||||||
EditCommand::InsertString(value.into_string("", config))
|
EditCommand::InsertString(value.into_string("", config))
|
||||||
}
|
}
|
||||||
"backspace" => EditCommand::Backspace,
|
"backspace" => EditCommand::Backspace,
|
||||||
|
@ -504,51 +511,50 @@ fn parse_edit(edit: &Value, config: &Config) -> Result<EditCommand, ShellError>
|
||||||
"undo" => EditCommand::Undo,
|
"undo" => EditCommand::Undo,
|
||||||
"redo" => EditCommand::Redo,
|
"redo" => EditCommand::Redo,
|
||||||
"cutrightuntil" => {
|
"cutrightuntil" => {
|
||||||
let char = extract_char("value", edit_cols, edit_vals, config, edit_span)?;
|
let value = extract_value("value", cols, vals, span)?;
|
||||||
|
let char = extract_char(value, config)?;
|
||||||
EditCommand::CutRightUntil(char)
|
EditCommand::CutRightUntil(char)
|
||||||
}
|
}
|
||||||
"cutrightbefore" => {
|
"cutrightbefore" => {
|
||||||
let char = extract_char("value", edit_cols, edit_vals, config, edit_span)?;
|
let value = extract_value("value", cols, vals, span)?;
|
||||||
|
let char = extract_char(value, config)?;
|
||||||
EditCommand::CutRightBefore(char)
|
EditCommand::CutRightBefore(char)
|
||||||
}
|
}
|
||||||
"moverightuntil" => {
|
"moverightuntil" => {
|
||||||
let char = extract_char("value", edit_cols, edit_vals, config, edit_span)?;
|
let value = extract_value("value", cols, vals, span)?;
|
||||||
|
let char = extract_char(value, config)?;
|
||||||
EditCommand::MoveRightUntil(char)
|
EditCommand::MoveRightUntil(char)
|
||||||
}
|
}
|
||||||
"moverightbefore" => {
|
"moverightbefore" => {
|
||||||
let char = extract_char("value", edit_cols, edit_vals, config, edit_span)?;
|
let value = extract_value("value", cols, vals, span)?;
|
||||||
|
let char = extract_char(value, config)?;
|
||||||
EditCommand::MoveRightBefore(char)
|
EditCommand::MoveRightBefore(char)
|
||||||
}
|
}
|
||||||
"cutleftuntil" => {
|
"cutleftuntil" => {
|
||||||
let char = extract_char("value", edit_cols, edit_vals, config, edit_span)?;
|
let value = extract_value("value", cols, vals, span)?;
|
||||||
|
let char = extract_char(value, config)?;
|
||||||
EditCommand::CutLeftUntil(char)
|
EditCommand::CutLeftUntil(char)
|
||||||
}
|
}
|
||||||
"cutleftbefore" => {
|
"cutleftbefore" => {
|
||||||
let char = extract_char("value", edit_cols, edit_vals, config, edit_span)?;
|
let value = extract_value("value", cols, vals, span)?;
|
||||||
|
let char = extract_char(value, config)?;
|
||||||
EditCommand::CutLeftBefore(char)
|
EditCommand::CutLeftBefore(char)
|
||||||
}
|
}
|
||||||
"moveleftuntil" => {
|
"moveleftuntil" => {
|
||||||
let char = extract_char("value", edit_cols, edit_vals, config, edit_span)?;
|
let value = extract_value("value", cols, vals, span)?;
|
||||||
|
let char = extract_char(value, config)?;
|
||||||
EditCommand::MoveLeftUntil(char)
|
EditCommand::MoveLeftUntil(char)
|
||||||
}
|
}
|
||||||
"moveleftbefore" => {
|
"moveleftbefore" => {
|
||||||
let char = extract_char("value", edit_cols, edit_vals, config, edit_span)?;
|
let value = extract_value("value", cols, vals, span)?;
|
||||||
|
let char = extract_char(value, config)?;
|
||||||
EditCommand::MoveLeftBefore(char)
|
EditCommand::MoveLeftBefore(char)
|
||||||
}
|
}
|
||||||
e => {
|
e => {
|
||||||
return Err(ShellError::UnsupportedConfigValue(
|
return Err(ShellError::UnsupportedConfigValue(
|
||||||
"reedline EditCommand".to_string(),
|
"reedline EditCommand".to_string(),
|
||||||
e.to_string(),
|
e.to_string(),
|
||||||
edit.span()?,
|
*span,
|
||||||
))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
e => {
|
|
||||||
return Err(ShellError::UnsupportedConfigValue(
|
|
||||||
"record with EditCommand".to_string(),
|
|
||||||
e.into_abbreviated_string(config),
|
|
||||||
edit.span()?,
|
|
||||||
))
|
))
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -556,20 +562,13 @@ fn parse_edit(edit: &Value, config: &Config) -> Result<EditCommand, ShellError>
|
||||||
Ok(edit)
|
Ok(edit)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn extract_char<'record>(
|
fn extract_char(value: &Value, config: &Config) -> Result<char, ShellError> {
|
||||||
name: &str,
|
let span = value.span()?;
|
||||||
cols: &'record [String],
|
|
||||||
vals: &'record [Value],
|
|
||||||
config: &Config,
|
|
||||||
span: &Span,
|
|
||||||
) -> Result<char, ShellError> {
|
|
||||||
let value = extract_value(name, cols, vals, span)?;
|
|
||||||
|
|
||||||
value
|
value
|
||||||
.into_string("", config)
|
.into_string("", config)
|
||||||
.chars()
|
.chars()
|
||||||
.next()
|
.next()
|
||||||
.ok_or_else(|| ShellError::MissingConfigValue("char to insert".to_string(), *span))
|
.ok_or_else(|| ShellError::MissingConfigValue("char to insert".to_string(), span))
|
||||||
}
|
}
|
||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
|
@ -602,13 +601,9 @@ mod test {
|
||||||
#[test]
|
#[test]
|
||||||
fn test_edit_event() {
|
fn test_edit_event() {
|
||||||
let cols = vec!["edit".to_string()];
|
let cols = vec!["edit".to_string()];
|
||||||
let vals = vec![Value::Record {
|
let vals = vec![Value::String {
|
||||||
cols: vec!["cmd".to_string()],
|
|
||||||
vals: vec![Value::String {
|
|
||||||
val: "Clear".to_string(),
|
val: "Clear".to_string(),
|
||||||
span: Span::test_data(),
|
span: Span::test_data(),
|
||||||
}],
|
|
||||||
span: Span::test_data(),
|
|
||||||
}];
|
}];
|
||||||
|
|
||||||
let span = Span::test_data();
|
let span = Span::test_data();
|
||||||
|
|
Loading…
Reference in a new issue