mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-25 09:12:24 +00:00
Ignore spurious configure_area events.
Colin Watson reports that on pre-releases of Ubuntu 18.04, configure events which don't actually involve a change of window size show up annoyingly often. Our handling of configure events involves throwing away the backing Cairo surface, making a fresh blank one, and scheduling a top-level callback to get terminal.c to do a repaint and populate the new surface; so a draw event before that callback occurs causes the window contents to flicker off and on again, not to mention wasting a lot of time. The simplest solution is to spot spurious configures, and respond by not throwing away the previous Cairo surface in the first place.
This commit is contained in:
parent
971b04f9de
commit
510187a733
@ -91,6 +91,7 @@ struct clipboard_state {
|
|||||||
struct gui_data {
|
struct gui_data {
|
||||||
GtkWidget *window, *area, *sbar;
|
GtkWidget *window, *area, *sbar;
|
||||||
gboolean sbar_visible;
|
gboolean sbar_visible;
|
||||||
|
gboolean area_configured;
|
||||||
GtkBox *hbox;
|
GtkBox *hbox;
|
||||||
GtkAdjustment *sbar_adjust;
|
GtkAdjustment *sbar_adjust;
|
||||||
GtkWidget *menu, *specialsmenu, *specialsitem1, *specialsitem2,
|
GtkWidget *menu, *specialsmenu, *specialsitem1, *specialsitem2,
|
||||||
@ -645,6 +646,16 @@ gint configure_area(GtkWidget *widget, GdkEventConfigure *event, gpointer data)
|
|||||||
need_size = 1;
|
need_size = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* If the terminal size hasn't changed since the previous call to
|
||||||
|
* this function (in particular, if there has at least _been_ a
|
||||||
|
* previous call to this function), then, we can assume this event
|
||||||
|
* is spurious and do nothing further.
|
||||||
|
*/
|
||||||
|
if (!need_size && inst->area_configured)
|
||||||
|
return TRUE;
|
||||||
|
inst->area_configured = TRUE;
|
||||||
|
|
||||||
{
|
{
|
||||||
int backing_w = w * inst->font_width + 2*inst->window_border;
|
int backing_w = w * inst->font_width + 2*inst->window_border;
|
||||||
int backing_h = h * inst->font_height + 2*inst->window_border;
|
int backing_h = h * inst->font_height + 2*inst->window_border;
|
||||||
|
Loading…
Reference in New Issue
Block a user