Fix parsing of event types/modifiers with certain keys (#716)
This commit is contained in:
parent
10d1dc246d
commit
263a0fb5cf
@ -537,11 +537,16 @@ pub(crate) fn parse_csi_special_key_code(buffer: &[u8]) -> Result<Option<Interna
|
|||||||
// This CSI sequence can be a list of semicolon-separated numbers.
|
// This CSI sequence can be a list of semicolon-separated numbers.
|
||||||
let first = next_parsed::<u8>(&mut split)?;
|
let first = next_parsed::<u8>(&mut split)?;
|
||||||
|
|
||||||
let modifiers = if let Ok(modifier_mask) = next_parsed::<u8>(&mut split) {
|
let (modifiers, kind, state) =
|
||||||
parse_modifiers(modifier_mask)
|
if let Ok((modifier_mask, kind_code)) = modifier_and_kind_parsed(&mut split) {
|
||||||
} else {
|
(
|
||||||
KeyModifiers::NONE
|
parse_modifiers(modifier_mask),
|
||||||
};
|
parse_key_event_kind(kind_code),
|
||||||
|
parse_modifiers_to_state(modifier_mask),
|
||||||
|
)
|
||||||
|
} else {
|
||||||
|
(KeyModifiers::NONE, KeyEventKind::Press, KeyEventState::NONE)
|
||||||
|
};
|
||||||
|
|
||||||
let keycode = match first {
|
let keycode = match first {
|
||||||
1 | 7 => KeyCode::Home,
|
1 | 7 => KeyCode::Home,
|
||||||
@ -558,7 +563,9 @@ pub(crate) fn parse_csi_special_key_code(buffer: &[u8]) -> Result<Option<Interna
|
|||||||
_ => return Err(could_not_parse_event_error()),
|
_ => return Err(could_not_parse_event_error()),
|
||||||
};
|
};
|
||||||
|
|
||||||
let input_event = Event::Key(KeyEvent::new(keycode, modifiers));
|
let input_event = Event::Key(KeyEvent::new_with_kind_and_state(
|
||||||
|
keycode, modifiers, kind, state,
|
||||||
|
));
|
||||||
|
|
||||||
Ok(Some(InternalEvent::Event(input_event)))
|
Ok(Some(InternalEvent::Event(input_event)))
|
||||||
}
|
}
|
||||||
@ -1364,4 +1371,24 @@ mod tests {
|
|||||||
)))),
|
)))),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_parse_csi_numbered_escape_code_with_types() {
|
||||||
|
assert_eq!(
|
||||||
|
parse_event(b"\x1B[5;1:3~", false).unwrap(),
|
||||||
|
Some(InternalEvent::Event(Event::Key(KeyEvent::new_with_kind(
|
||||||
|
KeyCode::PageUp,
|
||||||
|
KeyModifiers::empty(),
|
||||||
|
KeyEventKind::Release,
|
||||||
|
)))),
|
||||||
|
);
|
||||||
|
assert_eq!(
|
||||||
|
parse_event(b"\x1B[6;5:3~", false).unwrap(),
|
||||||
|
Some(InternalEvent::Event(Event::Key(KeyEvent::new_with_kind(
|
||||||
|
KeyCode::PageDown,
|
||||||
|
KeyModifiers::CONTROL,
|
||||||
|
KeyEventKind::Release,
|
||||||
|
)))),
|
||||||
|
);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user