handle option/alt key combos

This commit is contained in:
cy384 2021-04-02 23:16:58 -04:00
parent 1596e71dd1
commit 40c338ac02
1 changed files with 15 additions and 0 deletions

View File

@ -515,10 +515,25 @@ int handle_keypress(EventRecord* event)
// note that this is after translation, e.g. shift-f -> 'F' // note that this is after translation, e.g. shift-f -> 'F'
else if (c) else if (c)
{ {
// TODO this sucks
// manually send an escape if we have alt option held
if (event->modifiers & optionKey)
{
ssh_con.send_buffer[0] = '\e';
ssh_write(ssh_con.send_buffer, 1);
}
if (key_to_vterm[c] != VTERM_KEY_NONE) if (key_to_vterm[c] != VTERM_KEY_NONE)
{ {
// doesn't seem like vterm does modifiers properly
vterm_keyboard_key(con.vterm, key_to_vterm[c], VTERM_MOD_NONE); vterm_keyboard_key(con.vterm, key_to_vterm[c], VTERM_MOD_NONE);
} }
else if (event->modifiers & optionKey)
{
int unmodified_key = KeyTranslate((void*)GetScriptManagerVariable(smKCHRCache), (event->message & keyCodeMask)>>8, 0);
ssh_con.send_buffer[0] = unmodified_key & 0xff;
ssh_write(ssh_con.send_buffer, 1);
}
else else
{ {
ssh_con.send_buffer[0] = c; ssh_con.send_buffer[0] = c;