Refactor: inline clear_pager()

This commit is contained in:
Johannes Altmanninger 2020-08-26 22:43:59 +02:00
parent 9000a3b2fa
commit b25b291d38

View file

@ -646,7 +646,6 @@ class reader_data_t : public std::enable_shared_from_this<reader_data_t> {
maybe_t<char_event_t> read_normal_chars(readline_loop_state_t &rls); maybe_t<char_event_t> read_normal_chars(readline_loop_state_t &rls);
void handle_readline_command(readline_cmd_t cmd, readline_loop_state_t &rls); void handle_readline_command(readline_cmd_t cmd, readline_loop_state_t &rls);
void clear_pager();
void select_completion_in_direction(selection_motion_t dir); void select_completion_in_direction(selection_motion_t dir);
void flash(); void flash();
@ -1638,7 +1637,7 @@ void reader_data_t::update_autosuggestion() {
void reader_data_t::accept_autosuggestion(bool full, bool single, move_word_style_t style) { void reader_data_t::accept_autosuggestion(bool full, bool single, move_word_style_t style) {
if (!autosuggestion.empty()) { if (!autosuggestion.empty()) {
// Accepting an autosuggestion clears the pager. // Accepting an autosuggestion clears the pager.
clear_pager(); pager.clear();
// Accept the autosuggestion. // Accept the autosuggestion.
if (full) { if (full) {
@ -1662,11 +1661,6 @@ void reader_data_t::accept_autosuggestion(bool full, bool single, move_word_styl
} }
} }
// Ensure we have no pager contents.
void reader_data_t::clear_pager() {
pager.clear();
}
void reader_data_t::select_completion_in_direction(selection_motion_t dir) { void reader_data_t::select_completion_in_direction(selection_motion_t dir) {
bool selection_changed = pager.select_next_completion_in_direction(dir, current_page_rendering); bool selection_changed = pager.select_next_completion_in_direction(dir, current_page_rendering);
if (selection_changed) { if (selection_changed) {
@ -2673,7 +2667,7 @@ maybe_t<char_event_t> reader_data_t::read_normal_chars(readline_loop_state_t &rl
// End paging upon inserting into the normal command line. // End paging upon inserting into the normal command line.
if (el == &command_line) { if (el == &command_line) {
clear_pager(); pager.clear();
} }
// Since we handled a normal character, we don't have a last command. // Since we handled a normal character, we don't have a last command.
@ -2965,7 +2959,7 @@ void reader_data_t::handle_readline_command(readline_cmd_t c, readline_loop_stat
case rl::execute: { case rl::execute: {
// If the user hits return while navigating the pager, it only clears the pager. // If the user hits return while navigating the pager, it only clears the pager.
if (is_navigating_pager_contents()) { if (is_navigating_pager_contents()) {
clear_pager(); pager.clear();
break; break;
} }
@ -2974,7 +2968,7 @@ void reader_data_t::handle_readline_command(readline_cmd_t c, readline_loop_stat
// The user may have hit return with pager contents, but while not navigating them. // The user may have hit return with pager contents, but while not navigating them.
// Clear the pager in that event. // Clear the pager in that event.
clear_pager(); pager.clear();
// We only execute the command line. // We only execute the command line.
editable_line_t *el = &command_line; editable_line_t *el = &command_line;
@ -3505,7 +3499,7 @@ void reader_data_t::handle_readline_command(readline_cmd_t c, readline_loop_stat
bool ok = (c == rl::undo) ? el->undo() : el->redo(); bool ok = (c == rl::undo) ? el->undo() : el->redo();
if (ok) { if (ok) {
if (el == &command_line) { if (el == &command_line) {
clear_pager(); pager.clear();
} }
update_buff_pos(el); update_buff_pos(el);
} else { } else {
@ -3622,7 +3616,7 @@ maybe_t<wcstring> reader_data_t::readline(int nchars_or_0) {
// Clear the pager if necessary. // Clear the pager if necessary.
bool focused_on_search_field = (active_edit_line() == &pager.search_field_line); bool focused_on_search_field = (active_edit_line() == &pager.search_field_line);
if (command_ends_paging(readline_cmd, focused_on_search_field)) { if (command_ends_paging(readline_cmd, focused_on_search_field)) {
clear_pager(); pager.clear();
} }
handle_readline_command(readline_cmd, rls); handle_readline_command(readline_cmd, rls);
@ -3656,7 +3650,7 @@ maybe_t<wcstring> reader_data_t::readline(int nchars_or_0) {
// End paging upon inserting into the normal command line. // End paging upon inserting into the normal command line.
if (el == &command_line) { if (el == &command_line) {
clear_pager(); pager.clear();
command_line_has_transient_edit = false; command_line_has_transient_edit = false;
} }
} else { } else {
@ -3797,7 +3791,7 @@ void reader_set_buffer(const wcstring &b, size_t pos) {
reader_data_t *data = current_data_or_null(); reader_data_t *data = current_data_or_null();
if (!data) return; if (!data) return;
data->clear_pager(); data->pager.clear();
data->set_buffer_maintaining_pager(b, pos); data->set_buffer_maintaining_pager(b, pos);
} }