mirror of
https://github.com/fish-shell/fish-shell
synced 2024-12-31 23:28:45 +00:00
Refactor: inline clear_pager()
This commit is contained in:
parent
9000a3b2fa
commit
b25b291d38
1 changed files with 8 additions and 14 deletions
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue