patch 9.1.0580: :lmap mapping for keypad key not applied when typed in Select 
mode

Commit: 
https://github.com/vim/vim/commit/90a800274ded86d5d79dbea7ba647cd69b029b4e
Author: zeertzjq <zeert...@outlook.com>
Date:   Sat Jul 13 19:06:44 2024 +0200

    patch 9.1.0580: :lmap mapping for keypad key not applied when typed in 
Select mode
    
    Problem:  An :lmap mapping for a printable keypad key is not applied
              when typing it in Select mode.
    Solution: Change keypad key to ASCII after setting vgetc_char.
              (zeertzjq)
    
    closes: #15245
    
    Signed-off-by: zeertzjq <zeert...@outlook.com>
    Signed-off-by: Christian Brabandt <c...@256bit.org>

diff --git a/src/getchar.c b/src/getchar.c
index 0a37b7b11..9d54377cc 100644
--- a/src/getchar.c
+++ b/src/getchar.c
@@ -1999,6 +1999,43 @@ vgetc(void)
 #endif
            }
 
+           // For a multi-byte character get all the bytes and return the
+           // converted character.
+           // Note: This will loop until enough bytes are received!
+           if (has_mbyte && (n = MB_BYTE2LEN_CHECK(c)) > 1)
+           {
+               ++no_mapping;
+               buf[0] = c;
+               for (i = 1; i < n; ++i)
+               {
+                   buf[i] = vgetorpeek(TRUE);
+                   if (buf[i] == K_SPECIAL
+#ifdef FEAT_GUI
+                           || (buf[i] == CSI)
+#endif
+                           )
+                   {
+                       // Must be a K_SPECIAL - KS_SPECIAL - KE_FILLER
+                       // sequence, which represents a K_SPECIAL (0x80),
+                       // or a CSI - KS_EXTRA - KE_CSI sequence, which
+                       // represents a CSI (0x9B),
+                       // or a K_SPECIAL - KS_EXTRA - KE_CSI, which is CSI
+                       // too.
+                       c = vgetorpeek(TRUE);
+                       if (vgetorpeek(TRUE) == KE_CSI && c == KS_EXTRA)
+                           buf[i] = CSI;
+                   }
+               }
+               --no_mapping;
+               c = (*mb_ptr2char)(buf);
+           }
+
+           if (vgetc_char == 0)
+           {
+               vgetc_mod_mask = mod_mask;
+               vgetc_char = c;
+           }
+
            // a keypad or special function key was not mapped, use it like
            // its ASCII equivalent
            switch (c)
@@ -2062,43 +2099,6 @@ vgetc(void)
                case K_XRIGHT:  c = K_RIGHT; break;
            }
 
-           // For a multi-byte character get all the bytes and return the
-           // converted character.
-           // Note: This will loop until enough bytes are received!
-           if (has_mbyte && (n = MB_BYTE2LEN_CHECK(c)) > 1)
-           {
-               ++no_mapping;
-               buf[0] = c;
-               for (i = 1; i < n; ++i)
-               {
-                   buf[i] = vgetorpeek(TRUE);
-                   if (buf[i] == K_SPECIAL
-#ifdef FEAT_GUI
-                           || (buf[i] == CSI)
-#endif
-                           )
-                   {
-                       // Must be a K_SPECIAL - KS_SPECIAL - KE_FILLER
-                       // sequence, which represents a K_SPECIAL (0x80),
-                       // or a CSI - KS_EXTRA - KE_CSI sequence, which
-                       // represents a CSI (0x9B),
-                       // or a K_SPECIAL - KS_EXTRA - KE_CSI, which is CSI
-                       // too.
-                       c = vgetorpeek(TRUE);
-                       if (vgetorpeek(TRUE) == KE_CSI && c == KS_EXTRA)
-                           buf[i] = CSI;
-                   }
-               }
-               --no_mapping;
-               c = (*mb_ptr2char)(buf);
-           }
-
-           if (vgetc_char == 0)
-           {
-               vgetc_mod_mask = mod_mask;
-               vgetc_char = c;
-           }
-
            break;
        }
 
diff --git a/src/testdir/test_selectmode.vim b/src/testdir/test_selectmode.vim
index bf1b52b32..63aa0b9a1 100644
--- a/src/testdir/test_selectmode.vim
+++ b/src/testdir/test_selectmode.vim
@@ -321,4 +321,20 @@ func Test_ins_ctrl_o_in_insert_mode_resets_selectmode()
   bwipe!
 endfunc
 
+" Test that an :lmap mapping for a printable keypad key is applied when typing
+" it in Select mode.
+func Test_selectmode_keypad_lmap()
+  new
+  lnoremap <buffer> <kPoint> ???
+  lnoremap <buffer> <kEnter> !!!
+  setlocal iminsert=1
+  call setline(1, 'abcdef')
+  call feedkeys("gH\<kPoint>\<Esc>", 'tx')
+  call assert_equal(['???'], getline(1, '$'))
+  call feedkeys("gH\<kEnter>\<Esc>", 'tx')
+  call assert_equal(['!!!'], getline(1, '$'))
+
+  bwipe!
+endfunc
+
 " vim: shiftwidth=2 sts=2 expandtab
diff --git a/src/version.c b/src/version.c
index ac04272c6..b117443ca 100644
--- a/src/version.c
+++ b/src/version.c
@@ -704,6 +704,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    580,
 /**/
     579,
 /**/

-- 
-- 
You received this message from the "vim_dev" maillist.
Do not top-post! Type your reply below the text you are replying to.
For more information, visit http://www.vim.org/maillist.php

--- 
You received this message because you are subscribed to the Google Groups 
"vim_dev" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to vim_dev+unsubscr...@googlegroups.com.
To view this discussion on the web visit 
https://groups.google.com/d/msgid/vim_dev/E1sTxus-0091EP-ET%40256bit.org.

Raspunde prin e-mail lui