mirror of
https://github.com/vim/vim.git
synced 2025-09-24 03:44:06 -04:00
patch 8.0.1837: one character cmdline abbreviation not triggered after '<,'>
Problem: One character cmdline abbreviation not triggered after '<,'>. Solution: Skip over the special range. (Christian Brabandt, closes #2320)
This commit is contained in:
@@ -3572,10 +3572,25 @@ gotocmdline(int clr)
|
|||||||
static int
|
static int
|
||||||
ccheck_abbr(int c)
|
ccheck_abbr(int c)
|
||||||
{
|
{
|
||||||
|
int spos = 0;
|
||||||
|
|
||||||
if (p_paste || no_abbr) /* no abbreviations or in paste mode */
|
if (p_paste || no_abbr) /* no abbreviations or in paste mode */
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
|
||||||
return check_abbr(c, ccline.cmdbuff, ccline.cmdpos, 0);
|
/* Do not consider '<,'> be part of the mapping, skip leading whitespace.
|
||||||
|
* Actually accepts any mark. */
|
||||||
|
while (VIM_ISWHITE(ccline.cmdbuff[spos]) && spos < ccline.cmdlen)
|
||||||
|
spos++;
|
||||||
|
if (ccline.cmdlen - spos > 5
|
||||||
|
&& ccline.cmdbuff[spos] == '\''
|
||||||
|
&& ccline.cmdbuff[spos + 2] == ','
|
||||||
|
&& ccline.cmdbuff[spos + 3] == '\'')
|
||||||
|
spos += 5;
|
||||||
|
else
|
||||||
|
/* check abbreviation from the beginning of the commandline */
|
||||||
|
spos = 0;
|
||||||
|
|
||||||
|
return check_abbr(c, ccline.cmdbuff, ccline.cmdpos, spos);
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined(FEAT_CMDL_COMPL) || defined(PROTO)
|
#if defined(FEAT_CMDL_COMPL) || defined(PROTO)
|
||||||
|
@@ -214,3 +214,19 @@ func Test_abbreviation_CR()
|
|||||||
delfunc Eatchar
|
delfunc Eatchar
|
||||||
bw!
|
bw!
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
|
func Test_cabbr_visual_mode()
|
||||||
|
cabbr s su
|
||||||
|
call feedkeys(":s \<c-B>\"\<CR>", 'itx')
|
||||||
|
call assert_equal('"su ', getreg(':'))
|
||||||
|
call feedkeys(":'<,'>s \<c-B>\"\<CR>", 'itx')
|
||||||
|
let expected = '"'. "'<,'>su "
|
||||||
|
call assert_equal(expected, getreg(':'))
|
||||||
|
call feedkeys(": '<,'>s \<c-B>\"\<CR>", 'itx')
|
||||||
|
let expected = '" '. "'<,'>su "
|
||||||
|
call assert_equal(expected, getreg(':'))
|
||||||
|
call feedkeys(":'a,'bs \<c-B>\"\<CR>", 'itx')
|
||||||
|
let expected = '"'. "'a,'bsu "
|
||||||
|
call assert_equal(expected, getreg(':'))
|
||||||
|
cunabbr s
|
||||||
|
endfunc
|
||||||
|
@@ -761,6 +761,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 */
|
||||||
|
/**/
|
||||||
|
1837,
|
||||||
/**/
|
/**/
|
||||||
1836,
|
1836,
|
||||||
/**/
|
/**/
|
||||||
|
Reference in New Issue
Block a user