Kernel/Terminal: Add support for ANSI DSR
This commit is contained in:
parent
8a00b53050
commit
28bf2d6374
|
@ -360,11 +360,24 @@ namespace Kernel
|
||||||
return reset_ansi();
|
return reset_ansi();
|
||||||
}
|
}
|
||||||
reset_ansi();
|
reset_ansi();
|
||||||
dprintln_if(DEBUG_VTTY, "invalid ANSI CSI ?{}{}", m_ansi_state.nums[0], (char)ch);
|
dprintln_if(DEBUG_VTTY, "invalid ANSI CSI character {}", static_cast<char>(ch));
|
||||||
|
return;
|
||||||
|
case 'n':
|
||||||
|
if (m_ansi_state.nums[0] == 6)
|
||||||
|
{
|
||||||
|
char buffer[2 + 10 + 1 + 10 + 1];
|
||||||
|
size_t len = 0;
|
||||||
|
BAN::Formatter::print([&](char ch) { buffer[len++] = ch; }, "\e[{};{}R", m_row + 1, m_column + 1);
|
||||||
|
for (size_t i = 0; i < len; i++)
|
||||||
|
handle_input_byte(buffer[i]);
|
||||||
|
return reset_ansi();
|
||||||
|
};
|
||||||
|
reset_ansi();
|
||||||
|
dprintln_if(DEBUG_VTTY, "Unsupported ANSI CSI character n");
|
||||||
return;
|
return;
|
||||||
default:
|
default:
|
||||||
reset_ansi();
|
reset_ansi();
|
||||||
dprintln_if(DEBUG_VTTY, "Unsupported ANSI CSI character {}", ch);
|
dprintln_if(DEBUG_VTTY, "Unsupported ANSI CSI character {}", static_cast<char>(ch));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -517,11 +517,21 @@ Rectangle Terminal::handle_csi(char ch)
|
||||||
case 'l':
|
case 'l':
|
||||||
if (!m_csi_info.question || m_csi_info.fields[0] != 25)
|
if (!m_csi_info.question || m_csi_info.fields[0] != 25)
|
||||||
{
|
{
|
||||||
dprintln("invalid ANSI CSI ?{}{}", m_csi_info.fields[0], (char)ch);
|
dprintln("unsupported ANSI CSI {}", ch);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
m_cursor_shown = (ch == 'h');
|
m_cursor_shown = (ch == 'h');
|
||||||
break;
|
break;
|
||||||
|
case 'n':
|
||||||
|
if (m_csi_info.fields[0] != 6)
|
||||||
|
{
|
||||||
|
dprintln("unsupported ANSI CSI n");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
char buffer[2 + 10 + 1 + 10 + 2];
|
||||||
|
sprintf(buffer, "\e[%u;%uR", m_cursor.y + 1, m_cursor.x + 1);
|
||||||
|
write(m_shell_info.pts_master, buffer, strlen(buffer));
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
dprintln("TODO: CSI {}", ch);
|
dprintln("TODO: CSI {}", ch);
|
||||||
break;
|
break;
|
||||||
|
|
Loading…
Reference in New Issue