… | |
… | |
279 | } |
279 | } |
280 | |
280 | |
281 | iso14755buf = 0; |
281 | iso14755buf = 0; |
282 | } |
282 | } |
283 | |
283 | |
284 | int |
284 | static int |
285 | rxvt_term::hex_keyval (XKeyEvent &ev) |
285 | hex_keyval (XKeyEvent &ev) |
286 | { |
286 | { |
287 | // check wether this event corresponds to a hex digit |
287 | // check wether this event corresponds to a hex digit |
288 | // if the modifiers had not been pressed. |
288 | // if the modifiers had not been pressed. |
289 | for (int index = 0; index < 8; index++) |
289 | for (int index = 0; index < 8; index++) |
290 | { |
290 | { |
… | |
… | |
297 | } |
297 | } |
298 | |
298 | |
299 | return -1; |
299 | return -1; |
300 | } |
300 | } |
301 | #endif |
301 | #endif |
|
|
302 | |
|
|
303 | static inline KeySym |
|
|
304 | translate_keypad (KeySym keysym, bool kp) |
|
|
305 | { |
|
|
306 | #ifdef XK_KP_Home |
|
|
307 | static const KeySym keypadtrans[] = { |
|
|
308 | XK_KP_7, // XK_KP_Home |
|
|
309 | XK_KP_4, // XK_KP_Left |
|
|
310 | XK_KP_8, // XK_KP_Up |
|
|
311 | XK_KP_6, // XK_KP_Right |
|
|
312 | XK_KP_2, // XK_KP_Down |
|
|
313 | # ifndef UNSHIFTED_SCROLLKEYS |
|
|
314 | XK_KP_9, // XK_KP_Prior |
|
|
315 | XK_KP_3, // XK_KP_Next |
|
|
316 | # else |
|
|
317 | XK_Prior, |
|
|
318 | XK_Next, |
|
|
319 | # endif |
|
|
320 | XK_KP_1, // XK_KP_End |
|
|
321 | XK_KP_5, // XK_KP_Begin |
|
|
322 | }; |
|
|
323 | |
|
|
324 | if (IN_RANGE_INC (keysym, XK_KP_Home, XK_KP_Begin)) |
|
|
325 | { |
|
|
326 | unsigned int index = keysym - XK_KP_Home; |
|
|
327 | keysym = kp ? keypadtrans[index] : XK_Home + index; |
|
|
328 | } |
|
|
329 | else if (keysym == XK_KP_Insert) |
|
|
330 | keysym = kp ? XK_KP_0 : XK_Insert; |
|
|
331 | # ifndef NO_DELETE_KEY |
|
|
332 | else if (keysym == XK_KP_Delete) |
|
|
333 | keysym = kp ? XK_KP_Decimal : XK_Delete; |
|
|
334 | # endif |
|
|
335 | #endif |
|
|
336 | return keysym; |
|
|
337 | } |
|
|
338 | |
|
|
339 | static inline int |
|
|
340 | map_function_key (KeySym keysym) |
|
|
341 | { |
|
|
342 | int param = 0; |
|
|
343 | |
|
|
344 | if (IN_RANGE_INC (keysym, XK_F1, XK_F35)) |
|
|
345 | { |
|
|
346 | param = 11 + keysym - XK_F1; |
|
|
347 | if (keysym >= XK_F17) |
|
|
348 | param += 4; |
|
|
349 | else if (keysym >= XK_F15) |
|
|
350 | param += 3; |
|
|
351 | else if (keysym >= XK_F11) |
|
|
352 | param += 2; |
|
|
353 | else if (keysym >= XK_F6) |
|
|
354 | param += 1; |
|
|
355 | } |
|
|
356 | else |
|
|
357 | switch (keysym) |
|
|
358 | { |
|
|
359 | case XK_Find: |
|
|
360 | param = 1; |
|
|
361 | break; |
|
|
362 | case XK_Insert: |
|
|
363 | param = 2; |
|
|
364 | break; |
|
|
365 | #ifdef DXK_Remove |
|
|
366 | case DXK_Remove: |
|
|
367 | #endif |
|
|
368 | case XK_Execute: |
|
|
369 | param = 3; |
|
|
370 | break; |
|
|
371 | case XK_Select: |
|
|
372 | param = 4; |
|
|
373 | break; |
|
|
374 | #ifndef UNSHIFTED_SCROLLKEYS |
|
|
375 | case XK_Prior: |
|
|
376 | param = 5; |
|
|
377 | break; |
|
|
378 | case XK_Next: |
|
|
379 | param = 6; |
|
|
380 | break; |
|
|
381 | case XK_Home: |
|
|
382 | param = 7; |
|
|
383 | break; |
|
|
384 | case XK_End: |
|
|
385 | param = 8; |
|
|
386 | break; |
|
|
387 | #endif |
|
|
388 | case XK_Help: |
|
|
389 | param = 28; |
|
|
390 | break; |
|
|
391 | case XK_Menu: |
|
|
392 | param = 29; |
|
|
393 | break; |
|
|
394 | } |
|
|
395 | return param; |
|
|
396 | } |
302 | |
397 | |
303 | void |
398 | void |
304 | rxvt_term::key_press (XKeyEvent &ev) |
399 | rxvt_term::key_press (XKeyEvent &ev) |
305 | { |
400 | { |
306 | int ctrl, meta, shft, len; |
401 | int ctrl, meta, shft, len; |
… | |
… | |
546 | } |
641 | } |
547 | #endif |
642 | #endif |
548 | |
643 | |
549 | if (keysym >= 0xFF00 && keysym <= 0xFFFF) |
644 | if (keysym >= 0xFF00 && keysym <= 0xFFFF) |
550 | { |
645 | { |
551 | bool kp = priv_modes & PrivMode_aplKP ? !shft : shft; |
646 | bool kp = priv_modes & PrivMode_aplKP ? !shft : shft; |
552 | unsigned int newlen = 1; |
647 | unsigned int newlen = 1; |
553 | #ifdef XK_KP_Home |
648 | |
554 | static const KeySym keypadtrans[] = { |
649 | switch (translate_keypad (keysym, kp)) |
555 | XK_KP_7, // XK_KP_Home |
650 | { |
556 | XK_KP_4, // XK_KP_Left |
651 | #ifndef NO_BACKSPACE_KEY |
557 | XK_KP_8, // XK_KP_Up |
652 | case XK_BackSpace: |
558 | XK_KP_6, // XK_KP_Right |
653 | if (priv_modes & PrivMode_HaveBackSpace) |
559 | XK_KP_2, // XK_KP_Down |
654 | { |
560 | #ifndef UNSHIFTED_SCROLLKEYS |
655 | kbuf[0] = (!! (priv_modes & PrivMode_BackSpace) |
561 | XK_KP_9, // XK_KP_Prior |
656 | ^ !!ctrl) ? '\b' : '\177'; |
562 | XK_KP_3, // XK_KP_Next |
657 | kbuf[1] = '\0'; |
563 | #else |
|
|
564 | XK_Prior, |
|
|
565 | XK_Next, |
|
|
566 | #endif |
|
|
567 | XK_KP_1, // XK_KP_End |
|
|
568 | XK_KP_5, // XK_KP_Begin |
|
|
569 | }; |
658 | } |
|
|
659 | else |
|
|
660 | strcpy (kbuf, rs[Rs_backspace_key]); |
|
|
661 | break; |
|
|
662 | #endif |
|
|
663 | #ifndef NO_DELETE_KEY |
|
|
664 | case XK_Delete: |
|
|
665 | strcpy (kbuf, rs[Rs_delete_key]); |
|
|
666 | break; |
|
|
667 | #endif |
|
|
668 | case XK_Tab: |
|
|
669 | if (shft) |
|
|
670 | strcpy (kbuf, "\033[Z"); |
|
|
671 | else |
|
|
672 | { |
|
|
673 | #ifdef CTRL_TAB_MAKES_META |
|
|
674 | if (ctrl) |
|
|
675 | meta = 1; |
|
|
676 | #endif |
|
|
677 | #ifdef MOD4_TAB_MAKES_META |
|
|
678 | if (ev.state & Mod4Mask) |
|
|
679 | meta = 1; |
|
|
680 | #endif |
|
|
681 | newlen = 0; |
|
|
682 | } |
|
|
683 | break; |
570 | |
684 | |
571 | if (IN_RANGE_INC (keysym, XK_KP_Home, XK_KP_Begin)) |
685 | case XK_Up: /* "\033[A" */ |
|
|
686 | case XK_Down: /* "\033[B" */ |
|
|
687 | case XK_Right: /* "\033[C" */ |
|
|
688 | case XK_Left: /* "\033[D" */ |
|
|
689 | strcpy (kbuf, "\033[Z"); |
|
|
690 | kbuf[2] = "DACB"[keysym - XK_Left]; |
|
|
691 | /* do Shift first */ |
|
|
692 | if (shft) |
|
|
693 | kbuf[2] = "dacb"[keysym - XK_Left]; |
|
|
694 | else if (ctrl) |
|
|
695 | { |
|
|
696 | kbuf[1] = 'O'; |
|
|
697 | kbuf[2] = "dacb"[keysym - XK_Left]; |
|
|
698 | } |
|
|
699 | else if (priv_modes & PrivMode_aplCUR) |
|
|
700 | kbuf[1] = 'O'; |
|
|
701 | break; |
|
|
702 | |
|
|
703 | case XK_KP_Enter: |
|
|
704 | /* allow shift to override */ |
|
|
705 | if (kp) |
|
|
706 | { |
|
|
707 | strcpy (kbuf, "\033OM"); |
|
|
708 | break; |
|
|
709 | } |
|
|
710 | |
|
|
711 | /* FALLTHROUGH */ |
|
|
712 | |
|
|
713 | case XK_Return: |
|
|
714 | if (priv_modes & PrivMode_LFNL) |
|
|
715 | { |
|
|
716 | kbuf[0] = '\015'; |
|
|
717 | kbuf[1] = '\012'; |
|
|
718 | kbuf[2] = '\0'; |
|
|
719 | } |
|
|
720 | else |
|
|
721 | { |
|
|
722 | kbuf[0] = '\015'; |
|
|
723 | kbuf[1] = '\0'; |
|
|
724 | } |
|
|
725 | break; |
|
|
726 | |
|
|
727 | case XK_KP_F1: /* "\033OP" */ |
|
|
728 | case XK_KP_F2: /* "\033OQ" */ |
|
|
729 | case XK_KP_F3: /* "\033OR" */ |
|
|
730 | case XK_KP_F4: /* "\033OS" */ |
|
|
731 | strcpy (kbuf, "\033OP"); |
|
|
732 | kbuf[2] += (keysym - XK_KP_F1); |
|
|
733 | break; |
|
|
734 | |
|
|
735 | case XK_KP_Multiply: /* "\033Oj" : "*" */ |
|
|
736 | case XK_KP_Add: /* "\033Ok" : "+" */ |
|
|
737 | case XK_KP_Separator: /* "\033Ol" : "," */ |
|
|
738 | case XK_KP_Subtract: /* "\033Om" : "-" */ |
|
|
739 | case XK_KP_Decimal: /* "\033On" : "." */ |
|
|
740 | case XK_KP_Divide: /* "\033Oo" : "/" */ |
|
|
741 | case XK_KP_0: /* "\033Op" : "0" */ |
|
|
742 | case XK_KP_1: /* "\033Oq" : "1" */ |
|
|
743 | case XK_KP_2: /* "\033Or" : "2" */ |
|
|
744 | case XK_KP_3: /* "\033Os" : "3" */ |
|
|
745 | case XK_KP_4: /* "\033Ot" : "4" */ |
|
|
746 | case XK_KP_5: /* "\033Ou" : "5" */ |
|
|
747 | case XK_KP_6: /* "\033Ov" : "6" */ |
|
|
748 | case XK_KP_7: /* "\033Ow" : "7" */ |
|
|
749 | case XK_KP_8: /* "\033Ox" : "8" */ |
|
|
750 | case XK_KP_9: /* "\033Oy" : "9" */ |
|
|
751 | /* allow shift to override */ |
|
|
752 | if (kp) |
|
|
753 | { |
|
|
754 | strcpy (kbuf, "\033Oj"); |
|
|
755 | kbuf[2] += (keysym - XK_KP_Multiply); |
|
|
756 | } |
|
|
757 | else |
|
|
758 | { |
|
|
759 | kbuf[0] = ('*' + (keysym - XK_KP_Multiply)); |
|
|
760 | kbuf[1] = '\0'; |
|
|
761 | } |
|
|
762 | break; |
|
|
763 | |
|
|
764 | default: |
572 | { |
765 | { |
573 | unsigned int index = keysym - XK_KP_Home; |
766 | int param = map_function_key (keysym); |
574 | keysym = kp ? keypadtrans[index] : XK_Home + index; |
767 | if (param > 0) |
|
|
768 | sprintf (kbuf,"\033[%d~", param); |
|
|
769 | else |
|
|
770 | newlen = 0; |
575 | } |
771 | } |
576 | else if (keysym == XK_KP_Insert) |
|
|
577 | keysym = kp ? XK_KP_0 : XK_Insert; |
|
|
578 | #ifndef NO_DELETE_KEY |
|
|
579 | else if (keysym == XK_KP_Delete) |
|
|
580 | keysym = kp ? XK_KP_Decimal : XK_Delete; |
|
|
581 | #endif |
|
|
582 | #endif |
|
|
583 | switch (keysym) |
|
|
584 | { |
|
|
585 | #ifndef NO_BACKSPACE_KEY |
|
|
586 | case XK_BackSpace: |
|
|
587 | if (priv_modes & PrivMode_HaveBackSpace) |
|
|
588 | { |
|
|
589 | kbuf[0] = (!! (priv_modes & PrivMode_BackSpace) |
|
|
590 | ^ !!ctrl) ? '\b' : '\177'; |
|
|
591 | kbuf[1] = '\0'; |
|
|
592 | } |
|
|
593 | else |
|
|
594 | strcpy (kbuf, rs[Rs_backspace_key]); |
|
|
595 | break; |
772 | break; |
596 | #endif |
|
|
597 | #ifndef NO_DELETE_KEY |
|
|
598 | case XK_Delete: |
|
|
599 | strcpy (kbuf, rs[Rs_delete_key]); |
|
|
600 | break; |
|
|
601 | #endif |
|
|
602 | case XK_Tab: |
|
|
603 | if (shft) |
|
|
604 | strcpy (kbuf, "\033[Z"); |
|
|
605 | else |
|
|
606 | { |
|
|
607 | #ifdef CTRL_TAB_MAKES_META |
|
|
608 | if (ctrl) |
|
|
609 | meta = 1; |
|
|
610 | #endif |
|
|
611 | #ifdef MOD4_TAB_MAKES_META |
|
|
612 | if (ev.state & Mod4Mask) |
|
|
613 | meta = 1; |
|
|
614 | #endif |
|
|
615 | newlen = 0; |
|
|
616 | } |
|
|
617 | break; |
|
|
618 | |
|
|
619 | case XK_Up: /* "\033[A" */ |
|
|
620 | case XK_Down: /* "\033[B" */ |
|
|
621 | case XK_Right: /* "\033[C" */ |
|
|
622 | case XK_Left: /* "\033[D" */ |
|
|
623 | strcpy (kbuf, "\033[Z"); |
|
|
624 | kbuf[2] = "DACB"[keysym - XK_Left]; |
|
|
625 | /* do Shift first */ |
|
|
626 | if (shft) |
|
|
627 | kbuf[2] = "dacb"[keysym - XK_Left]; |
|
|
628 | else if (ctrl) |
|
|
629 | { |
|
|
630 | kbuf[1] = 'O'; |
|
|
631 | kbuf[2] = "dacb"[keysym - XK_Left]; |
|
|
632 | } |
|
|
633 | else if (priv_modes & PrivMode_aplCUR) |
|
|
634 | kbuf[1] = 'O'; |
|
|
635 | break; |
|
|
636 | |
|
|
637 | #ifndef UNSHIFTED_SCROLLKEYS |
|
|
638 | case XK_Prior: |
|
|
639 | strcpy (kbuf, "\033[5~"); |
|
|
640 | break; |
|
|
641 | case XK_Next: |
|
|
642 | strcpy (kbuf, "\033[6~"); |
|
|
643 | break; |
|
|
644 | #endif |
|
|
645 | case XK_KP_Enter: |
|
|
646 | /* allow shift to override */ |
|
|
647 | if (kp) |
|
|
648 | { |
|
|
649 | strcpy (kbuf, "\033OM"); |
|
|
650 | break; |
|
|
651 | } |
|
|
652 | |
|
|
653 | /* FALLTHROUGH */ |
|
|
654 | |
|
|
655 | case XK_Return: |
|
|
656 | if (priv_modes & PrivMode_LFNL) |
|
|
657 | { |
|
|
658 | kbuf[0] = '\015'; |
|
|
659 | kbuf[1] = '\012'; |
|
|
660 | kbuf[2] = '\0'; |
|
|
661 | } |
|
|
662 | else |
|
|
663 | { |
|
|
664 | kbuf[0] = '\015'; |
|
|
665 | kbuf[1] = '\0'; |
|
|
666 | } |
|
|
667 | break; |
|
|
668 | |
|
|
669 | case XK_KP_F1: /* "\033OP" */ |
|
|
670 | case XK_KP_F2: /* "\033OQ" */ |
|
|
671 | case XK_KP_F3: /* "\033OR" */ |
|
|
672 | case XK_KP_F4: /* "\033OS" */ |
|
|
673 | strcpy (kbuf, "\033OP"); |
|
|
674 | kbuf[2] += (keysym - XK_KP_F1); |
|
|
675 | break; |
|
|
676 | |
|
|
677 | case XK_KP_Multiply: /* "\033Oj" : "*" */ |
|
|
678 | case XK_KP_Add: /* "\033Ok" : "+" */ |
|
|
679 | case XK_KP_Separator: /* "\033Ol" : "," */ |
|
|
680 | case XK_KP_Subtract: /* "\033Om" : "-" */ |
|
|
681 | case XK_KP_Decimal: /* "\033On" : "." */ |
|
|
682 | case XK_KP_Divide: /* "\033Oo" : "/" */ |
|
|
683 | case XK_KP_0: /* "\033Op" : "0" */ |
|
|
684 | case XK_KP_1: /* "\033Oq" : "1" */ |
|
|
685 | case XK_KP_2: /* "\033Or" : "2" */ |
|
|
686 | case XK_KP_3: /* "\033Os" : "3" */ |
|
|
687 | case XK_KP_4: /* "\033Ot" : "4" */ |
|
|
688 | case XK_KP_5: /* "\033Ou" : "5" */ |
|
|
689 | case XK_KP_6: /* "\033Ov" : "6" */ |
|
|
690 | case XK_KP_7: /* "\033Ow" : "7" */ |
|
|
691 | case XK_KP_8: /* "\033Ox" : "8" */ |
|
|
692 | case XK_KP_9: /* "\033Oy" : "9" */ |
|
|
693 | /* allow shift to override */ |
|
|
694 | if (kp) |
|
|
695 | { |
|
|
696 | strcpy (kbuf, "\033Oj"); |
|
|
697 | kbuf[2] += (keysym - XK_KP_Multiply); |
|
|
698 | } |
|
|
699 | else |
|
|
700 | { |
|
|
701 | kbuf[0] = ('*' + (keysym - XK_KP_Multiply)); |
|
|
702 | kbuf[1] = '\0'; |
|
|
703 | } |
|
|
704 | break; |
|
|
705 | |
|
|
706 | case XK_Find: |
|
|
707 | strcpy (kbuf, "\033[1~"); |
|
|
708 | break; |
|
|
709 | |
|
|
710 | case XK_Insert: |
|
|
711 | strcpy (kbuf, "\033[2~"); |
|
|
712 | break; |
|
|
713 | #ifdef DXK_Remove /* support for DEC remove like key */ |
|
|
714 | case DXK_Remove: |
|
|
715 | /* FALLTHROUGH */ |
|
|
716 | #endif |
|
|
717 | case XK_Execute: |
|
|
718 | strcpy (kbuf, "\033[3~"); |
|
|
719 | break; |
|
|
720 | case XK_Select: |
|
|
721 | strcpy (kbuf, "\033[4~"); |
|
|
722 | break; |
|
|
723 | case XK_End: |
|
|
724 | strcpy (kbuf, KS_END); |
|
|
725 | break; |
|
|
726 | case XK_Home: |
|
|
727 | strcpy (kbuf, KS_HOME); |
|
|
728 | break; |
|
|
729 | |
|
|
730 | #define FKEY(n, fkey) \ |
|
|
731 | sprintf ((char *)kbuf,"\033[%2d~", (int) ((n) + (keysym - fkey))) |
|
|
732 | |
|
|
733 | case XK_F1: /* "\033[11~" */ |
|
|
734 | case XK_F2: /* "\033[12~" */ |
|
|
735 | case XK_F3: /* "\033[13~" */ |
|
|
736 | case XK_F4: /* "\033[14~" */ |
|
|
737 | case XK_F5: /* "\033[15~" */ |
|
|
738 | FKEY (11, XK_F1); |
|
|
739 | break; |
|
|
740 | case XK_F6: /* "\033[17~" */ |
|
|
741 | case XK_F7: /* "\033[18~" */ |
|
|
742 | case XK_F8: /* "\033[19~" */ |
|
|
743 | case XK_F9: /* "\033[20~" */ |
|
|
744 | case XK_F10: /* "\033[21~" */ |
|
|
745 | FKEY (17, XK_F6); |
|
|
746 | break; |
|
|
747 | case XK_F11: /* "\033[23~" */ |
|
|
748 | case XK_F12: /* "\033[24~" */ |
|
|
749 | case XK_F13: /* "\033[25~" */ |
|
|
750 | case XK_F14: /* "\033[26~" */ |
|
|
751 | FKEY (23, XK_F11); |
|
|
752 | break; |
|
|
753 | case XK_F15: /* "\033[28~" */ |
|
|
754 | case XK_F16: /* "\033[29~" */ |
|
|
755 | FKEY (28, XK_F15); |
|
|
756 | break; |
|
|
757 | case XK_Help: /* "\033[28~" */ |
|
|
758 | FKEY (28, XK_Help); |
|
|
759 | break; |
|
|
760 | case XK_Menu: /* "\033[29~" */ |
|
|
761 | FKEY (29, XK_Menu); |
|
|
762 | break; |
|
|
763 | case XK_F17: /* "\033[31~" */ |
|
|
764 | case XK_F18: /* "\033[32~" */ |
|
|
765 | case XK_F19: /* "\033[33~" */ |
|
|
766 | case XK_F20: /* "\033[34~" */ |
|
|
767 | case XK_F21: /* "\033[35~" */ |
|
|
768 | case XK_F22: /* "\033[36~" */ |
|
|
769 | case XK_F23: /* "\033[37~" */ |
|
|
770 | case XK_F24: /* "\033[38~" */ |
|
|
771 | case XK_F25: /* "\033[39~" */ |
|
|
772 | case XK_F26: /* "\033[40~" */ |
|
|
773 | case XK_F27: /* "\033[41~" */ |
|
|
774 | case XK_F28: /* "\033[42~" */ |
|
|
775 | case XK_F29: /* "\033[43~" */ |
|
|
776 | case XK_F30: /* "\033[44~" */ |
|
|
777 | case XK_F31: /* "\033[45~" */ |
|
|
778 | case XK_F32: /* "\033[46~" */ |
|
|
779 | case XK_F33: /* "\033[47~" */ |
|
|
780 | case XK_F34: /* "\033[48~" */ |
|
|
781 | case XK_F35: /* "\033[49~" */ |
|
|
782 | FKEY (31, XK_F17); |
|
|
783 | break; |
|
|
784 | #undef FKEY |
|
|
785 | default: |
|
|
786 | newlen = 0; |
|
|
787 | break; |
|
|
788 | } |
773 | } |
789 | |
774 | |
790 | if (newlen) |
775 | if (newlen) |
791 | len = strlen (kbuf); |
776 | len = strlen (kbuf); |
792 | |
777 | |
793 | /* |
778 | /* |
794 | * Pass meta for all function keys, if 'meta' option set |
779 | * Pass meta for all function keys, if 'meta' option set |
795 | */ |
780 | */ |
796 | #ifdef META8_OPTION |
781 | #ifdef META8_OPTION |