mirror of
				https://github.com/tmux/tmux.git
				synced 2025-10-26 12:27:15 +00:00 
			
		
		
		
	Some key tweaks, fix status bar to not rely on attr.
This commit is contained in:
		
							
								
								
									
										2
									
								
								TODO
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								TODO
									
									
									
									
									
								
							| @@ -65,6 +65,8 @@ | |||||||
| - window splitting? | - window splitting? | ||||||
| - if only one arg to switch-window, assume source-index | - if only one arg to switch-window, assume source-index | ||||||
| - test on wsvt25, vt100, vt220 | - test on wsvt25, vt100, vt220 | ||||||
|  | - clear EOL etc CANNOT rely on it using the current colour/attr and should | ||||||
|  |   not emulate it doing so - it should always fill with black | ||||||
|  |  | ||||||
| -- For 0.2 -------------------------------------------------------------------- | -- For 0.2 -------------------------------------------------------------------- | ||||||
| - anything which uses cmd_{send,recv}_string will break if the string is | - anything which uses cmd_{send,recv}_string will break if the string is | ||||||
|   | |||||||
							
								
								
									
										52
									
								
								input-keys.c
									
									
									
									
									
								
							
							
						
						
									
										52
									
								
								input-keys.c
									
									
									
									
									
								
							| @@ -1,4 +1,4 @@ | |||||||
