Reset before calling window_draw otherwise it'll have the wrong idea of the current state (since it copies from screen).

This commit is contained in:
Nicholas Marriott 2007-11-24 18:32:52 +00:00
parent 112f4d9f60
commit b9034946ad
2 changed files with 9 additions and 9 deletions

View File

@ -1,4 +1,4 @@
/* $Id: server-fn.c,v 1.33 2007-11-24 18:09:59 nicm Exp $ */ /* $Id: server-fn.c,v 1.34 2007-11-24 18:32:52 nicm Exp $ */
/* /*
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net> * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
@ -343,7 +343,7 @@ server_write_message(struct client *c, const char *fmt, ...)
size = BUFFER_USED(c->out); size = BUFFER_USED(c->out);
screen_draw_start(&ctx, &w->screen, c->out, 0, 0); screen_draw_start(&ctx, &w->screen, c->out, 0, 0);
screen_draw_move(&ctx, 0, c->sy); screen_draw_move(&ctx, 0, c->sy - 1);
screen_draw_set_attributes(&ctx, ATTR_REVERSE, 0x88); screen_draw_set_attributes(&ctx, ATTR_REVERSE, 0x88);
va_start(ap, fmt); va_start(ap, fmt);
xvasprintf(&msg, fmt, ap); xvasprintf(&msg, fmt, ap);
@ -368,11 +368,11 @@ server_write_message(struct client *c, const char *fmt, ...)
buffer_add(c->out, sizeof hdr); buffer_add(c->out, sizeof hdr);
size = BUFFER_USED(c->out); size = BUFFER_USED(c->out);
screen_draw_stop(&ctx);
if (status_lines == 0) if (status_lines == 0)
window_draw(w, c->out, screen_last_y(&w->screen), 1); window_draw(w, c->out, c->sy - 1, 1);
else else
status_write(c); status_write(c);
screen_draw_stop(&ctx);
size = BUFFER_USED(c->out) - size; size = BUFFER_USED(c->out) - size;
hdr.type = MSG_DATA; hdr.type = MSG_DATA;

10
tmux.h
View File

@ -1,4 +1,4 @@
/* $Id: tmux.h,v 1.98 2007-11-23 17:52:54 nicm Exp $ */ /* $Id: tmux.h,v 1.99 2007-11-24 18:32:52 nicm Exp $ */
/* /*
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net> * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
@ -374,8 +374,8 @@ struct screen {
u_int saved_cx; u_int saved_cx;
u_int saved_cy; u_int saved_cy;
u_int saved_attr; u_char saved_attr;
u_int saved_colr; u_char saved_colr;
int mode; int mode;
}; };
@ -402,8 +402,8 @@ struct screen_draw_ctx {
u_int ox; u_int ox;
u_int oy; u_int oy;
u_int attr; u_char attr;
u_int colr; u_char colr;
struct screen_draw_sel sel; struct screen_draw_sel sel;
}; };