… | |
… | |
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)) |
1449 | ; |
1449 | ; |
1450 | |
1450 | |
… | |
… | |
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)); |
… | |
… | |
1945 | /* |
1966 | /* |
1946 | * Mouse report disabled scrollbar: |
1967 | * Mouse report disabled scrollbar: |
1947 | * arrow buttons - send up/down |
1968 | * arrow buttons - send up/down |
1948 | * click on scrollbar - send pageup/down |
1969 | * click on scrollbar - send pageup/down |
1949 | */ |
1970 | */ |
1950 | if ((scrollBar.style == R_SB_NEXT |
|
|
1951 | && scrollbarnext_upButton (ev.y)) |
1971 | if (scrollBar.upButton (ev.y)) |
1952 | || (scrollBar.style == R_SB_RXVT |
|
|
1953 | && scrollbarrxvt_upButton (ev.y))) |
|
|
1954 | tt_printf ("\033[A"); |
1972 | tt_printf ("\033[A"); |
1955 | else if ((scrollBar.style == R_SB_NEXT |
1973 | else if (scrollBar.dnButton (ev.y)) |
1956 | && scrollbarnext_dnButton (ev.y)) |
|
|
1957 | || (scrollBar.style == R_SB_RXVT |
|
|
1958 | && scrollbarrxvt_dnButton (ev.y))) |
|
|
1959 | tt_printf ("\033[B"); |
1974 | tt_printf ("\033[B"); |
1960 | else |
1975 | else |
1961 | switch (ev.button) |
1976 | switch (ev.button) |
1962 | { |
1977 | { |
1963 | case Button2: |
1978 | case Button2: |
… | |
… | |
1975 | #endif /* NO_SCROLLBAR_REPORT */ |
1990 | #endif /* NO_SCROLLBAR_REPORT */ |
1976 | |
1991 | |
1977 | { |
1992 | { |
1978 | char upordown = 0; |
1993 | char upordown = 0; |
1979 | |
1994 | |
1980 | if (scrollBar.style == R_SB_NEXT) |
|
|
1981 | { |
|
|
1982 | if (scrollbarnext_upButton (ev.y)) |
1995 | if (scrollBar.upButton (ev.y)) |
1983 | upordown = -1; /* up */ |
1996 | upordown = -1; /* up */ |
1984 | else if (scrollbarnext_dnButton (ev.y)) |
1997 | else if (scrollBar.dnButton (ev.y)) |
1985 | upordown = 1; /* down */ |
1998 | upordown = 1; /* down */ |
1986 | } |
|
|
1987 | else if (scrollBar.style == R_SB_RXVT) |
|
|
1988 | { |
|
|
1989 | if (scrollbarrxvt_upButton (ev.y)) |
|
|
1990 | upordown = -1; /* up */ |
|
|
1991 | else if (scrollbarrxvt_dnButton (ev.y)) |
|
|
1992 | upordown = 1; /* down */ |
|
|
1993 | } |
|
|
1994 | |
1999 | |
1995 | if (upordown) |
2000 | if (upordown) |
1996 | { |
2001 | { |
1997 | #ifndef NO_SCROLLBAR_BUTTON_CONTINUAL_SCROLLING |
2002 | #ifndef NO_SCROLLBAR_BUTTON_CONTINUAL_SCROLLING |
1998 | if (!cont_scroll_ev.is_active ()) |
2003 | if (!cont_scroll_ev.is_active ()) |
… | |
… | |
2827 | // versions. |
2832 | // versions. |
2828 | // |
2833 | // |
2829 | tt_printf ("\033[>%d;95;0c", 'U'); |
2834 | tt_printf ("\033[>%d;95;0c", 'U'); |
2830 | } |
2835 | } |
2831 | break; |
2836 | break; |
|
|
2837 | |
2832 | case '?': |
2838 | case '?': |
2833 | if (ch == 'h' || ch == 'l' || ch == 'r' || ch == 's' || ch == 't') |
2839 | if (ch == 'h' || ch == 'l' || ch == 'r' || ch == 's' || ch == 't') |
2834 | process_terminal_mode (ch, priv, nargs, arg); |
2840 | process_terminal_mode (ch, priv, nargs, arg); |
2835 | break; |
2841 | break; |
2836 | } |
2842 | } |
… | |
… | |
3352 | *buf++ = '\0'; |
3358 | *buf++ = '\0'; |
3353 | |
3359 | |
3354 | process_color_seq (op, color, name, resp); |
3360 | process_color_seq (op, color, name, resp); |
3355 | } |
3361 | } |
3356 | break; |
3362 | break; |
|
|
3363 | case Rxvt_restoreFG: |
3357 | case XTerm_Color00: |
3364 | case XTerm_Color00: |
3358 | process_color_seq (op, Color_fg, str, resp); |
3365 | process_color_seq (op, Color_fg, str, resp); |
3359 | break; |
3366 | break; |
|
|
3367 | case Rxvt_restoreBG: |
3360 | case XTerm_Color01: |
3368 | case XTerm_Color01: |
3361 | process_color_seq (op, Color_bg, str, resp); |
3369 | process_color_seq (op, Color_bg, str, resp); |
3362 | break; |
3370 | break; |
3363 | #ifndef NO_CURSORCOLOR |
3371 | #ifndef NO_CURSORCOLOR |
3364 | case XTerm_Color_cursor: |
3372 | case XTerm_Color_cursor: |
… | |
… | |
3442 | if (changed) |
3450 | if (changed) |
3443 | update_background (); |
3451 | update_background (); |
3444 | } |
3452 | } |
3445 | break; |
3453 | break; |
3446 | #endif |
3454 | #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 | |
3455 | |
3455 | case XTerm_logfile: |
3456 | case XTerm_logfile: |
3456 | // TODO, when secure mode? |
3457 | // TODO, when secure mode? |
3457 | break; |
3458 | break; |
3458 | |
3459 | |
… | |
… | |
3613 | // 1037 send DEL for keypad delete NYI |
3614 | // 1037 send DEL for keypad delete NYI |
3614 | { 1047, PrivMode_Screen }, |
3615 | { 1047, PrivMode_Screen }, |
3615 | // 1048 save and restore cursor |
3616 | // 1048 save and restore cursor |
3616 | { 1049, PrivMode_Screen }, /* xterm extension, clear screen on ti rather than te */ |
3617 | { 1049, PrivMode_Screen }, /* xterm extension, clear screen on ti rather than te */ |
3617 | // 1051, 1052, 1060, 1061 keyboard emulation NYI |
3618 | // 1051, 1052, 1060, 1061 keyboard emulation NYI |
|
|
3619 | { 2004, PrivMode_BracketPaste }, |
3618 | }; |
3620 | }; |
3619 | |
3621 | |
3620 | if (nargs == 0) |
3622 | if (nargs == 0) |
3621 | return; |
3623 | return; |
3622 | |
3624 | |
… | |
… | |
3670 | */ |
3672 | */ |
3671 | PrivMode (1, PrivMode_vt52); |
3673 | PrivMode (1, PrivMode_vt52); |
3672 | break; |
3674 | break; |
3673 | case 3: /* 80/132 */ |
3675 | case 3: /* 80/132 */ |
3674 | if (priv_modes & PrivMode_132OK) |
3676 | if (priv_modes & PrivMode_132OK) |
|
|
3677 | { |
|
|
3678 | scr_poweron (); |
3675 | set_widthheight (((state ? 132 : 80) * fwidth), height); |
3679 | set_widthheight (((state ? 132 : 80) * fwidth), 24 * fheight); |
|
|
3680 | } |
3676 | break; |
3681 | break; |
3677 | case 4: /* smooth scrolling */ |
3682 | case 4: /* smooth scrolling */ |
3678 | set_option (Opt_jumpScroll, !state); |
3683 | set_option (Opt_jumpScroll, !state); |
3679 | break; |
3684 | break; |
3680 | case 5: /* reverse video */ |
3685 | case 5: /* reverse video */ |