Make sure we don't miss queue redraws between commit and ack.

This commit is contained in:
Kristian Høgsberg 2008-12-08 11:13:26 -05:00
parent c47303f2d2
commit 721f09f187

View File

@ -53,7 +53,7 @@ static const char socket_name[] = "\0wayland";
struct terminal { struct terminal {
struct window *window; struct window *window;
struct wl_display *display; struct wl_display *display;
int resize_scheduled; int redraw_scheduled, redraw_pending;
char *data; char *data;
int width, height, tail, row, column, total_rows; int width, height, tail, row, column, total_rows;
int fd, master; int fd, master;
@ -125,6 +125,17 @@ idle_redraw(void *data)
#define STATE_NORMAL 0 #define STATE_NORMAL 0
#define STATE_SKIP_TO_ALPHA 1 #define STATE_SKIP_TO_ALPHA 1
static void
terminal_schedule_redraw(struct terminal *terminal)
{
if (!terminal->redraw_scheduled) {
g_idle_add(idle_redraw, terminal);
terminal->redraw_scheduled = 1;
} else {
terminal->redraw_pending = 1;
}
}
static void static void
terminal_data(struct terminal *terminal, const char *data, size_t length) terminal_data(struct terminal *terminal, const char *data, size_t length)
{ {
@ -171,6 +182,8 @@ terminal_data(struct terminal *terminal, const char *data, size_t length)
break; break;
} }
} }
terminal_schedule_redraw(terminal);
} }
static void static void
@ -178,10 +191,7 @@ resize_handler(struct window *window, int32_t width, int32_t height, void *data)
{ {
struct terminal *terminal = data; struct terminal *terminal = data;
if (!terminal->resize_scheduled) { terminal_schedule_redraw(terminal);
g_idle_add(idle_redraw, terminal);
terminal->resize_scheduled = 1;
}
} }
static void static void
@ -189,8 +199,13 @@ acknowledge_handler(struct window *window, uint32_t key, void *data)
{ {
struct terminal *terminal = data; struct terminal *terminal = data;
terminal->resize_scheduled = 0; terminal->redraw_scheduled = 0;
buffer_destroy(terminal->buffer, terminal->fd); buffer_destroy(terminal->buffer, terminal->fd);
if (terminal->redraw_pending) {
terminal->redraw_pending = 0;
terminal_schedule_redraw(terminal);
}
} }
struct key { struct key {
@ -319,7 +334,7 @@ terminal_create(struct wl_display *display, int fd)
terminal->window = window_create(display, fd, "Wayland Terminal", terminal->window = window_create(display, fd, "Wayland Terminal",
500, 100, 500, 400); 500, 100, 500, 400);
terminal->display = display; terminal->display = display;
terminal->resize_scheduled = 1; terminal->redraw_scheduled = 1;
terminal->width = 80; terminal->width = 80;
terminal->height = 25; terminal->height = 25;
size = (terminal->width + 1) * terminal->height; size = (terminal->width + 1) * terminal->height;
@ -348,11 +363,6 @@ io_handler(GIOChannel *source,
terminal_data(terminal, buffer, bytes_read); terminal_data(terminal, buffer, bytes_read);
if (!terminal->resize_scheduled) {
g_idle_add(idle_redraw, terminal);
terminal->resize_scheduled = 1;
}
return TRUE; return TRUE;
} }