… | |
… | |
1458 | break; |
1458 | break; |
1459 | } |
1459 | } |
1460 | break; |
1460 | break; |
1461 | |
1461 | |
1462 | case FocusIn: |
1462 | case FocusIn: |
|
|
1463 | if (ev.xfocus.detail != NotifyInferior && ev.xfocus.detail != NotifyPointer) |
1463 | focus_in (); |
1464 | focus_in (); |
1464 | break; |
1465 | break; |
1465 | |
1466 | |
1466 | case FocusOut: |
1467 | case FocusOut: |
|
|
1468 | if (ev.xfocus.detail != NotifyInferior && ev.xfocus.detail != NotifyPointer) |
1467 | focus_out (); |
1469 | focus_out (); |
1468 | break; |
1470 | break; |
1469 | |
1471 | |
1470 | case ConfigureNotify: |
1472 | case ConfigureNotify: |
1471 | if (ev.xconfigure.window == parent[0]) |
1473 | if (ev.xconfigure.window == parent[0]) |
1472 | { |
1474 | { |
… | |
… | |
1480 | } |
1482 | } |
1481 | |
1483 | |
1482 | HOOK_INVOKE ((this, HOOK_CONFIGURE_NOTIFY, DT_XEVENT, &ev, DT_END)); |
1484 | HOOK_INVOKE ((this, HOOK_CONFIGURE_NOTIFY, DT_XEVENT, &ev, DT_END)); |
1483 | |
1485 | |
1484 | #ifdef TRANSPARENT /* XXX: maybe not needed - leave in for now */ |
1486 | #ifdef TRANSPARENT /* XXX: maybe not needed - leave in for now */ |
|
|
1487 | #if 0 |
1485 | if (OPTION (Opt_transparent)) |
1488 | if (OPTION (Opt_transparent)) |
1486 | check_our_parents (); |
1489 | check_our_parents (); |
|
|
1490 | #endif |
1487 | #endif |
1491 | #endif |
1488 | } |
1492 | } |
1489 | break; |
1493 | break; |
1490 | |
1494 | |
1491 | case PropertyNotify: |
1495 | case PropertyNotify: |
… | |
… | |
3674 | seen_esc = true; |
3678 | seen_esc = true; |
3675 | continue; |
3679 | continue; |
3676 | } |
3680 | } |
3677 | else if (ch == C0_BEL || ch == CHAR_ST) |
3681 | else if (ch == C0_BEL || ch == CHAR_ST) |
3678 | break; |
3682 | break; |
|
|
3683 | else if (ch == C0_SYN) |
|
|
3684 | ch = cmd_get8 (); |
3679 | else if (ch < 0x20) |
3685 | else if (ch < 0x20) |
3680 | return NULL; /* other control character - exit */ |
3686 | return NULL; /* other control character - exit */ |
3681 | |
3687 | |
3682 | seen_esc = false; |
3688 | seen_esc = false; |
3683 | |
3689 | |
3684 | if (n >= STRING_MAX - 1) |
3690 | if (n >= STRING_MAX - 1) |
3685 | // stop at some sane length |
3691 | // stop at some sane length |
3686 | return NULL; |
3692 | return NULL; |
3687 | |
3693 | |
3688 | if (ch == C0_SYN) |
|
|
3689 | string[n++] = cmd_get8 (); |
|
|
3690 | else |
|
|
3691 | string[n++] = ch; |
3694 | string[n++] = ch; |
3692 | } |
3695 | } |
3693 | |
3696 | |
3694 | string[n++] = '\0'; |
3697 | string[n++] = '\0'; |
3695 | |
3698 | |
3696 | ends_how = (ch == 0x5c ? C0_ESC : ch); |
3699 | ends_how = (ch == 0x5c ? C0_ESC : ch); |