Make return not execute the selected completion in the pager, instead

just accept it
This commit is contained in:
ridiculousfish 2014-01-27 22:01:38 -08:00
parent 369229ea71
commit 441522f97b

View file

@ -1060,7 +1060,6 @@ static bool command_ends_paging(wchar_t c, bool focused_on_search_field)
case R_END_OF_HISTORY: case R_END_OF_HISTORY:
case R_HISTORY_TOKEN_SEARCH_BACKWARD: case R_HISTORY_TOKEN_SEARCH_BACKWARD:
case R_HISTORY_TOKEN_SEARCH_FORWARD: case R_HISTORY_TOKEN_SEARCH_FORWARD:
case R_EXECUTE:
case R_ACCEPT_AUTOSUGGESTION: case R_ACCEPT_AUTOSUGGESTION:
case R_CANCEL: case R_CANCEL:
return true; return true;
@ -1077,6 +1076,10 @@ static bool command_ends_paging(wchar_t c, bool focused_on_search_field)
case R_SUPPRESS_AUTOSUGGESTION: case R_SUPPRESS_AUTOSUGGESTION:
default: default:
return false; return false;
/* R_EXECUTE does end paging, but only executes if it was not paging. So it's handled specially */
case R_EXECUTE:
return false;
/* These commands operate on the search field if that's where the focus is */ /* These commands operate on the search field if that's where the focus is */
case R_BEGINNING_OF_LINE: case R_BEGINNING_OF_LINE:
@ -3532,6 +3535,13 @@ const wchar_t *reader_readline(void)
/* Delete any autosuggestion */ /* Delete any autosuggestion */
data->autosuggestion.clear(); data->autosuggestion.clear();
/* If the user hits return while navigating the pager, it only clears the pager */
if (data->is_navigating_pager_contents())
{
clear_pager();
break;
}
/* We only execute the command line */ /* We only execute the command line */
editable_line_t *el = &data->command_line; editable_line_t *el = &data->command_line;