X-Git-Url: https://asedeno.scripts.mit.edu/gitweb/?a=blobdiff_plain;f=terminal.h;h=606d7939cf0cfc6747ab5556281acd590ddf0166;hb=49d2cf19accb059b3b68d1fc2b78e606a578c3e8;hp=9bc13127f7dc47073c94fa6dfadb8c06a0665022;hpb=089775eb0294ff6e2a2a3725bee63cd846d592ab;p=PuTTY.git diff --git a/terminal.h b/terminal.h index 9bc13127..606d7939 100644 --- a/terminal.h +++ b/terminal.h @@ -65,6 +65,12 @@ struct termline { struct termchar *chars; }; +struct bidi_cache_entry { + int width; + struct termchar *chars; + int *forward, *backward; /* the permutations of line positions */ +}; + struct terminal_tag { int compatibility_level; @@ -112,7 +118,7 @@ struct terminal_tag { int cursor_on; /* cursor enabled flag */ int reset_132; /* Flag ESC c resets to 80 cols */ int use_bce; /* Use Background coloured erase */ - int blinker; /* When blinking is the cursor on ? */ + int cblinker; /* When blinking is the cursor on ? */ int tblinker; /* When the blinking text is on */ int blink_is_real; /* Actually blink blinking text */ int term_echoing; /* Does terminal want local echo? */ @@ -131,15 +137,12 @@ struct terminal_tag { int rows, cols, savelines; int has_focus; int in_vbell; - unsigned long vbell_startpoint; + long vbell_end; int app_cursor_keys, app_keypad_keys, vt52_mode; int repeat_off, cr_lf_return; int seen_disp_event; int big_cursor; - long last_blink; /* used for real blinking control */ - long last_tblink; - int xterm_mouse; /* send mouse messages to app */ int mouse_is_down; /* used while tracking mouse buttons */ @@ -240,6 +243,19 @@ struct terminal_tag { */ int in_term_out; + /* + * We schedule a window update shortly after receiving terminal + * data. This tracks whether one is currently pending. + */ + int window_update_pending; + long next_update; + + /* + * Track pending blinks and tblinks. + */ + int tblink_pending, cblink_pending; + long next_tblink, next_cblink; + /* * These are buffers used by the bidi and Arabic shaping code. */ @@ -247,7 +263,7 @@ struct terminal_tag { int ltemp_size; bidi_char *wcFrom, *wcTo; int wcFromTo_size; - termchar **pre_bidi_cache, **post_bidi_cache; + struct bidi_cache_entry *pre_bidi_cache, *post_bidi_cache; int bidi_cache_size; };