add 'A' and 'I' commands
This commit is contained in:
parent
237dbf9c2b
commit
dbe5843d77
@ -333,16 +333,17 @@ void BufferPane::handle_key(uint32_t keyval)
|
|||||||
case '$':
|
case '$':
|
||||||
cursor_move(CursorMovement::EOL);
|
cursor_move(CursorMovement::EOL);
|
||||||
break;
|
break;
|
||||||
|
case 'A':
|
||||||
|
enter_insert_mode(EnterInsertModeMode::END_OF_LINE);
|
||||||
|
break;
|
||||||
case 'G':
|
case 'G':
|
||||||
cursor_move(CursorMovement::LAST_LINE);
|
cursor_move(CursorMovement::LAST_LINE);
|
||||||
break;
|
break;
|
||||||
|
case 'I':
|
||||||
|
enter_insert_mode(EnterInsertModeMode::START_OF_LINE);
|
||||||
|
break;
|
||||||
case 'a':
|
case 'a':
|
||||||
if (**m_iterator != '\n')
|
enter_insert_mode(EnterInsertModeMode::END_OF_CHAR);
|
||||||
{
|
|
||||||
m_iterator->go_forward();
|
|
||||||
}
|
|
||||||
m_buffer->enter_insert_mode(*m_iterator);
|
|
||||||
m_window->request_redraw();
|
|
||||||
break;
|
break;
|
||||||
case 'g':
|
case 'g':
|
||||||
cursor_move(CursorMovement::FIRST_LINE);
|
cursor_move(CursorMovement::FIRST_LINE);
|
||||||
@ -351,8 +352,7 @@ void BufferPane::handle_key(uint32_t keyval)
|
|||||||
cursor_move(CursorMovement::LEFT);
|
cursor_move(CursorMovement::LEFT);
|
||||||
break;
|
break;
|
||||||
case 'i':
|
case 'i':
|
||||||
m_buffer->enter_insert_mode(*m_iterator);
|
enter_insert_mode(EnterInsertModeMode::START_OF_CHAR);
|
||||||
m_window->request_redraw();
|
|
||||||
break;
|
break;
|
||||||
case 'j':
|
case 'j':
|
||||||
cursor_move(CursorMovement::DOWN);
|
cursor_move(CursorMovement::DOWN);
|
||||||
@ -486,6 +486,42 @@ void BufferPane::cursor_move(CursorMovement which)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void BufferPane::enter_insert_mode(EnterInsertModeMode which)
|
||||||
|
{
|
||||||
|
if (m_buffer->insert_mode())
|
||||||
|
return;
|
||||||
|
|
||||||
|
switch (which)
|
||||||
|
{
|
||||||
|
case EnterInsertModeMode::START_OF_CHAR:
|
||||||
|
m_buffer->enter_insert_mode(*m_iterator);
|
||||||
|
break;
|
||||||
|
case EnterInsertModeMode::END_OF_CHAR:
|
||||||
|
if (**m_iterator != '\n')
|
||||||
|
{
|
||||||
|
m_iterator->go_forward();
|
||||||
|
}
|
||||||
|
m_buffer->enter_insert_mode(*m_iterator);
|
||||||
|
break;
|
||||||
|
case EnterInsertModeMode::START_OF_LINE:
|
||||||
|
m_iterator->go_start_of_line();
|
||||||
|
enter_insert_mode(EnterInsertModeMode::START_OF_CHAR);
|
||||||
|
break;
|
||||||
|
case EnterInsertModeMode::END_OF_LINE:
|
||||||
|
m_iterator->go_end_of_line(false);
|
||||||
|
enter_insert_mode(EnterInsertModeMode::END_OF_CHAR);
|
||||||
|
break;
|
||||||
|
case EnterInsertModeMode::NEW_LINE_BEFORE:
|
||||||
|
/* TODO */
|
||||||
|
break;
|
||||||
|
case EnterInsertModeMode::NEW_LINE_AFTER:
|
||||||
|
/* TODO */
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
m_window->request_redraw();
|
||||||
|
}
|
||||||
|
|
||||||
void BufferPane::forward_to_column(int column, bool allow_eol)
|
void BufferPane::forward_to_column(int column, bool allow_eol)
|
||||||
{
|
{
|
||||||
Buffer::Iterator start_of_line = *m_iterator;
|
Buffer::Iterator start_of_line = *m_iterator;
|
||||||
|
@ -29,6 +29,16 @@ protected:
|
|||||||
LAST_LINE,
|
LAST_LINE,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
enum class EnterInsertModeMode : uint8_t
|
||||||
|
{
|
||||||
|
START_OF_CHAR,
|
||||||
|
END_OF_CHAR,
|
||||||
|
START_OF_LINE,
|
||||||
|
END_OF_LINE,
|
||||||
|
NEW_LINE_BEFORE,
|
||||||
|
NEW_LINE_AFTER,
|
||||||
|
};
|
||||||
|
|
||||||
int effective_scroll_offset()
|
int effective_scroll_offset()
|
||||||
{
|
{
|
||||||
return std::min(m_scroll_offset, (m_rows - 1) / 2);
|
return std::min(m_scroll_offset, (m_rows - 1) / 2);
|
||||||
@ -53,6 +63,7 @@ protected:
|
|||||||
return m_height - (row + 1) * m_window->font()->get_line_height();
|
return m_height - (row + 1) * m_window->font()->get_line_height();
|
||||||
}
|
}
|
||||||
void cursor_move(CursorMovement which);
|
void cursor_move(CursorMovement which);
|
||||||
|
void enter_insert_mode(EnterInsertModeMode which);
|
||||||
void forward_to_column(int column, bool allow_eol);
|
void forward_to_column(int column, bool allow_eol);
|
||||||
size_t display_line() const { return m_iterator->line() + 1u; }
|
size_t display_line() const { return m_iterator->line() + 1u; }
|
||||||
size_t display_column() const;
|
size_t display_column() const;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user