2010-03-30 Thomas Wolff <towo@towo.net>

* fhandler.h (class dev_console): Drop vt100_graphics_mode_active.
	Add flags vt100_graphics_mode_G0, vt100_graphics_mode_G1 and
	iso_2022_G1.
	* fhandler_console.cc: Throughout, tune VT100 graphics mode switching
	to follow ISO 2022 strictly.
This commit is contained in:
Corinna Vinschen 2010-03-30 16:17:34 +00:00
parent 298cf05c21
commit ca8eb333c9
2 changed files with 24 additions and 12 deletions

View File

@ -1,3 +1,11 @@
2010-03-30 Thomas Wolff <towo@towo.net>
* fhandler.h (class dev_console): Drop vt100_graphics_mode_active.
Add flags vt100_graphics_mode_G0, vt100_graphics_mode_G1 and
iso_2022_G1.
* fhandler_console.cc: Throughout, tune VT100 graphics mode switching
to follow ISO 2022 strictly.
2010-03-30 Corinna Vinschen <corinna@vinschen.de> 2010-03-30 Corinna Vinschen <corinna@vinschen.de>
* syscalls.cc (open): Remove call to sig_dispatch_pending. * syscalls.cc (open): Remove call to sig_dispatch_pending.

View File

@ -1161,7 +1161,9 @@ static wchar_t __vt100_conv [31] = {
inline inline
bool fhandler_console::write_console (PWCHAR buf, DWORD len, DWORD& done) bool fhandler_console::write_console (PWCHAR buf, DWORD len, DWORD& done)
{ {
if (dev_state->vt100_graphics_mode_active) if (dev_state->iso_2022_G1
? dev_state->vt100_graphics_mode_G1
: dev_state->vt100_graphics_mode_G0)
for (DWORD i = 0; i < len; i ++) for (DWORD i = 0; i < len; i ++)
if (buf[i] >= (unsigned char) '`' && buf[i] <= (unsigned char) '~') if (buf[i] >= (unsigned char) '`' && buf[i] <= (unsigned char) '~')
buf[i] = __vt100_conv[buf[i] - (unsigned char) '`']; buf[i] = __vt100_conv[buf[i] - (unsigned char) '`'];
@ -1734,11 +1736,11 @@ fhandler_console::write_normal (const unsigned char *src,
int x, y; int x, y;
switch (base_chars[*found]) switch (base_chars[*found])
{ {
case SO: case SO: /* Shift Out: Invoke G1 character set (ISO 2022) */
dev_state->vt100_graphics_mode_active = true; dev_state->iso_2022_G1 = true;
break; break;
case SI: case SI: /* Shift In: Invoke G0 character set (ISO 2022) */
dev_state->vt100_graphics_mode_active = false; dev_state->iso_2022_G1 = false;
break; break;
case BEL: case BEL:
beep (); beep ();
@ -1862,6 +1864,9 @@ fhandler_console::write (const void *vsrc, size_t len)
else if (*src == 'c') /* RIS Full Reset */ else if (*src == 'c') /* RIS Full Reset */
{ {
dev_state->set_default_attr (); dev_state->set_default_attr ();
dev_state->vt100_graphics_mode_G0 = false;
dev_state->vt100_graphics_mode_G1 = false;
dev_state->iso_2022_G1 = false;
clear_screen (0, 0, -1, -1); clear_screen (0, 0, -1, -1);
cursor_set (true, 0, 0); cursor_set (true, 0, 0);
dev_state->state_ = normal; dev_state->state_ = normal;
@ -1959,20 +1964,19 @@ fhandler_console::write (const void *vsrc, size_t len)
else else
dev_state->state_ = gotarg1; dev_state->state_ = gotarg1;
break; break;
case gotparen: case gotparen: /* Designate G0 Character Set (ISO 2022) */
if (*src == '0') if (*src == '0')
dev_state->vt100_graphics_mode_active = true; dev_state->vt100_graphics_mode_G0 = true;
else else
dev_state->vt100_graphics_mode_active = false; dev_state->vt100_graphics_mode_G0 = false;
dev_state->state_ = normal; dev_state->state_ = normal;
src++; src++;
break; break;
case gotrparen: case gotrparen: /* Designate G1 Character Set (ISO 2022) */
/* This is not strictly needed, ^N/^O can just always be enabled */
if (*src == '0') if (*src == '0')
/*dev_state->vt100_graphics_mode_SOSI_enabled = true*/; dev_state->vt100_graphics_mode_G1 = true;
else else
/*dev_state->vt100_graphics_mode_SOSI_enabled = false*/; dev_state->vt100_graphics_mode_G1 = false;
dev_state->state_ = normal; dev_state->state_ = normal;
src++; src++;
break; break;