mirror of
https://github.com/tmux/tmux.git
synced 2025-01-27 16:48:49 +00:00
Record intermediate for p2/s2 and fake up charset redefinition (some programs use it to switch character set).
This commit is contained in:
parent
cf092dc27f
commit
6304e23984
58
input.c
58
input.c
@ -1,4 +1,4 @@
|
|||||||
/* $Id: input.c,v 1.65 2008-11-04 20:06:48 nicm Exp $ */
|
/* $Id: input.c,v 1.66 2008-11-04 20:41:10 nicm Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||||
@ -245,6 +245,8 @@ input_parse(struct window *w)
|
|||||||
void
|
void
|
||||||
input_state_first(u_char ch, struct input_ctx *ictx)
|
input_state_first(u_char ch, struct input_ctx *ictx)
|
||||||
{
|
{
|
||||||
|
ictx->intermediate = '\0';
|
||||||
|
|
||||||
if (INPUT_C0CONTROL(ch)) {
|
if (INPUT_C0CONTROL(ch)) {
|
||||||
if (ch == 0x1b)
|
if (ch == 0x1b)
|
||||||
input_state(ictx, input_state_escape);
|
input_state(ictx, input_state_escape);
|
||||||
@ -289,6 +291,8 @@ input_state_escape(u_char ch, struct input_ctx *ictx)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (INPUT_INTERMEDIATE(ch)) {
|
if (INPUT_INTERMEDIATE(ch)) {
|
||||||
|
log_debug2(":: in1 %zu: %hhu (%c)", ictx->off, ch, ch);
|
||||||
|
ictx->intermediate = ch;
|
||||||
input_state(ictx, input_state_intermediate);
|
input_state(ictx, input_state_intermediate);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -327,8 +331,11 @@ input_state_escape(u_char ch, struct input_ctx *ictx)
|
|||||||
void
|
void
|
||||||
input_state_intermediate(u_char ch, struct input_ctx *ictx)
|
input_state_intermediate(u_char ch, struct input_ctx *ictx)
|
||||||
{
|
{
|
||||||
if (INPUT_INTERMEDIATE(ch))
|
if (INPUT_INTERMEDIATE(ch)) {
|
||||||
|
/* Multiple intermediates currently ignored. */
|
||||||
|
log_debug2(":: in2 %zu: %hhu (%c)", ictx->off, ch, ch);
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (INPUT_PARAMETER(ch)) {
|
if (INPUT_PARAMETER(ch)) {
|
||||||
input_state(ictx, input_state_first);
|
input_state(ictx, input_state_first);
|
||||||
@ -372,8 +379,10 @@ input_state_sequence_next(u_char ch, struct input_ctx *ictx)
|
|||||||
if (INPUT_INTERMEDIATE(ch)) {
|
if (INPUT_INTERMEDIATE(ch)) {
|
||||||
if (input_add_argument(ictx, '\0') != 0)
|
if (input_add_argument(ictx, '\0') != 0)
|
||||||
input_state(ictx, input_state_first);
|
input_state(ictx, input_state_first);
|
||||||
else
|
else {
|
||||||
|
log_debug2(":: si1 %zu: %hhu (%c)", ictx->off, ch, ch);
|
||||||
input_state(ictx, input_state_sequence_intermediate);
|
input_state(ictx, input_state_sequence_intermediate);
|
||||||
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -405,7 +414,7 @@ void
|
|||||||
input_state_sequence_intermediate(u_char ch, struct input_ctx *ictx)
|
input_state_sequence_intermediate(u_char ch, struct input_ctx *ictx)
|
||||||
{
|
{
|
||||||
if (INPUT_INTERMEDIATE(ch)) {
|
if (INPUT_INTERMEDIATE(ch)) {
|
||||||
log_debug2(":: in %zu: %hhu (%c)", ictx->off, ch, ch);
|
log_debug2(":: si2 %zu: %hhu (%c)", ictx->off, ch, ch);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -601,14 +610,22 @@ input_handle_private_two(u_char ch, struct input_ctx *ictx)
|
|||||||
{
|
{
|
||||||
struct screen *s = ictx->ctx.s;
|
struct screen *s = ictx->ctx.s;
|
||||||
|
|
||||||
log_debug2("-- p2 %zu: %hhu (%c)", ictx->off, ch, ch);
|
log_debug2(
|
||||||
|
"-- p2 %zu: %hhu (%c) %hhu", ictx->off, ch, ch, ictx->intermediate);
|
||||||
|
|
||||||
switch (ch) {
|
switch (ch) {
|
||||||
#if 0
|
case '0': /* Dscs (graphics) */
|
||||||
case '0': /* Don't know? */
|
/*
|
||||||
|
* Not really supported, but fake it up enough for those that
|
||||||
|
* use it to switch character sets (by redefining G0 to
|
||||||
|
* graphics set, rather than switching to G1).
|
||||||
|
*/
|
||||||
|
switch (ictx->intermediate) {
|
||||||
|
case '(': /* G0 */
|
||||||
ictx->cell.attr |= GRID_ATTR_CHARSET;
|
ictx->cell.attr |= GRID_ATTR_CHARSET;
|
||||||
break;
|
break;
|
||||||
#endif
|
}
|
||||||
|
break;
|
||||||
case '=': /* DECKPAM */
|
case '=': /* DECKPAM */
|
||||||
screen_write_kkeypadmode(&ictx->ctx, 1);
|
screen_write_kkeypadmode(&ictx->ctx, 1);
|
||||||
log_debug("kkeypad on (application mode)");
|
log_debug("kkeypad on (application mode)");
|
||||||
@ -636,14 +653,22 @@ input_handle_private_two(u_char ch, struct input_ctx *ictx)
|
|||||||
void
|
void
|
||||||
input_handle_standard_two(u_char ch, struct input_ctx *ictx)
|
input_handle_standard_two(u_char ch, struct input_ctx *ictx)
|
||||||
{
|
{
|
||||||
log_debug2("-- s2 %zu: %hhu (%c)", ictx->off, ch, ch);
|
log_debug2(
|
||||||
|
"-- s2 %zu: %hhu (%c) %hhu", ictx->off, ch, ch, ictx->intermediate);
|
||||||
|
|
||||||
switch (ch) {
|
switch (ch) {
|
||||||
#if 0
|
case 'B': /* Dscs (ASCII) */
|
||||||
case 'B': /* Don't know? */
|
/*
|
||||||
|
* Not really supported, but fake it up enough for those that
|
||||||
|
* use it to switch character sets (by redefining G0 to
|
||||||
|
* graphics set, rather than switching to G1).
|
||||||
|
*/
|
||||||
|
switch (ictx->intermediate) {
|
||||||
|
case '(': /* G0 */
|
||||||
ictx->cell.attr &= ~GRID_ATTR_CHARSET;
|
ictx->cell.attr &= ~GRID_ATTR_CHARSET;
|
||||||
break;
|
break;
|
||||||
#endif
|
}
|
||||||
|
break;
|
||||||
case 'c': /* RIS */
|
case 'c': /* RIS */
|
||||||
memcpy(&ictx->cell, &grid_default_cell, sizeof ictx->cell);
|
memcpy(&ictx->cell, &grid_default_cell, sizeof ictx->cell);
|
||||||
|
|
||||||
@ -1187,12 +1212,21 @@ input_handle_sequence_sgr(struct input_ctx *ictx)
|
|||||||
case 8:
|
case 8:
|
||||||
gc->attr |= GRID_ATTR_HIDDEN;
|
gc->attr |= GRID_ATTR_HIDDEN;
|
||||||
break;
|
break;
|
||||||
|
case 22:
|
||||||
|
gc->attr &= ~(GRID_ATTR_BRIGHT|GRID_ATTR_DIM);
|
||||||
|
break;
|
||||||
case 23:
|
case 23:
|
||||||
gc->attr &= ~GRID_ATTR_ITALICS;
|
gc->attr &= ~GRID_ATTR_ITALICS;
|
||||||
break;
|
break;
|
||||||
case 24:
|
case 24:
|
||||||
gc->attr &= ~GRID_ATTR_UNDERSCORE;
|
gc->attr &= ~GRID_ATTR_UNDERSCORE;
|
||||||
break;
|
break;
|
||||||
|
case 25:
|
||||||
|
gc->attr &= ~GRID_ATTR_BLINK;
|
||||||
|
break;
|
||||||
|
case 27:
|
||||||
|
gc->attr &= ~GRID_ATTR_REVERSE;
|
||||||
|
break;
|
||||||
case 30:
|
case 30:
|
||||||
case 31:
|
case 31:
|
||||||
case 32:
|
case 32:
|
||||||
|
3
tmux.h
3
tmux.h
@ -1,4 +1,4 @@
|
|||||||
/* $Id: tmux.h,v 1.193 2008-10-09 22:00:33 nicm Exp $ */
|
/* $Id: tmux.h,v 1.194 2008-11-04 20:41:10 nicm Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||||
@ -532,6 +532,7 @@ struct input_ctx {
|
|||||||
u_int utf8_len;
|
u_int utf8_len;
|
||||||
u_int utf8_off;
|
u_int utf8_off;
|
||||||
|
|
||||||
|
u_char intermediate;
|
||||||
void *(*state)(u_char, struct input_ctx *);
|
void *(*state)(u_char, struct input_ctx *);
|
||||||
|
|
||||||
u_char private;
|
u_char private;
|
||||||
|
Loading…
Reference in New Issue
Block a user