Kernel: Make backspace \b and delete 0x7F
This is what `vim` seems to expect and imo makes way more sense.
This commit is contained in:
parent
72d9e4c1e7
commit
51b6329c86
|
@ -210,6 +210,8 @@ namespace Kernel
|
||||||
void SerialTTY::handle_irq()
|
void SerialTTY::handle_irq()
|
||||||
{
|
{
|
||||||
uint8_t ch = IO::inb(m_serial.port());
|
uint8_t ch = IO::inb(m_serial.port());
|
||||||
|
if (ch == 0x7F)
|
||||||
|
ch = '\b';
|
||||||
|
|
||||||
SpinLockGuard _(m_input_lock);
|
SpinLockGuard _(m_input_lock);
|
||||||
if (m_input.full())
|
if (m_input.full())
|
||||||
|
|
|
@ -285,14 +285,6 @@ namespace Kernel
|
||||||
|
|
||||||
void TTY::do_backspace()
|
void TTY::do_backspace()
|
||||||
{
|
{
|
||||||
auto print_backspace =
|
|
||||||
[this]
|
|
||||||
{
|
|
||||||
putchar('\b');
|
|
||||||
putchar(' ');
|
|
||||||
putchar('\b');
|
|
||||||
};
|
|
||||||
|
|
||||||
if (m_output.bytes > 0)
|
if (m_output.bytes > 0)
|
||||||
{
|
{
|
||||||
uint8_t last = m_output.buffer[m_output.bytes - 1];
|
uint8_t last = m_output.buffer[m_output.bytes - 1];
|
||||||
|
@ -308,20 +300,20 @@ namespace Kernel
|
||||||
}
|
}
|
||||||
ASSERT(m_output.bytes > 0);
|
ASSERT(m_output.bytes > 0);
|
||||||
m_output.bytes--;
|
m_output.bytes--;
|
||||||
print_backspace();
|
putchar('\b');
|
||||||
}
|
}
|
||||||
// Caret notation
|
// Caret notation
|
||||||
else if (last < 32 || last == 127)
|
else if (last < 32 || last == 127)
|
||||||
{
|
{
|
||||||
m_output.bytes--;
|
m_output.bytes--;
|
||||||
print_backspace();
|
putchar('\b');
|
||||||
print_backspace();
|
putchar('\b');
|
||||||
}
|
}
|
||||||
// Ascii
|
// Ascii
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
m_output.bytes--;
|
m_output.bytes--;
|
||||||
print_backspace();
|
putchar('\b');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -461,7 +461,7 @@ namespace Kernel
|
||||||
break;
|
break;
|
||||||
case BS:
|
case BS:
|
||||||
if (m_column > 0)
|
if (m_column > 0)
|
||||||
m_column--;
|
putchar_at(' ', --m_column, m_row);
|
||||||
break;
|
break;
|
||||||
case HT:
|
case HT:
|
||||||
m_column++;
|
m_column++;
|
||||||
|
@ -480,7 +480,7 @@ namespace Kernel
|
||||||
break;
|
break;
|
||||||
case ESC:
|
case ESC:
|
||||||
m_state = State::WaitingAnsiEscape;
|
m_state = State::WaitingAnsiEscape;
|
||||||
break;;
|
break;
|
||||||
default:
|
default:
|
||||||
putchar_at(codepoint, m_column, m_row);
|
putchar_at(codepoint, m_column, m_row);
|
||||||
m_last_graphic_char = codepoint;
|
m_last_graphic_char = codepoint;
|
||||||
|
|
|
@ -58,10 +58,10 @@ namespace LibInput
|
||||||
"å", "ä", "ö",
|
"å", "ä", "ö",
|
||||||
"0", "1", "2", "3", "4", "5", "6", "7", "8", "9",
|
"0", "1", "2", "3", "4", "5", "6", "7", "8", "9",
|
||||||
nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr,
|
nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr,
|
||||||
/*"Insert", "PrintScreen", "Delete", "Home", "End", "PageUp", "PageDown",*/ nullptr, nullptr, "\e[3~", nullptr, nullptr, nullptr, nullptr, "\n", " ",
|
/*"Insert", "PrintScreen", "Delete", "Home", "End", "PageUp", "PageDown",*/ nullptr, nullptr, "\x7F", nullptr, nullptr, nullptr, nullptr, "\n", " ",
|
||||||
"!", "\"", "#", "¤", "%", "&", "/", "§", "½",
|
"!", "\"", "#", "¤", "%", "&", "/", "§", "½",
|
||||||
"(", ")", "[", "]", "{", "}",
|
"(", ")", "[", "]", "{", "}",
|
||||||
"=", "?", "+", "\\", "´", "`", "¨", "¸", "\x7F", "@", "£", "$", "€",
|
"=", "?", "+", "\\", "´", "`", "¨", "¸", "\b", "@", "£", "$", "€",
|
||||||
"\e", "\t", nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr,
|
"\e", "\t", nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr,
|
||||||
"'", "*", "^", "~", "\e[A", "\e[B", "\e[D", "\e[C",
|
"'", "*", "^", "~", "\e[A", "\e[B", "\e[D", "\e[C",
|
||||||
",", ";", ".", ":", "-", "_", nullptr, nullptr, "<", ">", "|", "¬", "¦",
|
",", ";", ".", ":", "-", "_", nullptr, nullptr, "<", ">", "|", "¬", "¦",
|
||||||
|
@ -77,10 +77,10 @@ namespace LibInput
|
||||||
"Å", "Ä", "Ö",
|
"Å", "Ä", "Ö",
|
||||||
"0", "1", "2", "3", "4", "5", "6", "7", "8", "9",
|
"0", "1", "2", "3", "4", "5", "6", "7", "8", "9",
|
||||||
nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr,
|
nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr,
|
||||||
/*"Insert", "PrintScreen", "Delete", "Home", "End", "PageUp", "PageDown",*/ nullptr, nullptr, "\e[3~", nullptr, nullptr, nullptr, nullptr, "\n", " ",
|
/*"Insert", "PrintScreen", "Delete", "Home", "End", "PageUp", "PageDown",*/ nullptr, nullptr, "\x7F", nullptr, nullptr, nullptr, nullptr, "\n", " ",
|
||||||
"!", "\"", "#", "¤", "%", "&", "/", "§", "½",
|
"!", "\"", "#", "¤", "%", "&", "/", "§", "½",
|
||||||
"(", ")", "[", "]", "{", "}",
|
"(", ")", "[", "]", "{", "}",
|
||||||
"=", "?", "+", "\\", "´", "`", "¨", "¸", "\x7F", "@", "£", "$", "€",
|
"=", "?", "+", "\\", "´", "`", "¨", "¸", "\b", "@", "£", "$", "€",
|
||||||
"\e", "\t", nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr,
|
"\e", "\t", nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr,
|
||||||
"'", "*", "^", "~", "\e[A", "\e[B", "\e[D", "\e[C",
|
"'", "*", "^", "~", "\e[A", "\e[B", "\e[D", "\e[C",
|
||||||
",", ";", ".", ":", "-", "_", nullptr, nullptr, "<", ">", "|", "¬", "¦",
|
",", ";", ".", ":", "-", "_", nullptr, nullptr, "<", ">", "|", "¬", "¦",
|
||||||
|
@ -96,10 +96,10 @@ namespace LibInput
|
||||||
"Å", "Ä", "Ö",
|
"Å", "Ä", "Ö",
|
||||||
"0", "1", "2", "3", "4", "5", "6", "7", "8", "9",
|
"0", "1", "2", "3", "4", "5", "6", "7", "8", "9",
|
||||||
nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr,
|
nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr,
|
||||||
/*"Insert", "PrintScreen", "Delete", "Home", "End", "PageUp", "PageDown",*/ nullptr, nullptr, "\e[3~", nullptr, nullptr, nullptr, nullptr, "\n", " ",
|
/*"Insert", "PrintScreen", "Delete", "Home", "End", "PageUp", "PageDown",*/ nullptr, nullptr, "\x7F", nullptr, nullptr, nullptr, nullptr, "\n", " ",
|
||||||
"!", "\"", "#", "¤", "%", "&", "/", "§", "½",
|
"!", "\"", "#", "¤", "%", "&", "/", "§", "½",
|
||||||
"(", ")", "[", "]", "{", "}",
|
"(", ")", "[", "]", "{", "}",
|
||||||
"=", "?", "+", "\\", "´", "`", "¨", "¸", "\x7F", "@", "£", "$", "€",
|
"=", "?", "+", "\\", "´", "`", "¨", "¸", "\b", "@", "£", "$", "€",
|
||||||
"\e", "\t", nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr,
|
"\e", "\t", nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr, nullptr,
|
||||||
"'", "*", "^", "~", "\e[A", "\e[B", "\e[D", "\e[C",
|
"'", "*", "^", "~", "\e[A", "\e[B", "\e[D", "\e[C",
|
||||||
",", ";", ".", ":", "-", "_", nullptr, nullptr, "<", ">", "|", "¬", "¦",
|
",", ";", ".", ":", "-", "_", nullptr, nullptr, "<", ">", "|", "¬", "¦",
|
||||||
|
|
|
@ -468,9 +468,9 @@ BAN::Optional<BAN::String> Input::get_input(BAN::Optional<BAN::StringView> custo
|
||||||
if (m_buffer_col <= 0)
|
if (m_buffer_col <= 0)
|
||||||
break;
|
break;
|
||||||
while ((m_buffers[m_buffer_index][m_buffer_col - 1] & 0xC0) == 0x80)
|
while ((m_buffers[m_buffer_index][m_buffer_col - 1] & 0xC0) == 0x80)
|
||||||
m_buffer_col--;
|
m_buffers[m_buffer_index].remove(--m_buffer_col);
|
||||||
m_buffer_col--;
|
m_buffers[m_buffer_index].remove(--m_buffer_col);
|
||||||
printf("\e[D");
|
printf("\b\e[s%s \e[u", m_buffers[m_buffer_index].data() + m_buffer_col);
|
||||||
fflush(stdout);
|
fflush(stdout);
|
||||||
break;
|
break;
|
||||||
case '\x01': // ^A
|
case '\x01': // ^A
|
||||||
|
@ -490,13 +490,13 @@ BAN::Optional<BAN::String> Input::get_input(BAN::Optional<BAN::StringView> custo
|
||||||
break;
|
break;
|
||||||
putchar('\n');
|
putchar('\n');
|
||||||
return {};
|
return {};
|
||||||
case '\x7F': // backspace
|
case '\x7F':
|
||||||
if (m_buffer_col <= 0)
|
if (m_buffer_col >= m_buffers[m_buffer_index].size())
|
||||||
break;
|
break;
|
||||||
while ((m_buffers[m_buffer_index][m_buffer_col - 1] & 0xC0) == 0x80)
|
m_buffers[m_buffer_index].remove(m_buffer_col);
|
||||||
m_buffers[m_buffer_index].remove(--m_buffer_col);
|
while (m_buffer_col < m_buffers[m_buffer_index].size() && (m_buffers[m_buffer_index][m_buffer_col] & 0xC0) == 0x80)
|
||||||
m_buffers[m_buffer_index].remove(--m_buffer_col);
|
m_buffers[m_buffer_index].remove(m_buffer_col);
|
||||||
printf("\b\e[s%s \e[u", m_buffers[m_buffer_index].data() + m_buffer_col);
|
printf("\e[s%s \e[u", m_buffers[m_buffer_index].data() + m_buffer_col);
|
||||||
fflush(stdout);
|
fflush(stdout);
|
||||||
break;
|
break;
|
||||||
case '\n':
|
case '\n':
|
||||||
|
|
Loading…
Reference in New Issue