keymap: Test backslash escaping in commands
This commit is contained in:
parent
91dca3f667
commit
67a287dd81
@ -448,9 +448,16 @@ pub fn doc(&self) -> &str {
|
||||
|
||||
impl fmt::Debug for MappableCommand {
|
||||
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
|
||||
f.debug_tuple("MappableCommand")
|
||||
.field(&self.name())
|
||||
.finish()
|
||||
match self {
|
||||
MappableCommand::Static { name, .. } => {
|
||||
f.debug_tuple("MappableCommand").field(name).finish()
|
||||
}
|
||||
MappableCommand::Typable { name, args, .. } => f
|
||||
.debug_tuple("MappableCommand")
|
||||
.field(name)
|
||||
.field(args)
|
||||
.finish(),
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@ -505,12 +512,16 @@ fn eq(&self, other: &Self) -> bool {
|
||||
match (self, other) {
|
||||
(
|
||||
MappableCommand::Typable {
|
||||
name: first_name, ..
|
||||
name: first_name,
|
||||
args: first_args,
|
||||
..
|
||||
},
|
||||
MappableCommand::Typable {
|
||||
name: second_name, ..
|
||||
name: second_name,
|
||||
args: second_args,
|
||||
..
|
||||
},
|
||||
) => first_name == second_name,
|
||||
) => first_name == second_name && first_args == second_args,
|
||||
(
|
||||
MappableCommand::Static {
|
||||
name: first_name, ..
|
||||
|
@ -600,4 +600,43 @@ fn reverse_map() {
|
||||
"Mismatch"
|
||||
)
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn escaped_keymap() {
|
||||
use crate::commands::MappableCommand;
|
||||
use helix_view::input::{KeyCode, KeyEvent, KeyModifiers};
|
||||
|
||||
let keys = r#"
|
||||
"+" = [
|
||||
"select_all",
|
||||
":pipe sed -E 's/\\s+$//g'",
|
||||
]
|
||||
"#;
|
||||
|
||||
let key = KeyEvent {
|
||||
code: KeyCode::Char('+'),
|
||||
modifiers: KeyModifiers::NONE,
|
||||
};
|
||||
|
||||
let expectation = Keymap::new(KeyTrie::Node(KeyTrieNode::new(
|
||||
"",
|
||||
hashmap! {
|
||||
key => KeyTrie::Sequence(vec!{
|
||||
MappableCommand::select_all,
|
||||
MappableCommand::Typable {
|
||||
name: "pipe".to_string(),
|
||||
args: vec!{
|
||||
"sed".to_string(),
|
||||
"-E".to_string(),
|
||||
"'s/\\s+$//g'".to_string()
|
||||
},
|
||||
doc: "".to_string(),
|
||||
},
|
||||
})
|
||||
},
|
||||
vec![key],
|
||||
)));
|
||||
|
||||
assert_eq!(toml::from_str(keys), Ok(expectation));
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user