mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2024-11-26 01:20:25 +00:00
GTextEditor: Support forward delete/merge with the Delete key.
This commit is contained in:
parent
ac78cdae46
commit
a64b71fb3d
Notes:
sideshowbarker
2024-07-19 15:08:20 +09:00
Author: https://github.com/awesomekling Commit: https://github.com/SerenityOS/serenity/commit/a64b71fb3d4
1 changed files with 25 additions and 1 deletions
|
@ -190,20 +190,42 @@ void GTextEditor::keydown_event(GKeyEvent& event)
|
|||
if (m_cursor.column() > 0) {
|
||||
// Backspace within line
|
||||
current_line().remove(m_cursor.column() - 1);
|
||||
update_scrollbar_ranges();
|
||||
set_cursor(m_cursor.line(), m_cursor.column() - 1);
|
||||
}
|
||||
if (m_cursor.column() == 0 && m_cursor.line() != 0) {
|
||||
// Erase at column 0; merge with previous line
|
||||
// Backspace at column 0; merge with previous line
|
||||
auto& previous_line = *m_lines[m_cursor.line() - 1];
|
||||
int previous_length = previous_line.length();
|
||||
previous_line.append(current_line().characters(), current_line().length());
|
||||
m_lines.remove(m_cursor.line());
|
||||
update_scrollbar_ranges();
|
||||
update();
|
||||
set_cursor(m_cursor.line() - 1, previous_length);
|
||||
}
|
||||
return;
|
||||
}
|
||||
|
||||
if (!event.modifiers() && event.key() == KeyCode::Key_Delete) {
|
||||
if (m_cursor.column() < current_line().length()) {
|
||||
// Delete within line
|
||||
current_line().remove(m_cursor.column());
|
||||
update_scrollbar_ranges();
|
||||
update_cursor();
|
||||
}
|
||||
if (m_cursor.column() == (current_line().length() + 1) && m_cursor.line() != line_count() - 1) {
|
||||
// Delete at end of line; merge with next line
|
||||
auto& next_line = *m_lines[m_cursor.line() + 1];
|
||||
int previous_length = current_line().length();
|
||||
current_line().append(next_line.characters(), next_line.length());
|
||||
m_lines.remove(m_cursor.line() + 1);
|
||||
update_scrollbar_ranges();
|
||||
update();
|
||||
set_cursor(m_cursor.line(), previous_length);
|
||||
}
|
||||
return;
|
||||
}
|
||||
|
||||
if (!event.text().is_empty())
|
||||
insert_at_cursor(event.text()[0]);
|
||||
|
||||
|
@ -256,6 +278,8 @@ Rect GTextEditor::line_widget_rect(int line_index) const
|
|||
rect.move_by(-(m_horizontal_scrollbar->value() - padding()), -(m_vertical_scrollbar->value() - padding()));
|
||||
rect.set_width(rect.width() + 1); // Add 1 pixel for when the cursor is on the end.
|
||||
rect.intersect(this->rect());
|
||||
// This feels rather hackish, but extend the rect to the edge of the content view:
|
||||
rect.set_right(m_vertical_scrollbar->relative_rect().left() - 1);
|
||||
return rect;
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue