patch 9.1.1849: CTRL-F and CTRL-B don't work in more prompt

Problem:  CTRL-F and CTRL-B don't work in more prompt
Solution: Make CTRL-F and CTRL-B scroll by a screen down/up
          (Bjoern Foersterling)

closes: #18545

Signed-off-by: bfoersterling <bjoern.foersterling@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
This commit is contained in:
bfoersterling
2025-10-12 14:26:34 +00:00
committed by Christian Brabandt
parent 40dec4609d
commit fcf4c435af
5 changed files with 48 additions and 30 deletions

View File

@ -1,4 +1,4 @@
*message.txt* For Vim version 9.1. Last change: 2025 Aug 06 *message.txt* For Vim version 9.1. Last change: 2025 Oct 12
VIM REFERENCE MANUAL by Bram Moolenaar VIM REFERENCE MANUAL by Bram Moolenaar
@ -862,22 +862,23 @@ group.
Type effect ~ Type effect ~
<CR> or <NL> or j or <Down> one more line <CR> or <NL> or j or <Down> one more line
d down a page (half a screen) d down a page (half a screen)
<Space> or f or <PageDown> down a screen <Space> or f or <PageDown> or CTRL-F down a screen
G down all the way, until the hit-enter G down all the way, until the
prompt hit-enter prompt
<BS> or k or <Up> one line back <BS> or k or <Up> one line back
u up a page (half a screen) u up a page (half a screen)
b or <PageUp> back a screen b or <PageUp> or CTRL-B back a screen
g back to the start g back to the start
q, <Esc> or CTRL-C stop the listing q, <Esc> or CTRL-C stop the listing
: stop the listing and enter a : stop the listing and enter a
command-line command-line
<C-Y> yank (copy) a modeless selection to <C-Y> yank (copy) a modeless
the clipboard ("* and "+ registers) selection to the clipboard
{menu-entry} what the menu is defined to in ("* and "+ registers)
Cmdline-mode. {menu-entry} what the menu is defined to
in Cmdline-mode.
<LeftMouse> next page (*) <LeftMouse> next page (*)
Any other key causes the meaning of the keys to be displayed. Any other key causes the meaning of the keys to be displayed.

View File

@ -1,4 +1,4 @@
*version9.txt* For Vim version 9.1. Last change: 2025 Oct 07 *version9.txt* For Vim version 9.1. Last change: 2025 Oct 12
VIM REFERENCE MANUAL by Bram Moolenaar VIM REFERENCE MANUAL by Bram Moolenaar
@ -41780,6 +41780,7 @@ Others: ~
Command-line. Command-line.
- |min()|/|max()| can handle all comparable data types. - |min()|/|max()| can handle all comparable data types.
- Vim triggers the |TermResponseAll| autocommand for any terminal OSC value. - Vim triggers the |TermResponseAll| autocommand for any terminal OSC value.
- Support CTRL-B and CTRL-F in the |more-prompt|.
*added-9.2* *added-9.2*
Added ~ Added ~

View File

@ -1356,7 +1356,7 @@ wait_return(int redraw)
*/ */
if (p_more && !p_cp) if (p_more && !p_cp)
{ {
if (c == 'b' || c == 'k' || c == 'u' || c == 'g' if (c == 'b' || c == Ctrl_B || c == 'k' || c == 'u' || c == 'g'
|| c == K_UP || c == K_PAGEUP) || c == K_UP || c == K_PAGEUP)
{ {
if (msg_scrolled > Rows) if (msg_scrolled > Rows)
@ -1385,7 +1385,7 @@ wait_return(int redraw)
} }
} }
else if (msg_scrolled > Rows - 2 else if (msg_scrolled > Rows - 2
&& (c == 'j' || c == 'd' || c == 'f' && (c == 'j' || c == 'd' || c == 'f' || c == Ctrl_F
|| c == K_DOWN || c == K_PAGEDOWN)) || c == K_DOWN || c == K_PAGEDOWN))
c = K_IGNORE; c = K_IGNORE;
} }
@ -3318,12 +3318,14 @@ do_more_prompt(int typed_char)
break; break;
case 'b': // one page back case 'b': // one page back
case Ctrl_B:
case K_PAGEUP: case K_PAGEUP:
toscroll = -(Rows - 1); toscroll = -(Rows - 1);
break; break;
case ' ': // one extra page case ' ': // one extra page
case 'f': case 'f':
case Ctrl_F:
case K_PAGEDOWN: case K_PAGEDOWN:
case K_LEFTMOUSE: case K_LEFTMOUSE:
toscroll = Rows - 1; toscroll = Rows - 1;

View File