| /* $Id: input-keys.c,v 1.5 2007-12-01 11:24:17 nicm Exp $ */ | /* $Id: input-keys.c,v 1.6 2008-01-03 21:32:11 nicm Exp $ */ | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net> |  * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net> | ||||||
| @@ -29,7 +29,6 @@ struct { | |||||||
| 	const char	*data; | 	const char	*data; | ||||||
| } input_keys[] = { | } input_keys[] = { | ||||||
| 	{ KEYC_DC,     "\e[3~" }, | 	{ KEYC_DC,     "\e[3~" }, | ||||||
| 	{ KEYC_DOWN,   "\eOB" }, |  | ||||||
| 	{ KEYC_F1,     "\eOP" }, | 	{ KEYC_F1,     "\eOP" }, | ||||||
| 	{ KEYC_F10,    "\e[21~" }, | 	{ KEYC_F10,    "\e[21~" }, | ||||||
| 	{ KEYC_F11,    "\e[23~" }, | 	{ KEYC_F11,    "\e[23~" }, | ||||||
| @@ -44,12 +43,20 @@ struct { | |||||||
| 	{ KEYC_F9,     "\e[20~" }, | 	{ KEYC_F9,     "\e[20~" }, | ||||||
| 	{ KEYC_FIND,   "\e[1~" }, | 	{ KEYC_FIND,   "\e[1~" }, | ||||||
| 	{ KEYC_IC,     "\e[2~" }, | 	{ KEYC_IC,     "\e[2~" }, | ||||||
| 	{ KEYC_LEFT,   "\eOD" }, |  | ||||||
| 	{ KEYC_SELECT, "\e[4~" }, |  | ||||||
| 	{ KEYC_NPAGE,  "\e[6~" }, | 	{ KEYC_NPAGE,  "\e[6~" }, | ||||||
| 	{ KEYC_PPAGE,  "\e[5~" }, | 	{ KEYC_PPAGE,  "\e[5~" }, | ||||||
|  | 	{ KEYC_SELECT, "\e[4~" }, | ||||||
|  |  | ||||||
|  | 	{ KEYC_UP,     "\eOA" }, | ||||||
|  | 	{ KEYC_DOWN,   "\eOB" }, | ||||||
|  | 	{ KEYC_LEFT,   "\eOD" }, | ||||||
| 	{ KEYC_RIGHT,  "\eOC" }, | 	{ KEYC_RIGHT,  "\eOC" }, | ||||||
| 	{ KEYC_UP,     "\eOA" } |  | ||||||
|  | 	{ KEYC_A1,     "\eOw" }, | ||||||
|  | 	{ KEYC_A3,     "\eOy" }, | ||||||
|  | 	{ KEYC_B2,     "\eOu" }, | ||||||
|  | 	{ KEYC_C1,     "\eOq" }, | ||||||
|  | 	{ KEYC_C3,     "\eOs" } | ||||||
| }; | }; | ||||||
| #define NINPUTKEYS (sizeof input_keys / sizeof input_keys[0]) | #define NINPUTKEYS (sizeof input_keys / sizeof input_keys[0]) | ||||||
|  |  | ||||||
| @@ -65,6 +72,41 @@ input_key(struct window *w, int key) | |||||||
| 		return; | 		return; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | #ifdef notyetifever | ||||||
|  | /* XXX can't we just pass the keypad changes through to tty? */ | ||||||
|  | 	if (!(w->screen->mode & MODE_KKEYPAD)) { | ||||||
|  | 		switch (key) { | ||||||
|  | 		case KEYC_A1: | ||||||
|  | 			buffer_write8(w->out, '9'); | ||||||
|  | 			return; | ||||||
|  | 		case KEYC_UP: | ||||||
|  | 			buffer_write8(w->out, '8'); | ||||||
|  | 			return; | ||||||
|  | 		case KEYC_A3: | ||||||
|  | 			buffer_write8(w->out, '7'); | ||||||
|  | 			return; | ||||||
|  | 		case KEYC_LEFT: | ||||||
|  | 			buffer_write8(w->out, '6'); | ||||||
|  | 			return; | ||||||
|  | 		case KEYC_B2: | ||||||
|  | 			buffer_write8(w->out, '5'); | ||||||
|  | 			return; | ||||||
|  | 		case KEYC_RIGHT: | ||||||
|  | 			buffer_write8(w->out, '4'); | ||||||
|  | 			return; | ||||||
|  | 		case KEYC_C1: | ||||||
|  | 			buffer_write8(w->out, '3'); | ||||||
|  | 			return; | ||||||
|  | 		case KEYC_DOWN: | ||||||
|  | 			buffer_write8(w->out, '2'); | ||||||
|  | 			return; | ||||||
|  | 		case KEYC_C3: | ||||||
|  | 			buffer_write8(w->out, '1'); | ||||||
|  | 			return; | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | #endif | ||||||
|  | 	 | ||||||
| 	for (i = 0; i < NINPUTKEYS; i++) { | 	for (i = 0; i < NINPUTKEYS; i++) { | ||||||
| 		if (input_keys[i].key == key) { | 		if (input_keys[i].key == key) { | ||||||
| 			log_debug2( | 			log_debug2( | ||||||
|   | |||||||
							
								
								
									
										12
									
								
								input.c
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								input.c
									
									
									
									
									
								
							| @@ -1,4 +1,4 @@ | |||||||
| /* $Id: input.c,v 1.45 2007-12-06 13:54:33 nicm Exp $ */ | /* $Id: input.c,v 1.46 2008-01-03 21:32:11 nicm Exp $ */ | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net> |  * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net> | ||||||
| @@ -554,9 +554,11 @@ input_handle_private_two(u_char ch, struct input_ctx *ictx) | |||||||
| 	switch (ch) { | 	switch (ch) { | ||||||
| 	case '=':	/* DECKPAM */ | 	case '=':	/* DECKPAM */ | ||||||
| 		screen_write_set_mode(&ictx->ctx, MODE_KKEYPAD); | 		screen_write_set_mode(&ictx->ctx, MODE_KKEYPAD); | ||||||
|  | 		log_debug("kkeypad on"); | ||||||
| 		break; | 		break; | ||||||
| 	case '>':	/* DECKPNM*/ | 	case '>':	/* DECKPNM*/ | ||||||
| 		screen_write_clear_mode(&ictx->ctx, MODE_KKEYPAD); | 		screen_write_clear_mode(&ictx->ctx, MODE_KKEYPAD); | ||||||
|  | 		log_debug("kkeypad off"); | ||||||
| 		break; | 		break; | ||||||
| 	case '7':	/* DECSC */ | 	case '7':	/* DECSC */ | ||||||
| 		s->saved_cx = s->cx; | 		s->saved_cx = s->cx; | ||||||
| @@ -917,12 +919,15 @@ input_handle_sequence_sm(struct input_ctx *ictx) | |||||||
| 		switch (n) { | 		switch (n) { | ||||||
| 		case 1:		/* GATM */ | 		case 1:		/* GATM */ | ||||||
| 			screen_write_set_mode(&ictx->ctx, MODE_KCURSOR); | 			screen_write_set_mode(&ictx->ctx, MODE_KCURSOR); | ||||||
|  | 			log_debug("kcursor on"); | ||||||
| 			break; | 			break; | ||||||
| 		case 25:	/* TCEM */ | 		case 25:	/* TCEM */ | ||||||
| 			screen_write_set_mode(&ictx->ctx, MODE_CURSOR); | 			screen_write_set_mode(&ictx->ctx, MODE_CURSOR); | ||||||
|  | 			log_debug("cursor on"); | ||||||
| 			break; | 			break; | ||||||
| 		case 1000: | 		case 1000: | ||||||
| 			screen_write_set_mode(&ictx->ctx, MODE_MOUSE); | 			screen_write_set_mode(&ictx->ctx, MODE_MOUSE); | ||||||
|  | 			log_debug("mouse on"); | ||||||
| 			break; | 			break; | ||||||
| 		default: | 		default: | ||||||
| 			log_debug("unknown SM [%hhu]: %u", ictx->private, n); | 			log_debug("unknown SM [%hhu]: %u", ictx->private, n); | ||||||
| @@ -932,6 +937,7 @@ input_handle_sequence_sm(struct input_ctx *ictx) | |||||||
| 		switch (n) { | 		switch (n) { | ||||||
| 		case 4:		/* IRM */ | 		case 4:		/* IRM */ | ||||||
| 			screen_write_set_mode(&ictx->ctx, MODE_INSERT); | 			screen_write_set_mode(&ictx->ctx, MODE_INSERT); | ||||||
|  | 			log_debug("insert on"); | ||||||
| 			break; | 			break; | ||||||
| 		case 34: | 		case 34: | ||||||
| 			/* Cursor high visibility not supported. */ | 			/* Cursor high visibility not supported. */ | ||||||
| @@ -957,12 +963,15 @@ input_handle_sequence_rm(struct input_ctx *ictx) | |||||||
| 		switch (n) { | 		switch (n) { | ||||||
| 		case 1:		/* GATM */ | 		case 1:		/* GATM */ | ||||||
| 			screen_write_clear_mode(&ictx->ctx, MODE_KCURSOR); | 			screen_write_clear_mode(&ictx->ctx, MODE_KCURSOR); | ||||||
|  | 			log_debug("kcursor off"); | ||||||
| 			break; | 			break; | ||||||
| 		case 25:	/* TCEM */ | 		case 25:	/* TCEM */ | ||||||
| 			screen_write_clear_mode(&ictx->ctx, MODE_CURSOR); | 			screen_write_clear_mode(&ictx->ctx, MODE_CURSOR); | ||||||
|  | 			log_debug("cursor off"); | ||||||
| 			break; | 			break; | ||||||
| 		case 1000: | 		case 1000: | ||||||
| 			screen_write_clear_mode(&ictx->ctx, MODE_MOUSE); | 			screen_write_clear_mode(&ictx->ctx, MODE_MOUSE); | ||||||
|  | 			log_debug("mouse off"); | ||||||
| 			break; | 			break; | ||||||
| 		default: | 		default: | ||||||
| 			log_debug("unknown RM [%hhu]: %u", ictx->private, n); | 			log_debug("unknown RM [%hhu]: %u", ictx->private, n); | ||||||
| @@ -972,6 +981,7 @@ input_handle_sequence_rm(struct input_ctx *ictx) | |||||||
| 		switch (n) { | 		switch (n) { | ||||||
| 		case 4:		/* IRM */ | 		case 4:		/* IRM */ | ||||||
| 			screen_write_clear_mode(&ictx->ctx, MODE_INSERT); | 			screen_write_clear_mode(&ictx->ctx, MODE_INSERT); | ||||||
|  | 			log_debug("insert off"); | ||||||
| 			break; | 			break; | ||||||
| 		case 34: | 		case 34: | ||||||
| 			/* Cursor high visibility not supported. */ | 			/* Cursor high visibility not supported. */ | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| /* $Id: screen-redraw.c,v 1.3 2008-01-03 20:01:47 nicm Exp $ */ | /* $Id: screen-redraw.c,v 1.4 2008-01-03 21:32:11 nicm Exp $ */ | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net> |  * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net> | ||||||
| @@ -161,14 +161,6 @@ screen_redraw_clear_screen(struct screen_redraw_ctx *ctx) | |||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
| /* Clear to end of line. */ |  | ||||||
| void |  | ||||||
| screen_redraw_clear_end_of_line(struct screen_redraw_ctx *ctx) |  | ||||||
| { |  | ||||||
| 	if (ctx->s->cx < screen_last_x(ctx->s)) |  | ||||||
| 		ctx->write(ctx->data, TTY_CLEARENDOFLINE); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| /* Redraw single cell. */ | /* Redraw single cell. */ | ||||||
| void | void | ||||||
| screen_redraw_cell(struct screen_redraw_ctx *ctx, u_int px, u_int py) | screen_redraw_cell(struct screen_redraw_ctx *ctx, u_int px, u_int py) | ||||||
|   | |||||||
							
								
								
									
										4
									
								
								screen.c
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								screen.c
									
									
									
									
									
								
							| @@ -1,4 +1,4 @@ | |||||||
| /* $Id: screen.c,v 1.58 2007-12-06 22:13:14 nicm Exp $ */ | /* $Id: screen.c,v 1.59 2008-01-03 21:32:11 nicm Exp $ */ | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net> |  * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net> | ||||||
| @@ -144,7 +144,7 @@ screen_create(struct screen *s, u_int dx, u_int dy) | |||||||
| 	s->attr = SCREEN_DEFATTR; | 	s->attr = SCREEN_DEFATTR; | ||||||
| 	s->colr = SCREEN_DEFCOLR; | 	s->colr = SCREEN_DEFCOLR; | ||||||
|  |  | ||||||
| 	s->mode = MODE_CURSOR; | 	s->mode = MODE_CURSOR|MODE_KCURSOR|MODE_KKEYPAD; | ||||||
| 	s->title = xstrdup(""); | 	s->title = xstrdup(""); | ||||||
|  |  | ||||||
| 	s->grid_data = xmalloc(dy * (sizeof *s->grid_data)); | 	s->grid_data = xmalloc(dy * (sizeof *s->grid_data)); | ||||||
|   | |||||||
							
								
								
									
										7
									
								
								status.c
									
									
									
									
									
								
							
							
						
						
									
										7
									
								
								status.c
									
									
									
									
									
								
							| @@ -1,4 +1,4 @@ | |||||||
| /* $Id: status.c,v 1.17 2008-01-03 20:01:47 nicm Exp $ */ | /* $Id: status.c,v 1.18 2008-01-03 21:32:11 nicm Exp $ */ | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net> |  * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net> | ||||||
| @@ -52,7 +52,10 @@ status_write_client(struct client *c) | |||||||
| 		if (ctx.s->cx > screen_last_x(ctx.s)) | 		if (ctx.s->cx > screen_last_x(ctx.s)) | ||||||
| 			break; | 			break; | ||||||
| 	} | 	} | ||||||
| 	screen_redraw_clear_end_of_line(&ctx); | 	while (ctx.s->cx < screen_size_x(ctx.s)) { | ||||||
|  | 		ctx.write(ctx.data, TTY_CHARACTER, ' '); | ||||||
|  | 		ctx.s->cx++; | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	screen_redraw_stop(&ctx); | 	screen_redraw_stop(&ctx); | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										3
									
								
								tmux.h
									
									
									
									
									
								
							
							
						
						
									
										3
									
								
								tmux.h
									
									
									
									
									
								
							| @@ -1,4 +1,4 @@ | |||||||
| /* $Id: tmux.h,v 1.113 2007-12-06 21:57:57 nicm Exp $ */ | /* $Id: tmux.h,v 1.114 2008-01-03 21:32:11 nicm Exp $ */ | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net> |  * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net> | ||||||
| @@ -892,7 +892,6 @@ void	screen_redraw_move_cursor(struct screen_redraw_ctx *, u_int, u_int); | |||||||
| void	screen_redraw_set_attributes(struct screen_redraw_ctx *, u_int, u_int); | void	screen_redraw_set_attributes(struct screen_redraw_ctx *, u_int, u_int); | ||||||
| void printflike2 screen_redraw_write_string( | void printflike2 screen_redraw_write_string( | ||||||
|     	     struct screen_redraw_ctx *, const char *, ...); |     	     struct screen_redraw_ctx *, const char *, ...); | ||||||
| void	screen_redraw_clear_end_of_line(struct screen_redraw_ctx *); |  | ||||||
| void	screen_redraw_clear_screen(struct screen_redraw_ctx *); | void	screen_redraw_clear_screen(struct screen_redraw_ctx *); | ||||||
| void	screen_redraw_cell(struct screen_redraw_ctx *, u_int, u_int); | void	screen_redraw_cell(struct screen_redraw_ctx *, u_int, u_int); | ||||||
| void	screen_redraw_area( | void	screen_redraw_area( | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| /* $Id: window-more.c,v 1.9 2007-12-07 09:26:56 nicm Exp $ */ | /* $Id: window-more.c,v 1.10 2008-01-03 21:32:11 nicm Exp $ */ | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net> |  * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net> | ||||||
| @@ -93,7 +93,7 @@ window_more_init(struct window *w) | |||||||
|  |  | ||||||
| 	s = &data->screen; | 	s = &data->screen; | ||||||
| 	screen_create(s, screen_size_x(&w->base), screen_size_y(&w->base)); | 	screen_create(s, screen_size_x(&w->base), screen_size_y(&w->base)); | ||||||
| 	s->mode = 0; | 	s->mode &= ~MODE_CURSOR; | ||||||
| 	 | 	 | ||||||
| 	return (s); | 	return (s); | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| /* $Id: window-scroll.c,v 1.16 2007-12-06 10:04:43 nicm Exp $ */ | /* $Id: window-scroll.c,v 1.17 2008-01-03 21:32:11 nicm Exp $ */ | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net> |  * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net> | ||||||
| @@ -66,7 +66,7 @@ window_scroll_init(struct window *w) | |||||||
|  |  | ||||||
| 	s = &data->screen; | 	s = &data->screen; | ||||||
| 	screen_create(s, screen_size_x(&w->base), screen_size_y(&w->base)); | 	screen_create(s, screen_size_x(&w->base), screen_size_y(&w->base)); | ||||||
| 	s->mode = 0; | 	s->mode &= ~MODE_CURSOR; | ||||||
|  |  | ||||||
| 	screen_write_start(&ctx, s, NULL, NULL); | 	screen_write_start(&ctx, s, NULL, NULL); | ||||||
| 	for (i = 0; i < screen_size_y(s); i++) | 	for (i = 0; i < screen_size_y(s); i++) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Nicholas Marriott
					Nicholas Marriott