… | |
… | |
1079 | { |
1079 | { |
1080 | if (scr_refresh_rend (RS_Blink, RS_Blink)) |
1080 | if (scr_refresh_rend (RS_Blink, RS_Blink)) |
1081 | { |
1081 | { |
1082 | hidden_text = !hidden_text; |
1082 | hidden_text = !hidden_text; |
1083 | want_refresh = 1; |
1083 | want_refresh = 1; |
1084 | refresh_check (); |
1084 | refresh_check (); |
1085 | } |
1085 | } |
1086 | else |
1086 | else |
1087 | w.stop (); |
1087 | w.stop (); |
1088 | } |
1088 | } |
1089 | #endif |
1089 | #endif |
… | |
… | |
1438 | && ev.xfocus.mode != NotifyGrab) |
1438 | && ev.xfocus.mode != NotifyGrab) |
1439 | focus_out (); |
1439 | focus_out (); |
1440 | break; |
1440 | break; |
1441 | |
1441 | |
1442 | case ConfigureNotify: |
1442 | case ConfigureNotify: |
1443 | /* fprintf (stderr, "ConfigureNotify for %X, parent is %X, geom is %dx%d%+d%+d, old geom was %dx%d\n", |
1443 | /*fprintf (stderr, "ConfigureNotify for %X, parent is %X, geom is %dx%d%+d%+d, old geom was %dx%d\n", |
1444 | ev.xconfigure.window, parent[0], ev.xconfigure.width, ev.xconfigure.height, ev.xconfigure.x, ev.xconfigure.y, |
1444 | ev.xconfigure.window, parent[0], ev.xconfigure.width, ev.xconfigure.height, ev.xconfigure.x, ev.xconfigure.y, |
1445 | szHint.width, szHint.height); */ |
1445 | szHint.width, szHint.height); */ |
1446 | if (ev.xconfigure.window == parent[0]) |
1446 | if (ev.xconfigure.window == parent[0]) |
1447 | { |
1447 | { |
1448 | while (XCheckTypedWindowEvent (dpy, ev.xconfigure.window, ConfigureNotify, &ev)) |
1448 | while (XCheckTypedWindowEvent (dpy, ev.xconfigure.window, ConfigureNotify, &ev)) |
… | |
… | |
1455 | } |
1455 | } |
1456 | else |
1456 | else |
1457 | { |
1457 | { |
1458 | #ifdef HAVE_BG_PIXMAP |
1458 | #ifdef HAVE_BG_PIXMAP |
1459 | if (bgPixmap.window_position_sensitive ()) |
1459 | if (bgPixmap.window_position_sensitive ()) |
|
|
1460 | { |
|
|
1461 | if (mapped) |
1460 | update_background (); |
1462 | update_background (); |
|
|
1463 | else |
|
|
1464 | bgPixmap.invalidate (); |
|
|
1465 | } |
1461 | #endif |
1466 | #endif |
1462 | } |
1467 | } |
1463 | |
1468 | |
1464 | HOOK_INVOKE ((this, HOOK_CONFIGURE_NOTIFY, DT_XEVENT, &ev, DT_END)); |
1469 | HOOK_INVOKE ((this, HOOK_CONFIGURE_NOTIFY, DT_XEVENT, &ev, DT_END)); |
1465 | } |
1470 | } |
… | |
… | |
1485 | case SelectionRequest: |
1490 | case SelectionRequest: |
1486 | selection_send (ev.xselectionrequest); |
1491 | selection_send (ev.xselectionrequest); |
1487 | break; |
1492 | break; |
1488 | |
1493 | |
1489 | case MapNotify: |
1494 | case MapNotify: |
|
|
1495 | #ifdef HAVE_BG_PIXMAP |
|
|
1496 | /* This is needed spcifically to fix the case of no window manager or a |
|
|
1497 | * non-reparenting window manager. In those cases we never get first |
|
|
1498 | * ConfigureNotify. Also that speeds startup under normal WM, by taking |
|
|
1499 | * care of multiplicity of ConfigureNotify events arriwing while WM does |
|
|
1500 | * reparenting. |
|
|
1501 | * We should not render background immidiately, as there could be several |
|
|
1502 | * ConfigureNotify's to follow. Lets take care of all of them in one scoop |
|
|
1503 | * by scheduling background redraw as soon as we can, but giving a short |
|
|
1504 | * bit of time for ConfigureNotifies to arrive. |
|
|
1505 | * We should render background PRIOR to drawing any text, but AFTER all |
|
|
1506 | * of ConfigureNotifys for the best results. |
|
|
1507 | */ |
|
|
1508 | if (bgPixmap.flags & bgPixmap_t::isInvalid) |
|
|
1509 | update_background_ev.start (0.025); |
|
|
1510 | #endif |
1490 | mapped = 1; |
1511 | mapped = 1; |
1491 | #ifdef TEXT_BLINK |
1512 | #ifdef TEXT_BLINK |
1492 | text_blink_ev.start (); |
1513 | text_blink_ev.start (); |
1493 | #endif |
1514 | #endif |
1494 | HOOK_INVOKE ((this, HOOK_MAP_NOTIFY, DT_XEVENT, &ev, DT_END)); |
1515 | HOOK_INVOKE ((this, HOOK_MAP_NOTIFY, DT_XEVENT, &ev, DT_END)); |
… | |
… | |
2827 | // versions. |
2848 | // versions. |
2828 | // |
2849 | // |
2829 | tt_printf ("\033[>%d;95;0c", 'U'); |
2850 | tt_printf ("\033[>%d;95;0c", 'U'); |
2830 | } |
2851 | } |
2831 | break; |
2852 | break; |
|
|
2853 | |
2832 | case '?': |
2854 | case '?': |
2833 | if (ch == 'h' || ch == 'l' || ch == 'r' || ch == 's' || ch == 't') |
2855 | if (ch == 'h' || ch == 'l' || ch == 'r' || ch == 's' || ch == 't') |
2834 | process_terminal_mode (ch, priv, nargs, arg); |
2856 | process_terminal_mode (ch, priv, nargs, arg); |
2835 | break; |
2857 | break; |
2836 | } |
2858 | } |
… | |
… | |
3352 | *buf++ = '\0'; |
3374 | *buf++ = '\0'; |
3353 | |
3375 | |
3354 | process_color_seq (op, color, name, resp); |
3376 | process_color_seq (op, color, name, resp); |
3355 | } |
3377 | } |
3356 | break; |
3378 | break; |
|
|
3379 | case Rxvt_restoreFG: |
3357 | case XTerm_Color00: |
3380 | case XTerm_Color00: |
3358 | process_color_seq (op, Color_fg, str, resp); |
3381 | process_color_seq (op, Color_fg, str, resp); |
3359 | break; |
3382 | break; |
|
|
3383 | case Rxvt_restoreBG: |
3360 | case XTerm_Color01: |
3384 | case XTerm_Color01: |
3361 | process_color_seq (op, Color_bg, str, resp); |
3385 | process_color_seq (op, Color_bg, str, resp); |
3362 | break; |
3386 | break; |
3363 | #ifndef NO_CURSORCOLOR |
3387 | #ifndef NO_CURSORCOLOR |
3364 | case XTerm_Color_cursor: |
3388 | case XTerm_Color_cursor: |
… | |
… | |
3442 | if (changed) |
3466 | if (changed) |
3443 | update_background (); |
3467 | update_background (); |
3444 | } |
3468 | } |
3445 | break; |
3469 | break; |
3446 | #endif |
3470 | #endif |
3447 | |
|
|
3448 | case Rxvt_restoreFG: |
|
|
3449 | set_window_color (Color_fg, str); |
|
|
3450 | break; |
|
|
3451 | case Rxvt_restoreBG: |
|
|
3452 | set_window_color (Color_bg, str); |
|
|
3453 | break; |
|
|
3454 | |
3471 | |
3455 | case XTerm_logfile: |
3472 | case XTerm_logfile: |
3456 | // TODO, when secure mode? |
3473 | // TODO, when secure mode? |
3457 | break; |
3474 | break; |
3458 | |
3475 | |