… | |
… | |
1041 | } |
1041 | } |
1042 | |
1042 | |
1043 | display->flush (); |
1043 | display->flush (); |
1044 | } |
1044 | } |
1045 | |
1045 | |
|
|
1046 | /* checks wether a refresh is requested and starts the refresh timer */ |
1046 | void |
1047 | void |
1047 | rxvt_term::prepare_cb (ev::prepare &w, int revents) |
1048 | rxvt_term::refresh_check () |
1048 | { |
1049 | { |
1049 | make_current (); |
|
|
1050 | |
|
|
1051 | display->flush (); |
|
|
1052 | |
|
|
1053 | if (want_refresh && !flush_ev.is_active ()) |
1050 | if (want_refresh && !flush_ev.is_active ()) |
1054 | flush_ev.start (1. / 60.); // refresh at max. 60 Hz normally |
1051 | flush_ev.start (1. / 60.); // refresh at max. 60 Hz normally |
|
|
1052 | |
|
|
1053 | display->flush (); |
1055 | } |
1054 | } |
1056 | |
1055 | |
1057 | void |
1056 | void |
1058 | rxvt_term::flush_cb (ev::timer &w, int revents) |
1057 | rxvt_term::flush_cb (ev::timer &w, int revents) |
1059 | { |
1058 | { |
… | |
… | |
1067 | void |
1066 | void |
1068 | rxvt_term::cursor_blink_cb (ev::timer &w, int revents) |
1067 | rxvt_term::cursor_blink_cb (ev::timer &w, int revents) |
1069 | { |
1068 | { |
1070 | hidden_cursor = !hidden_cursor; |
1069 | hidden_cursor = !hidden_cursor; |
1071 | want_refresh = 1; |
1070 | want_refresh = 1; |
|
|
1071 | refresh_check (); |
1072 | } |
1072 | } |
1073 | #endif |
1073 | #endif |
1074 | |
1074 | |
1075 | #ifdef TEXT_BLINK |
1075 | #ifdef TEXT_BLINK |
1076 | void |
1076 | void |
… | |
… | |
1078 | { |
1078 | { |
1079 | if (scr_refresh_rend (RS_Blink, RS_Blink)) |
1079 | if (scr_refresh_rend (RS_Blink, RS_Blink)) |
1080 | { |
1080 | { |
1081 | hidden_text = !hidden_text; |
1081 | hidden_text = !hidden_text; |
1082 | want_refresh = 1; |
1082 | want_refresh = 1; |
|
|
1083 | refresh_check (); |
1083 | } |
1084 | } |
1084 | else |
1085 | else |
1085 | w.stop (); |
1086 | w.stop (); |
1086 | } |
1087 | } |
1087 | #endif |
1088 | #endif |
1088 | |
1089 | |
1089 | #ifndef NO_SCROLLBAR_BUTTON_CONTINUAL_SCROLLING |
1090 | #ifndef NO_SCROLLBAR_BUTTON_CONTINUAL_SCROLLING |
1090 | void |
1091 | void |
1091 | rxvt_term::cont_scroll_cb (ev::timer &w, int revents) |
1092 | rxvt_term::cont_scroll_cb (ev::timer &w, int revents) |
1092 | { |
1093 | { |
1093 | if ((scrollbar_isUp() || scrollbar_isDn()) && |
1094 | if ((scrollbar_isUp () || scrollbar_isDn ()) |
1094 | scr_page (scrollbar_isUp() ? UP : DN, 1)) |
1095 | && scr_page (scrollbar_isUp () ? UP : DN, 1)) |
|
|
1096 | { |
1095 | want_refresh = 1; |
1097 | want_refresh = 1; |
|
|
1098 | refresh_check (); |
|
|
1099 | } |
1096 | else |
1100 | else |
1097 | w.stop (); |
1101 | w.stop (); |
1098 | } |
1102 | } |
1099 | #endif |
1103 | #endif |
1100 | |
1104 | |
… | |
… | |
1104 | { |
1108 | { |
1105 | if (scr_page (scroll_selection_dir, scroll_selection_lines)) |
1109 | if (scr_page (scroll_selection_dir, scroll_selection_lines)) |
1106 | { |
1110 | { |
1107 | selection_extend (selection_save_x, selection_save_y, selection_save_state); |
1111 | selection_extend (selection_save_x, selection_save_y, selection_save_state); |
1108 | want_refresh = 1; |
1112 | want_refresh = 1; |
|
|
1113 | refresh_check (); |
1109 | } |
1114 | } |
1110 | else |
1115 | else |
1111 | w.stop (); |
1116 | w.stop (); |
1112 | } |
1117 | } |
1113 | #endif |
1118 | #endif |
1114 | |
1119 | |
1115 | #if defined(MOUSE_WHEEL) && defined(MOUSE_SLIP_WHEELING) |
1120 | #if defined(MOUSE_WHEEL) && defined(MOUSE_SLIP_WHEELING) |
1116 | void |
1121 | void |
1117 | rxvt_term::slip_wheel_cb (ev::timer &w, int revents) |
1122 | rxvt_term::slip_wheel_cb (ev::timer &w, int revents) |
1118 | { |
1123 | { |
1119 | if (scr_page (mouse_slip_wheel_speed < 0 ? DN : UP, abs (mouse_slip_wheel_speed))) |
1124 | if (scr_changeview (view_start - mouse_slip_wheel_speed)) |
|
|
1125 | { |
1120 | want_refresh = 1; |
1126 | want_refresh = 1; |
|
|
1127 | refresh_check (); |
|
|
1128 | } |
1121 | |
1129 | |
1122 | if (view_start == top_row || view_start == 0 || mouse_slip_wheel_speed == 0) |
1130 | if (view_start == top_row || view_start == 0 || mouse_slip_wheel_speed == 0) |
1123 | { |
1131 | { |
1124 | mouse_slip_wheel_speed = 0; |
1132 | mouse_slip_wheel_speed = 0; |
1125 | w.stop (); |
1133 | w.stop (); |
… | |
… | |
1506 | while (XCheckTypedWindowEvent (dpy, vt, ev.xany.type, &ev)) |
1514 | while (XCheckTypedWindowEvent (dpy, vt, ev.xany.type, &ev)) |
1507 | { |
1515 | { |
1508 | scr_expose (ev.xexpose.x, ev.xexpose.y, |
1516 | scr_expose (ev.xexpose.x, ev.xexpose.y, |
1509 | ev.xexpose.width, ev.xexpose.height, False); |
1517 | ev.xexpose.width, ev.xexpose.height, False); |
1510 | } |
1518 | } |
|
|
1519 | |
1511 | want_refresh = 1; |
1520 | want_refresh = 1; |
1512 | } |
1521 | } |
1513 | else |
1522 | else |
1514 | { |
1523 | { |
1515 | XEvent unused_event; |
1524 | XEvent unused_event; |
… | |
… | |
1662 | |
1671 | |
1663 | if (ev.type == KeyPress && hidden_pointer == 0) |
1672 | if (ev.type == KeyPress && hidden_pointer == 0) |
1664 | pointer_blank (); |
1673 | pointer_blank (); |
1665 | } |
1674 | } |
1666 | #endif |
1675 | #endif |
|
|
1676 | |
|
|
1677 | refresh_check (); |
1667 | } |
1678 | } |
1668 | |
1679 | |
1669 | void |
1680 | void |
1670 | rxvt_term::focus_in () |
1681 | rxvt_term::focus_in () |
1671 | { |
1682 | { |
… | |
… | |
1784 | update_background (); |
1795 | update_background (); |
1785 | } |
1796 | } |
1786 | break; |
1797 | break; |
1787 | } |
1798 | } |
1788 | # endif |
1799 | # endif |
|
|
1800 | |
|
|
1801 | refresh_check (); |
1789 | } |
1802 | } |
1790 | #endif |
1803 | #endif |
1791 | |
1804 | |
1792 | void |
1805 | void |
1793 | rxvt_term::button_press (XButtonEvent &ev) |
1806 | rxvt_term::button_press (XButtonEvent &ev) |
… | |
… | |
2297 | } |
2310 | } |
2298 | |
2311 | |
2299 | ch = NOCHAR; |
2312 | ch = NOCHAR; |
2300 | } |
2313 | } |
2301 | } |
2314 | } |
|
|
2315 | |
|
|
2316 | refresh_check (); |
2302 | |
2317 | |
2303 | return flag; |
2318 | return flag; |
2304 | } |
2319 | } |
2305 | |
2320 | |
2306 | // read the next character |
2321 | // read the next character |