@ -232,18 +232,20 @@ func Test_message_more()
call term_sendkeys(buf, "\<Down>") call term_sendkeys(buf, "\<Down>")
call WaitForAssert({-> assert_equal(' 9 9', term_getline(buf, 5))}) call WaitForAssert({-> assert_equal(' 9 9', term_getline(buf, 5))})
" Down a screen with <Space>, f, or <PageDown>. " Down a screen with <Space>, f, <C-F> or <PageDown>.
call term_sendkeys(buf, 'f') call term_sendkeys(buf, 'f')
call WaitForAssert({-> assert_equal(' 14 14', term_getline(buf, 5))}) call WaitForAssert({-> assert_equal(' 14 14', term_getline(buf, 5))})
call WaitForAssert({-> assert_equal('-- More --', term_getline(buf, 6))}) call WaitForAssert({-> assert_equal('-- More --', term_getline(buf, 6))})
call term_sendkeys(buf, ' ') call term_sendkeys(buf, "\<C-F>")
call WaitForAssert({-> assert_equal(' 19 19', term_getline(buf, 5))}) call WaitForAssert({-> assert_equal(' 19 19', term_getline(buf, 5))})
call term_sendkeys(buf, "\<PageDown>") call term_sendkeys(buf, ' ')
call WaitForAssert({-> assert_equal(' 24 24', term_getline(buf, 5))}) call WaitForAssert({-> assert_equal(' 24 24', term_getline(buf, 5))})
call term_sendkeys(buf, "\<PageDown>")
call WaitForAssert({-> assert_equal(' 29 29', term_getline(buf, 5))})
" Down a page (half a screen) with d. " Down a page (half a screen) with d.
call term_sendkeys(buf, 'd') call term_sendkeys(buf, 'd')
call WaitForAssert({-> assert_equal(' 27 27', term_getline(buf, 5))}) call WaitForAssert({-> assert_equal(' 32 32', term_getline(buf, 5))})
" Down all the way with 'G'. " Down all the way with 'G'.
call term_sendkeys(buf, 'G') call term_sendkeys(buf, 'G')
@ -258,15 +260,17 @@ func Test_message_more()
call term_sendkeys(buf, "\<Up>") call term_sendkeys(buf, "\<Up>")
call WaitForAssert({-> assert_equal(' 97 97', term_getline(buf, 5))}) call WaitForAssert({-> assert_equal(' 97 97', term_getline(buf, 5))})
" Up a screen with b or <PageUp>. " Up a screen with b, <C-B> or <PageUp>.
call term_sendkeys(buf, 'b') call term_sendkeys(buf, 'b')
call WaitForAssert({-> assert_equal(' 92 92', term_getline(buf, 5))}) call WaitForAssert({-> assert_equal(' 92 92', term_getline(buf, 5))})
call term_sendkeys(buf, "\<PageUp>") call term_sendkeys(buf, "\<C-B>")
call WaitForAssert({-> assert_equal(' 87 87', term_getline(buf, 5))}) call WaitForAssert({-> assert_equal(' 87 87', term_getline(buf, 5))})
call term_sendkeys(buf, "\<PageUp>")
call WaitForAssert({-> assert_equal(' 82 82', term_getline(buf, 5))})
" Up a page (half a screen) with u. " Up a page (half a screen) with u.
call term_sendkeys(buf, 'u') call term_sendkeys(buf, 'u')
call WaitForAssert({-> assert_equal(' 84 84', term_getline(buf, 5))}) call WaitForAssert({-> assert_equal(' 79 79', term_getline(buf, 5))})
" Up all the way with 'g'. " Up all the way with 'g'.
call term_sendkeys(buf, 'g') call term_sendkeys(buf, 'g')
@ -274,13 +278,16 @@ func Test_message_more()
call WaitForAssert({-> assert_equal(':%p#', term_getline(buf, 1))}) call WaitForAssert({-> assert_equal(':%p#', term_getline(buf, 1))})
call WaitForAssert({-> assert_equal('-- More --', term_getline(buf, 6))}) call WaitForAssert({-> assert_equal('-- More --', term_getline(buf, 6))})
" All the way down. Pressing f should do nothing but pressing " All the way down. Pressing f or Ctrl-F should do nothing but pressing
" space should end the more prompt. " space should end the more prompt.
call term_sendkeys(buf, 'G') call term_sendkeys(buf, 'G')
call WaitForAssert({-> assert_equal('100 100', term_getline(buf, 5))}) call WaitForAssert({-> assert_equal('100 100', term_getline(buf, 5))})
call WaitForAssert({-> assert_equal('Press ENTER or type command to continue', term_getline(buf, 6))}) call WaitForAssert({-> assert_equal('Press ENTER or type command to continue', term_getline(buf, 6))})
call term_sendkeys(buf, 'f') call term_sendkeys(buf, 'f')
call WaitForAssert({-> assert_equal('100 100', term_getline(buf, 5))}) call WaitForAssert({-> assert_equal('100 100', term_getline(buf, 5))})
call term_sendkeys(buf, "\<C-F>")
call WaitForAssert({-> assert_equal('100 100', term_getline(buf, 5))})
call WaitForAssert({-> assert_equal('Press ENTER or type command to continue', term_getline(buf, 6))})
call term_sendkeys(buf, ' ') call term_sendkeys(buf, ' ')
call WaitForAssert({-> assert_equal('100', term_getline(buf, 5))}) call WaitForAssert({-> assert_equal('100', term_getline(buf, 5))})
@ -339,6 +346,11 @@ func Test_message_more_scrollback()
call term_sendkeys(buf, 'b') call term_sendkeys(buf, 'b')
call VerifyScreenDump(buf, 'Test_more_scrollback_2', {}) call VerifyScreenDump(buf, 'Test_more_scrollback_2', {})
call term_sendkeys(buf, "\<C-F>")
call TermWait(buf)
call term_sendkeys(buf, "\<C-B>")
call VerifyScreenDump(buf, 'Test_more_scrollback_2', {})
call term_sendkeys(buf, 'q') call term_sendkeys(buf, 'q')
call TermWait(buf) call TermWait(buf)
call StopVimInTerminal(buf) call StopVimInTerminal(buf)

View File

@ -729,6 +729,8 @@ static char *(features[]) =
static int included_patches[] = static int included_patches[] =
{ /* Add new patch number below this line */ { /* Add new patch number below this line */
/**/
1849,
/**/ /**/
1848, 1848,
/**/ /**/