Hi Bram,

After this change, the 2-letter and 3-letter substitute commands don't work.
I think the following check in one_letter_cmd() is not correct:

    if (!in_vim9script())
      return FALSE;

- Yegappan

On Thu, Mar 24, 2022 at 6:09 AM Bram Moolenaar <[email protected]> wrote:
>
>
> Patch 8.2.4618
> Problem:    Command line completion does not recognize single letter commands.
> Solution:   Use the condition from find_ex_command().
> Files:      src/ex_docmd.c
>
>
> *** ../vim-8.2.4617/src/ex_docmd.c      2022-03-23 19:44:56.098161437 +0000
> --- src/ex_docmd.c      2022-03-24 13:07:29.803912969 +0000
> ***************
> *** 3421,3426 ****
> --- 3421,3458 ----
>   #endif
>
>   /*
> +  * Return TRUE and set "*idx" if "p" points to a one letter command.
> +  * If not in Vim9 script:
> +  * - The 'k' command can directly be followed by any character.
> +  * - The 's' command can be followed directly by 'c', 'g', 'i', 'I' or 'r'
> +  *        but :sre[wind] is another command, as are :scr[iptnames],
> +  *        :scs[cope], :sim[alt], :sig[ns] and :sil[ent].
> +  */
> +     static int
> + one_letter_cmd(char_u *p, cmdidx_T *idx)
> + {
> +     if (!in_vim9script())
> +       return FALSE;
> +     if (*p == 'k')
> +     {
> +       *idx = CMD_k;
> +       return TRUE;
> +     }
> +     if (p[0] == 's'
> +           && ((p[1] == 'c' && (p[2] == NUL || (p[2] != 's' && p[2] != 'r'
> +                       && (p[3] == NUL || (p[3] != 'i' && p[4] != 'p')))))
> +               || p[1] == 'g'
> +               || (p[1] == 'i' && p[2] != 'm' && p[2] != 'l' && p[2] != 'g')
> +               || p[1] == 'I'
> +               || (p[1] == 'r' && p[2] != 'e')))
> +     {
> +       *idx = CMD_substitute;
> +       return TRUE;
> +     }
> +     return FALSE;
> + }
> +
> + /*
>    * Find an Ex command by its name, either built-in or user.
>    * Start of the name can be found at eap->cmd.
>    * Sets eap->cmdidx and returns a pointer to char after the command name.
> ***************
> *** 3654,3683 ****
>
>       /*
>        * Isolate the command and search for it in the command table.
> -      * Exceptions:
> -      * - The 'k' command can directly be followed by any character.
> -      *   But it is not used in Vim9 script.
> -      * - the 's' command can be followed directly by 'c', 'g', 'i', 'I' or 
> 'r'
> -      *            but :sre[wind] is another command, as are :scr[iptnames],
> -      *            :scs[cope], :sim[alt], :sig[ns] and :sil[ent].
> -      * - the "d" command can directly be followed by 'l' or 'p' flag.
>        */
>       p = eap->cmd;
> !     if (!vim9 && *p == 'k')
> !     {
> !       eap->cmdidx = CMD_k;
> !       ++p;
> !     }
> !     else if (!vim9
> !           && p[0] == 's'
> !           && ((p[1] == 'c' && (p[2] == NUL || (p[2] != 's' && p[2] != 'r'
> !                       && (p[3] == NUL || (p[3] != 'i' && p[4] != 'p')))))
> !               || p[1] == 'g'
> !               || (p[1] == 'i' && p[2] != 'm' && p[2] != 'l' && p[2] != 'g')
> !               || p[1] == 'I'
> !               || (p[1] == 'r' && p[2] != 'e')))
>       {
> -       eap->cmdidx = CMD_substitute;
>         ++p;
>       }
>       else
> --- 3686,3695 ----
>
>       /*
>        * Isolate the command and search for it in the command table.
>        */
>       p = eap->cmd;
> !     if (one_letter_cmd(p, &eap->cmdidx))
>       {
>         ++p;
>       }
>       else
> ***************
> *** 3702,3707 ****
> --- 3714,3721 ----
>         if (p == eap->cmd && vim_strchr((char_u *)"@*!=><&~#}", *p) != NULL)
>             ++p;
>         len = (int)(p - eap->cmd);
> +       // The "d" command can directly be followed by 'l' or 'p' flag, when
> +       // not in Vim9 script.
>         if (!vim9 && *eap->cmd == 'd' && (p[-1] == 'l' || p[-1] == 'p'))
>         {
>             // Check for ":dl", ":dell", etc. to ":deletel": that's
> ***************
> *** 3955,3964 ****
>   {
>       cmdidx_T idx;
>
> !     for (idx = (cmdidx_T)0; (int)idx < (int)CMD_SIZE;
> !           idx = (cmdidx_T)((int)idx + 1))
> !       if (STRNCMP(cmdnames[(int)idx].cmd_name, cmd, (size_t)len) == 0)
> !           break;
>
>       return idx;
>   }
> --- 3969,3979 ----
>   {
>       cmdidx_T idx;
>
> !     if (!one_letter_cmd(cmd, &idx))
> !       for (idx = (cmdidx_T)0; (int)idx < (int)CMD_SIZE;
> !               idx = (cmdidx_T)((int)idx + 1))
> !           if (STRNCMP(cmdnames[(int)idx].cmd_name, cmd, (size_t)len) == 0)
> !               break;
>
>       return idx;
>   }
> *** ../vim-8.2.4617/src/version.c       2022-03-24 11:22:07.219294092 +0000
> --- src/version.c       2022-03-24 13:01:44.932420328 +0000
> ***************
> *** 752,753 ****
> --- 752,755 ----
>   {   /* Add new patch number below this line */
> + /**/
> +     4618,
>   /**/
>

-- 
-- 
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 [email protected].
To view this discussion on the web visit 
https://groups.google.com/d/msgid/vim_dev/CAAW7x7%3DF4tNBJf%2BF9XXFMb2-c%2BzAZggUfT2ubTQUxZy9ZFQ2DQ%40mail.gmail.com.

Raspunde prin e-mail lui